forked from temporalio/samples-go
/
main.go
48 lines (41 loc) · 1.2 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 (
"context"
"log"
codecserver "github.com/temporalio/samples-go/codec-server"
"go.temporal.io/sdk/client"
)
func main() {
// The client is a heavyweight object that should be created once per process.
c, err := client.Dial(client.Options{
// Set DataConverter here to ensure that workflow inputs and results are
// encoded as required.
DataConverter: codecserver.DataConverter,
})
if err != nil {
log.Fatalln("Unable to create client", err)
}
defer c.Close()
workflowOptions := client.StartWorkflowOptions{
ID: "codecserver_workflowID",
TaskQueue: "codecserver",
}
// The workflow input "My Compressed Friend" will be encoded by the codec before being sent to Temporal
we, err := c.ExecuteWorkflow(
context.Background(),
workflowOptions,
codecserver.Workflow,
"Plain text input",
)
if err != nil {
log.Fatalln("Unable to execute workflow", err)
}
log.Println("Started workflow", "WorkflowID", we.GetID(), "RunID", we.GetRunID())
// Synchronously wait for the workflow completion.
var result string
err = we.Get(context.Background(), &result)
if err != nil {
log.Fatalln("Unable get workflow result", err)
}
log.Println("Workflow result:", result)
}