forked from zax-29/sentrytemporal
/
main.go
48 lines (40 loc) · 1.11 KB
/
main.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
package main
import (
"log"
"github.com/getsentry/sentry-go"
"go.temporal.io/sdk/client"
sdkinterceptor "go.temporal.io/sdk/interceptor"
"go.temporal.io/sdk/worker"
sentrytemp "github.com/zax-29/sentrytemporal"
"github.com/zax-29/sentrytemporal/tests/activity_cases"
)
func main() {
err := sentry.Init(sentry.ClientOptions{
AttachStacktrace: true,
})
if err != nil {
log.Fatalln("init sentry failed", err)
}
// The client and worker are heavyweight objects that should be created once per process.
c, err := client.Dial(client.Options{})
if err != nil {
log.Fatalln("Unable to create client", err)
}
defer c.Close()
w := worker.New(c, "sentry", worker.Options{
// Create interceptor that will put started time on the logger
Interceptors: []sdkinterceptor.WorkerInterceptor{
sentrytemp.New(
sentry.CurrentHub(),
sentrytemp.Options{},
),
},
})
w.RegisterWorkflow(activity_cases.Workflow)
w.RegisterActivity(activity_cases.ActivityPanic)
w.RegisterActivity(activity_cases.ActivityError)
err = w.Run(worker.InterruptCh())
if err != nil {
log.Fatalln("Unable to start worker", err)
}
}