apollo-backend/internal/cmd/api.go

65 lines
1.2 KiB
Go
Raw Permalink 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/spf13/cobra"
2022-05-23 18:17:25 +00:00
"go.uber.org/zap"
)
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"))
}
2022-05-23 18:29:15 +00:00
logger := cmdutil.NewLogger("api")
2022-05-23 18:17:25 +00:00
defer func() { _ = logger.Sync() }()
statsd, err := cmdutil.NewStatsdClient()
if err != nil {
return err
}
defer statsd.Close()
2022-06-27 22:47:07 +00:00
db, err := cmdutil.NewDatabasePool(ctx, 16)
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() }()
2022-05-23 18:17:25 +00:00
logger.Info("started api", zap.Int("port", port))
<-ctx.Done()
2021-09-25 13:19:42 +00:00
_ = srv.Shutdown(ctx)
return nil
},
}
return cmd
}