mirror of
https://github.com/compute-blade-community/compute-blade-agent.git
synced 2026-04-21 17:45:43 +02:00
* refactor(fancontroller): improve fan controller validation logic and error handling for temperature steps * refactor(agent): restructure gRPC server implementation by moving it to a new api package for better organization and maintainability * feat(agent): implement gRPC server for managing compute blade agents and add graceful shutdown support refactor(agent): restructure agent code by moving API logic to a dedicated file and improving error handling fix(agent): update logging messages for clarity and consistency across the agent's operations chore(agent): remove unused API code and consolidate event handling logic for better maintainability style(agent): improve code formatting and organization for better readability and adherence to conventions * feat(agent): add support for TLS configuration in gRPC server * feat(api): add gRPC server authentication * fix * feat(config): add listen mode configuration to support tcp or unix sockets feat(agent): implement listen mode in gRPC service to allow flexible socket types feat(bladectl): enhance configuration loading and add support for TLS credentials fix(bladectl): improve error handling for gRPC connection and event emission style(logging): change log level from Warn to Info for better clarity in logs * add logging middleware + fixes * fix remote-connection to gRPC API Server debugging the SAN issues took the soul out of me... And then the stupid mistake in cmd_root where I didn't construct the TLS credentials correctly... Oh dear... * cleanup * cleanup * cleanup commands * cleanup * make README.md nicer * Update cmd/agent/main.go Co-authored-by: Matthias Riegler <github@m4tbit.de> * Update cmd/bladectl/cmd_root.go Co-authored-by: Matthias Riegler <github@m4tbit.de> * move bladectl config into correct directory * fix bugs * // FIXME: No dead code * nit: code style * nit(YAGNI): you aint gonna need it. Don't make life harder than it needs to be * nit(YAGNI): you aint gonna need it. Don't make life harder than it needs to be * nit(YAGNI): you aint gonna need it. Don't make life harder than it needs to be * nit(cmd_identify) --------- Co-authored-by: Matthias Riegler <github@m4tbit.de>
46 lines
1.4 KiB
Go
46 lines
1.4 KiB
Go
package api
|
|
|
|
import (
|
|
"github.com/uptime-industries/compute-blade-agent/pkg/agent"
|
|
"go.uber.org/zap"
|
|
)
|
|
|
|
// GrpcApiServiceOption defines a functional option for configuring an AgentGrpcService instance.
|
|
type GrpcApiServiceOption func(*AgentGrpcService)
|
|
|
|
// WithComputeBladeAgent sets the ComputeBladeAgent implementation for the AgentGrpcService.
|
|
func WithComputeBladeAgent(agent agent.ComputeBladeAgent) GrpcApiServiceOption {
|
|
return func(service *AgentGrpcService) {
|
|
service.agent = agent
|
|
}
|
|
}
|
|
|
|
// WithAuthentication configures the authentication requirement for the gRPC service by enabling or disabling it.
|
|
func WithAuthentication(enabled bool) GrpcApiServiceOption {
|
|
return func(service *AgentGrpcService) {
|
|
service.authenticated = enabled
|
|
}
|
|
}
|
|
|
|
// WithListenAddr sets the server's listen address on an AgentGrpcService instance.
|
|
func WithListenAddr(server string) GrpcApiServiceOption {
|
|
return func(service *AgentGrpcService) {
|
|
service.listenAddr = server
|
|
}
|
|
}
|
|
|
|
// WithListenMode configures the listen mode for the AgentGrpcService using the provided mode string.
|
|
func WithListenMode(mode string) GrpcApiServiceOption {
|
|
return func(service *AgentGrpcService) {
|
|
lMode, err := ListenModeFromString(mode)
|
|
if err != nil {
|
|
zap.L().Fatal(err.Error(),
|
|
zap.String("mode", mode),
|
|
zap.Strings("advice", err.Advice()),
|
|
)
|
|
}
|
|
|
|
service.listenMode = lMode
|
|
}
|
|
}
|