Add Bootstrap and AgentSyncBundle handlers to gateway package with X-Gateway-Bootstrap-Token header authentication. Implement UpsertByName repository method for idempotent gateway registration. Update gateway entrypoint script to auto-generate keys and bootstrap gateway on first run, persisting gateway ID to disk. Add GATEWAY_BOOTSTRAP_TOKEN config and update environment variables for gateway name, bootstrap URL, and sync URL.
58 lines
1.3 KiB
Go
58 lines
1.3 KiB
Go
package gateway
|
|
|
|
import (
|
|
"context"
|
|
|
|
"github.com/google/uuid"
|
|
|
|
"nexavpn/backend/internal/wireguard"
|
|
)
|
|
|
|
type Service struct {
|
|
repo Repository
|
|
}
|
|
|
|
func NewService(repo Repository) *Service {
|
|
return &Service{repo: repo}
|
|
}
|
|
|
|
func (s *Service) List(ctx context.Context) ([]Gateway, error) {
|
|
return s.repo.List(ctx)
|
|
}
|
|
|
|
func (s *Service) SelectActive(ctx context.Context) (Gateway, error) {
|
|
return s.repo.FirstActive(ctx)
|
|
}
|
|
|
|
func (s *Service) BuildSyncBundle(ctx context.Context, gatewayID string) (wireguard.GatewayBundle, error) {
|
|
id, err := uuid.Parse(gatewayID)
|
|
if err != nil {
|
|
return wireguard.GatewayBundle{}, err
|
|
}
|
|
return s.repo.BuildSyncBundle(ctx, id)
|
|
}
|
|
|
|
func (s *Service) Update(ctx context.Context, gatewayID string, input UpdateRequest) (Gateway, error) {
|
|
id, err := uuid.Parse(gatewayID)
|
|
if err != nil {
|
|
return Gateway{}, err
|
|
}
|
|
return s.repo.Update(ctx, id, input)
|
|
}
|
|
|
|
func (s *Service) Bootstrap(ctx context.Context, input BootstrapRequest) (Gateway, error) {
|
|
if input.Name == "" {
|
|
input.Name = "primary-gateway"
|
|
}
|
|
if input.ListenPort == 0 {
|
|
input.ListenPort = 51820
|
|
}
|
|
if input.VPNCIDR == "" {
|
|
input.VPNCIDR = "100.96.0.0/24"
|
|
}
|
|
if len(input.DNSServers) == 0 {
|
|
input.DNSServers = []string{"10.20.0.53"}
|
|
}
|
|
return s.repo.UpsertByName(ctx, input)
|
|
}
|