/
activity.go
executable file
·87 lines (69 loc) · 2.12 KB
/
activity.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
78
79
80
81
82
83
84
85
86
87
package app
import (
"fmt"
"strings"
"sync"
"github.com/TIBCOSoftware/flogo-lib/core/activity"
"github.com/TIBCOSoftware/flogo-lib/core/data"
"github.com/TIBCOSoftware/flogo-lib/logger"
)
var log = logger.GetLogger("activity-tibco-app")
const (
ivAttrName = "attribute"
ivOp = "operation"
ivType = "type"
ivValue = "value"
ovValue = "value"
)
// AppActivity is a App Activity implementation
type AppActivity struct {
sync.Mutex
metadata *activity.Metadata
}
// NewActivity creates a new AppActivity
func NewActivity(metadata *activity.Metadata) activity.Activity {
return &AppActivity{metadata: metadata}
}
// Metadata implements activity.Activity.Metadata
func (a *AppActivity) Metadata() *activity.Metadata {
return a.metadata
}
// Eval implements activity.Activity.Eval
func (a *AppActivity) Eval(context activity.Context) (done bool, err error) {
attrName := context.GetInput(ivAttrName).(string)
op := strings.ToUpper(context.GetInput(ivOp).(string)) //ADD,UPDATE,GET
switch op {
case "ADD":
log.Debug("In ADD operation")
dt, ok := data.ToTypeEnum(strings.ToLower(context.GetInput(ivType).(string)))
if !ok {
errorMsg := fmt.Sprintf("Unsupported type '%s'", context.GetInput(ivType).(string))
log.Error(errorMsg)
return false, activity.NewError(errorMsg, "", nil)
}
val := context.GetInput(ivValue)
//data.CoerceToValue(val, dt)
data.GetGlobalScope().AddAttr(attrName, dt, val)
context.SetOutput(ovValue, val)
case "GET":
log.Debug("In GET operation")
typedVal, ok := data.GetGlobalScope().GetAttr(attrName)
if !ok {
errorMsg := fmt.Sprintf("Attribute not defined: '%s'", attrName)
log.Error(errorMsg)
return false, activity.NewError(errorMsg, "", nil)
}
context.SetOutput(ovValue, typedVal.Value())
case "UPDATE":
log.Debug("In UPDATE operation")
val := context.GetInput(ivValue)
//data.CoerceToValue(val, dt)
data.GetGlobalScope().SetAttrValue(attrName, val)
context.SetOutput(ovValue, val)
default:
errorMsg := fmt.Sprintf("Unsupported Op:'%s' ", op)
log.Error(errorMsg)
return false, activity.NewError(errorMsg, "", nil)
}
return true, nil
}