2022-07-22 16:52:36 +02:00
|
|
|
// Code generated by go-swagger; DO NOT EDIT.
|
|
|
|
|
|
|
|
package operations
|
|
|
|
|
|
|
|
// This file was generated by the swagger tool.
|
|
|
|
// Editing this file might prove futile when you re-run the swagger generate command
|
|
|
|
|
|
|
|
import (
|
|
|
|
"fmt"
|
|
|
|
"net/http"
|
|
|
|
"strings"
|
|
|
|
|
|
|
|
"github.com/go-openapi/errors"
|
|
|
|
"github.com/go-openapi/loads"
|
|
|
|
"github.com/go-openapi/runtime"
|
|
|
|
"github.com/go-openapi/runtime/middleware"
|
|
|
|
"github.com/go-openapi/runtime/security"
|
|
|
|
"github.com/go-openapi/spec"
|
|
|
|
"github.com/go-openapi/strfmt"
|
|
|
|
"github.com/go-openapi/swag"
|
|
|
|
|
2022-07-27 20:45:16 +02:00
|
|
|
"github.com/openziti-test-kitchen/zrok/rest_model_zrok"
|
2022-11-30 17:43:00 +01:00
|
|
|
"github.com/openziti-test-kitchen/zrok/rest_server_zrok/operations/account"
|
2022-12-01 21:13:43 +01:00
|
|
|
"github.com/openziti-test-kitchen/zrok/rest_server_zrok/operations/admin"
|
2022-11-30 17:43:00 +01:00
|
|
|
"github.com/openziti-test-kitchen/zrok/rest_server_zrok/operations/environment"
|
2022-07-26 21:16:02 +02:00
|
|
|
"github.com/openziti-test-kitchen/zrok/rest_server_zrok/operations/metadata"
|
2022-11-18 21:36:55 +01:00
|
|
|
"github.com/openziti-test-kitchen/zrok/rest_server_zrok/operations/service"
|
2022-07-22 16:52:36 +02:00
|
|
|
)
|
|
|
|
|
2022-07-22 17:16:30 +02:00
|
|
|
// NewZrokAPI creates a new Zrok instance
|
|
|
|
func NewZrokAPI(spec *loads.Document) *ZrokAPI {
|
|
|
|
return &ZrokAPI{
|
2022-07-22 16:52:36 +02:00
|
|
|
handlers: make(map[string]map[string]http.Handler),
|
|
|
|
formats: strfmt.Default,
|
|
|
|
defaultConsumes: "application/json",
|
|
|
|
defaultProduces: "application/json",
|
|
|
|
customConsumers: make(map[string]runtime.Consumer),
|
|
|
|
customProducers: make(map[string]runtime.Producer),
|
|
|
|
PreServerShutdown: func() {},
|
|
|
|
ServerShutdown: func() {},
|
|
|
|
spec: spec,
|
|
|
|
useSwaggerUI: false,
|
|
|
|
ServeError: errors.ServeError,
|
|
|
|
BasicAuthenticator: security.BasicAuth,
|
|
|
|
APIKeyAuthenticator: security.APIKeyAuth,
|
|
|
|
BearerAuthenticator: security.BearerAuth,
|
|
|
|
|
|
|
|
JSONConsumer: runtime.JSONConsumer(),
|
|
|
|
|
|
|
|
JSONProducer: runtime.JSONProducer(),
|
|
|
|
|
2022-11-23 18:12:11 +01:00
|
|
|
ServiceAccessHandler: service.AccessHandlerFunc(func(params service.AccessParams, principal *rest_model_zrok.Principal) middleware.Responder {
|
|
|
|
return middleware.NotImplemented("operation service.Access has not yet been implemented")
|
|
|
|
}),
|
2022-12-01 21:13:43 +01:00
|
|
|
AdminCreateFrontendHandler: admin.CreateFrontendHandlerFunc(func(params admin.CreateFrontendParams, principal *rest_model_zrok.Principal) middleware.Responder {
|
|
|
|
return middleware.NotImplemented("operation admin.CreateFrontend has not yet been implemented")
|
|
|
|
}),
|
2022-12-06 20:06:12 +01:00
|
|
|
AdminCreateIdentityHandler: admin.CreateIdentityHandlerFunc(func(params admin.CreateIdentityParams, principal *rest_model_zrok.Principal) middleware.Responder {
|
|
|
|
return middleware.NotImplemented("operation admin.CreateIdentity has not yet been implemented")
|
|
|
|
}),
|
2022-12-02 14:58:41 +01:00
|
|
|
AdminDeleteFrontendHandler: admin.DeleteFrontendHandlerFunc(func(params admin.DeleteFrontendParams, principal *rest_model_zrok.Principal) middleware.Responder {
|
|
|
|
return middleware.NotImplemented("operation admin.DeleteFrontend has not yet been implemented")
|
|
|
|
}),
|
2022-11-30 17:43:00 +01:00
|
|
|
EnvironmentDisableHandler: environment.DisableHandlerFunc(func(params environment.DisableParams, principal *rest_model_zrok.Principal) middleware.Responder {
|
|
|
|
return middleware.NotImplemented("operation environment.Disable has not yet been implemented")
|
2022-07-25 17:44:17 +02:00
|
|
|
}),
|
2022-11-30 17:43:00 +01:00
|
|
|
EnvironmentEnableHandler: environment.EnableHandlerFunc(func(params environment.EnableParams, principal *rest_model_zrok.Principal) middleware.Responder {
|
|
|
|
return middleware.NotImplemented("operation environment.Enable has not yet been implemented")
|
2022-07-25 23:05:44 +02:00
|
|
|
}),
|
2022-12-22 19:51:29 +01:00
|
|
|
MetadataGetEnvironmentDetailHandler: metadata.GetEnvironmentDetailHandlerFunc(func(params metadata.GetEnvironmentDetailParams, principal *rest_model_zrok.Principal) middleware.Responder {
|
|
|
|
return middleware.NotImplemented("operation metadata.GetEnvironmentDetail has not yet been implemented")
|
|
|
|
}),
|
2022-11-30 17:17:09 +01:00
|
|
|
ServiceGetServiceHandler: service.GetServiceHandlerFunc(func(params service.GetServiceParams, principal *rest_model_zrok.Principal) middleware.Responder {
|
|
|
|
return middleware.NotImplemented("operation service.GetService has not yet been implemented")
|
|
|
|
}),
|
2022-12-22 21:09:37 +01:00
|
|
|
MetadataGetServiceDetailHandler: metadata.GetServiceDetailHandlerFunc(func(params metadata.GetServiceDetailParams, principal *rest_model_zrok.Principal) middleware.Responder {
|
|
|
|
return middleware.NotImplemented("operation metadata.GetServiceDetail has not yet been implemented")
|
|
|
|
}),
|
2022-11-30 17:43:00 +01:00
|
|
|
AccountInviteHandler: account.InviteHandlerFunc(func(params account.InviteParams) middleware.Responder {
|
|
|
|
return middleware.NotImplemented("operation account.Invite has not yet been implemented")
|
|
|
|
}),
|
2022-12-02 15:30:06 +01:00
|
|
|
AdminListFrontendsHandler: admin.ListFrontendsHandlerFunc(func(params admin.ListFrontendsParams, principal *rest_model_zrok.Principal) middleware.Responder {
|
|
|
|
return middleware.NotImplemented("operation admin.ListFrontends has not yet been implemented")
|
|
|
|
}),
|
2022-11-30 17:43:00 +01:00
|
|
|
AccountLoginHandler: account.LoginHandlerFunc(func(params account.LoginParams) middleware.Responder {
|
|
|
|
return middleware.NotImplemented("operation account.Login has not yet been implemented")
|
2022-08-02 19:23:31 +02:00
|
|
|
}),
|
2022-08-03 20:58:11 +02:00
|
|
|
MetadataOverviewHandler: metadata.OverviewHandlerFunc(func(params metadata.OverviewParams, principal *rest_model_zrok.Principal) middleware.Responder {
|
2022-08-03 20:36:40 +02:00
|
|
|
return middleware.NotImplemented("operation metadata.Overview has not yet been implemented")
|
|
|
|
}),
|
2022-11-30 17:43:00 +01:00
|
|
|
AccountRegisterHandler: account.RegisterHandlerFunc(func(params account.RegisterParams) middleware.Responder {
|
|
|
|
return middleware.NotImplemented("operation account.Register has not yet been implemented")
|
2022-09-20 19:42:34 +02:00
|
|
|
}),
|
2022-11-18 21:36:55 +01:00
|
|
|
ServiceShareHandler: service.ShareHandlerFunc(func(params service.ShareParams, principal *rest_model_zrok.Principal) middleware.Responder {
|
|
|
|
return middleware.NotImplemented("operation service.Share has not yet been implemented")
|
2022-07-26 21:38:35 +02:00
|
|
|
}),
|
2022-11-23 18:12:11 +01:00
|
|
|
ServiceUnaccessHandler: service.UnaccessHandlerFunc(func(params service.UnaccessParams, principal *rest_model_zrok.Principal) middleware.Responder {
|
|
|
|
return middleware.NotImplemented("operation service.Unaccess has not yet been implemented")
|
|
|
|
}),
|
2022-11-18 21:36:55 +01:00
|
|
|
ServiceUnshareHandler: service.UnshareHandlerFunc(func(params service.UnshareParams, principal *rest_model_zrok.Principal) middleware.Responder {
|
|
|
|
return middleware.NotImplemented("operation service.Unshare has not yet been implemented")
|
2022-07-27 17:35:28 +02:00
|
|
|
}),
|
2022-12-02 16:46:53 +01:00
|
|
|
AdminUpdateFrontendHandler: admin.UpdateFrontendHandlerFunc(func(params admin.UpdateFrontendParams, principal *rest_model_zrok.Principal) middleware.Responder {
|
|
|
|
return middleware.NotImplemented("operation admin.UpdateFrontend has not yet been implemented")
|
|
|
|
}),
|
2022-12-02 19:21:05 +01:00
|
|
|
ServiceUpdateShareHandler: service.UpdateShareHandlerFunc(func(params service.UpdateShareParams, principal *rest_model_zrok.Principal) middleware.Responder {
|
|
|
|
return middleware.NotImplemented("operation service.UpdateShare has not yet been implemented")
|
|
|
|
}),
|
2022-11-30 17:43:00 +01:00
|
|
|
AccountVerifyHandler: account.VerifyHandlerFunc(func(params account.VerifyParams) middleware.Responder {
|
|
|
|
return middleware.NotImplemented("operation account.Verify has not yet been implemented")
|
2022-09-19 21:58:52 +02:00
|
|
|
}),
|
2022-07-25 17:51:23 +02:00
|
|
|
MetadataVersionHandler: metadata.VersionHandlerFunc(func(params metadata.VersionParams) middleware.Responder {
|
|
|
|
return middleware.NotImplemented("operation metadata.Version has not yet been implemented")
|
|
|
|
}),
|
2022-07-27 20:45:16 +02:00
|
|
|
|
|
|
|
// Applies when the "x-token" header is set
|
|
|
|
KeyAuth: func(token string) (*rest_model_zrok.Principal, error) {
|
|
|
|
return nil, errors.NotImplemented("api key auth (key) x-token from header param [x-token] has not yet been implemented")
|
|
|
|
},
|
|
|
|
// default authorizer is authorized meaning no requests are blocked
|
|
|
|
APIAuthorizer: security.Authorized(),
|
2022-07-22 16:52:36 +02:00
|
|
|
}
|
|
|
|
}
|
|
|
|
|
2022-07-22 17:16:30 +02:00
|
|
|
/*ZrokAPI zrok client access */
|
|
|
|
type ZrokAPI struct {
|
2022-07-22 16:52:36 +02:00
|
|
|
spec *loads.Document
|
|
|
|
context *middleware.Context
|
|
|
|
handlers map[string]map[string]http.Handler
|
|
|
|
formats strfmt.Registry
|
|
|
|
customConsumers map[string]runtime.Consumer
|
|
|
|
customProducers map[string]runtime.Producer
|
|
|
|
defaultConsumes string
|
|
|
|
defaultProduces string
|
|
|
|
Middleware func(middleware.Builder) http.Handler
|
|
|
|
useSwaggerUI bool
|
|
|
|
|
|
|
|
// BasicAuthenticator generates a runtime.Authenticator from the supplied basic auth function.
|
|
|
|
// It has a default implementation in the security package, however you can replace it for your particular usage.
|
|
|
|
BasicAuthenticator func(security.UserPassAuthentication) runtime.Authenticator
|
|
|
|
|
|
|
|
// APIKeyAuthenticator generates a runtime.Authenticator from the supplied token auth function.
|
|
|
|
// It has a default implementation in the security package, however you can replace it for your particular usage.
|
|
|
|
APIKeyAuthenticator func(string, string, security.TokenAuthentication) runtime.Authenticator
|
|
|
|
|
|
|
|
// BearerAuthenticator generates a runtime.Authenticator from the supplied bearer token auth function.
|
|
|
|
// It has a default implementation in the security package, however you can replace it for your particular usage.
|
|
|
|
BearerAuthenticator func(string, security.ScopedTokenAuthentication) runtime.Authenticator
|
|
|
|
|
|
|
|
// JSONConsumer registers a consumer for the following mime types:
|
2022-07-22 17:45:37 +02:00
|
|
|
// - application/zrok.v1+json
|
2022-07-22 16:52:36 +02:00
|
|
|
JSONConsumer runtime.Consumer
|
|
|
|
|
|
|
|
// JSONProducer registers a producer for the following mime types:
|
2022-07-22 17:45:37 +02:00
|
|
|
// - application/zrok.v1+json
|
2022-07-22 16:52:36 +02:00
|
|
|
JSONProducer runtime.Producer
|
|
|
|
|
2022-07-27 20:45:16 +02:00
|
|
|
// KeyAuth registers a function that takes a token and returns a principal
|
|
|
|
// it performs authentication based on an api key x-token provided in the header
|
|
|
|
KeyAuth func(string) (*rest_model_zrok.Principal, error)
|
|
|
|
|
|
|
|
// APIAuthorizer provides access control (ACL/RBAC/ABAC) by providing access to the request and authenticated principal
|
|
|
|
APIAuthorizer runtime.Authorizer
|
|
|
|
|
2022-11-23 18:12:11 +01:00
|
|
|
// ServiceAccessHandler sets the operation handler for the access operation
|
|
|
|
ServiceAccessHandler service.AccessHandler
|
2022-12-01 21:13:43 +01:00
|
|
|
// AdminCreateFrontendHandler sets the operation handler for the create frontend operation
|
|
|
|
AdminCreateFrontendHandler admin.CreateFrontendHandler
|
2022-12-06 20:06:12 +01:00
|
|
|
// AdminCreateIdentityHandler sets the operation handler for the create identity operation
|
|
|
|
AdminCreateIdentityHandler admin.CreateIdentityHandler
|
2022-12-02 14:58:41 +01:00
|
|
|
// AdminDeleteFrontendHandler sets the operation handler for the delete frontend operation
|
|
|
|
AdminDeleteFrontendHandler admin.DeleteFrontendHandler
|
2022-11-30 17:43:00 +01:00
|
|
|
// EnvironmentDisableHandler sets the operation handler for the disable operation
|
|
|
|
EnvironmentDisableHandler environment.DisableHandler
|
|
|
|
// EnvironmentEnableHandler sets the operation handler for the enable operation
|
|
|
|
EnvironmentEnableHandler environment.EnableHandler
|
2022-12-22 19:51:29 +01:00
|
|
|
// MetadataGetEnvironmentDetailHandler sets the operation handler for the get environment detail operation
|
|
|
|
MetadataGetEnvironmentDetailHandler metadata.GetEnvironmentDetailHandler
|
2022-11-30 17:17:09 +01:00
|
|
|
// ServiceGetServiceHandler sets the operation handler for the get service operation
|
|
|
|
ServiceGetServiceHandler service.GetServiceHandler
|
2022-12-22 21:09:37 +01:00
|
|
|
// MetadataGetServiceDetailHandler sets the operation handler for the get service detail operation
|
|
|
|
MetadataGetServiceDetailHandler metadata.GetServiceDetailHandler
|
2022-11-30 17:43:00 +01:00
|
|
|
// AccountInviteHandler sets the operation handler for the invite operation
|
|
|
|
AccountInviteHandler account.InviteHandler
|
2022-12-02 15:30:06 +01:00
|
|
|
// AdminListFrontendsHandler sets the operation handler for the list frontends operation
|
|
|
|
AdminListFrontendsHandler admin.ListFrontendsHandler
|
2022-11-30 17:43:00 +01:00
|
|
|
// AccountLoginHandler sets the operation handler for the login operation
|
|
|
|
AccountLoginHandler account.LoginHandler
|
2022-08-03 20:36:40 +02:00
|
|
|
// MetadataOverviewHandler sets the operation handler for the overview operation
|
|
|
|
MetadataOverviewHandler metadata.OverviewHandler
|
2022-11-30 17:43:00 +01:00
|
|
|
// AccountRegisterHandler sets the operation handler for the register operation
|
|
|
|
AccountRegisterHandler account.RegisterHandler
|
2022-11-18 21:36:55 +01:00
|
|
|
// ServiceShareHandler sets the operation handler for the share operation
|
|
|
|
ServiceShareHandler service.ShareHandler
|
2022-11-23 18:12:11 +01:00
|
|
|
// ServiceUnaccessHandler sets the operation handler for the unaccess operation
|
|
|
|
ServiceUnaccessHandler service.UnaccessHandler
|
2022-11-18 21:36:55 +01:00
|
|
|
// ServiceUnshareHandler sets the operation handler for the unshare operation
|
|
|
|
ServiceUnshareHandler service.UnshareHandler
|
2022-12-02 16:46:53 +01:00
|
|
|
// AdminUpdateFrontendHandler sets the operation handler for the update frontend operation
|
|
|
|
AdminUpdateFrontendHandler admin.UpdateFrontendHandler
|
2022-12-02 19:21:05 +01:00
|
|
|
// ServiceUpdateShareHandler sets the operation handler for the update share operation
|
|
|
|
ServiceUpdateShareHandler service.UpdateShareHandler
|
2022-11-30 17:43:00 +01:00
|
|
|
// AccountVerifyHandler sets the operation handler for the verify operation
|
|
|
|
AccountVerifyHandler account.VerifyHandler
|
2022-07-25 17:51:23 +02:00
|
|
|
// MetadataVersionHandler sets the operation handler for the version operation
|
|
|
|
MetadataVersionHandler metadata.VersionHandler
|
2022-07-22 16:52:36 +02:00
|
|
|
|
|
|
|
// ServeError is called when an error is received, there is a default handler
|
|
|
|
// but you can set your own with this
|
|
|
|
ServeError func(http.ResponseWriter, *http.Request, error)
|
|
|
|
|
|
|
|
// PreServerShutdown is called before the HTTP(S) server is shutdown
|
|
|
|
// This allows for custom functions to get executed before the HTTP(S) server stops accepting traffic
|
|
|
|
PreServerShutdown func()
|
|
|
|
|
|
|
|
// ServerShutdown is called when the HTTP(S) server is shut down and done
|
|
|
|
// handling all active connections and does not accept connections any more
|
|
|
|
ServerShutdown func()
|
|
|
|
|
|
|
|
// Custom command line argument groups with their descriptions
|
|
|
|
CommandLineOptionsGroups []swag.CommandLineOptionsGroup
|
|
|
|
|
|
|
|
// User defined logger function.
|
|
|
|
Logger func(string, ...interface{})
|
|
|
|
}
|
|
|
|
|
|
|
|
// UseRedoc for documentation at /docs
|
2022-07-22 17:16:30 +02:00
|
|
|
func (o *ZrokAPI) UseRedoc() {
|
2022-07-22 16:52:36 +02:00
|
|
|
o.useSwaggerUI = false
|
|
|
|
}
|
|
|
|
|
|
|
|
// UseSwaggerUI for documentation at /docs
|
2022-07-22 17:16:30 +02:00
|
|
|
func (o *ZrokAPI) UseSwaggerUI() {
|
2022-07-22 16:52:36 +02:00
|
|
|
o.useSwaggerUI = true
|
|
|
|
}
|
|
|
|
|
|
|
|
// SetDefaultProduces sets the default produces media type
|
2022-07-22 17:16:30 +02:00
|
|
|
func (o *ZrokAPI) SetDefaultProduces(mediaType string) {
|
2022-07-22 16:52:36 +02:00
|
|
|
o.defaultProduces = mediaType
|
|
|
|
}
|
|
|
|
|
|
|
|
// SetDefaultConsumes returns the default consumes media type
|
2022-07-22 17:16:30 +02:00
|
|
|
func (o *ZrokAPI) SetDefaultConsumes(mediaType string) {
|
2022-07-22 16:52:36 +02:00
|
|
|
o.defaultConsumes = mediaType
|
|
|
|
}
|
|
|
|
|
|
|
|
// SetSpec sets a spec that will be served for the clients.
|
2022-07-22 17:16:30 +02:00
|
|
|
func (o *ZrokAPI) SetSpec(spec *loads.Document) {
|
2022-07-22 16:52:36 +02:00
|
|
|
o.spec = spec
|
|
|
|
}
|
|
|
|
|
|
|
|
// DefaultProduces returns the default produces media type
|
2022-07-22 17:16:30 +02:00
|
|
|
func (o *ZrokAPI) DefaultProduces() string {
|
2022-07-22 16:52:36 +02:00
|
|
|
return o.defaultProduces
|
|
|
|
}
|
|
|
|
|
|
|
|
// DefaultConsumes returns the default consumes media type
|
2022-07-22 17:16:30 +02:00
|
|
|
func (o *ZrokAPI) DefaultConsumes() string {
|
2022-07-22 16:52:36 +02:00
|
|
|
return o.defaultConsumes
|
|
|
|
}
|
|
|
|
|
|
|
|
// Formats returns the registered string formats
|
2022-07-22 17:16:30 +02:00
|
|
|
func (o *ZrokAPI) Formats() strfmt.Registry {
|
2022-07-22 16:52:36 +02:00
|
|
|
return o.formats
|
|
|
|
}
|
|
|
|
|
|
|
|
// RegisterFormat registers a custom format validator
|
2022-07-22 17:16:30 +02:00
|
|
|
func (o *ZrokAPI) RegisterFormat(name string, format strfmt.Format, validator strfmt.Validator) {
|
2022-07-22 16:52:36 +02:00
|
|
|
o.formats.Add(name, format, validator)
|
|
|
|
}
|
|
|
|
|
2022-07-22 17:16:30 +02:00
|
|
|
// Validate validates the registrations in the ZrokAPI
|
|
|
|
func (o *ZrokAPI) Validate() error {
|
2022-07-22 16:52:36 +02:00
|
|
|
var unregistered []string
|
|
|
|
|
|
|
|
if o.JSONConsumer == nil {
|
|
|
|
unregistered = append(unregistered, "JSONConsumer")
|
|
|
|
}
|
|
|
|
|
|
|
|
if o.JSONProducer == nil {
|
|
|
|
unregistered = append(unregistered, "JSONProducer")
|
|
|
|
}
|
|
|
|
|
2022-07-27 20:45:16 +02:00
|
|
|
if o.KeyAuth == nil {
|
|
|
|
unregistered = append(unregistered, "XTokenAuth")
|
|
|
|
}
|
|
|
|
|
2022-11-23 18:12:11 +01:00
|
|
|
if o.ServiceAccessHandler == nil {
|
|
|
|
unregistered = append(unregistered, "service.AccessHandler")
|
|
|
|
}
|
2022-12-01 21:13:43 +01:00
|
|
|
if o.AdminCreateFrontendHandler == nil {
|
|
|
|
unregistered = append(unregistered, "admin.CreateFrontendHandler")
|
|
|
|
}
|
2022-12-06 20:06:12 +01:00
|
|
|
if o.AdminCreateIdentityHandler == nil {
|
|
|
|
unregistered = append(unregistered, "admin.CreateIdentityHandler")
|
|
|
|
}
|
2022-12-02 14:58:41 +01:00
|
|
|
if o.AdminDeleteFrontendHandler == nil {
|
|
|
|
unregistered = append(unregistered, "admin.DeleteFrontendHandler")
|
|
|
|
}
|
2022-11-30 17:43:00 +01:00
|
|
|
if o.EnvironmentDisableHandler == nil {
|
|
|
|
unregistered = append(unregistered, "environment.DisableHandler")
|
2022-09-01 23:39:02 +02:00
|
|
|
}
|
2022-11-30 17:43:00 +01:00
|
|
|
if o.EnvironmentEnableHandler == nil {
|
|
|
|
unregistered = append(unregistered, "environment.EnableHandler")
|
2022-07-25 23:05:44 +02:00
|
|
|
}
|
2022-12-22 19:51:29 +01:00
|
|
|
if o.MetadataGetEnvironmentDetailHandler == nil {
|
|
|
|
unregistered = append(unregistered, "metadata.GetEnvironmentDetailHandler")
|
|
|
|
}
|
2022-11-30 17:17:09 +01:00
|
|
|
if o.ServiceGetServiceHandler == nil {
|
|
|
|
unregistered = append(unregistered, "service.GetServiceHandler")
|
|
|
|
}
|
2022-12-22 21:09:37 +01:00
|
|
|
if o.MetadataGetServiceDetailHandler == nil {
|
|
|
|
unregistered = append(unregistered, "metadata.GetServiceDetailHandler")
|
|
|
|
}
|
2022-11-30 17:43:00 +01:00
|
|
|
if o.AccountInviteHandler == nil {
|
|
|
|
unregistered = append(unregistered, "account.InviteHandler")
|
|
|
|
}
|
2022-12-02 15:30:06 +01:00
|
|
|
if o.AdminListFrontendsHandler == nil {
|
|
|
|
unregistered = append(unregistered, "admin.ListFrontendsHandler")
|
|
|
|
}
|
2022-11-30 17:43:00 +01:00
|
|
|
if o.AccountLoginHandler == nil {
|
|
|
|
unregistered = append(unregistered, "account.LoginHandler")
|
2022-08-02 19:23:31 +02:00
|
|
|
}
|
2022-08-03 20:36:40 +02:00
|
|
|
if o.MetadataOverviewHandler == nil {
|
|
|
|
unregistered = append(unregistered, "metadata.OverviewHandler")
|
|
|
|
}
|
2022-11-30 17:43:00 +01:00
|
|
|
if o.AccountRegisterHandler == nil {
|
|
|
|
unregistered = append(unregistered, "account.RegisterHandler")
|
2022-09-20 19:42:34 +02:00
|
|
|
}
|
2022-11-18 21:36:55 +01:00
|
|
|
if o.ServiceShareHandler == nil {
|
|
|
|
unregistered = append(unregistered, "service.ShareHandler")
|
2022-07-26 21:38:35 +02:00
|
|
|
}
|
2022-11-23 18:12:11 +01:00
|
|
|
if o.ServiceUnaccessHandler == nil {
|
|
|
|
unregistered = append(unregistered, "service.UnaccessHandler")
|
|
|
|
}
|
2022-11-18 21:36:55 +01:00
|
|
|
if o.ServiceUnshareHandler == nil {
|
|
|
|
unregistered = append(unregistered, "service.UnshareHandler")
|
2022-07-27 17:35:28 +02:00
|
|
|
}
|
2022-12-02 16:46:53 +01:00
|
|
|
if o.AdminUpdateFrontendHandler == nil {
|
|
|
|
unregistered = append(unregistered, "admin.UpdateFrontendHandler")
|
|
|
|
}
|
2022-12-02 19:21:05 +01:00
|
|
|
if o.ServiceUpdateShareHandler == nil {
|
|
|
|
unregistered = append(unregistered, "service.UpdateShareHandler")
|
|
|
|
}
|
2022-11-30 17:43:00 +01:00
|
|
|
if o.AccountVerifyHandler == nil {
|
|
|
|
unregistered = append(unregistered, "account.VerifyHandler")
|
2022-09-19 21:58:52 +02:00
|
|
|
}
|
2022-07-25 17:51:23 +02:00
|
|
|
if o.MetadataVersionHandler == nil {
|
|
|
|
unregistered = append(unregistered, "metadata.VersionHandler")
|
|
|
|
}
|
2022-07-22 16:52:36 +02:00
|
|
|
|
|
|
|
if len(unregistered) > 0 {
|
|
|
|
return fmt.Errorf("missing registration: %s", strings.Join(unregistered, ", "))
|
|
|
|
}
|
|
|
|
|
|
|
|
return nil
|
|
|
|
}
|
|
|
|
|
|
|
|
// ServeErrorFor gets a error handler for a given operation id
|
2022-07-22 17:16:30 +02:00
|
|
|
func (o *ZrokAPI) ServeErrorFor(operationID string) func(http.ResponseWriter, *http.Request, error) {
|
2022-07-22 16:52:36 +02:00
|
|
|
return o.ServeError
|
|
|
|
}
|
|
|
|
|
|
|
|
// AuthenticatorsFor gets the authenticators for the specified security schemes
|
2022-07-22 17:16:30 +02:00
|
|
|
func (o *ZrokAPI) AuthenticatorsFor(schemes map[string]spec.SecurityScheme) map[string]runtime.Authenticator {
|
2022-07-27 20:45:16 +02:00
|
|
|
result := make(map[string]runtime.Authenticator)
|
|
|
|
for name := range schemes {
|
|
|
|
switch name {
|
|
|
|
case "key":
|
|
|
|
scheme := schemes[name]
|
|
|
|
result[name] = o.APIKeyAuthenticator(scheme.Name, scheme.In, func(token string) (interface{}, error) {
|
|
|
|
return o.KeyAuth(token)
|
|
|
|
})
|
|
|
|
|
|
|
|
}
|
|
|
|
}
|
|
|
|
return result
|
2022-07-22 16:52:36 +02:00
|
|
|
}
|
|
|
|
|
|
|
|
// Authorizer returns the registered authorizer
|
2022-07-22 17:16:30 +02:00
|
|
|
func (o *ZrokAPI) Authorizer() runtime.Authorizer {
|
2022-07-27 20:45:16 +02:00
|
|
|
return o.APIAuthorizer
|
2022-07-22 16:52:36 +02:00
|
|
|
}
|
|
|
|
|
|
|
|
// ConsumersFor gets the consumers for the specified media types.
|
|
|
|
// MIME type parameters are ignored here.
|
2022-07-22 17:16:30 +02:00
|
|
|
func (o *ZrokAPI) ConsumersFor(mediaTypes []string) map[string]runtime.Consumer {
|
2022-07-22 16:52:36 +02:00
|
|
|
result := make(map[string]runtime.Consumer, len(mediaTypes))
|
|
|
|
for _, mt := range mediaTypes {
|
|
|
|
switch mt {
|
2022-07-22 17:45:37 +02:00
|
|
|
case "application/zrok.v1+json":
|
|
|
|
result["application/zrok.v1+json"] = o.JSONConsumer
|
2022-07-22 16:52:36 +02:00
|
|
|
}
|
|
|
|
|
|
|
|
if c, ok := o.customConsumers[mt]; ok {
|
|
|
|
result[mt] = c
|
|
|
|
}
|
|
|
|
}
|
|
|
|
return result
|
|
|
|
}
|
|
|
|
|
|
|
|
// ProducersFor gets the producers for the specified media types.
|
|
|
|
// MIME type parameters are ignored here.
|
2022-07-22 17:16:30 +02:00
|
|
|
func (o *ZrokAPI) ProducersFor(mediaTypes []string) map[string]runtime.Producer {
|
2022-07-22 16:52:36 +02:00
|
|
|
result := make(map[string]runtime.Producer, len(mediaTypes))
|
|
|
|
for _, mt := range mediaTypes {
|
|
|
|
switch mt {
|
2022-07-22 17:45:37 +02:00
|
|
|
case "application/zrok.v1+json":
|
|
|
|
result["application/zrok.v1+json"] = o.JSONProducer
|
2022-07-22 16:52:36 +02:00
|
|
|
}
|
|
|
|
|
|
|
|
if p, ok := o.customProducers[mt]; ok {
|
|
|
|
result[mt] = p
|
|
|
|
}
|
|
|
|
}
|
|
|
|
return result
|
|
|
|
}
|
|
|
|
|
|
|
|
// HandlerFor gets a http.Handler for the provided operation method and path
|
2022-07-22 17:16:30 +02:00
|
|
|
func (o *ZrokAPI) HandlerFor(method, path string) (http.Handler, bool) {
|
2022-07-22 16:52:36 +02:00
|
|
|
if o.handlers == nil {
|
|
|
|
return nil, false
|
|
|
|
}
|
|
|
|
um := strings.ToUpper(method)
|
|
|
|
if _, ok := o.handlers[um]; !ok {
|
|
|
|
return nil, false
|
|
|
|
}
|
|
|
|
if path == "/" {
|
|
|
|
path = ""
|
|
|
|
}
|
|
|
|
h, ok := o.handlers[um][path]
|
|
|
|
return h, ok
|
|
|
|
}
|
|
|
|
|
2022-07-22 17:16:30 +02:00
|
|
|
// Context returns the middleware context for the zrok API
|
|
|
|
func (o *ZrokAPI) Context() *middleware.Context {
|
2022-07-22 16:52:36 +02:00
|
|
|
if o.context == nil {
|
|
|
|
o.context = middleware.NewRoutableContext(o.spec, o, nil)
|
|
|
|
}
|
|
|
|
|
|
|
|
return o.context
|
|
|
|
}
|
|
|
|
|
2022-07-22 17:16:30 +02:00
|
|
|
func (o *ZrokAPI) initHandlerCache() {
|
2022-07-22 16:52:36 +02:00
|
|
|
o.Context() // don't care about the result, just that the initialization happened
|
|
|
|
if o.handlers == nil {
|
|
|
|
o.handlers = make(map[string]map[string]http.Handler)
|
|
|
|
}
|
|
|
|
|
2022-11-23 18:12:11 +01:00
|
|
|
if o.handlers["POST"] == nil {
|
|
|
|
o.handlers["POST"] = make(map[string]http.Handler)
|
|
|
|
}
|
|
|
|
o.handlers["POST"]["/access"] = service.NewAccess(o.context, o.ServiceAccessHandler)
|
2022-07-25 17:44:17 +02:00
|
|
|
if o.handlers["POST"] == nil {
|
|
|
|
o.handlers["POST"] = make(map[string]http.Handler)
|
|
|
|
}
|
2022-12-01 21:13:43 +01:00
|
|
|
o.handlers["POST"]["/frontend"] = admin.NewCreateFrontend(o.context, o.AdminCreateFrontendHandler)
|
2022-12-06 20:06:12 +01:00
|
|
|
if o.handlers["POST"] == nil {
|
|
|
|
o.handlers["POST"] = make(map[string]http.Handler)
|
|
|
|
}
|
|
|
|
o.handlers["POST"]["/identity"] = admin.NewCreateIdentity(o.context, o.AdminCreateIdentityHandler)
|
2022-12-02 14:58:41 +01:00
|
|
|
if o.handlers["DELETE"] == nil {
|
|
|
|
o.handlers["DELETE"] = make(map[string]http.Handler)
|
|
|
|
}
|
|
|
|
o.handlers["DELETE"]["/frontend"] = admin.NewDeleteFrontend(o.context, o.AdminDeleteFrontendHandler)
|
2022-12-01 21:13:43 +01:00
|
|
|
if o.handlers["POST"] == nil {
|
|
|
|
o.handlers["POST"] = make(map[string]http.Handler)
|
|
|
|
}
|
2022-11-30 17:43:00 +01:00
|
|
|
o.handlers["POST"]["/disable"] = environment.NewDisable(o.context, o.EnvironmentDisableHandler)
|
2022-09-01 23:39:02 +02:00
|
|
|
if o.handlers["POST"] == nil {
|
|
|
|
o.handlers["POST"] = make(map[string]http.Handler)
|
|
|
|
}
|
2022-11-30 17:43:00 +01:00
|
|
|
o.handlers["POST"]["/enable"] = environment.NewEnable(o.context, o.EnvironmentEnableHandler)
|
2022-11-30 17:17:09 +01:00
|
|
|
if o.handlers["GET"] == nil {
|
|
|
|
o.handlers["GET"] = make(map[string]http.Handler)
|
|
|
|
}
|
2022-12-22 20:56:19 +01:00
|
|
|
o.handlers["GET"]["/detail/environment/{envZId}"] = metadata.NewGetEnvironmentDetail(o.context, o.MetadataGetEnvironmentDetailHandler)
|
2022-12-22 19:51:29 +01:00
|
|
|
if o.handlers["GET"] == nil {
|
|
|
|
o.handlers["GET"] = make(map[string]http.Handler)
|
|
|
|
}
|
2022-11-30 17:17:09 +01:00
|
|
|
o.handlers["GET"]["/service"] = service.NewGetService(o.context, o.ServiceGetServiceHandler)
|
2022-12-22 21:09:37 +01:00
|
|
|
if o.handlers["GET"] == nil {
|
|
|
|
o.handlers["GET"] = make(map[string]http.Handler)
|
|
|
|
}
|
|
|
|
o.handlers["GET"]["/detail/service/{svcToken}"] = metadata.NewGetServiceDetail(o.context, o.MetadataGetServiceDetailHandler)
|
2022-07-26 21:38:35 +02:00
|
|
|
if o.handlers["POST"] == nil {
|
|
|
|
o.handlers["POST"] = make(map[string]http.Handler)
|
|
|
|
}
|
2022-11-30 17:43:00 +01:00
|
|
|
o.handlers["POST"]["/invite"] = account.NewInvite(o.context, o.AccountInviteHandler)
|
2022-12-02 15:30:06 +01:00
|
|
|
if o.handlers["GET"] == nil {
|
|
|
|
o.handlers["GET"] = make(map[string]http.Handler)
|
|
|
|
}
|
|
|
|
o.handlers["GET"]["/frontends"] = admin.NewListFrontends(o.context, o.AdminListFrontendsHandler)
|
2022-11-30 17:43:00 +01:00
|
|
|
if o.handlers["POST"] == nil {
|
|
|
|
o.handlers["POST"] = make(map[string]http.Handler)
|
|
|
|
}
|
|
|
|
o.handlers["POST"]["/login"] = account.NewLogin(o.context, o.AccountLoginHandler)
|
2022-08-03 20:36:40 +02:00
|
|
|
if o.handlers["GET"] == nil {
|
|
|
|
o.handlers["GET"] = make(map[string]http.Handler)
|
|
|
|
}
|
|
|
|
o.handlers["GET"]["/overview"] = metadata.NewOverview(o.context, o.MetadataOverviewHandler)
|
2022-08-02 19:23:31 +02:00
|
|
|
if o.handlers["POST"] == nil {
|
|
|
|
o.handlers["POST"] = make(map[string]http.Handler)
|
|
|
|
}
|
2022-11-30 17:43:00 +01:00
|
|
|
o.handlers["POST"]["/register"] = account.NewRegister(o.context, o.AccountRegisterHandler)
|
2022-09-20 19:42:34 +02:00
|
|
|
if o.handlers["POST"] == nil {
|
|
|
|
o.handlers["POST"] = make(map[string]http.Handler)
|
|
|
|
}
|
2022-11-18 21:36:55 +01:00
|
|
|
o.handlers["POST"]["/share"] = service.NewShare(o.context, o.ServiceShareHandler)
|
2022-07-27 17:35:28 +02:00
|
|
|
if o.handlers["DELETE"] == nil {
|
|
|
|
o.handlers["DELETE"] = make(map[string]http.Handler)
|
|
|
|
}
|
2022-11-23 18:12:11 +01:00
|
|
|
o.handlers["DELETE"]["/unaccess"] = service.NewUnaccess(o.context, o.ServiceUnaccessHandler)
|
|
|
|
if o.handlers["DELETE"] == nil {
|
|
|
|
o.handlers["DELETE"] = make(map[string]http.Handler)
|
|
|
|
}
|
2022-11-18 21:36:55 +01:00
|
|
|
o.handlers["DELETE"]["/unshare"] = service.NewUnshare(o.context, o.ServiceUnshareHandler)
|
2022-12-02 16:46:53 +01:00
|
|
|
if o.handlers["PATCH"] == nil {
|
|
|
|
o.handlers["PATCH"] = make(map[string]http.Handler)
|
|
|
|
}
|
|
|
|
o.handlers["PATCH"]["/frontend"] = admin.NewUpdateFrontend(o.context, o.AdminUpdateFrontendHandler)
|
2022-12-02 19:21:05 +01:00
|
|
|
if o.handlers["PATCH"] == nil {
|
|
|
|
o.handlers["PATCH"] = make(map[string]http.Handler)
|
|
|
|
}
|
|
|
|
o.handlers["PATCH"]["/share"] = service.NewUpdateShare(o.context, o.ServiceUpdateShareHandler)
|
2022-09-19 22:26:54 +02:00
|
|
|
if o.handlers["POST"] == nil {
|
|
|
|
o.handlers["POST"] = make(map[string]http.Handler)
|
2022-07-25 17:51:23 +02:00
|
|
|
}
|
2022-11-30 17:43:00 +01:00
|
|
|
o.handlers["POST"]["/verify"] = account.NewVerify(o.context, o.AccountVerifyHandler)
|
2022-09-19 21:58:52 +02:00
|
|
|
if o.handlers["GET"] == nil {
|
|
|
|
o.handlers["GET"] = make(map[string]http.Handler)
|
|
|
|
}
|
2022-07-25 17:51:23 +02:00
|
|
|
o.handlers["GET"]["/version"] = metadata.NewVersion(o.context, o.MetadataVersionHandler)
|
2022-07-22 16:52:36 +02:00
|
|
|
}
|
|
|
|
|
|
|
|
// Serve creates a http handler to serve the API over HTTP
|
|
|
|
// can be used directly in http.ListenAndServe(":8000", api.Serve(nil))
|
2022-07-22 17:16:30 +02:00
|
|
|
func (o *ZrokAPI) Serve(builder middleware.Builder) http.Handler {
|
2022-07-22 16:52:36 +02:00
|
|
|
o.Init()
|
|
|
|
|
|
|
|
if o.Middleware != nil {
|
|
|
|
return o.Middleware(builder)
|
|
|
|
}
|
|
|
|
if o.useSwaggerUI {
|
|
|
|
return o.context.APIHandlerSwaggerUI(builder)
|
|
|
|
}
|
|
|
|
return o.context.APIHandler(builder)
|
|
|
|
}
|
|
|
|
|
|
|
|
// Init allows you to just initialize the handler cache, you can then recompose the middleware as you see fit
|
2022-07-22 17:16:30 +02:00
|
|
|
func (o *ZrokAPI) Init() {
|
2022-07-22 16:52:36 +02:00
|
|
|
if len(o.handlers) == 0 {
|
|
|
|
o.initHandlerCache()
|
|
|
|
}
|
|
|
|
}
|
|
|
|
|
|
|
|
// RegisterConsumer allows you to add (or override) a consumer for a media type.
|
2022-07-22 17:16:30 +02:00
|
|
|
func (o *ZrokAPI) RegisterConsumer(mediaType string, consumer runtime.Consumer) {
|
2022-07-22 16:52:36 +02:00
|
|
|
o.customConsumers[mediaType] = consumer
|
|
|
|
}
|
|
|
|
|
|
|
|
// RegisterProducer allows you to add (or override) a producer for a media type.
|
2022-07-22 17:16:30 +02:00
|
|
|
func (o *ZrokAPI) RegisterProducer(mediaType string, producer runtime.Producer) {
|
2022-07-22 16:52:36 +02:00
|
|
|
o.customProducers[mediaType] = producer
|
|
|
|
}
|
|
|
|
|
|
|
|
// AddMiddlewareFor adds a http middleware to existing handler
|
2022-07-22 17:16:30 +02:00
|
|
|
func (o *ZrokAPI) AddMiddlewareFor(method, path string, builder middleware.Builder) {
|
2022-07-22 16:52:36 +02:00
|
|
|
um := strings.ToUpper(method)
|
|
|
|
if path == "/" {
|
|
|
|
path = ""
|
|
|
|
}
|
|
|
|
o.Init()
|
|
|
|
if h, ok := o.handlers[um][path]; ok {
|
|
|
|
o.handlers[method][path] = builder(h)
|
|
|
|
}
|
|
|
|
}
|