operations

package
v1.5.3 Latest Latest
Warning

This package is not in the latest version of its module.

Go to latest
Published: Mar 13, 2024 License: AGPL-3.0 Imports: 14 Imported by: 0

Documentation

Index

Constants

This section is empty.

Variables

This section is empty.

Functions

This section is empty.

Types

type APIServiceAPI

type APIServiceAPI struct {
	Middleware func(middleware.Builder) http.Handler

	// 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:
	//   - application/json
	JSONConsumer runtime.Consumer

	// JSONProducer registers a producer for the following mime types:
	//   - application/json
	JSONProducer runtime.Producer

	// BearerAuth registers a function that takes a token and returns a principal
	// it performs authentication based on an api key Authorization provided in the header
	BearerAuth func(string) (interface{}, error)

	// APIAuthorizer provides access control (ACL/RBAC/ABAC) by providing access to the request and authenticated principal
	APIAuthorizer runtime.Authorizer

	// UserAuthHandler sets the operation handler for the auth operation
	UserAuthHandler user.AuthHandler
	// SystemClusterHandler sets the operation handler for the cluster operation
	SystemClusterHandler system.ClusterHandler
	// UserCommunityHistoryHandler sets the operation handler for the community history operation
	UserCommunityHistoryHandler user.CommunityHistoryHandler
	// SystemDiscordServerHandler sets the operation handler for the discord server operation
	SystemDiscordServerHandler system.DiscordServerHandler
	// UserLoginHandler sets the operation handler for the login operation
	UserLoginHandler user.LoginHandler
	// SystemOpenDiscordServerHandler sets the operation handler for the open discord server operation
	SystemOpenDiscordServerHandler system.OpenDiscordServerHandler
	// AdminSetUserEnableHandler sets the operation handler for the set user enable operation
	AdminSetUserEnableHandler admin.SetUserEnableHandler
	// AdminSetUserPrivateHandler sets the operation handler for the set user private operation
	AdminSetUserPrivateHandler admin.SetUserPrivateHandler
	// UserUserHistoryHandler sets the operation handler for the user history operation
	UserUserHistoryHandler user.UserHistoryHandler
	// UserUserInfoHandler sets the operation handler for the user info operation
	UserUserInfoHandler user.UserInfoHandler
	// AdminUserListHandler sets the operation handler for the user list operation
	AdminUserListHandler admin.UserListHandler

	// 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{})
	// contains filtered or unexported fields
}

APIServiceAPI API

func NewAPIServiceAPI

func NewAPIServiceAPI(spec *loads.Document) *APIServiceAPI

NewAPIServiceAPI creates a new APIService instance

func (*APIServiceAPI) AddMiddlewareFor

func (o *APIServiceAPI) AddMiddlewareFor(method, path string, builder middleware.Builder)

AddMiddlewareFor adds a http middleware to existing handler

func (*APIServiceAPI) AuthenticatorsFor

func (o *APIServiceAPI) AuthenticatorsFor(schemes map[string]spec.SecurityScheme) map[string]runtime.Authenticator

AuthenticatorsFor gets the authenticators for the specified security schemes

func (*APIServiceAPI) Authorizer

func (o *APIServiceAPI) Authorizer() runtime.Authorizer

Authorizer returns the registered authorizer

func (*APIServiceAPI) ConsumersFor

func (o *APIServiceAPI) ConsumersFor(mediaTypes []string) map[string]runtime.Consumer

ConsumersFor gets the consumers for the specified media types. MIME type parameters are ignored here.

func (*APIServiceAPI) Context

func (o *APIServiceAPI) Context() *middleware.Context

Context returns the middleware context for the API service API

func (*APIServiceAPI) DefaultConsumes

func (o *APIServiceAPI) DefaultConsumes() string

DefaultConsumes returns the default consumes media type

func (*APIServiceAPI) DefaultProduces

func (o *APIServiceAPI) DefaultProduces() string

DefaultProduces returns the default produces media type

func (*APIServiceAPI) Formats

func (o *APIServiceAPI) Formats() strfmt.Registry

Formats returns the registered string formats

func (*APIServiceAPI) HandlerFor

func (o *APIServiceAPI) HandlerFor(method, path string) (http.Handler, bool)

HandlerFor gets a http.Handler for the provided operation method and path

func (*APIServiceAPI) Init

func (o *APIServiceAPI) Init()

Init allows you to just initialize the handler cache, you can then recompose the middleware as you see fit

func (*APIServiceAPI) ProducersFor

func (o *APIServiceAPI) ProducersFor(mediaTypes []string) map[string]runtime.Producer

ProducersFor gets the producers for the specified media types. MIME type parameters are ignored here.

func (*APIServiceAPI) RegisterConsumer

func (o *APIServiceAPI) RegisterConsumer(mediaType string, consumer runtime.Consumer)

RegisterConsumer allows you to add (or override) a consumer for a media type.

func (*APIServiceAPI) RegisterFormat

func (o *APIServiceAPI) RegisterFormat(name string, format strfmt.Format, validator strfmt.Validator)

RegisterFormat registers a custom format validator

func (*APIServiceAPI) RegisterProducer

func (o *APIServiceAPI) RegisterProducer(mediaType string, producer runtime.Producer)

RegisterProducer allows you to add (or override) a producer for a media type.

func (*APIServiceAPI) Serve

func (o *APIServiceAPI) Serve(builder middleware.Builder) http.Handler

Serve creates a http handler to serve the API over HTTP can be used directly in http.ListenAndServe(":8000", api.Serve(nil))

func (*APIServiceAPI) ServeErrorFor

func (o *APIServiceAPI) ServeErrorFor(operationID string) func(http.ResponseWriter, *http.Request, error)

ServeErrorFor gets a error handler for a given operation id

func (*APIServiceAPI) SetDefaultConsumes

func (o *APIServiceAPI) SetDefaultConsumes(mediaType string)

SetDefaultConsumes returns the default consumes media type

func (*APIServiceAPI) SetDefaultProduces

func (o *APIServiceAPI) SetDefaultProduces(mediaType string)

SetDefaultProduces sets the default produces media type

func (*APIServiceAPI) SetSpec

func (o *APIServiceAPI) SetSpec(spec *loads.Document)

SetSpec sets a spec that will be served for the clients.

func (*APIServiceAPI) UseRedoc

func (o *APIServiceAPI) UseRedoc()

UseRedoc for documentation at /docs

func (*APIServiceAPI) UseSwaggerUI

func (o *APIServiceAPI) UseSwaggerUI()

UseSwaggerUI for documentation at /docs

func (*APIServiceAPI) Validate

func (o *APIServiceAPI) Validate() error

Validate validates the registrations in the APIServiceAPI

Directories

Path Synopsis

Jump to

Keyboard shortcuts

? : This menu
/ : Search site
f or F : Jump to
y or Y : Canonical URL