Documentation ¶
Index ¶
- type ConfigBytesProvider
- type ConfigurableRouter
- type ConfigurableServiceDiscovery
- type ECVKeyProvider
- type InitFunc
- type InitInfo
- type Server
- func (s *Server) Close() error
- func (s *Server) Running() bool
- func (s *Server) Shutdown(ctx context.Context) error
- func (s *Server) Start() (rErr error)
- func (s *Server) State() ServerState
- func (s *Server) WithClientAuth(clientAuth tls.ClientAuthType) *Server
- func (s *Server) WithDisableGoRuntimeMetrics() *Server
- func (s *Server) WithDisableKeepAlives() *Server
- func (s *Server) WithDisableServiceDependencyHealth() *Server
- func (s *Server) WithDisableShutdownSignalHandler() *Server
- func (s *Server) WithDisableSigQuitHandler() *Server
- func (s *Server) WithECVKeyFromFile(fPath string) *Server
- func (s *Server) WithECVKeyProvider(ecvProvider ECVKeyProvider) *Server
- func (s *Server) WithHealth(healthSources ...healthstatus.HealthCheckSource) *Server
- func (s *Server) WithHealthStatusChangeHandlers(handlers ...status.HealthStatusChangeHandler) *Server
- func (s *Server) WithInitFunc(initFn InitFunc) *Server
- func (s *Server) WithInstallConfig(installConfigStruct interface{}) *Server
- func (s *Server) WithInstallConfigFromFile(fpath string) *Server
- func (s *Server) WithInstallConfigProvider(p ConfigBytesProvider) *Server
- func (s *Server) WithInstallConfigType(installConfigStruct interface{}) *Server
- func (s *Server) WithLiveness(liveness healthstatus.Source) *Server
- func (s *Server) WithLoggerStdoutWriter(loggerStdoutWriter io.Writer) *Server
- func (s *Server) WithManagementTraceSampler(traceSampler wtracing.Sampler) *Server
- func (s *Server) WithManagementTraceSamplerRate(sampleRate float64) *Server
- func (s *Server) WithMetricTypeValuesBlacklist(blacklist map[string]map[string]struct{}) *Server
- func (s *Server) WithMetricsBlacklist(blacklist map[string]struct{}) *Server
- func (s *Server) WithMiddleware(middleware wrouter.RequestHandlerMiddleware) *Server
- func (s *Server) WithOrigin(origin string) *Server
- func (s *Server) WithOriginFromCallLine() *Server
- func (s *Server) WithReadiness(readiness healthstatus.Source) *Server
- func (s *Server) WithRouterImplProvider(routerImplProvider func() wrouter.RouterImpl) *Server
- func (s *Server) WithRuntimeConfig(in interface{}) *Server
- func (s *Server) WithRuntimeConfigFromFile(fpath string) *Server
- func (s *Server) WithRuntimeConfigProvider(r refreshable.Refreshable) *Server
- func (s *Server) WithRuntimeConfigProviderFunc(f func(ctx context.Context) (refreshable.Refreshable, error)) *Server
- func (s *Server) WithRuntimeConfigType(runtimeConfigStruct interface{}) *Server
- func (s *Server) WithSelfSignedCertificate() *Server
- func (s *Server) WithSigQuitHandlerWriter(w io.Writer) *Server
- func (s *Server) WithStrictUnmarshalConfig() *Server
- func (s *Server) WithTraceSampler(traceSampler wtracing.Sampler) *Server
- func (s *Server) WithTraceSamplerRate(sampleRate float64) *Server
- type ServerState
- type ServiceDiscovery
Constants ¶
This section is empty.
Variables ¶
This section is empty.
Functions ¶
This section is empty.
Types ¶
type ConfigBytesProvider ¶
type ConfigurableRouter ¶
type ConfigurableRouter interface { wrouter.Router WithHealth(healthSources ...healthstatus.HealthCheckSource) *Server WithReadiness(readiness healthstatus.Source) *Server WithLiveness(liveness healthstatus.Source) *Server }
ConfigurableRouter is a wrouter.Router that provides additional support for configuring things such as health, readiness, liveness and middleware.
type ConfigurableServiceDiscovery ¶ added in v2.22.0
type ConfigurableServiceDiscovery interface { ServiceDiscovery // ServiceConfig builds a RefreshableClientConfig based on the 'service-discovery' block in runtime configuration and any overrides. ServiceConfig(serviceName string) httpclient.RefreshableClientConfig // WithDefaultConfig adds the provided ClientConfig to a list of extra defaults to be merged together for the final // client configurations returned by NewClient and NewHTTPClient. WithDefaultConfig(defaults httpclient.ClientConfig) // WithServiceConfig allows for additional configuration from outside the default runtime.service-discovery block. // Use this option to consume configuration overrides from a 'legacy' location in configuration when migrating // to live-reloadable clients. Users should strive to move overrides to the default location in witchcraft config // to benefit from live-reloadability. All config provided by WithServiceConfig will be merged into the default // refreshable ServicesConfig. In case of conflict, the config provided here overrides the defaults. WithServiceConfig(serviceName string, cfg httpclient.ClientConfig) // WithDefaultParams stores the provided params function. When constructing a new client, the function will // be evaluated and the params added to all clients. // May be called multiple times; all parameters for NewClient are appended in the order they are provided. // See individual parameter behavior for override semantics when provided multiple times. // Parameters from WithDefaultParams are applied after params from configuration. WithDefaultParams(params func(serviceName string) ([]httpclient.ClientParam, error)) // WithServiceParams stores the provided params for when building clients of serviceName. // May be called multiple times; all parameters for NewClient are appended in the order they are provided. // See individual parameter behavior for override semantics when provided multiple times. // Parameters from WithServiceParams are applied after params from configuration. WithServiceParams(serviceName string, params ...httpclient.ClientParam) // WithUserAgent overrides the default user-agent header constructed from the product name and version in install config. WithUserAgent(userAgent string) }
ConfigurableServiceDiscovery is an extension to the ServiceDiscovery interface which allows for injecting external configuration to be used when constructing clients. New usages should prefer the runtime.service-discovery block but in some cases reading from deprecated config locations is necessary to avoid breaking changes when config files are loosely coupled to code versions.
func NewServiceDiscovery ¶ added in v2.22.0
func NewServiceDiscovery(install config.Install, services config.RefreshableServicesConfig) ConfigurableServiceDiscovery
type ECVKeyProvider ¶
type ECVKeyProvider interface {
Load() (*encryptedconfigvalue.KeyWithType, error)
}
func ECVKeyFromFile ¶
func ECVKeyFromFile(path string) ECVKeyProvider
func ECVKeyFromStatic ¶
func ECVKeyFromStatic(kwt *encryptedconfigvalue.KeyWithType) ECVKeyProvider
func ECVKeyNoOp ¶
func ECVKeyNoOp() ECVKeyProvider
type InitFunc ¶
InitFunc is a function type used to initialize a server. ctx is a context configured with loggers and is valid for the duration of the server. Refer to the documentation of InitInfo for its fields.
If the returned cleanup function is non-nil, it is deferred and run on server shutdown. If the returned error is non-nil, the server will not start and will return the error.
type InitInfo ¶
type InitInfo struct { // Router is a ConfigurableRouter that implements wrouter.Router for the server. It can be // used to register endpoints on the server and to configure things such as health, readiness and liveness sources and // any middleware (note that any values set using router will override any values previously set on the server). Router ConfigurableRouter // InstallConfig the install configuration. Its type is determined by the struct provided to the // "WithInstallConfigType" function (the default is config.Install). InstallConfig interface{} // RuntimeConfig is a refreshable that contains the initial runtime configuration. The type returned by the // refreshable is determined by the struct provided to the "WithRuntimeConfigType" function (the default is // config.Runtime). RuntimeConfig refreshable.Refreshable // Clients exposes the service-discovery configuration as a conjure-go-runtime client builder. // Returned clients are configured with user-agent based on {install.ProductName}/{install.ProductVersion}. Clients ConfigurableServiceDiscovery // ShutdownServer gracefully closes the server, waiting for any in-flight requests to finish (or the context to be cancelled). // When the InitFunc is executed, the server is not yet started. This will most often be useful if launching a goroutine which // requires access to shutdown the server in some error condition. ShutdownServer func(context.Context) error }
type Server ¶
type Server struct {
// contains filtered or unexported fields
}
func (*Server) Running ¶
Running returns true if the server is in the "running" state (as opposed to "idle" or "initializing"), false otherwise.
func (*Server) Start ¶
Start begins serving HTTPS traffic and blocks until s.Close() or s.Shutdown() return. Errors are logged via s.svcLogger before being returned. Panics are recovered; in the case of a recovered panic, Start will log and return a non-nil error containing the recovered object (overwriting any existing error).
func (*Server) State ¶
func (s *Server) State() ServerState
State returns the state of the current server (idle, initializing or running).
func (*Server) WithClientAuth ¶
func (s *Server) WithClientAuth(clientAuth tls.ClientAuthType) *Server
WithClientAuth configures the server to use the specified client authentication type for its TLS connections.
func (*Server) WithDisableGoRuntimeMetrics ¶
WithDisableGoRuntimeMetrics disables the server's enabled-by-default collection of runtime memory statistics.
func (*Server) WithDisableKeepAlives ¶
WithDisableKeepAlives disables keep-alives on the server by calling SetKeepAlivesEnabled(false) on the http.Server used by the server. Note that this setting is only applied to the main server -- if the management server is separate from the main server, this setting is not applied to the management server. Refer to the documentation for SetKeepAlivesEnabled in http.Server for more information on when a server may want to use this setting.
func (*Server) WithDisableServiceDependencyHealth ¶ added in v2.47.0
WithDisableServiceDependencyHealth disables the server's enabled-by-default SERVICE_DEPENDENCY check.
func (*Server) WithDisableShutdownSignalHandler ¶
WithDisableShutdownSignalHandler disables the server's enabled-by-default shutdown on SIGTERM and SIGINT.
func (*Server) WithDisableSigQuitHandler ¶
WithDisableSigQuitHandler disables the server's enabled-by-default goroutine dump on SIGQUIT.
func (*Server) WithECVKeyFromFile ¶
WithECVKeyFromFile configures the server to use the ECV key in the file at the specified path as the ECV key for decrypting ECV values in configuration.
func (*Server) WithECVKeyProvider ¶
func (s *Server) WithECVKeyProvider(ecvProvider ECVKeyProvider) *Server
WithECVKeyProvider configures the server to use the ECV key provided by the specified provider as the ECV key for decrypting ECV values in configuration.
func (*Server) WithHealth ¶
func (s *Server) WithHealth(healthSources ...healthstatus.HealthCheckSource) *Server
WithHealth configures the server to use the specified health check sources to report the server's health. If multiple healthSource's results have the same key, the result from the latest entry in healthSources will be used. These results are combined with the server's built-in health source, which uses the `SERVER_STATUS` key.
func (*Server) WithHealthStatusChangeHandlers ¶
func (s *Server) WithHealthStatusChangeHandlers(handlers ...status.HealthStatusChangeHandler) *Server
WithHealthStatusChangeHandlers configures the health status change handlers that are called whenever the configured HealthCheckSource returns a health status with differing check states.
func (*Server) WithInitFunc ¶
WithInitFunc configures the server to use the provided setup function to set up its initial state.
func (*Server) WithInstallConfig ¶
WithInstallConfig configures the server to use the provided install configuration. The provided install configuration must support being marshaled as YAML.
func (*Server) WithInstallConfigFromFile ¶
WithInstallConfigFromFile configures the server to read the install configuration from the file at the specified path.
func (*Server) WithInstallConfigProvider ¶
func (s *Server) WithInstallConfigProvider(p ConfigBytesProvider) *Server
WithInstallConfigProvider configures the server to use the install configuration obtained by reading the bytes from the specified ConfigBytesProvider.
func (*Server) WithInstallConfigType ¶
WithInstallConfigType configures the server to use the type of the provided struct as the type for the install configuration. The YAML representation of the install configuration is unmarshaled into a newly created struct that has the same type as the provided struct, so the provided struct should either embed or be compatible with config.Install.
func (*Server) WithLiveness ¶
func (s *Server) WithLiveness(liveness healthstatus.Source) *Server
WithLiveness configures the server to use the specified source to report liveness.
func (*Server) WithLoggerStdoutWriter ¶
WithLoggerStdoutWriter configures the writer that loggers will write to IF they are configured to write to STDOUT. This configuration is typically only used in specialized scenarios (for example, to write logger output to an in-memory buffer rather than Stdout for tests).
func (*Server) WithManagementTraceSampler ¶
WithManagementTraceSampler configures the server's management trace log tracer to use the specified traceSampler function to make a determination on whether or not a trace should be sampled (if such a decision needs to be made).
func (*Server) WithManagementTraceSamplerRate ¶
WithManagementTraceSamplerRate is a convenience function for creating a management traceSampler based off a sample rate
func (*Server) WithMetricTypeValuesBlacklist ¶
WithMetricTypeValuesBlacklist sets the value of the metric type value blacklist to be the same as the provided value (the content is copied).
func (*Server) WithMetricsBlacklist ¶
WithMetricsBlacklist sets the metric blacklist to the provided set of metrics. The provided metrics should be the name of the metric (for example, "server.response.size"). The blacklist only supports blacklisting at the metric level: blacklisting an individual metric value (such as "server.response.size.count") will not have any effect. The provided input is copied.
func (*Server) WithMiddleware ¶
func (s *Server) WithMiddleware(middleware wrouter.RequestHandlerMiddleware) *Server
WithMiddleware configures the server to use the specified middleware. The provided middleware is added to any other specified middleware.
func (*Server) WithOrigin ¶
WithOrigin configures the server to use the specified origin.
func (*Server) WithOriginFromCallLine ¶
WithOriginFromCallLine configures the server to use the svc1log.OriginFromCallLine parameter.
func (*Server) WithReadiness ¶
func (s *Server) WithReadiness(readiness healthstatus.Source) *Server
WithReadiness configures the server to use the specified source to report readiness.
func (*Server) WithRouterImplProvider ¶
func (s *Server) WithRouterImplProvider(routerImplProvider func() wrouter.RouterImpl) *Server
WithRouterImplProvider configures the server to use the specified routerImplProvider to provide router implementations.
func (*Server) WithRuntimeConfig ¶
WithRuntimeConfig configures the server to use the provided runtime configuration. The provided runtime configuration must support being marshaled as YAML.
func (*Server) WithRuntimeConfigFromFile ¶
WithRuntimeConfigFromFile configures the server to use the file at the provided path as its runtime configuration. The server will create a refreshable.Refreshable using the file at the provided path (and will thus live-reload the configuration based on updates to the file).
func (*Server) WithRuntimeConfigProvider ¶
func (s *Server) WithRuntimeConfigProvider(r refreshable.Refreshable) *Server
WithRuntimeConfigProvider configures the server to use the provided Refreshable as its runtime configuration. The value provided by the refreshable must be the byte slice for the runtime configuration.
func (*Server) WithRuntimeConfigProviderFunc ¶ added in v2.28.0
func (s *Server) WithRuntimeConfigProviderFunc(f func(ctx context.Context) (refreshable.Refreshable, error)) *Server
WithRuntimeConfigProviderFunc configures the server to use the returned Refreshable as its runtime configuration. The value provided by the refreshable must be a []byte for the yaml runtime configuration.
func (*Server) WithRuntimeConfigType ¶
WithRuntimeConfigType configures the server to use the type of the provided struct as the type for the runtime configuration. The YAML representation of the runtime configuration is unmarshaled into a newly created struct that has the same type as the provided struct, so the provided struct should either embed or be compatible with config.Runtime.
func (*Server) WithSelfSignedCertificate ¶
WithSelfSignedCertificate configures the server to use a dynamically generated self-signed certificate for its TLS authentication. Because there is no way to verify the certificate used by the server, this option is typically only used in tests or very specialized circumstances where the connection to the server can be verified/authenticated using separate external mechanisms.
func (*Server) WithSigQuitHandlerWriter ¶
WithSigQuitHandlerWriter sets the output for the goroutine dump on SIGQUIT.
func (*Server) WithStrictUnmarshalConfig ¶
WithStrictUnmarshalConfig configures the server to use the provided strict unmarshal configuration.
func (*Server) WithTraceSampler ¶
WithTraceSampler configures the server's application trace log tracer to use the specified traceSampler function to make a determination on whether or not a trace should be sampled (if such a decision needs to be made).
func (*Server) WithTraceSamplerRate ¶
WithTraceSamplerRate is a convenience function for creating an application traceSampler based off a sample rate
type ServerState ¶
type ServerState int32
const ( ServerIdle ServerState = iota ServerInitializing ServerRunning ServerShuttingDown )
func (ServerState) String ¶
func (s ServerState) String() string
type ServiceDiscovery ¶ added in v2.22.0
type ServiceDiscovery interface { // NewClient is an alias for httpclient.NewClientFromRefreshableConfig based on the 'service-discovery' block in runtime configuration. NewClient(ctx context.Context, serviceName string, additionalParams ...httpclient.ClientParam) (httpclient.Client, error) // NewHTTPClient is an alias for httpclient.NewHTTPClientFromRefreshableConfig based on the 'service-discovery' block in runtime configuration. NewHTTPClient(ctx context.Context, serviceName string, additionalParams ...httpclient.HTTPClientParam) (httpclient.RefreshableHTTPClient, error) }