VerifactuMidAPI/main.go

88 lines
2.2 KiB
Go

package main
import (
"fmt"
"log"
"net/http"
"os"
"time"
"VerifactuMidAPI/api"
_ "VerifactuMidAPI/internal/formats/dolibarr"
_ "VerifactuMidAPI/internal/formats/native"
"VerifactuMidAPI/internal"
"VerifactuMidAPI/internal/cert"
"VerifactuMidAPI/internal/config"
"VerifactuMidAPI/internal/crypto"
"VerifactuMidAPI/verifactu"
)
func main() {
cfg, err := config.Load("config.yml")
if err != nil {
log.Fatalf("loading config: %v", err)
}
certStorage := cert.NewStorage(cfg.Certificates.StoragePath)
if err := certStorage.Init(); err != nil {
log.Fatalf("initializing cert storage: %v", err)
}
keyPair, err := crypto.LoadOrCreateKeyPair(cfg.Crypto.KeysPath)
if err != nil {
log.Fatalf("loading/creating key pair: %v", err)
}
hashStorage := internal.NewFileLastRecordStorage("./data")
facturaSvc := internal.NewFacturaService(hashStorage)
var veriClient *verifactu.Client
envURL := verifactu.GetTestURL()
if cfg.VeriFactu.Production {
envURL = verifactu.GetProdURL()
log.Println("VeriFactu: PRODUCTION environment")
} else {
log.Println("VeriFactu: TEST environment")
}
verifactuCfg := verifactu.ClientConfig{
BaseURL: envURL,
Timeout: 30 * time.Second,
}
if cfg.Certificates.CertFile != "" {
verifactuCfg.CertificatePath = cfg.Certificates.CertFile
verifactuCfg.CertificatePassword = cfg.Certificates.CertPassword
log.Printf("VeriFactu: Cert path: %s", cfg.Certificates.CertFile)
log.Printf("VeriFactu: Cert password set: %v", cfg.Certificates.CertPassword != "")
}
client, err := verifactu.NewClient(verifactuCfg)
if err != nil {
log.Printf("warning: verifactu client initialization failed: %v", err)
} else {
veriClient = client
log.Printf("VeriFactu: Connected to %s", envURL)
}
facturaSvc.SetVerifactuClient(veriClient)
handler := api.New(cfg, certStorage, keyPair, facturaSvc)
mux := http.NewServeMux()
handler.RegisterRoutes(mux)
addr := fmt.Sprintf(":%d", cfg.Server.Port)
log.Printf("Starting server on %s", addr)
if err := http.ListenAndServe(addr, mux); err != nil {
log.Fatalf("server error: %v", err)
}
}
func init() {
if _, err := os.Stat("config.yml"); os.IsNotExist(err) {
log.Println("Warning: config.yml not found, using defaults")
}
}