2016-02-26 17:27:07 +00:00
|
|
|
// Copyright © 2016 Abcum Ltd
|
|
|
|
//
|
|
|
|
// Licensed under the Apache License, Version 2.0 (the "License");
|
|
|
|
// you may not use this file except in compliance with the License.
|
|
|
|
// You may obtain a copy of the License at
|
|
|
|
//
|
|
|
|
// http://www.apache.org/licenses/LICENSE-2.0
|
|
|
|
//
|
|
|
|
// Unless required by applicable law or agreed to in writing, software
|
|
|
|
// distributed under the License is distributed on an "AS IS" BASIS,
|
|
|
|
// WITHOUT WARRANTIES OR CONDITIONS OF ANY KIND, either express or implied.
|
|
|
|
// See the License for the specific language governing permissions and
|
|
|
|
// limitations under the License.
|
|
|
|
|
|
|
|
package sql
|
|
|
|
|
|
|
|
import (
|
|
|
|
"fmt"
|
|
|
|
"strings"
|
|
|
|
)
|
|
|
|
|
2016-02-27 12:05:35 +00:00
|
|
|
// EmptyError represents an error that occurred during parsing.
|
|
|
|
type EmptyError struct{}
|
|
|
|
|
|
|
|
// Error returns the string representation of the error.
|
|
|
|
func (e *EmptyError) Error() string {
|
2016-02-28 09:38:12 +00:00
|
|
|
return fmt.Sprint("Your SQL query is empty")
|
2016-02-27 12:05:35 +00:00
|
|
|
}
|
|
|
|
|
2016-11-04 11:25:53 +00:00
|
|
|
// QueryError represents an error that occured when switching access.
|
|
|
|
type QueryError struct{}
|
|
|
|
|
|
|
|
// Error returns the string representation of the error.
|
|
|
|
func (e *QueryError) Error() string {
|
|
|
|
return fmt.Sprint("You don't have permission to perform this query type")
|
|
|
|
}
|
|
|
|
|
|
|
|
// BlankError represents an error that occured when switching access.
|
|
|
|
type BlankError struct{}
|
|
|
|
|
|
|
|
// Error returns the string representation of the error.
|
|
|
|
func (e *BlankError) Error() string {
|
|
|
|
return fmt.Sprint("You need to specify a namespace and a database to use")
|
|
|
|
}
|
|
|
|
|
2017-02-20 01:09:24 +00:00
|
|
|
// PermsError represents an error that occured when switching access.
|
|
|
|
type PermsError struct {
|
|
|
|
Resource string
|
2016-11-14 10:20:45 +00:00
|
|
|
}
|
|
|
|
|
|
|
|
// Error returns the string representation of the error.
|
2017-02-20 01:09:24 +00:00
|
|
|
func (e *PermsError) Error() string {
|
|
|
|
return fmt.Sprintf("You don't have permission to access the '%s' resource", e.Resource)
|
2016-11-14 10:20:45 +00:00
|
|
|
}
|
|
|
|
|
2017-11-16 20:53:13 +00:00
|
|
|
// GroupError occurs when a 'group' expression is invalid.
|
|
|
|
type GroupError struct {
|
|
|
|
found interface{}
|
|
|
|
}
|
|
|
|
|
|
|
|
// Error returns the string representation of the error.
|
|
|
|
func (e *GroupError) Error() string {
|
|
|
|
return fmt.Sprintf("Found '%v' but field is not an aggregate function, and is not present in GROUP expression", e.found)
|
|
|
|
}
|
|
|
|
|
2016-02-26 17:27:07 +00:00
|
|
|
// ParseError represents an error that occurred during parsing.
|
|
|
|
type ParseError struct {
|
|
|
|
Found string
|
|
|
|
Expected []string
|
|
|
|
}
|
|
|
|
|
|
|
|
// Error returns the string representation of the error.
|
|
|
|
func (e *ParseError) Error() string {
|
2016-05-23 12:32:02 +00:00
|
|
|
if len(e.Found) > 1000 {
|
|
|
|
return fmt.Sprintf("Found `%s...` but expected `%s`", e.Found[:1000], strings.Join(e.Expected, ", "))
|
|
|
|
}
|
2016-02-27 12:02:41 +00:00
|
|
|
return fmt.Sprintf("Found `%s` but expected `%s`", e.Found, strings.Join(e.Expected, ", "))
|
2016-02-26 17:27:07 +00:00
|
|
|
}
|