apollo-backend/internal/cmd/api.go

66 lines
1.2 KiB
Go
Raw Normal View History

package cmd
import (
"context"
"os"
"strconv"
"github.com/christianselig/apollo-backend/internal/api"
"github.com/christianselig/apollo-backend/internal/cmdutil"
"github.com/sirupsen/logrus"
"github.com/spf13/cobra"
)
func APICmd(ctx context.Context) *cobra.Command {
var port int
cmd := &cobra.Command{
Use: "api",
Args: cobra.ExactArgs(0),
Short: "Runs the RESTful API.",
RunE: func(cmd *cobra.Command, args []string) error {
2021-07-13 18:22:41 +00:00
port = 4000
if os.Getenv("PORT") != "" {
port, _ = strconv.Atoi(os.Getenv("PORT"))
}
logger := cmdutil.NewLogrusLogger(false)
statsd, err := cmdutil.NewStatsdClient()
if err != nil {
return err
}
defer statsd.Close()
2021-07-23 00:22:46 +00:00
db, err := cmdutil.NewDatabasePool(ctx, 1)
if err != nil {
return err
}
defer db.Close()
redis, err := cmdutil.NewRedisClient(ctx)
if err != nil {
return err
}
defer redis.Close()
2022-03-12 17:50:05 +00:00
api := api.NewAPI(ctx, logger, statsd, redis, db)
srv := api.Server(port)
2021-09-25 13:19:42 +00:00
go func() { _ = srv.ListenAndServe() }()
logger.WithFields(logrus.Fields{
"port": port,
}).Info("started api")
<-ctx.Done()
2021-09-25 13:19:42 +00:00
_ = srv.Shutdown(ctx)
return nil
},
}
return cmd
}