apollo-backend/cmd/apollo-api/main.go

118 lines
2.1 KiB
Go
Raw Normal View History

2021-05-10 00:51:15 +00:00
package main
import (
2021-07-13 14:17:20 +00:00
"context"
2021-05-10 00:51:15 +00:00
"fmt"
"log"
"net/http"
"os"
2021-07-13 14:17:20 +00:00
"os/signal"
"syscall"
2021-05-10 00:51:15 +00:00
2021-07-08 02:19:02 +00:00
"github.com/DataDog/datadog-go/statsd"
2021-07-13 14:17:20 +00:00
"github.com/jackc/pgx/v4/pgxpool"
2021-05-10 00:51:15 +00:00
"github.com/joho/godotenv"
"github.com/sirupsen/logrus"
2021-06-24 02:19:43 +00:00
2021-07-05 23:22:24 +00:00
"github.com/christianselig/apollo-backend/internal/data"
"github.com/christianselig/apollo-backend/internal/reddit"
2021-05-10 00:51:15 +00:00
)
type config struct {
port int
}
type application struct {
2021-06-24 02:19:43 +00:00
cfg config
logger *logrus.Logger
2021-07-13 14:17:20 +00:00
pool *pgxpool.Pool
2021-06-24 02:19:43 +00:00
models *data.Models
client *reddit.Client
2021-05-10 00:51:15 +00:00
}
func main() {
2021-07-13 14:17:20 +00:00
_ = godotenv.Load()
ctx, cancel := context.WithCancel(context.Background())
var logger *logrus.Logger
{
logger = logrus.New()
if os.Getenv("ENV") == "" {
logger.SetLevel(logrus.DebugLevel)
} else {
logger.SetFormatter(&logrus.TextFormatter{
DisableColors: true,
FullTimestamp: true,
})
}
}
2021-07-06 00:20:00 +00:00
2021-05-10 00:51:15 +00:00
var cfg config
2021-07-13 14:17:20 +00:00
// Set up Postgres connection
var pool *pgxpool.Pool
{
url := fmt.Sprintf("%s?sslmode=require", os.Getenv("DATABASE_CONNECTION_POOL_URL"))
config, err := pgxpool.ParseConfig(url)
if err != nil {
panic(err)
}
2021-07-06 00:37:47 +00:00
2021-07-13 14:17:20 +00:00
// Setting the build statement cache to nil helps this work with pgbouncer
config.ConnConfig.BuildStatementCache = nil
config.ConnConfig.PreferSimpleProtocol = true
pool, err = pgxpool.ConnectConfig(ctx, config)
if err != nil {
panic(err)
}
defer pool.Close()
2021-05-10 00:51:15 +00:00
}
2021-07-08 02:19:02 +00:00
statsd, err := statsd.New("127.0.0.1:8125")
if err != nil {
log.Fatal(err)
}
rc := reddit.NewClient(
os.Getenv("REDDIT_CLIENT_ID"),
os.Getenv("REDDIT_CLIENT_SECRET"),
statsd,
)
2021-05-10 00:51:15 +00:00
app := &application{
cfg,
logger,
2021-07-13 14:17:20 +00:00
pool,
data.NewModels(ctx, pool),
2021-05-10 00:51:15 +00:00
rc,
}
2021-07-06 00:23:50 +00:00
port, ok := os.LookupEnv("PORT")
if !ok {
port = "4000"
}
2021-05-10 00:51:15 +00:00
srv := &http.Server{
2021-07-06 00:23:50 +00:00
Addr: fmt.Sprintf(":%s", port),
2021-05-10 00:51:15 +00:00
Handler: app.routes(),
}
logger.Printf("starting server on %s", srv.Addr)
2021-07-13 14:17:20 +00:00
go srv.ListenAndServe()
signals := make(chan os.Signal, 1)
signal.Notify(signals, syscall.SIGINT, syscall.SIGTERM)
defer signal.Stop(signals)
<-signals // wait for signal
srv.Shutdown(ctx)
cancel()
go func() {
<-signals // hard exit on second signal (in case shutdown gets stuck)
os.Exit(1)
}()
2021-05-10 00:51:15 +00:00
}