2020-03-11 18:31:33 +00:00
|
|
|
package tenant
|
|
|
|
|
|
|
|
import (
|
2020-04-02 09:01:44 +00:00
|
|
|
"fmt"
|
|
|
|
"strings"
|
|
|
|
|
2020-04-03 17:39:20 +00:00
|
|
|
"github.com/influxdata/influxdb/v2"
|
2020-03-11 18:31:33 +00:00
|
|
|
)
|
|
|
|
|
|
|
|
var (
|
|
|
|
// ErrNameisEmpty is when a name is empty
|
|
|
|
ErrNameisEmpty = &influxdb.Error{
|
|
|
|
Code: influxdb.EInvalid,
|
|
|
|
Msg: "name is empty",
|
|
|
|
}
|
2020-03-17 19:23:00 +00:00
|
|
|
|
|
|
|
// NotUniqueIDError is used when attempting to create an org or bucket that already
|
|
|
|
// exists.
|
|
|
|
NotUniqueIDError = &influxdb.Error{
|
|
|
|
Code: influxdb.EConflict,
|
|
|
|
Msg: "ID already exists",
|
|
|
|
}
|
|
|
|
|
|
|
|
// ErrFailureGeneratingID occurs ony when the random number generator
|
|
|
|
// cannot generate an ID in MaxIDGenerationN times.
|
|
|
|
ErrFailureGeneratingID = &influxdb.Error{
|
|
|
|
Code: influxdb.EInternal,
|
|
|
|
Msg: "unable to generate valid id",
|
|
|
|
}
|
2020-04-06 21:58:15 +00:00
|
|
|
|
|
|
|
// ErrOnboardingNotAllowed occurs when request to onboard comes in and we are not allowing this request
|
|
|
|
ErrOnboardingNotAllowed = &influxdb.Error{
|
|
|
|
Code: influxdb.EConflict,
|
|
|
|
Msg: "onboarding has already been completed",
|
|
|
|
}
|
|
|
|
|
|
|
|
ErrOnboardInvalid = &influxdb.Error{
|
|
|
|
Code: influxdb.EEmptyValue,
|
|
|
|
Msg: "onboard failed, missing value",
|
|
|
|
}
|
2020-04-07 18:13:27 +00:00
|
|
|
|
|
|
|
ErrNotFound = &influxdb.Error{
|
|
|
|
Code: influxdb.ENotFound,
|
|
|
|
Msg: "not found",
|
|
|
|
}
|
2020-03-11 18:31:33 +00:00
|
|
|
)
|
|
|
|
|
|
|
|
// ErrInternalServiceError is used when the error comes from an internal system.
|
|
|
|
func ErrInternalServiceError(err error) *influxdb.Error {
|
|
|
|
return &influxdb.Error{
|
|
|
|
Code: influxdb.EInternal,
|
|
|
|
Err: err,
|
|
|
|
}
|
|
|
|
}
|
2020-04-02 09:01:44 +00:00
|
|
|
|
|
|
|
type errSlice []error
|
|
|
|
|
|
|
|
func (e errSlice) Error() string {
|
|
|
|
l := len(e)
|
|
|
|
sb := strings.Builder{}
|
|
|
|
for i, err := range e {
|
|
|
|
if i > 0 {
|
|
|
|
sb.WriteRune('\n')
|
|
|
|
}
|
|
|
|
sb.WriteString(fmt.Sprintf("error %d/%d: %s", i+1, l, err.Error()))
|
|
|
|
}
|
|
|
|
return sb.String()
|
|
|
|
}
|
|
|
|
|
|
|
|
// AggregateError enables composing multiple errors.
|
|
|
|
// This is ideal in the case that you are applying functions with side effects to a slice of elements.
|
|
|
|
// E.g., deleting/updating a slice of resources.
|
|
|
|
type AggregateError struct {
|
|
|
|
errs errSlice
|
|
|
|
}
|
|
|
|
|
|
|
|
// NewAggregateError returns a new AggregateError.
|
|
|
|
func NewAggregateError() *AggregateError {
|
|
|
|
return &AggregateError{
|
|
|
|
errs: make([]error, 0),
|
|
|
|
}
|
|
|
|
}
|
|
|
|
|
|
|
|
// Add adds an error to the aggregate.
|
|
|
|
func (e *AggregateError) Add(err error) {
|
|
|
|
if err == nil {
|
|
|
|
return
|
|
|
|
}
|
|
|
|
e.errs = append(e.errs, err)
|
|
|
|
}
|
|
|
|
|
|
|
|
// Err returns a proper error from this aggregate error.
|
|
|
|
func (e *AggregateError) Err() error {
|
|
|
|
if len(e.errs) > 0 {
|
|
|
|
return e.errs
|
|
|
|
}
|
|
|
|
return nil
|
|
|
|
}
|