Documentation ¶
Index ¶
Constants ¶
This section is empty.
Variables ¶
This section is empty.
Functions ¶
This section is empty.
Types ¶
type ClientConfig ¶ added in v0.21.0
type ClientConfig struct { Address string // Address on which the server is accessible Port uint16 // Port on which the server is accessible PropagateAuthHeaders bool // If true propagate any authorization header to the server RetryServerErrors bool // If true, the client will automatically retry on server errors UnaryInterceptors []grpc.UnaryClientInterceptor // Client unary interceptors to apply StreamInterceptors []grpc.StreamClientInterceptor // Client stream interceptors to apply Options []grpc.DialOption // Additional server options }
ClientConfig contains the configuration necessary for connecting to a gRPC Server.
func NewDefaultClientConfig ¶ added in v0.21.0
func NewDefaultClientConfig(ctx context.Context) ClientConfig
NewDefaultClientConfig returns the default SpotHero gRPC plaintext Client Configuration
func NewDefaultTLSClientConfig ¶ added in v0.51.0
func NewDefaultTLSClientConfig(ctx context.Context) ClientConfig
NewDefaultTLSClientConfig returns the default SpotHero gRPC TLS Client Configuration
func (ClientConfig) GetConn ¶ added in v0.21.0
func (cc ClientConfig) GetConn() (*grpc.ClientConn, error)
GetConn dials and returns a gRPC connection. It is the responsibility of the caller to make sure they call `conn.Close()` through a defer statement or otherwise.
func (*ClientConfig) RegisterFlags ¶ added in v0.21.0
func (cc *ClientConfig) RegisterFlags(flags *pflag.FlagSet, serverName string)
RegisterFlags registers gRPC client configuration flags with pflags. Callers must specify a server name when calling this function. For example, if your service interacts with grpc service "foo" and "bar", you might register flags for both of these servers in your application. As such you must provide the names "foo" and "bar" and call this function twice. If you do, you will end up with a set of flags for each server in the format `--foo-grpc-server-address` and `--bar-grpc-server-address`.
Failure to provide a server name will result in a panic.
type Config ¶
type Config struct { Name string // Name of the GRPC Server Address string // Address on which the server will be accessible Port uint16 // Port on which the server will be accessible TLSEnabled bool // Whether or not traffic should be served via HTTPS TLSCrtPath string // Location of TLS Certificate TLSKeyPath string // Location of TLS Key ServerRegistration func(*grpc.Server) // Callback for registering GRPC API Servers StreamInterceptors []grpc.StreamServerInterceptor // A list of global GRPC stream interceptor functions to be called. Order is honored left to right. UnaryInterceptors []grpc.UnaryServerInterceptor // A list of global GRPC unary interceptor functions to be called. Order is honored left to right. CancelSignals []os.Signal // OS Signals to be used to cancel running servers. Defaults to SIGINT/`os.Interrupt`. }
Config contains the configuration necessary for running a GRPC Server.
func NewDefaultConfig ¶
NewDefaultConfig returns a default GRPC server config object. The caller must still supply the name of the server and a serverRegistration callback. The serverRegistration callback is a function that registers GRPC API servers with the provided GRPC server.
func (Config) NewServer ¶
NewServer creates and returns a configured Server object given a GRPC configuration object.
func (*Config) RegisterFlags ¶
RegisterFlags registers GRPC flags with pflags
type Server ¶
type Server struct {
// contains filtered or unexported fields
}
Server contains the configured GRPC server and related components
func (Server) Run ¶
Run starts the GRPC server. The function returns an error if the GRPC server cannot bind to its listen address. This function is non-blocking and will return immediately. If no error is returned the server is running. The returned channel will be closed after the server shuts down.