2021-05-03 19:48:20 +00:00
|
|
|
package api
|
|
|
|
|
|
|
|
import (
|
2022-04-27 18:59:32 +00:00
|
|
|
"context"
|
2022-03-30 12:21:39 +00:00
|
|
|
"net/http"
|
2022-04-27 18:59:32 +00:00
|
|
|
|
2021-05-03 19:48:20 +00:00
|
|
|
"github.com/smallstep/certificates/api"
|
2022-04-27 18:59:32 +00:00
|
|
|
"github.com/smallstep/certificates/authority"
|
2021-05-03 19:48:20 +00:00
|
|
|
)
|
|
|
|
|
2022-09-30 00:16:26 +00:00
|
|
|
var mustAuthority = func(ctx context.Context) adminAuthority {
|
|
|
|
return authority.MustFromContext(ctx)
|
2021-05-03 19:48:20 +00:00
|
|
|
}
|
|
|
|
|
2022-09-30 00:16:26 +00:00
|
|
|
type router struct {
|
|
|
|
acmeResponder ACMEAdminResponder
|
|
|
|
policyResponder PolicyAdminResponder
|
|
|
|
webhookResponder WebhookAdminResponder
|
2022-04-27 18:59:32 +00:00
|
|
|
}
|
|
|
|
|
2022-09-30 00:16:26 +00:00
|
|
|
type RouterOption func(*router)
|
|
|
|
|
|
|
|
func WithACMEResponder(acmeResponder ACMEAdminResponder) RouterOption {
|
|
|
|
return func(r *router) {
|
|
|
|
r.acmeResponder = acmeResponder
|
2021-07-22 21:48:41 +00:00
|
|
|
}
|
2021-05-03 19:48:20 +00:00
|
|
|
}
|
|
|
|
|
2022-09-30 00:16:26 +00:00
|
|
|
func WithPolicyResponder(policyResponder PolicyAdminResponder) RouterOption {
|
|
|
|
return func(r *router) {
|
|
|
|
r.policyResponder = policyResponder
|
|
|
|
}
|
|
|
|
}
|
|
|
|
|
|
|
|
func WithWebhookResponder(webhookResponder WebhookAdminResponder) RouterOption {
|
|
|
|
return func(r *router) {
|
|
|
|
r.webhookResponder = webhookResponder
|
|
|
|
}
|
2022-04-27 18:59:32 +00:00
|
|
|
}
|
|
|
|
|
2021-05-03 19:48:20 +00:00
|
|
|
// Route traffic and implement the Router interface.
|
2022-09-30 00:16:26 +00:00
|
|
|
func Route(r api.Router, options ...RouterOption) {
|
|
|
|
router := &router{}
|
|
|
|
for _, fn := range options {
|
|
|
|
fn(router)
|
|
|
|
}
|
|
|
|
|
2022-03-30 12:21:39 +00:00
|
|
|
authnz := func(next http.HandlerFunc) http.HandlerFunc {
|
2022-04-27 18:59:32 +00:00
|
|
|
return extractAuthorizeTokenAdmin(requireAPIEnabled(next))
|
2021-05-03 19:48:20 +00:00
|
|
|
}
|
|
|
|
|
2022-03-30 12:21:39 +00:00
|
|
|
enabledInStandalone := func(next http.HandlerFunc) http.HandlerFunc {
|
2022-05-06 20:21:41 +00:00
|
|
|
return checkAction(next, true)
|
2022-03-15 14:51:45 +00:00
|
|
|
}
|
|
|
|
|
2022-03-30 12:21:39 +00:00
|
|
|
disabledInStandalone := func(next http.HandlerFunc) http.HandlerFunc {
|
2022-05-06 20:21:41 +00:00
|
|
|
return checkAction(next, false)
|
2022-03-15 14:51:45 +00:00
|
|
|
}
|
|
|
|
|
2022-03-31 14:12:29 +00:00
|
|
|
acmeEABMiddleware := func(next http.HandlerFunc) http.HandlerFunc {
|
2022-05-06 20:21:41 +00:00
|
|
|
return authnz(loadProvisionerByName(requireEABEnabled(next)))
|
2022-03-31 14:12:29 +00:00
|
|
|
}
|
|
|
|
|
|
|
|
authorityPolicyMiddleware := func(next http.HandlerFunc) http.HandlerFunc {
|
|
|
|
return authnz(enabledInStandalone(next))
|
|
|
|
}
|
|
|
|
|
|
|
|
provisionerPolicyMiddleware := func(next http.HandlerFunc) http.HandlerFunc {
|
2022-05-06 20:21:41 +00:00
|
|
|
return authnz(disabledInStandalone(loadProvisionerByName(next)))
|
2022-03-31 14:12:29 +00:00
|
|
|
}
|
|
|
|
|
|
|
|
acmePolicyMiddleware := func(next http.HandlerFunc) http.HandlerFunc {
|
2022-05-06 20:21:41 +00:00
|
|
|
return authnz(disabledInStandalone(loadProvisionerByName(requireEABEnabled(loadExternalAccountKey(next)))))
|
2022-03-31 14:12:29 +00:00
|
|
|
}
|
|
|
|
|
2022-09-30 00:16:26 +00:00
|
|
|
webhookMiddleware := func(next http.HandlerFunc) http.HandlerFunc {
|
|
|
|
return authnz(loadProvisionerByName(next))
|
|
|
|
}
|
|
|
|
|
2021-05-03 19:48:20 +00:00
|
|
|
// Provisioners
|
2022-04-27 18:59:32 +00:00
|
|
|
r.MethodFunc("GET", "/provisioners/{name}", authnz(GetProvisioner))
|
|
|
|
r.MethodFunc("GET", "/provisioners", authnz(GetProvisioners))
|
|
|
|
r.MethodFunc("POST", "/provisioners", authnz(CreateProvisioner))
|
|
|
|
r.MethodFunc("PUT", "/provisioners/{name}", authnz(UpdateProvisioner))
|
|
|
|
r.MethodFunc("DELETE", "/provisioners/{name}", authnz(DeleteProvisioner))
|
2021-05-03 19:48:20 +00:00
|
|
|
|
|
|
|
// Admins
|
2022-04-27 18:59:32 +00:00
|
|
|
r.MethodFunc("GET", "/admins/{id}", authnz(GetAdmin))
|
|
|
|
r.MethodFunc("GET", "/admins", authnz(GetAdmins))
|
|
|
|
r.MethodFunc("POST", "/admins", authnz(CreateAdmin))
|
|
|
|
r.MethodFunc("PATCH", "/admins/{id}", authnz(UpdateAdmin))
|
|
|
|
r.MethodFunc("DELETE", "/admins/{id}", authnz(DeleteAdmin))
|
2021-07-17 15:35:44 +00:00
|
|
|
|
2022-05-06 21:11:10 +00:00
|
|
|
// ACME responder
|
2022-09-30 00:16:26 +00:00
|
|
|
if router.acmeResponder != nil {
|
2022-05-06 21:11:10 +00:00
|
|
|
// ACME External Account Binding Keys
|
2022-09-30 00:16:26 +00:00
|
|
|
r.MethodFunc("GET", "/acme/eab/{provisionerName}/{reference}", acmeEABMiddleware(router.acmeResponder.GetExternalAccountKeys))
|
|
|
|
r.MethodFunc("GET", "/acme/eab/{provisionerName}", acmeEABMiddleware(router.acmeResponder.GetExternalAccountKeys))
|
|
|
|
r.MethodFunc("POST", "/acme/eab/{provisionerName}", acmeEABMiddleware(router.acmeResponder.CreateExternalAccountKey))
|
|
|
|
r.MethodFunc("DELETE", "/acme/eab/{provisionerName}/{id}", acmeEABMiddleware(router.acmeResponder.DeleteExternalAccountKey))
|
2022-05-06 21:11:10 +00:00
|
|
|
}
|
2022-04-07 12:11:53 +00:00
|
|
|
|
2022-05-06 21:11:10 +00:00
|
|
|
// Policy responder
|
2022-09-30 00:16:26 +00:00
|
|
|
if router.policyResponder != nil {
|
2022-05-06 21:11:10 +00:00
|
|
|
// Policy - Authority
|
2022-09-30 00:16:26 +00:00
|
|
|
r.MethodFunc("GET", "/policy", authorityPolicyMiddleware(router.policyResponder.GetAuthorityPolicy))
|
|
|
|
r.MethodFunc("POST", "/policy", authorityPolicyMiddleware(router.policyResponder.CreateAuthorityPolicy))
|
|
|
|
r.MethodFunc("PUT", "/policy", authorityPolicyMiddleware(router.policyResponder.UpdateAuthorityPolicy))
|
|
|
|
r.MethodFunc("DELETE", "/policy", authorityPolicyMiddleware(router.policyResponder.DeleteAuthorityPolicy))
|
2022-05-06 21:11:10 +00:00
|
|
|
|
|
|
|
// Policy - Provisioner
|
2022-09-30 00:16:26 +00:00
|
|
|
r.MethodFunc("GET", "/provisioners/{provisionerName}/policy", provisionerPolicyMiddleware(router.policyResponder.GetProvisionerPolicy))
|
|
|
|
r.MethodFunc("POST", "/provisioners/{provisionerName}/policy", provisionerPolicyMiddleware(router.policyResponder.CreateProvisionerPolicy))
|
|
|
|
r.MethodFunc("PUT", "/provisioners/{provisionerName}/policy", provisionerPolicyMiddleware(router.policyResponder.UpdateProvisionerPolicy))
|
|
|
|
r.MethodFunc("DELETE", "/provisioners/{provisionerName}/policy", provisionerPolicyMiddleware(router.policyResponder.DeleteProvisionerPolicy))
|
2022-05-06 21:11:10 +00:00
|
|
|
|
|
|
|
// Policy - ACME Account
|
2022-09-30 00:16:26 +00:00
|
|
|
r.MethodFunc("GET", "/acme/policy/{provisionerName}/reference/{reference}", acmePolicyMiddleware(router.policyResponder.GetACMEAccountPolicy))
|
|
|
|
r.MethodFunc("GET", "/acme/policy/{provisionerName}/key/{keyID}", acmePolicyMiddleware(router.policyResponder.GetACMEAccountPolicy))
|
|
|
|
r.MethodFunc("POST", "/acme/policy/{provisionerName}/reference/{reference}", acmePolicyMiddleware(router.policyResponder.CreateACMEAccountPolicy))
|
|
|
|
r.MethodFunc("POST", "/acme/policy/{provisionerName}/key/{keyID}", acmePolicyMiddleware(router.policyResponder.CreateACMEAccountPolicy))
|
|
|
|
r.MethodFunc("PUT", "/acme/policy/{provisionerName}/reference/{reference}", acmePolicyMiddleware(router.policyResponder.UpdateACMEAccountPolicy))
|
|
|
|
r.MethodFunc("PUT", "/acme/policy/{provisionerName}/key/{keyID}", acmePolicyMiddleware(router.policyResponder.UpdateACMEAccountPolicy))
|
|
|
|
r.MethodFunc("DELETE", "/acme/policy/{provisionerName}/reference/{reference}", acmePolicyMiddleware(router.policyResponder.DeleteACMEAccountPolicy))
|
|
|
|
r.MethodFunc("DELETE", "/acme/policy/{provisionerName}/key/{keyID}", acmePolicyMiddleware(router.policyResponder.DeleteACMEAccountPolicy))
|
|
|
|
}
|
|
|
|
|
|
|
|
if router.webhookResponder != nil {
|
|
|
|
r.MethodFunc("POST", "/provisioners/{provisionerName}/webhooks", webhookMiddleware(router.webhookResponder.CreateProvisionerWebhook))
|
|
|
|
r.MethodFunc("PUT", "/provisioners/{provisionerName}/webhooks/{webhookName}", webhookMiddleware(router.webhookResponder.UpdateProvisionerWebhook))
|
|
|
|
r.MethodFunc("DELETE", "/provisioners/{provisionerName}/webhooks/{webhookName}", webhookMiddleware(router.webhookResponder.DeleteProvisionerWebhook))
|
2022-05-06 21:11:10 +00:00
|
|
|
}
|
2021-05-03 19:48:20 +00:00
|
|
|
}
|