-
Notifications
You must be signed in to change notification settings - Fork 9
/
Copy pathactivity.go
122 lines (106 loc) · 3 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
88
89
90
91
92
93
94
95
96
97
98
99
100
101
102
103
104
105
106
107
108
109
110
111
112
113
114
115
116
117
118
119
120
121
122
package executeCypherQuery
import (
"github.com/neo4j/neo4j-go-driver/neo4j"
"github.com/project-flogo/core/activity"
"github.com/project-flogo/core/data/coerce"
"github.com/project-flogo/core/data/metadata"
"github.com/project-flogo/core/support/log"
)
var logquery = log.ChildLogger(log.RootLogger(), "neo4j-executecyppherquery")
func init() {
err := activity.Register(&Activity{}, New)
if err != nil {
logquery.Errorf("Neo4j Execute Query Activity init error : %s ", err.Error())
}
}
// New functioncommon
func New(ctx activity.InitContext) (activity.Activity, error) {
settings := &Settings{}
err := metadata.MapToStruct(ctx.Settings(), settings, true)
if err != nil {
return nil, err
}
if settings.Connection != "" {
neo4jcon, toConnerr := coerce.ToConnection(settings.Connection)
if toConnerr != nil {
return nil, toConnerr
}
driver := neo4jcon.GetConnection().(neo4j.Driver)
accessMode := neo4j.AccessModeRead
if settings.AccessMode != "Read" {
accessMode = neo4j.AccessModeWrite
}
act := &Activity{driver: driver, accessMode: accessMode, databaseName: settings.DatabaseName}
return act, nil
}
return nil, nil
}
// Activity is a stub for your Activity implementation
type Activity struct {
driver neo4j.Driver
accessMode neo4j.AccessMode
databaseName string
}
var activityMd = activity.ToMetadata(&Input{}, &Output{})
// Metadata implements activity.Activity.Metadata
func (a *Activity) Metadata() *activity.Metadata {
return activityMd
}
//Cleanup method
func (a *Activity) Cleanup() error {
logquery.Debugf("cleaning up Neo4j activity")
return nil
}
type NodeOutput struct {
Id int64
Labels []string
Props map[string]interface{}
}
// Eval implements activity.Activity.Eval
func (a *Activity) Eval(context activity.Context) (done bool, err error) {
logquery.Debugf("Executing neo4j cypher query Activity")
input := &Input{}
err = context.GetInputObject(input)
if err != nil {
return true, nil
}
sessionConfig := neo4j.SessionConfig{AccessMode: a.accessMode, DatabaseName: a.databaseName}
session, err := a.driver.NewSession(sessionConfig)
if err != nil {
logquery.Errorf("===session error==", err)
return false, err
}
result, err := session.Run(input.CypherQuery, input.QueryParams)
if err != nil {
return false, err
}
//nodeList := []NodeOutput{}
nodeList := []interface{}{}
for result.Next() {
keys := result.Record().Keys()
for i, _ := range keys {
record := result.Record().GetByIndex(i)
switch record.(type) {
case neo4j.Node:
node := record.(neo4j.Node)
nodeOutput := NodeOutput{Id: node.Id(),
Labels: node.Labels(),
Props: node.Props(),
}
nodeList = append(nodeList, nodeOutput)
case string:
node := record.(string)
nodeList = append(nodeList, node)
case int64:
node := record.(int64)
nodeList = append(nodeList, node)
case float64:
node := record.(float64)
nodeList = append(nodeList, node)
}
}
}
context.SetOutput("response", nodeList)
session.Close()
return true, nil
}