summaryrefslogtreecommitdiff
path: root/internal/app/action.go
blob: b5792534cfba12667cb0b36203722e93fc9279d7 (plain)
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
package app

import (
	"context"
	"fmt"
	"log/slog"

	"github.com/ChausseBenjamin/rafta/internal/logging"
	"github.com/ChausseBenjamin/rafta/internal/server"
	"github.com/ChausseBenjamin/rafta/internal/storage"
	"github.com/urfave/cli/v3"
)

func action(ctx context.Context, cmd *cli.Command) error {
	err := logging.Setup(
		cmd.String(FlagLogLevel),
		cmd.String(FlagLogFormat),
		cmd.String(FlagLogOutput),
	)
	if err != nil {
		slog.Warn("Error(s) occured during logger initialization", logging.ErrKey, err)
	}

	slog.Info("Starting rafta server")

	// TODO: Setup the db
	store, err := storage.Setup(cmd.String(FlagDBPath))
	if err != nil {
		slog.Error("Unable to setup database", logging.ErrKey, err)
	}

	srv, lis, err := server.Setup(cmd.Int(FlagListenPort), store)
	if err != nil {
		slog.Error("Unable to setup server", logging.ErrKey, err)

		return err
	}

	slog.Info(fmt.Sprintf("Listening on port %d", cmd.Int(FlagListenPort)))
	if err := srv.Serve(lis); err != nil {
		slog.Error("Server runtime error", logging.ErrKey, err)

		return err
	}

	return nil
}