surrealpatch/sql/error.go

87 lines
2.7 KiB
Go
Raw Normal View History

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
}
// 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-11-16 20:53:13 +00:00
// TransError represents an error that occured when switching access.
type TransError struct{}
// Error returns the string representation of the error.
func (e *TransError) Error() string {
return fmt.Sprintf("You can't change NAMESPACE or DATABASE inside of a transaction")
}
2017-02-20 01:09:24 +00:00
// PermsError represents an error that occured when switching access.
type PermsError struct {
Resource string
}
// 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)
}
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
}