-
Notifications
You must be signed in to change notification settings - Fork 0
/
Copy pathlambda.go
77 lines (68 loc) · 1.96 KB
/
lambda.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
package main
import (
"context"
"fmt"
"log/slog"
"os"
"github.com/Finatext/lambdaurl-buffered"
"github.com/aws/aws-lambda-go/lambda"
awsconfig "github.com/aws/aws-sdk-go-v2/config"
"github.com/aws/aws-sdk-go-v2/service/ssm"
"github.com/caarlos0/env/v11"
"github.com/cockroachdb/errors"
"github.com/Finatext/belldog/internal/appconfig"
"github.com/Finatext/belldog/internal/handler"
"github.com/Finatext/belldog/internal/service"
"github.com/Finatext/belldog/internal/slack"
"github.com/Finatext/belldog/internal/storage"
"github.com/Finatext/ssmenv-go"
)
func main() {
if err := doMain(); err != nil {
slog.Error("failed to run", slog.String("error", fmt.Sprintf("%+v", err)))
os.Exit(1)
}
}
func doMain() error {
ctx := context.Background()
logLevel := new(slog.LevelVar)
ops := slog.HandlerOptions{
AddSource: true,
Level: logLevel,
}
logger := slog.New(slog.NewJSONHandler(os.Stdout, &ops))
slog.SetDefault(logger)
awsConfig, err := awsconfig.LoadDefaultConfig(ctx)
if err != nil {
return errors.Wrap(err, "failed to load AWS config")
}
ssmClient := ssm.NewFromConfig(awsConfig)
replacedEnv, err := ssmenv.ReplacedEnv(ctx, ssmClient, os.Environ())
if err != nil {
return errors.Wrap(err, "failed to replace env")
}
config, err := env.ParseAsWithOptions[appconfig.Config](env.Options{
Environment: replacedEnv,
})
if err != nil {
return errors.Wrap(err, "failed to process config from env")
}
logLevel.Set(config.GoLog)
slackClient := slack.NewClient(config)
ddb, err := storage.NewDDB(ctx, awsConfig, config.DdbTableName)
if err != nil {
return err
}
tokenSvc := service.NewTokenService(&ddb)
switch config.Mode {
case "proxy":
e := handler.NewEchoHandler(config, &slackClient, &tokenSvc)
lambda.Start(lambdaurl.Wrap(e))
case "batch":
h := handler.NewBatchHandler(config, &slackClient, &ddb)
lambda.Start(h.HandleCloudWatchEvent)
default:
return errors.Newf("Unknown `mode` env given: %s", config.Mode)
}
return nil
}