-
Notifications
You must be signed in to change notification settings - Fork 1
/
Copy pathsetnode.go
42 lines (37 loc) · 1.49 KB
/
setnode.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
package quirk
import (
"context"
"fmt"
"github.com/dgraph-io/dgo/v2"
"github.com/dgraph-io/dgo/v2/protos/api"
)
// setNode will build a mutation RDF with the builder and will then
// execute it using the given transaction. Once executed it will return the UID map.
func setNode(ctx context.Context, txn *dgo.Txn, b builder,
identifier string, dat *DupleNode) (map[string]string, error) {
// loop through the duples to write the triples into the builder.
for _, d := range dat.Duples {
// get any optional XML datatype knowledge based on the value.
d.dataType = checkType(d.Object)
if uid, ok := d.Object.(UID); ok {
// Use the UID format instead of the regular object.
fmt.Fprintf(b, rdfReference+d.dataType+rdfEnd, identifier, d.Predicate, uid.Value())
} else if slice, ok := d.Object.([]byte); ok {
// Write a string casted byte slice into the builder.
fmt.Fprintf(b, rdfBase+d.dataType+rdfEnd, identifier, d.Predicate, string(slice))
} else {
// Write the triplet into the builder.
fmt.Fprintf(b, rdfBase+d.dataType+rdfEnd, identifier, d.Predicate, d.Object)
}
}
// Use our transaction to execute a mutation to insert or update our node.
// Renamed assigned to response to match dgo major version change.
// See Issue #17 for more info.
response, err := txn.Mutate(ctx, &api.Mutation{SetNquads: []byte(b.String())})
if err != nil {
return nil, err
}
// return the full map of UIDs back.
// Note: The key being the node's identifier.
return response.GetUids(), nil
}