-
Notifications
You must be signed in to change notification settings - Fork 0
/
Copy pathmain.go
118 lines (101 loc) · 3.33 KB
/
main.go
1
2
3
4
5
6
7
8
9
10
11
12
13
14
15
16
17
18
19
20
21
22
23
24
25
26
27
28
29
30
31
32
33
34
35
36
37
38
39
40
41
42
43
44
45
46
47
48
49
50
51
52
53
54
55
56
57
58
59
60
61
62
63
64
65
66
67
68
69
70
71
72
73
74
75
76
77
78
79
80
81
82
83
84
85
86
87
88
89
90
91
92
93
94
95
96
97
98
99
100
101
102
103
104
105
106
107
108
109
110
111
112
113
114
115
116
117
118
// Copyright (c) Spectro Cloud
// SPDX-License-Identifier: MPL-2.0
package main
import (
"context"
"fmt"
"net/http"
"strconv"
"strings"
"time"
"github.com/rs/zerolog/log"
"github.com/jmoiron/sqlx"
_ "github.com/lib/pq"
_ "go.uber.org/automaxprocs"
"spectrocloud.com/hello-universe-api/endpoints"
"spectrocloud.com/hello-universe-api/internal"
)
const (
db_driver string = "postgres"
)
var (
dbName string
dbUser string
dbPassword string
dbHost string
dbPort int64
globalTraceLevel string
globalDb *sqlx.DB
globalHost string
globalPort string
globalHostURL string = globalHost + ":" + globalPort
globalAuthorization bool
)
func init() {
globalTraceLevel = strings.ToUpper(internal.Getenv("TRACE", "INFO"))
internal.InitLogger(globalTraceLevel)
authorizationEnv := strings.ToUpper(internal.Getenv("AUTHORIZATION", "false"))
authorization, err := strconv.ParseBool(authorizationEnv)
if err != nil {
log.Fatal().Err(err).Msg("Error parsing authorization")
}
globalAuthorization = authorization
initDB := strings.ToLower(internal.Getenv("DB_INIT", "false"))
port := internal.Getenv("PORT", "3000")
host := internal.Getenv("HOST", "0.0.0.0")
globalHost = host
globalPort = port
globalHostURL = host + ":" + port
dbName = internal.Getenv("DB_NAME", "counter")
dbUser = internal.Getenv("DB_USER", "postgres")
dbHost = internal.Getenv("DB_HOST", "0.0.0.0")
dbEncryption := internal.Getenv("DB_ENCRYPTION", "disable")
dbPassword = internal.Getenv("DB_PASSWORD", "password")
dbPort = internal.StringToInt64(internal.Getenv("DB_PORT", "5432"))
db, err := sqlx.Open(db_driver, fmt.Sprintf(
"host=%s port=%d dbname=%s user=%s password=%s connect_timeout=5 sslmode=%s",
dbHost,
dbPort,
dbName,
dbUser,
dbPassword,
dbEncryption,
))
if err != nil {
log.Fatal().Err(err).Msg("Error connecting to database")
}
db.SetConnMaxIdleTime(45 * time.Second)
db.SetMaxIdleConns(3)
db.SetConnMaxLifetime(1 * time.Minute)
log.Debug().Msg("Checking database connection...")
err = db.Ping()
if err != nil {
log.Debug().Msg("Database is not available")
log.Fatal().Err(err).Msg("Error connecting to database")
}
if initDB == "true" {
log.Debug().Msg("Initializing database")
err = internal.InitDB(context.Background(), db)
if err != nil {
log.Fatal().Err(err).Msg("Error initializing database")
}
}
globalDb = db
}
func main() {
ctx := context.Background()
counterRoute := endpoints.NewCounterHandlerContext(globalDb, ctx, globalAuthorization)
healthRoute := endpoints.NewHealthHandlerContext(ctx, globalAuthorization)
http.HandleFunc(internal.ApiPrefix+"counter", counterRoute.CounterHTTPHandler)
http.HandleFunc(internal.ApiPrefix+"counter/{page}", counterRoute.CounterHTTPHandler)
http.HandleFunc(internal.ApiPrefix+"health", healthRoute.HealthHTTPHandler)
log.Info().Msgf("Server is configured for port %s and listening on %s", globalPort, globalHostURL)
log.Info().Msgf("Database is configured for %s:%d", dbHost, dbPort)
log.Info().Msgf("Trace level set to: %s", globalTraceLevel)
log.Info().Msgf("Authorization is set to: %v", globalAuthorization)
log.Info().Msg("Starting server...")
err := http.ListenAndServe(globalHostURL, nil)
if err != nil {
log.Fatal().Err(err).Msg("There's an error with the server")
}
}