// Copyright (c) 2015-2022 MinIO, Inc. // // This file is part of MinIO Object Storage stack // // 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, either version 3 of the License, or // (at your option) any later version. // // 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 . package cmd import ( "errors" "fmt" "strings" "github.com/minio/mc/pkg/probe" ) type dummyErr error var errDummy = func() *probe.Error { msg := "" return probe.NewError(dummyErr(errors.New(msg))).Untrace() } type invalidArgumentErr error var errInvalidArgument = func() *probe.Error { msg := "Invalid arguments provided, please refer " + "`mc -h` for relevant documentation." return probe.NewError(invalidArgumentErr(errors.New(msg))).Untrace() } type unableToGuessErr error var errUnableToGuess = func() *probe.Error { msg := "Unable to guess the type of copy operation." return probe.NewError(unableToGuessErr(errors.New(msg))) } type unrecognizedDiffTypeErr error var errUnrecognizedDiffType = func(diff differType) *probe.Error { msg := "Unrecognized diffType: " + diff.String() + " provided." return probe.NewError(unrecognizedDiffTypeErr(errors.New(msg))).Untrace() } type invalidAliasedURLErr error var errInvalidAliasedURL = func(URL string) *probe.Error { msg := "Use `mc alias set mycloud " + URL + " ...` to add an alias. Use the alias for S3 operations." return probe.NewError(invalidAliasedURLErr(errors.New(msg))).Untrace() } type invalidAliasErr error var errInvalidAlias = func(alias string) *probe.Error { msg := "Alias `" + alias + "` should have alphanumeric characters such as [helloWorld0, hello_World0, ...] and begin with a letter" return probe.NewError(invalidAliasErr(errors.New(msg))) } type invalidURLErr error var errInvalidURL = func(URL string) *probe.Error { msg := "URL `" + URL + "` for MinIO Client should be of the form scheme://host[:port]/ without resource component." return probe.NewError(invalidURLErr(errors.New(msg))) } type invalidAPISignatureErr error var errInvalidAPISignature = func(api, url string) *probe.Error { msg := fmt.Sprintf( "Unrecognized API signature %s for host %s. Valid options are `[%s]`", api, url, strings.Join(validAPIs, ", ")) return probe.NewError(invalidAPISignatureErr(errors.New(msg))) } type noMatchingHostErr error var errNoMatchingHost = func(URL string) *probe.Error { msg := "No matching host found for the given URL `" + URL + "`." return probe.NewError(noMatchingHostErr(errors.New(msg))).Untrace() } type invalidSourceErr error var errInvalidSource = func(URL string) *probe.Error { msg := "Invalid source `" + URL + "`." return probe.NewError(invalidSourceErr(errors.New(msg))).Untrace() } type invalidTargetErr error var errInvalidTarget = func(URL string) *probe.Error { msg := "Invalid target `" + URL + "`." return probe.NewError(invalidTargetErr(errors.New(msg))).Untrace() } type requiresRecuriveErr error var errRequiresRecursive = func(URL string) *probe.Error { msg := "To copy or move '" + URL + "' the --recursive flag is required." return probe.NewError(requiresRecuriveErr(errors.New(msg))).Untrace() } type copyIntoSelfErr error var errCopyIntoSelf = func(URL string) *probe.Error { msg := "Copying or moving '" + URL + "' into itself is not allowed." return probe.NewError(copyIntoSelfErr(errors.New(msg))).Untrace() } type targetNotFoundErr error var errTargetNotFound = func(URL string) *probe.Error { msg := "Target `" + URL + "` not found." return probe.NewError(targetNotFoundErr(errors.New(msg))).Untrace() } type overwriteNotAllowedErr struct { error } var errOverWriteNotAllowed = func(URL string) *probe.Error { msg := "Overwrite not allowed for `" + URL + "`. Use `--overwrite` to override this behavior." return probe.NewError(overwriteNotAllowedErr{errors.New(msg)}) } type targetIsNotDirErr error var errTargetIsNotDir = func(URL string) *probe.Error { msg := "Target `" + URL + "` is not a folder." return probe.NewError(targetIsNotDirErr(errors.New(msg))).Untrace() } type sourceIsDirErr error var errSourceIsDir = func(URL string) *probe.Error { msg := "Source `" + URL + "` is a folder." return probe.NewError(sourceIsDirErr(errors.New(msg))).Untrace() } type sseInvalidAliasErr error var errSSEInvalidAlias = func(prefix string) *probe.Error { msg := "SSE prefix " + prefix + " has an invalid alias." return probe.NewError(sseInvalidAliasErr(errors.New(msg))).Untrace() } type sseOverlappingAliasErr error var errSSEOverlappingAlias = func(prefix, overlappingPrefix string) *probe.Error { msg := "SSE prefix " + prefix + " overlaps with " + overlappingPrefix return probe.NewError(sseOverlappingAliasErr(errors.New(msg))).Untrace() } type ssePrefixMatchErr error var errSSEPrefixMatch = func() *probe.Error { msg := "SSE prefixes do not match any object paths." return probe.NewError(ssePrefixMatchErr(errors.New(msg))).Untrace() } type sseKeyMissingError error var errSSEKeyMissing = func() *probe.Error { m := "SSE key is missing" return probe.NewError(sseKeyMissingError(errors.New(m))).Untrace() } type sseKMSKeyFormatErr error var errSSEKMSKeyFormat = func(msg string) *probe.Error { m := "SSE key format error. " m += msg return probe.NewError(sseKMSKeyFormatErr(errors.New(m))).Untrace() } type sseClientKeyFormatErr error var errSSEClientKeyFormat = func(msg string) *probe.Error { m := "Encryption key should be either raw base64 encoded or hex encoded. " m += msg return probe.NewError(sseClientKeyFormatErr(errors.New(m))).Untrace() }