forked from temporalio/samples-go
/
main.go
36 lines (30 loc) · 824 Bytes
/
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
package main
import (
"context"
"flag"
"log"
"go.temporal.io/sdk/client"
"github.com/temporalio/samples-go/recovery"
)
func main() {
var workflowID string
flag.StringVar(&workflowID, "w", "trip_workflow", "WorkflowID.")
flag.Parse()
// The client is a heavyweight object that should be created once per process.
c, err := client.Dial(client.Options{
HostPort: client.DefaultHostPort,
})
if err != nil {
log.Fatalln("Unable to create client", err)
}
defer c.Close()
resp, err := c.QueryWorkflow(context.Background(), workflowID, "", recovery.QueryName)
if err != nil {
log.Fatalln("Unable to query workflow", err)
}
var result interface{}
if err := resp.Get(&result); err != nil {
log.Fatalln("Unable to decode query result", err)
}
log.Println("Received query result", "Result", result)
}