package apistatus

import (
	"git.frostfs.info/TrueCloudLab/frostfs-api-go/v2/apemanager"
	"git.frostfs.info/TrueCloudLab/frostfs-api-go/v2/status"
)

// APEManagerAccessDenied describes status of the failure because of the access control violation.
// Instances provide Status and StatusV2 interfaces.
type APEManagerAccessDenied struct {
	v2 status.Status
}

const defaultAPEManagerAccessDeniedMsg = "apemanager access denied"

func (x *APEManagerAccessDenied) Error() string {
	msg := x.v2.Message()
	if msg == "" {
		msg = defaultAPEManagerAccessDeniedMsg
	}

	return errMessageStatusV2(
		globalizeCodeV2(apemanager.StatusAPEManagerAccessDenied, apemanager.GlobalizeFail),
		msg,
	)
}

func (x *APEManagerAccessDenied) fromStatusV2(st *status.Status) {
	x.v2 = *st
}

// ToStatusV2 converts APEManagerAccessDenied to v2's Status.
// If the value was returned by FromStatusV2, returns the source message.
// Otherwise, returns message with
//   - code: APE_MANAGER_ACCESS_DENIED;
//   - string message: "apemanager access denied";
//   - details: empty.
func (x APEManagerAccessDenied) ToStatusV2() *status.Status {
	x.v2.SetCode(globalizeCodeV2(apemanager.StatusAPEManagerAccessDenied, apemanager.GlobalizeFail))
	x.v2.SetMessage(defaultAPEManagerAccessDeniedMsg)
	return &x.v2
}

// WriteReason writes human-readable access rejection reason.
func (x *APEManagerAccessDenied) WriteReason(reason string) {
	apemanager.WriteAccessDeniedDesc(&x.v2, reason)
}

// Reason returns human-readable access rejection reason returned by the server.
// Returns empty value is reason is not presented.
func (x APEManagerAccessDenied) Reason() string {
	return apemanager.ReadAccessDeniedDesc(x.v2)
}