Documentation ¶
Overview ¶
Package rest implements the HTTP server through which plugins can expose their REST APIs to the outside world.
Index ¶
- Constants
- func DeclareHTTPPortFlag(pluginName core.PluginName, defaultPortOpts ...uint)
- func FixConfig(cfg *Config)
- func ListenAndServeHTTP(config Config, handler http.Handler) (httpServer io.Closer, err error)
- func PluginConfig(pluginCfg config.PluginConfig, cfg *Config, pluginName core.PluginName) error
- type Config
- type Deps
- type ForkDeps
- type ForkPlugin
- func (plugin *ForkPlugin) AfterInit() error
- func (plugin *ForkPlugin) Close() error
- func (plugin *ForkPlugin) GetPort() int
- func (plugin *ForkPlugin) Init() (err error)
- func (plugin *ForkPlugin) RegisterHTTPHandler(path string, handler func(formatter *render.Render) http.HandlerFunc, ...) *mux.Route
- func (plugin *ForkPlugin) String() string
- type HTTPHandlers
- type ListenAndServe
- type Plugin
- func (plugin *Plugin) AfterInit() (err error)
- func (plugin *Plugin) Close() error
- func (plugin *Plugin) GetPort() int
- func (plugin *Plugin) Init() (err error)
- func (plugin *Plugin) RegisterHTTPHandler(path string, handler func(formatter *render.Render) http.HandlerFunc, ...) *mux.Route
- func (plugin *Plugin) String() string
Constants ¶
const ( // DefaultHTTPPort is used during HTTP server startup unless different port was configured DefaultHTTPPort = "9191" // DefaultIP 0.0.0.0 DefaultIP = "0.0.0.0" // DefaultEndpoint 0.0.0.0:9191 DefaultEndpoint = DefaultIP + ":" + DefaultHTTPPort )
Variables ¶
This section is empty.
Functions ¶
func DeclareHTTPPortFlag ¶
func DeclareHTTPPortFlag(pluginName core.PluginName, defaultPortOpts ...uint)
DeclareHTTPPortFlag declares http port (with usage & default value) a flag for a particular plugin name
func ListenAndServeHTTP ¶
ListenAndServeHTTP starts a http server.
func PluginConfig ¶
func PluginConfig(pluginCfg config.PluginConfig, cfg *Config, pluginName core.PluginName) error
PluginConfig tries : - to load flag <plugin-name>-port and then FixConfig() just in case - alternatively <plugin-name>-config and then FixConfig() just in case - alternatively DefaultConfig()
Types ¶
type Config ¶
type Config struct { // Endpoint is an address of HTTP server Endpoint string // ReadTimeout is the maximum duration for reading the entire // request, including the body. // // Because ReadTimeout does not let Handlers make per-request // decisions on each request body's acceptable deadline or // upload rate, most users will prefer to use // ReadHeaderTimeout. It is valid to use them both. ReadTimeout time.Duration // ReadHeaderTimeout is the amount of time allowed to read // request headers. The connection's read deadline is reset // after reading the headers and the Handler can decide what // is considered too slow for the body. ReadHeaderTimeout time.Duration // WriteTimeout is the maximum duration before timing out // writes of the response. It is reset whenever a new // request's header is read. Like ReadTimeout, it does not // let Handlers make decisions on a per-request basis. WriteTimeout time.Duration // IdleTimeout is the maximum amount of time to wait for the // next request when keep-alives are enabled. If IdleTimeout // is zero, the value of ReadTimeout is used. If both are // zero, there is no timeout. IdleTimeout time.Duration // MaxHeaderBytes controls the maximum number of bytes the // server will read parsing the request header's keys and // values, including the request line. It does not limit the // size of the request body. // If zero, DefaultMaxHeaderBytes is used. MaxHeaderBytes int }
Config is a configuration for HTTP server It is meant to be extended with security (TLS...)
func DefaultConfig ¶
func DefaultConfig() *Config
DefaultConfig returns new instance of config with default endpoint
type Deps ¶
type Deps struct { Log logging.PluginLogger //inject PluginName core.PluginName //inject config.PluginConfig //inject }
Deps lists the dependencies of the Rest plugin.
type ForkDeps ¶
type ForkDeps struct { // DefaultHTTP is used if there is no different configuration DefaultHTTP HTTPHandlers //inject Log logging.PluginLogger //inject PluginName core.PluginName //inject config.PluginConfig //inject }
ForkDeps lists the dependencies of the Fork on top of Rest plugin.
type ForkPlugin ¶
ForkPlugin checks the configuration and based on this it delegates API calls to new instance or existing instance of HTTP server
func (*ForkPlugin) AfterInit ¶
func (plugin *ForkPlugin) AfterInit() error
AfterInit starts the HTTP server. (only if port was different in Init())
func (*ForkPlugin) Close ¶
func (plugin *ForkPlugin) Close() error
Close stops the HTTP server. (only if port was different in Init())
func (*ForkPlugin) GetPort ¶
func (plugin *ForkPlugin) GetPort() int
GetPort returns plugin configuration port (delegated call)
func (*ForkPlugin) Init ¶
func (plugin *ForkPlugin) Init() (err error)
Init checks config if the port is different that it creates ne HTTP server
func (*ForkPlugin) RegisterHTTPHandler ¶
func (plugin *ForkPlugin) RegisterHTTPHandler(path string, handler func(formatter *render.Render) http.HandlerFunc, methods ...string) *mux.Route
RegisterHTTPHandler registers HTTP <handler> at the given <path>. (delegated call)
func (*ForkPlugin) String ¶
func (plugin *ForkPlugin) String() string
String returns plugin name (if not set defaults to "HTTP-FORK")
type HTTPHandlers ¶
type HTTPHandlers interface { // RegisterHTTPHandler propagates to Gorilla mux RegisterHTTPHandler(path string, handler func(formatter *render.Render) http.HandlerFunc, methods ...string) *mux.Route // GetPort returns configured port number (for debugging purposes) GetPort() int }
HTTPHandlers defines the API exposed by the REST plugin. Use this interface to declare dependency on the REST functionality, i.e.:
type Deps struct { HTTP rest.HTTPHandlers // inject plugin implementing RegisterHTTPHandler // other dependencies ... }
type ListenAndServe ¶
ListenAndServe is a function that uses <config> & <handler> to handle HTTP Requests. It return an instance of io.Closer to close the HTTP Server during cleanup.
type Plugin ¶
Plugin struct holds all plugin-related data.
func FromExistingServer ¶
func FromExistingServer(listenAndServe ListenAndServe) *Plugin
FromExistingServer is used mainly for testing purposes
Example:
httpmux.FromExistingServer(mock.SetHandler) mock.NewRequest("GET", "/v1/a", nil)
func (*Plugin) Init ¶
Init is the plugin entry point called by Agent Core - It prepares Gorilla MUX HTTP Router