| 123456789101112131415161718192021222324252627282930313233343536373839404142434445464748495051525354555657585960616263646566676869707172737475767778798081828384858687888990919293949596979899100101102103104105106107108109110111112113114115116117118119120121122123124125126127128129130131132133134135 | // Copyright (C) 2019 Nicola Murino//// This program is free software: you can redistribute it and/or modify// it under the terms of the GNU Affero General Public License as published// by the Free Software Foundation, version 3.//// This program is distributed in the hope that it will be useful,// but WITHOUT ANY WARRANTY; without even the implied warranty of// MERCHANTABILITY or FITNESS FOR A PARTICULAR PURPOSE. See the// GNU Affero General Public License for more details.//// You should have received a copy of the GNU Affero General Public License// along with this program. If not, see <https://www.gnu.org/licenses/>.package utilimport (	"errors"	"fmt")const (	templateLoadErrorHints = "Try setting the absolute templates path in your configuration file " +		"or specifying the config directory adding the `-c` flag to the serve options. For example: " +		"sftpgo serve -c \"<path to dir containing the default config file and templates directory>\"")// MaxRecursion defines the maximum number of allowed recursionsconst MaxRecursion = 1000// errors definitionsvar (	ErrValidation       = NewValidationError("")	ErrNotFound         = NewRecordNotFoundError("")	ErrMethodDisabled   = NewMethodDisabledError("")	ErrGeneric          = NewGenericError("")	ErrRecursionTooDeep = errors.New("recursion too deep"))// ValidationError raised if input data is not validtype ValidationError struct {	err string}// Validation error detailsfunc (e *ValidationError) Error() string {	return fmt.Sprintf("Validation error: %s", e.err)}// GetErrorString returns the unmodified error stringfunc (e *ValidationError) GetErrorString() string {	return e.err}// Is reports if target matchesfunc (e *ValidationError) Is(target error) bool {	_, ok := target.(*ValidationError)	return ok}// NewValidationError returns a validation errorsfunc NewValidationError(error string) *ValidationError {	return &ValidationError{		err: error,	}}// RecordNotFoundError raised if a requested object is not foundtype RecordNotFoundError struct {	err string}func (e *RecordNotFoundError) Error() string {	return fmt.Sprintf("not found: %s", e.err)}// Is reports if target matchesfunc (e *RecordNotFoundError) Is(target error) bool {	_, ok := target.(*RecordNotFoundError)	return ok}// NewRecordNotFoundError returns a not found errorfunc NewRecordNotFoundError(error string) *RecordNotFoundError {	return &RecordNotFoundError{		err: error,	}}// MethodDisabledError raised if a method is disabled in config file.// For example, if user management is disabled, this error is raised// every time a user operation is done using the REST APItype MethodDisabledError struct {	err string}// Method disabled error detailsfunc (e *MethodDisabledError) Error() string {	return fmt.Sprintf("Method disabled error: %s", e.err)}// Is reports if target matchesfunc (e *MethodDisabledError) Is(target error) bool {	_, ok := target.(*MethodDisabledError)	return ok}// NewMethodDisabledError returns a method disabled errorfunc NewMethodDisabledError(error string) *MethodDisabledError {	return &MethodDisabledError{		err: error,	}}// GenericError raised for not well categorized errortype GenericError struct {	err string}func (e *GenericError) Error() string {	return e.err}// Is reports if target matchesfunc (e *GenericError) Is(target error) bool {	_, ok := target.(*GenericError)	return ok}// NewGenericError returns a generic errorfunc NewGenericError(error string) *GenericError {	return &GenericError{		err: error,	}}
 |