416 lines
12 KiB
Go
416 lines
12 KiB
Go
package errorpkg
|
|
|
|
import (
|
|
"fmt"
|
|
"net/http"
|
|
"strings"
|
|
"voltaserve/model"
|
|
|
|
"github.com/go-playground/validator/v10"
|
|
)
|
|
|
|
func NewGroupNotFoundError(err error) *ErrorResponse {
|
|
return NewErrorResponse(
|
|
"group_not_found",
|
|
http.StatusNotFound,
|
|
"Group not found.",
|
|
MsgResourceNotFound,
|
|
err,
|
|
)
|
|
}
|
|
|
|
func NewFileNotFoundError(err error) *ErrorResponse {
|
|
return NewErrorResponse(
|
|
"file_not_found",
|
|
http.StatusNotFound,
|
|
"File not found.",
|
|
MsgResourceNotFound,
|
|
err,
|
|
)
|
|
}
|
|
|
|
func NewInvalidPathError(err error) *ErrorResponse {
|
|
return NewErrorResponse(
|
|
"invalid_path",
|
|
http.StatusBadRequest,
|
|
"Invalid path.",
|
|
MsgInvalidRequest,
|
|
err,
|
|
)
|
|
}
|
|
|
|
func NewWorkspaceNotFoundError(err error) *ErrorResponse {
|
|
return NewErrorResponse(
|
|
"workspace_not_found",
|
|
http.StatusNotFound,
|
|
"Workspace not found.",
|
|
MsgResourceNotFound,
|
|
err,
|
|
)
|
|
}
|
|
|
|
func NewOrganizationNotFoundError(err error) *ErrorResponse {
|
|
return NewErrorResponse(
|
|
"organization_not_found",
|
|
http.StatusNotFound,
|
|
"Organization not found.",
|
|
MsgResourceNotFound,
|
|
err,
|
|
)
|
|
}
|
|
|
|
func NewSnapshotNotFoundError(err error) *ErrorResponse {
|
|
return NewErrorResponse(
|
|
"snapshot_not_found",
|
|
http.StatusNotFound,
|
|
"Snapshot not found.",
|
|
"The file has no snapshots.",
|
|
err,
|
|
)
|
|
}
|
|
|
|
func NewS3ObjectNotFoundError(err error) *ErrorResponse {
|
|
return NewErrorResponse(
|
|
"s3_object_not_found",
|
|
http.StatusNotFound,
|
|
"S3 object not found.",
|
|
"The snapshot does not contain the S3 object requested.",
|
|
err,
|
|
)
|
|
}
|
|
|
|
func NewInvitationNotFoundError(err error) *ErrorResponse {
|
|
return NewErrorResponse(
|
|
"invitation_not_found",
|
|
http.StatusNotFound,
|
|
"Invitation not found.",
|
|
MsgResourceNotFound,
|
|
err,
|
|
)
|
|
}
|
|
|
|
func NewUserNotFoundError(err error) *ErrorResponse {
|
|
return NewErrorResponse(
|
|
"user_not_found",
|
|
http.StatusNotFound,
|
|
"User not found.",
|
|
MsgResourceNotFound,
|
|
err,
|
|
)
|
|
}
|
|
|
|
func NewInternalServerError(err error) *ErrorResponse {
|
|
return NewErrorResponse(
|
|
"internal_server_error",
|
|
http.StatusInternalServerError,
|
|
"Internal server error.",
|
|
MsgSomethingWentWrong,
|
|
err,
|
|
)
|
|
}
|
|
|
|
func NewOrganizationPermissionError(user model.User, org model.Organization, permission string) *ErrorResponse {
|
|
return NewErrorResponse(
|
|
"missing_organization_permission",
|
|
http.StatusForbidden,
|
|
fmt.Sprintf(
|
|
"User '%s' (%s) is missing the permission '%s' for organization '%s' (%s).",
|
|
user.GetUsername(), user.GetID(), permission, org.GetName(), org.GetID(),
|
|
),
|
|
fmt.Sprintf("Sorry, you don't have enough permissions for organization '%s'.", org.GetName()),
|
|
nil,
|
|
)
|
|
}
|
|
|
|
func NewCannotRemoveLastRemainingOwnerOfOrganizationError(id string) *ErrorResponse {
|
|
return NewErrorResponse(
|
|
"cannot_remove_last_owner_of_organization",
|
|
http.StatusBadRequest,
|
|
fmt.Sprintf("Cannot remove the last remaining owner of organization '%s'.", id), MsgInvalidRequest,
|
|
nil,
|
|
)
|
|
}
|
|
|
|
func NewGroupPermissionError(user model.User, org model.Organization, permission string) *ErrorResponse {
|
|
return NewErrorResponse(
|
|
"missing_group_permission",
|
|
http.StatusForbidden,
|
|
fmt.Sprintf(
|
|
"User '%s' (%s) is missing the permission '%s' for the group '%s' (%s).",
|
|
user.GetUsername(), user.GetID(), permission, org.GetName(), org.GetID(),
|
|
),
|
|
fmt.Sprintf("Sorry, you don't have enough permissions for the group '%s'.", org.GetName()),
|
|
nil,
|
|
)
|
|
}
|
|
|
|
func NewWorkspacePermissionError(user model.User, workspace model.Workspace, permission string) *ErrorResponse {
|
|
return NewErrorResponse(
|
|
"missing_workspace_permission",
|
|
http.StatusForbidden,
|
|
fmt.Sprintf(
|
|
"User '%s' (%s) is missing the permission '%s' for the workspace '%s' (%s).",
|
|
user.GetUsername(), user.GetID(), permission, workspace.GetName(), workspace.GetID(),
|
|
),
|
|
fmt.Sprintf("Sorry, you don't have enough permissions for the workspace '%s'.", workspace.GetName()),
|
|
nil,
|
|
)
|
|
}
|
|
|
|
func NewFilePermissionError(user model.User, file model.File, permission string) *ErrorResponse {
|
|
return NewErrorResponse(
|
|
"missing_file_permission",
|
|
http.StatusForbidden,
|
|
fmt.Sprintf(
|
|
"User '%s' (%s) is missing the permission '%s' for the file '%s' (%s).",
|
|
user.GetUsername(), user.GetID(), permission, file.GetName(), file.GetID(),
|
|
),
|
|
fmt.Sprintf("Sorry, you don't have enough permissions for the item '%s'.", file.GetName()),
|
|
nil,
|
|
)
|
|
}
|
|
|
|
func NewS3Error(message string) *ErrorResponse {
|
|
return NewErrorResponse(
|
|
"s3_error",
|
|
http.StatusInternalServerError,
|
|
message,
|
|
MsgSomethingWentWrong,
|
|
nil,
|
|
)
|
|
}
|
|
|
|
func NewMissingQueryParamError(param string) *ErrorResponse {
|
|
return NewErrorResponse(
|
|
"missing_query_param",
|
|
http.StatusBadRequest,
|
|
fmt.Sprintf("Query param '%s' is required.", param),
|
|
MsgInvalidRequest,
|
|
nil,
|
|
)
|
|
}
|
|
|
|
func NewInvalidQueryParamError(param string) *ErrorResponse {
|
|
return NewErrorResponse(
|
|
"invalid_query_param",
|
|
http.StatusBadRequest,
|
|
fmt.Sprintf("Query param '%s' is invalid.", param),
|
|
MsgInvalidRequest,
|
|
nil,
|
|
)
|
|
}
|
|
|
|
func NewStorageLimitExceededError() *ErrorResponse {
|
|
return NewErrorResponse(
|
|
"storage_limit_exceeded",
|
|
http.StatusForbidden,
|
|
"Storage limit exceeded.",
|
|
"The storage limit of your workspace has been reached, please increase it and try again.",
|
|
nil,
|
|
)
|
|
}
|
|
|
|
func NewInsufficientStorageCapacityError() *ErrorResponse {
|
|
return NewErrorResponse(
|
|
"insufficient_storage_capacity",
|
|
http.StatusForbidden,
|
|
"Insufficient storage capacity.",
|
|
"The requested storage capacity is insufficient.",
|
|
nil,
|
|
)
|
|
}
|
|
|
|
func NewRequestBodyValidationError(err error) *ErrorResponse {
|
|
var fields []string
|
|
for _, e := range err.(validator.ValidationErrors) {
|
|
fields = append(fields, e.Field())
|
|
}
|
|
return NewErrorResponse(
|
|
"request_validation_error",
|
|
http.StatusBadRequest,
|
|
fmt.Sprintf("Failed validation for the following fields: %s.", strings.Join(fields, ",")),
|
|
MsgInvalidRequest,
|
|
err,
|
|
)
|
|
}
|
|
|
|
func NewFileAlreadyChildOfDestinationError(source model.File, target model.File) *ErrorResponse {
|
|
return NewErrorResponse(
|
|
"file_already_child_of_destination",
|
|
http.StatusForbidden,
|
|
fmt.Sprintf("File '%s' (%s) is already a child of '%s' (%s).", source.GetName(), source.GetID(), target.GetName(), target.GetID()),
|
|
fmt.Sprintf("Item '%s' is already within '%s'.", source.GetName(), target.GetName()),
|
|
nil,
|
|
)
|
|
}
|
|
|
|
func NewFileCannotBeMovedIntoItselfError(source model.File) *ErrorResponse {
|
|
return NewErrorResponse(
|
|
"file_cannot_be_moved_into_itself",
|
|
http.StatusForbidden,
|
|
fmt.Sprintf("File '%s' (%s) cannot be moved into itself.", source.GetName(), source.GetID()),
|
|
fmt.Sprintf("Item '%s' cannot be moved into itself.", source.GetName()),
|
|
nil,
|
|
)
|
|
}
|
|
|
|
func NewFileIsNotAFolderError(file model.File) *ErrorResponse {
|
|
return NewErrorResponse(
|
|
"file_is_not_a_folder",
|
|
http.StatusForbidden,
|
|
fmt.Sprintf("File '%s' (%s) is not a folder.", file.GetName(), file.GetID()),
|
|
fmt.Sprintf("Item '%s' is not a folder.", file.GetName()),
|
|
nil,
|
|
)
|
|
}
|
|
|
|
func NewTargetIsGrandChildOfSourceError(file model.File) *ErrorResponse {
|
|
return NewErrorResponse(
|
|
"target_is_grant_child_of_source",
|
|
http.StatusForbidden,
|
|
fmt.Sprintf("File '%s' (%s) cannot be moved in another file within its own tree.", file.GetName(), file.GetID()),
|
|
fmt.Sprintf("Item '%s' cannot be moved in another item within its own tree.", file.GetName()),
|
|
nil,
|
|
)
|
|
}
|
|
|
|
func NewCannotDeleteWorkspaceRootError(file model.File, workspace model.Workspace) *ErrorResponse {
|
|
return NewErrorResponse(
|
|
"cannot_delete_workspace_root",
|
|
http.StatusForbidden,
|
|
fmt.Sprintf("Cannot delete the root file (%s) of the workspace '%s' (%s).", file.GetID(), workspace.GetName(), workspace.GetID()),
|
|
fmt.Sprintf("Cannot delete the root item of the workspace '%s'.", workspace.GetName()),
|
|
nil,
|
|
)
|
|
}
|
|
|
|
func NewFileCannotBeCopiedIntoOwnSubtreeError(file model.File) *ErrorResponse {
|
|
return NewErrorResponse(
|
|
"file_cannot_be_coped_into_own_subtree",
|
|
http.StatusForbidden,
|
|
fmt.Sprintf("File '%s' (%s) cannot be copied in another file within its own subtree.", file.GetName(), file.GetID()),
|
|
fmt.Sprintf("Item '%s' cannot be copied in another item within its own subtree.", file.GetName()),
|
|
nil,
|
|
)
|
|
}
|
|
|
|
func NewFileCannotBeCopiedIntoIselfError(file model.File) *ErrorResponse {
|
|
return NewErrorResponse(
|
|
"file_cannot_be_copied_into_itself",
|
|
http.StatusForbidden,
|
|
fmt.Sprintf("File '%s' (%s) cannot be copied into itself.", file.GetName(), file.GetID()),
|
|
fmt.Sprintf("Item '%s' cannot be copied into itself.", file.GetName()),
|
|
nil,
|
|
)
|
|
}
|
|
|
|
func NewFileWithSimilarNameExistsError() *ErrorResponse {
|
|
return NewErrorResponse(
|
|
"file_with_similar_name_exists",
|
|
http.StatusForbidden,
|
|
"File with similar name exists.",
|
|
"Item with similar name exists.",
|
|
nil,
|
|
)
|
|
}
|
|
|
|
func NewInvalidPageParameterError() *ErrorResponse {
|
|
return NewErrorResponse(
|
|
"invalid_page_parameter",
|
|
http.StatusBadRequest,
|
|
"Invalid page parameter, must be >= 1.",
|
|
MsgInvalidRequest,
|
|
nil,
|
|
)
|
|
}
|
|
|
|
func NewInvalidSizeParameterError() *ErrorResponse {
|
|
return NewErrorResponse(
|
|
"invalid_size_parameter",
|
|
http.StatusBadRequest,
|
|
"Invalid size parameter, must be >= 1.",
|
|
MsgInvalidRequest,
|
|
nil,
|
|
)
|
|
}
|
|
|
|
func NewCannotAcceptNonPendingInvitationError(invitation model.Invitation) *ErrorResponse {
|
|
return NewErrorResponse(
|
|
"cannot_accept_non_pending_invitation",
|
|
http.StatusForbidden,
|
|
fmt.Sprintf("Cannot accept an invitation which is not pending, the status of the invitation (%s) is (%s).", invitation.GetID(), invitation.GetStatus()),
|
|
"Cannot accept an invitation which is not pending.",
|
|
nil,
|
|
)
|
|
}
|
|
|
|
func NewCannotDeclineNonPendingInvitationError(invitation model.Invitation) *ErrorResponse {
|
|
return NewErrorResponse(
|
|
"cannot_decline_non_pending_invitation",
|
|
http.StatusForbidden,
|
|
fmt.Sprintf("Cannot decline an invitation which is not pending, the status of the invitation (%s) is (%s).", invitation.GetID(), invitation.GetStatus()),
|
|
"Cannot decline an invitation which is not pending.",
|
|
nil,
|
|
)
|
|
}
|
|
|
|
func NewCannotResendNonPendingInvitationError(invitation model.Invitation) *ErrorResponse {
|
|
return NewErrorResponse(
|
|
"cannot_resend_non_pending_invitation",
|
|
http.StatusForbidden,
|
|
fmt.Sprintf("Cannot resend an invitation which is not pending, the status of the invitation (%s) is (%s).", invitation.GetID(), invitation.GetStatus()),
|
|
"Cannot resend an invitation which is not pending.",
|
|
nil,
|
|
)
|
|
}
|
|
|
|
func NewUserNotAllowedToAcceptInvitationError(user model.User, invitation model.Invitation) *ErrorResponse {
|
|
return NewErrorResponse(
|
|
"user_not_allowed_to_accept_invitation",
|
|
http.StatusForbidden,
|
|
fmt.Sprintf("User '%s' (%s) is not allowed to accept the invitation (%s).", user.GetUsername(), user.GetID(), invitation.GetID()),
|
|
"Not allowed to accept this invitation.",
|
|
nil,
|
|
)
|
|
}
|
|
|
|
func NewUserNotAllowedToDeclineInvitationError(user model.User, invitation model.Invitation) *ErrorResponse {
|
|
return NewErrorResponse(
|
|
"user_not_allowed_to_decline_invitation",
|
|
http.StatusForbidden,
|
|
fmt.Sprintf("User '%s' (%s) is not allowed to decline the invitation (%s).", user.GetUsername(), user.GetID(), invitation.GetID()),
|
|
"Not allowed to decline this invitation.",
|
|
nil,
|
|
)
|
|
}
|
|
|
|
func NewUserNotAllowedToDeleteInvitationError(user model.User, invitation model.Invitation) *ErrorResponse {
|
|
return NewErrorResponse(
|
|
"user_not_allowed_to_delete_invitation",
|
|
http.StatusForbidden,
|
|
fmt.Sprintf("User '%s' (%s) not allowed to delete the invitation (%s).", user.GetUsername(), user.GetID(), invitation.GetID()),
|
|
"Not allowed to delete this invitation.",
|
|
nil,
|
|
)
|
|
}
|
|
|
|
func NewUserAlreadyMemberOfOrganizationError(user model.User, org model.Organization) *ErrorResponse {
|
|
return NewErrorResponse(
|
|
"user_already_member_of_organization",
|
|
http.StatusForbidden,
|
|
fmt.Sprintf("User '%s' (%s) is already a member of the organization '%s' (%s).", user.GetUsername(), user.GetID(), org.GetName(), org.GetID()),
|
|
fmt.Sprintf("You are already a member of the organization '%s'.", org.GetName()),
|
|
nil,
|
|
)
|
|
}
|
|
|
|
func NewInvalidAPIKeyError() *ErrorResponse {
|
|
return NewErrorResponse(
|
|
"invalid_api_key",
|
|
http.StatusUnauthorized,
|
|
"Invalid API key.",
|
|
"The API key is either missing or invalid.",
|
|
nil,
|
|
)
|
|
}
|