mirror of
https://github.com/compute-blade-community/compute-blade-agent.git
synced 2026-04-16 15:35:42 +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
832 B
Go
46 lines
832 B
Go
package certificate
|
|
|
|
import "fmt"
|
|
|
|
// Usage defines the intended purpose of a certificate, such as client or server usage.
|
|
type Usage int
|
|
|
|
func (c Usage) String() string {
|
|
switch c {
|
|
case UsageClient:
|
|
return "client"
|
|
|
|
case UsageServer:
|
|
return "server"
|
|
|
|
default:
|
|
return fmt.Sprintf("CertificateUsage(%d)", c)
|
|
}
|
|
}
|
|
|
|
const (
|
|
UsageClient Usage = iota // Certificate is for Client
|
|
UsageServer // Certificate is for Server
|
|
)
|
|
|
|
// Format represents the encoding format of a certificate, such as PEM or DER.
|
|
type Format int
|
|
|
|
func (c Format) String() string {
|
|
switch c {
|
|
case FormatPEM:
|
|
return "pem"
|
|
|
|
case FormatDER:
|
|
return "der"
|
|
|
|
default:
|
|
return fmt.Sprintf("CertificateFormat(%d)", c)
|
|
}
|
|
}
|
|
|
|
const (
|
|
FormatPEM Format = iota // PEM Encoded Certificate
|
|
FormatDER // DER Encoded Certificate
|
|
)
|