Docker/Downloads/Voltaserve/api/errorpkg/error_creators.go
2024-04-21 14:42:52 +02:00

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,
)
}