pki/vendor/github.com/go-acme/lego/v4/acme/errors.go

59 lines
1.6 KiB
Go
Raw Normal View History

2020-11-25 20:36:07 +01:00
package acme
import (
"fmt"
)
// Errors types.
const (
errNS = "urn:ietf:params:acme:error:"
BadNonceErr = errNS + "badNonce"
)
2020-12-04 20:40:08 +01:00
// ProblemDetails the problem details object.
2022-11-02 17:49:03 +01:00
// - https://www.rfc-editor.org/rfc/rfc7807.html#section-3.1
// - https://www.rfc-editor.org/rfc/rfc8555.html#section-7.3.3
2020-11-25 20:36:07 +01:00
type ProblemDetails struct {
Type string `json:"type,omitempty"`
Detail string `json:"detail,omitempty"`
HTTPStatus int `json:"status,omitempty"`
Instance string `json:"instance,omitempty"`
SubProblems []SubProblem `json:"subproblems,omitempty"`
// additional values to have a better error message (Not defined by the RFC)
Method string `json:"method,omitempty"`
URL string `json:"url,omitempty"`
}
2020-12-04 20:40:08 +01:00
// SubProblem a "subproblems".
2022-11-02 17:49:03 +01:00
// - https://www.rfc-editor.org/rfc/rfc8555.html#section-6.7.1
2020-11-25 20:36:07 +01:00
type SubProblem struct {
Type string `json:"type,omitempty"`
Detail string `json:"detail,omitempty"`
Identifier Identifier `json:"identifier,omitempty"`
}
func (p ProblemDetails) Error() string {
msg := fmt.Sprintf("acme: error: %d", p.HTTPStatus)
2021-04-07 10:58:21 +02:00
if p.Method != "" || p.URL != "" {
2020-11-25 20:36:07 +01:00
msg += fmt.Sprintf(" :: %s :: %s", p.Method, p.URL)
}
msg += fmt.Sprintf(" :: %s :: %s", p.Type, p.Detail)
for _, sub := range p.SubProblems {
msg += fmt.Sprintf(", problem: %q :: %s", sub.Type, sub.Detail)
}
2021-04-07 10:58:21 +02:00
if p.Instance != "" {
2020-11-25 20:36:07 +01:00
msg += ", url: " + p.Instance
}
return msg
}
// NonceError represents the error which is returned
// if the nonce sent by the client was not accepted by the server.
type NonceError struct {
*ProblemDetails
}