mirror of
https://github.com/DeBrosOfficial/network.git
synced 2025-12-11 07:38:49 +00:00
- Consolidated development commands into a new `dev` command group for better organization. - Introduced a `prod` command group to manage production environment operations. - Updated Makefile to simplify the development environment setup and improve logging. - Enhanced README to clarify the development process and health check requirements. - Removed deprecated configuration and service management commands to streamline the CLI interface.
190 lines
5.5 KiB
Go
190 lines
5.5 KiB
Go
package main
|
|
|
|
import (
|
|
"fmt"
|
|
"os"
|
|
"path/filepath"
|
|
"strings"
|
|
"time"
|
|
|
|
"github.com/DeBrosOfficial/network/pkg/config"
|
|
"github.com/DeBrosOfficial/network/pkg/gateway"
|
|
"github.com/DeBrosOfficial/network/pkg/logging"
|
|
"go.uber.org/zap"
|
|
)
|
|
|
|
// For transition, alias main.GatewayConfig to pkg/gateway.Config
|
|
// server.go will be removed; this keeps compatibility until then.
|
|
type GatewayConfig = gateway.Config
|
|
|
|
func getEnvDefault(key, def string) string {
|
|
if v := os.Getenv(key); strings.TrimSpace(v) != "" {
|
|
return v
|
|
}
|
|
return def
|
|
}
|
|
|
|
func getEnvBoolDefault(key string, def bool) bool {
|
|
v := strings.TrimSpace(os.Getenv(key))
|
|
if v == "" {
|
|
return def
|
|
}
|
|
switch strings.ToLower(v) {
|
|
case "1", "true", "t", "yes", "y", "on":
|
|
return true
|
|
case "0", "false", "f", "no", "n", "off":
|
|
return false
|
|
default:
|
|
return def
|
|
}
|
|
}
|
|
|
|
// parseGatewayConfig loads gateway.yaml from ~/.debros exclusively.
|
|
func parseGatewayConfig(logger *logging.ColoredLogger) *gateway.Config {
|
|
// Determine config path
|
|
configPath, err := config.DefaultPath("gateway.yaml")
|
|
if err != nil {
|
|
logger.ComponentError(logging.ComponentGeneral, "Failed to determine config path", zap.Error(err))
|
|
fmt.Fprintf(os.Stderr, "Configuration error: %v\n", err)
|
|
os.Exit(1)
|
|
}
|
|
|
|
// Load YAML
|
|
type yamlCfg struct {
|
|
ListenAddr string `yaml:"listen_addr"`
|
|
ClientNamespace string `yaml:"client_namespace"`
|
|
RQLiteDSN string `yaml:"rqlite_dsn"`
|
|
BootstrapPeers []string `yaml:"bootstrap_peers"`
|
|
EnableHTTPS bool `yaml:"enable_https"`
|
|
DomainName string `yaml:"domain_name"`
|
|
TLSCacheDir string `yaml:"tls_cache_dir"`
|
|
OlricServers []string `yaml:"olric_servers"`
|
|
OlricTimeout string `yaml:"olric_timeout"`
|
|
IPFSClusterAPIURL string `yaml:"ipfs_cluster_api_url"`
|
|
IPFSAPIURL string `yaml:"ipfs_api_url"`
|
|
IPFSTimeout string `yaml:"ipfs_timeout"`
|
|
IPFSReplicationFactor int `yaml:"ipfs_replication_factor"`
|
|
}
|
|
|
|
data, err := os.ReadFile(configPath)
|
|
if err != nil {
|
|
logger.ComponentError(logging.ComponentGeneral, "Config file not found",
|
|
zap.String("path", configPath),
|
|
zap.Error(err))
|
|
fmt.Fprintf(os.Stderr, "\nConfig file not found at %s\n", configPath)
|
|
fmt.Fprintf(os.Stderr, "Generate it using: dbn config init --type gateway\n")
|
|
os.Exit(1)
|
|
}
|
|
|
|
var y yamlCfg
|
|
// Use strict YAML decoding to reject unknown fields
|
|
if err := config.DecodeStrict(strings.NewReader(string(data)), &y); err != nil {
|
|
logger.ComponentError(logging.ComponentGeneral, "Failed to parse gateway config", zap.Error(err))
|
|
fmt.Fprintf(os.Stderr, "Configuration parse error: %v\n", err)
|
|
os.Exit(1)
|
|
}
|
|
|
|
// Build config from YAML
|
|
cfg := &gateway.Config{
|
|
ListenAddr: ":6001",
|
|
ClientNamespace: "default",
|
|
BootstrapPeers: nil,
|
|
RQLiteDSN: "",
|
|
EnableHTTPS: false,
|
|
DomainName: "",
|
|
TLSCacheDir: "",
|
|
OlricServers: nil,
|
|
OlricTimeout: 0,
|
|
IPFSClusterAPIURL: "",
|
|
IPFSAPIURL: "",
|
|
IPFSTimeout: 0,
|
|
IPFSReplicationFactor: 0,
|
|
}
|
|
|
|
if v := strings.TrimSpace(y.ListenAddr); v != "" {
|
|
cfg.ListenAddr = v
|
|
}
|
|
if v := strings.TrimSpace(y.ClientNamespace); v != "" {
|
|
cfg.ClientNamespace = v
|
|
}
|
|
if v := strings.TrimSpace(y.RQLiteDSN); v != "" {
|
|
cfg.RQLiteDSN = v
|
|
}
|
|
if len(y.BootstrapPeers) > 0 {
|
|
var bp []string
|
|
for _, p := range y.BootstrapPeers {
|
|
p = strings.TrimSpace(p)
|
|
if p != "" {
|
|
bp = append(bp, p)
|
|
}
|
|
}
|
|
if len(bp) > 0 {
|
|
cfg.BootstrapPeers = bp
|
|
}
|
|
}
|
|
|
|
// HTTPS configuration
|
|
cfg.EnableHTTPS = y.EnableHTTPS
|
|
if v := strings.TrimSpace(y.DomainName); v != "" {
|
|
cfg.DomainName = v
|
|
}
|
|
if v := strings.TrimSpace(y.TLSCacheDir); v != "" {
|
|
cfg.TLSCacheDir = v
|
|
} else if cfg.EnableHTTPS {
|
|
// Default TLS cache directory if HTTPS is enabled but not specified
|
|
homeDir, err := os.UserHomeDir()
|
|
if err == nil {
|
|
cfg.TLSCacheDir = filepath.Join(homeDir, ".debros", "tls-cache")
|
|
}
|
|
}
|
|
|
|
// Olric configuration
|
|
if len(y.OlricServers) > 0 {
|
|
cfg.OlricServers = y.OlricServers
|
|
}
|
|
if v := strings.TrimSpace(y.OlricTimeout); v != "" {
|
|
if parsed, err := time.ParseDuration(v); err == nil {
|
|
cfg.OlricTimeout = parsed
|
|
} else {
|
|
logger.ComponentWarn(logging.ComponentGeneral, "invalid olric_timeout, using default", zap.String("value", v), zap.Error(err))
|
|
}
|
|
}
|
|
|
|
// IPFS configuration
|
|
if v := strings.TrimSpace(y.IPFSClusterAPIURL); v != "" {
|
|
cfg.IPFSClusterAPIURL = v
|
|
}
|
|
if v := strings.TrimSpace(y.IPFSAPIURL); v != "" {
|
|
cfg.IPFSAPIURL = v
|
|
}
|
|
if v := strings.TrimSpace(y.IPFSTimeout); v != "" {
|
|
if parsed, err := time.ParseDuration(v); err == nil {
|
|
cfg.IPFSTimeout = parsed
|
|
} else {
|
|
logger.ComponentWarn(logging.ComponentGeneral, "invalid ipfs_timeout, using default", zap.String("value", v), zap.Error(err))
|
|
}
|
|
}
|
|
if y.IPFSReplicationFactor > 0 {
|
|
cfg.IPFSReplicationFactor = y.IPFSReplicationFactor
|
|
}
|
|
|
|
// Validate configuration
|
|
if errs := cfg.ValidateConfig(); len(errs) > 0 {
|
|
fmt.Fprintf(os.Stderr, "\nGateway configuration errors (%d):\n", len(errs))
|
|
for _, err := range errs {
|
|
fmt.Fprintf(os.Stderr, " - %s\n", err)
|
|
}
|
|
fmt.Fprintf(os.Stderr, "\nPlease fix the configuration and try again.\n")
|
|
os.Exit(1)
|
|
}
|
|
|
|
logger.ComponentInfo(logging.ComponentGeneral, "Loaded gateway configuration from YAML",
|
|
zap.String("path", configPath),
|
|
zap.String("addr", cfg.ListenAddr),
|
|
zap.String("namespace", cfg.ClientNamespace),
|
|
zap.Int("bootstrap_peer_count", len(cfg.BootstrapPeers)),
|
|
)
|
|
|
|
return cfg
|
|
}
|