mirror of
https://github.com/lorsanstand/HomeOps-Hub.git
synced 2026-06-19 20:05:17 +03:00
72 lines
1.8 KiB
Go
72 lines
1.8 KiB
Go
package agent_service
|
|
|
|
import (
|
|
"context"
|
|
"fmt"
|
|
|
|
"github.com/lorsanstand/HomeOps-Hub/agent/internal/utils/config_yaml"
|
|
"github.com/lorsanstand/HomeOps-Hub/shared/domain"
|
|
"github.com/rs/zerolog"
|
|
)
|
|
|
|
type Collector interface {
|
|
GatherInfoSystem() (domain.HostInfo, []domain.Capability)
|
|
}
|
|
|
|
type Settings interface {
|
|
InsertAgentID(agentID string) error
|
|
GetAgentID() string
|
|
}
|
|
|
|
type HubConnection interface {
|
|
RegisterAgent(ctx context.Context, RegisterData domain.RegisterAgentRequest) (domain.RegisterAgentResponse, error)
|
|
}
|
|
|
|
type AgentService struct {
|
|
collect Collector
|
|
conn HubConnection
|
|
log zerolog.Logger
|
|
cfg *config_yaml.AgentConfig
|
|
heartBeat int
|
|
settings Settings
|
|
}
|
|
|
|
func NewAgentService(
|
|
collector Collector,
|
|
conn HubConnection,
|
|
settings Settings,
|
|
cfg *config_yaml.AgentConfig,
|
|
logger zerolog.Logger,
|
|
) *AgentService {
|
|
logger = logger.With().Str("component", "internal.service.agent_serivce").Logger()
|
|
|
|
return &AgentService{collect: collector, conn: conn, cfg: cfg, log: logger, settings: settings}
|
|
}
|
|
|
|
func (a *AgentService) RegisterAgentConn(ctx context.Context) error {
|
|
a.log.Debug().Msg("getting info by system")
|
|
info, caps := a.collect.GatherInfoSystem()
|
|
a.log.Debug().Msg("create request data for register agent")
|
|
AgentID := a.settings.GetAgentID()
|
|
AgentName := a.cfg.AppName
|
|
AgentData := domain.RegisterAgentRequest{
|
|
AgentID: AgentID,
|
|
AgentName: AgentName,
|
|
Host: info,
|
|
Capabilities: caps,
|
|
AgentVersion: a.cfg.GetAgentVersion(),
|
|
}
|
|
|
|
data, err := a.conn.RegisterAgent(ctx, AgentData)
|
|
if err != nil {
|
|
return fmt.Errorf("register agent: %w", err)
|
|
}
|
|
|
|
if err = a.settings.InsertAgentID(data.AgentID); err != nil {
|
|
return fmt.Errorf("save agent ID: %w", err)
|
|
}
|
|
a.log.Info().Str("agentID", data.AgentID).Msg("agent registration end")
|
|
|
|
return nil
|
|
}
|