forked from TrueCloudLab/lego
60ae6e6dc9
As per announcement [1, 2], tools.ietf.org is going to shut down in the near future. This updates the links to the referenced RFCs to their new location, as per [3]. [1]: https://mailarchive.ietf.org/arch/msg/ietf/0n-6EXEmkTp3Uv_vj-5Vnm3o0bo/ [2]: https://mailarchive.ietf.org/arch/msg/ietf-announce/xKzJZIyanPCclTd7DU9PxBAbwhA/ [3]: https://github.com/ietf-tools/tools-transition-plan#new-service-locations
58 lines
1.6 KiB
Go
58 lines
1.6 KiB
Go
package acme
|
|
|
|
import (
|
|
"fmt"
|
|
)
|
|
|
|
// Errors types.
|
|
const (
|
|
errNS = "urn:ietf:params:acme:error:"
|
|
BadNonceErr = errNS + "badNonce"
|
|
)
|
|
|
|
// ProblemDetails the problem details object.
|
|
// - https://www.rfc-editor.org/rfc/rfc7807.html#section-3.1
|
|
// - https://www.rfc-editor.org/rfc/rfc8555.html#section-7.3.3
|
|
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"`
|
|
}
|
|
|
|
// SubProblem a "subproblems".
|
|
// - https://www.rfc-editor.org/rfc/rfc8555.html#section-6.7.1
|
|
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)
|
|
if p.Method != "" || p.URL != "" {
|
|
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)
|
|
}
|
|
|
|
if p.Instance != "" {
|
|
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
|
|
}
|