forked from TrueCloudLab/certificates
[acme db interface] wip
This commit is contained in:
parent
80a6640103
commit
116869ebc5
4 changed files with 17 additions and 16 deletions
|
@ -65,7 +65,8 @@ func (u *UpdateAccountRequest) Validate() error {
|
||||||
|
|
||||||
// NewAccount is the handler resource for creating new ACME accounts.
|
// NewAccount is the handler resource for creating new ACME accounts.
|
||||||
func (h *Handler) NewAccount(w http.ResponseWriter, r *http.Request) {
|
func (h *Handler) NewAccount(w http.ResponseWriter, r *http.Request) {
|
||||||
payload, err := payloadFromContext(r.Context())
|
ctx := r.Context()
|
||||||
|
payload, err := payloadFromContext(ctx)
|
||||||
if err != nil {
|
if err != nil {
|
||||||
api.WriteError(w, err)
|
api.WriteError(w, err)
|
||||||
return
|
return
|
||||||
|
@ -97,7 +98,7 @@ func (h *Handler) NewAccount(w http.ResponseWriter, r *http.Request) {
|
||||||
"account does not exist"))
|
"account does not exist"))
|
||||||
return
|
return
|
||||||
}
|
}
|
||||||
jwk, err := jwkFromContext(r.Context())
|
jwk, err := jwkFromContext(ctx)
|
||||||
if err != nil {
|
if err != nil {
|
||||||
api.WriteError(w, err)
|
api.WriteError(w, err)
|
||||||
return
|
return
|
||||||
|
@ -108,7 +109,7 @@ func (h *Handler) NewAccount(w http.ResponseWriter, r *http.Request) {
|
||||||
Contact: nar.Contact,
|
Contact: nar.Contact,
|
||||||
Status: acme.StatusValid,
|
Status: acme.StatusValid,
|
||||||
}
|
}
|
||||||
if err := h.db.CreateAccount(r.Context(), acc); err != nil {
|
if err := h.db.CreateAccount(ctx, acc); err != nil {
|
||||||
api.WriteError(w, acme.WrapErrorISE(err, "error creating account"))
|
api.WriteError(w, acme.WrapErrorISE(err, "error creating account"))
|
||||||
return
|
return
|
||||||
}
|
}
|
||||||
|
@ -126,12 +127,13 @@ func (h *Handler) NewAccount(w http.ResponseWriter, r *http.Request) {
|
||||||
|
|
||||||
// GetUpdateAccount is the api for updating an ACME account.
|
// GetUpdateAccount is the api for updating an ACME account.
|
||||||
func (h *Handler) GetUpdateAccount(w http.ResponseWriter, r *http.Request) {
|
func (h *Handler) GetUpdateAccount(w http.ResponseWriter, r *http.Request) {
|
||||||
acc, err := accountFromContext(r.Context())
|
ctx := r.Context()
|
||||||
|
acc, err := accountFromContext(ctx)
|
||||||
if err != nil {
|
if err != nil {
|
||||||
api.WriteError(w, err)
|
api.WriteError(w, err)
|
||||||
return
|
return
|
||||||
}
|
}
|
||||||
payload, err := payloadFromContext(r.Context())
|
payload, err := payloadFromContext(ctx)
|
||||||
if err != nil {
|
if err != nil {
|
||||||
api.WriteError(w, err)
|
api.WriteError(w, err)
|
||||||
return
|
return
|
||||||
|
@ -156,7 +158,7 @@ func (h *Handler) GetUpdateAccount(w http.ResponseWriter, r *http.Request) {
|
||||||
// in the ACME spec (https://tools.ietf.org/html/rfc8555#section-7.3.2).
|
// in the ACME spec (https://tools.ietf.org/html/rfc8555#section-7.3.2).
|
||||||
acc.Status = uar.Status
|
acc.Status = uar.Status
|
||||||
acc.Contact = uar.Contact
|
acc.Contact = uar.Contact
|
||||||
if err = h.db.UpdateAccount(r.Context(), acc); err != nil {
|
if err = h.db.UpdateAccount(ctx, acc); err != nil {
|
||||||
api.WriteError(w, acme.WrapErrorISE(err, "error updating account"))
|
api.WriteError(w, acme.WrapErrorISE(err, "error updating account"))
|
||||||
return
|
return
|
||||||
}
|
}
|
||||||
|
@ -164,8 +166,7 @@ func (h *Handler) GetUpdateAccount(w http.ResponseWriter, r *http.Request) {
|
||||||
|
|
||||||
h.linker.LinkAccount(ctx, acc)
|
h.linker.LinkAccount(ctx, acc)
|
||||||
|
|
||||||
w.Header().Set("Location", h.linker.GetLink(r.Context(), AccountLinkType,
|
w.Header().Set("Location", h.linker.GetLink(ctx, AccountLinkType, true, acc.ID))
|
||||||
true, acc.ID))
|
|
||||||
api.JSON(w, acc)
|
api.JSON(w, acc)
|
||||||
}
|
}
|
||||||
|
|
||||||
|
|
|
@ -136,9 +136,9 @@ func (l LinkType) String() string {
|
||||||
|
|
||||||
// LinkOrder sets the ACME links required by an ACME order.
|
// LinkOrder sets the ACME links required by an ACME order.
|
||||||
func (l *Linker) LinkOrder(ctx context.Context, o *acme.Order) {
|
func (l *Linker) LinkOrder(ctx context.Context, o *acme.Order) {
|
||||||
o.azURLs = make([]string, len(o.AuthorizationIDs))
|
o.AuthorizationURLs = make([]string, len(o.AuthorizationIDs))
|
||||||
for i, azID := range o.AutohrizationIDs {
|
for i, azID := range o.AuthorizationIDs {
|
||||||
o.azURLs[i] = l.GetLink(ctx, AuthzLinkType, true, azID)
|
o.AuthorizationURLs[i] = l.GetLink(ctx, AuthzLinkType, true, azID)
|
||||||
}
|
}
|
||||||
o.FinalizeURL = l.GetLink(ctx, FinalizeLinkType, true, o.ID)
|
o.FinalizeURL = l.GetLink(ctx, FinalizeLinkType, true, o.ID)
|
||||||
if o.CertificateID != "" {
|
if o.CertificateID != "" {
|
||||||
|
@ -148,12 +148,12 @@ func (l *Linker) LinkOrder(ctx context.Context, o *acme.Order) {
|
||||||
|
|
||||||
// LinkAccount sets the ACME links required by an ACME account.
|
// LinkAccount sets the ACME links required by an ACME account.
|
||||||
func (l *Linker) LinkAccount(ctx context.Context, acc *acme.Account) {
|
func (l *Linker) LinkAccount(ctx context.Context, acc *acme.Account) {
|
||||||
a.Orders = l.GetLink(ctx, OrdersByAccountLinkType, true, acc.ID)
|
acc.Orders = l.GetLink(ctx, OrdersByAccountLinkType, true, acc.ID)
|
||||||
}
|
}
|
||||||
|
|
||||||
// LinkChallenge sets the ACME links required by an ACME account.
|
// LinkChallenge sets the ACME links required by an ACME account.
|
||||||
func (l *Linker) LinkChallenge(ctx context.Context, ch *acme.Challenge) {
|
func (l *Linker) LinkChallenge(ctx context.Context, ch *acme.Challenge) {
|
||||||
a.URL = l.GetLink(ctx, ChallengeLinkType, true, ch.AuthzID, ch.ID)
|
ch.URL = l.GetLink(ctx, ChallengeLinkType, true, ch.AuthzID, ch.ID)
|
||||||
}
|
}
|
||||||
|
|
||||||
// LinkAuthorization sets the ACME links required by an ACME account.
|
// LinkAuthorization sets the ACME links required by an ACME account.
|
||||||
|
|
|
@ -119,7 +119,7 @@ func (h *Handler) NewOrder(w http.ResponseWriter, r *http.Request) {
|
||||||
return
|
return
|
||||||
}
|
}
|
||||||
|
|
||||||
h.linker.Link(ctx, o)
|
h.linker.LinkOrder(ctx, o)
|
||||||
|
|
||||||
w.Header().Set("Location", h.linker.GetLink(ctx, OrderLinkType, true, o.ID))
|
w.Header().Set("Location", h.linker.GetLink(ctx, OrderLinkType, true, o.ID))
|
||||||
api.JSONStatus(w, o, http.StatusCreated)
|
api.JSONStatus(w, o, http.StatusCreated)
|
||||||
|
|
|
@ -203,8 +203,8 @@ func (oids orderIDs) save(db nosql.DB, old orderIDs, accID string) error {
|
||||||
case err != nil:
|
case err != nil:
|
||||||
return errors.Wrapf(err, "error storing order IDs for account %s", accID)
|
return errors.Wrapf(err, "error storing order IDs for account %s", accID)
|
||||||
case !swapped:
|
case !swapped:
|
||||||
return ServerInternalErr(errors.Errorf("error storing order IDs "+
|
return errors.Errorf("error storing order IDs "+
|
||||||
"for account %s; order IDs changed since last read", accID))
|
"for account %s; order IDs changed since last read", accID)
|
||||||
default:
|
default:
|
||||||
return nil
|
return nil
|
||||||
}
|
}
|
||||||
|
|
Loading…
Reference in a new issue