boulder/web/probs.go

57 lines
2.0 KiB
Go

package web
import (
berrors "github.com/letsencrypt/boulder/errors"
"github.com/letsencrypt/boulder/probs"
)
func problemDetailsForBoulderError(err *berrors.BoulderError, msg string) *probs.ProblemDetails {
switch err.Type {
case berrors.Malformed:
return probs.Malformed("%s :: %s", msg, err)
case berrors.Unauthorized:
return probs.Unauthorized("%s :: %s", msg, err)
case berrors.NotFound:
return probs.NotFound("%s :: %s", msg, err)
case berrors.RateLimit:
return probs.RateLimited("%s :: %s", msg, err)
case berrors.InternalServer:
// Internal server error messages may include sensitive data, so we do
// not include it.
return probs.ServerInternal(msg)
case berrors.RejectedIdentifier:
return probs.RejectedIdentifier("%s :: %s", msg, err)
case berrors.InvalidEmail:
return probs.InvalidEmail("%s :: %s", msg, err)
case berrors.WrongAuthorizationState:
return probs.Malformed("%s :: %s", msg, err)
case berrors.CAA:
return probs.CAA("%s :: %s", msg, err)
case berrors.MissingSCTs:
// MissingSCTs are an internal server error, but with a specific error
// message related to the SCT problem
return probs.ServerInternal("%s :: %s", msg, "Unable to meet CA SCT embedding requirements")
default:
// Internal server error messages may include sensitive data, so we do
// not include it.
return probs.ServerInternal(msg)
}
}
// problemDetailsForError turns an error into a ProblemDetails with the special
// case of returning the same error back if its already a ProblemDetails. If the
// error is of an type unknown to ProblemDetailsForError, it will return a
// ServerInternal ProblemDetails.
func ProblemDetailsForError(err error, msg string) *probs.ProblemDetails {
switch e := err.(type) {
case *probs.ProblemDetails:
return e
case *berrors.BoulderError:
return problemDetailsForBoulderError(e, msg)
default:
// Internal server error messages may include sensitive data, so we do
// not include it.
return probs.ServerInternal(msg)
}
}