amocrm/cmd/main.go

35 lines
624 B
Go
Raw Normal View History

2024-04-04 09:42:40 +00:00
package main
import (
2024-04-09 07:42:21 +00:00
"amocrm/internal/initialize"
2024-04-04 09:42:40 +00:00
"context"
2024-04-19 16:05:42 +00:00
"fmt"
"os"
2024-04-04 09:42:40 +00:00
"os/signal"
"syscall"
2024-04-08 08:20:10 +00:00
"amocrm/internal/app"
2024-04-04 09:42:40 +00:00
"go.uber.org/zap"
)
func main() {
2024-04-19 16:05:42 +00:00
logger, err := zap.NewProduction()
2024-04-04 09:42:40 +00:00
if err != nil {
2024-04-19 16:05:42 +00:00
fmt.Printf("Failed to initialize logger: %v\n", err)
os.Exit(1)
2024-04-04 09:42:40 +00:00
}
2024-04-19 16:05:42 +00:00
config, err := initialize.LoadConfig()
2024-04-04 09:42:40 +00:00
if err != nil {
2024-04-19 16:05:42 +00:00
logger.Fatal("Failed to load config", zap.Error(err))
2024-04-04 09:42:40 +00:00
}
2024-04-19 16:05:42 +00:00
ctx, stop := signal.NotifyContext(context.Background(), syscall.SIGINT, syscall.SIGTERM)
defer stop()
if err = app.Run(ctx, *config, logger); err != nil {
logger.Fatal("App exited with error", zap.Error(err))
2024-04-04 09:42:40 +00:00
}
}