operations

package
v0.0.0-...-318a3d5 Latest Latest
Warning

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

Go to latest
Published: Dec 21, 2023 License: Apache-2.0 Imports: 16 Imported by: 0

Documentation

Index

Constants

This section is empty.

Variables

This section is empty.

Functions

This section is empty.

Types

type KeptnAPI

type KeptnAPI 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/cloudevents+json
	//   - application/json
	JSONConsumer runtime.Consumer
	// MultipartformConsumer registers a consumer for the following mime types:
	//   - multipart/form-data
	MultipartformConsumer runtime.Consumer

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

	// 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) (*models.Principal, error)

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

	// EventPostEventHandler sets the operation handler for the post event operation
	EventPostEventHandler event.PostEventHandler
	// AuthAuthHandler sets the operation handler for the auth operation
	AuthAuthHandler auth.AuthHandler
	// ImportOperationsImportHandler sets the operation handler for the import operation
	ImportOperationsImportHandler import_operations.ImportHandler
	// MetadataMetadataHandler sets the operation handler for the metadata operation
	MetadataMetadataHandler metadata.MetadataHandler

	// 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
}

KeptnAPI the keptn API

func NewKeptnAPI

func NewKeptnAPI(spec *loads.Document) *KeptnAPI

NewKeptnAPI creates a new Keptn instance

func (*KeptnAPI) AddMiddlewareFor

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

AddMiddlewareFor adds a http middleware to existing handler

func (*KeptnAPI) AuthenticatorsFor

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

AuthenticatorsFor gets the authenticators for the specified security schemes

func (*KeptnAPI) Authorizer

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

Authorizer returns the registered authorizer

func (*KeptnAPI) ConsumersFor

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

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

func (*KeptnAPI) Context

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

Context returns the middleware context for the keptn API

func (*KeptnAPI) DefaultConsumes

func (o *KeptnAPI) DefaultConsumes() string

DefaultConsumes returns the default consumes media type

func (*KeptnAPI) DefaultProduces

func (o *KeptnAPI) DefaultProduces() string

DefaultProduces returns the default produces media type

func (*KeptnAPI) Formats

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

Formats returns the registered string formats

func (*KeptnAPI) HandlerFor

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

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

func (*KeptnAPI) Init

func (o *KeptnAPI) Init()

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

func (*KeptnAPI) ProducersFor

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

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

func (*KeptnAPI) RegisterConsumer

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

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

func (*KeptnAPI) RegisterFormat

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

RegisterFormat registers a custom format validator

func (*KeptnAPI) RegisterProducer

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

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

func (*KeptnAPI) Serve

func (o *KeptnAPI) 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 (*KeptnAPI) ServeErrorFor

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

ServeErrorFor gets a error handler for a given operation id

func (*KeptnAPI) SetDefaultConsumes

func (o *KeptnAPI) SetDefaultConsumes(mediaType string)

SetDefaultConsumes returns the default consumes media type

func (*KeptnAPI) SetDefaultProduces

func (o *KeptnAPI) SetDefaultProduces(mediaType string)

SetDefaultProduces sets the default produces media type

func (*KeptnAPI) SetSpec

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

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

func (*KeptnAPI) UseRedoc

func (o *KeptnAPI) UseRedoc()

UseRedoc for documentation at /docs

func (*KeptnAPI) UseSwaggerUI

func (o *KeptnAPI) UseSwaggerUI()

UseSwaggerUI for documentation at /docs

func (*KeptnAPI) Validate

func (o *KeptnAPI) Validate() error

Validate validates the registrations in the KeptnAPI

Directories

Path Synopsis

Jump to

Keyboard shortcuts

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