/
database_memory_write.go
70 lines (63 loc) · 1.48 KB
/
database_memory_write.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
package elem
import (
"github.com/Bitspark/slang/pkg/core"
"github.com/google/uuid"
)
var databaseMemoryWriteId = uuid.MustParse("78e92496-dd73-4422-bcd0-691fa549dccd")
var databaseMemoryWriteCfg = &builtinConfig{
safe: true,
blueprint: core.Blueprint{
Id: databaseMemoryWriteId,
Meta: core.BlueprintMetaDef{
Name: "read from memory",
ShortDescription: "writes an item to memory and associates it with a key string",
Icon: "memory",
Tags: []string{"database", "memory"},
DocURL: "https://bitspark.de/slang/docs/operator/memory-write",
},
ServiceDefs: map[string]*core.ServiceDef{
core.MAIN_SERVICE: {
In: core.TypeDef{
Type: "map",
Map: map[string]*core.TypeDef{
"key": {
Type: "string",
},
"value": {
Type: "generic",
Generic: "valueType",
},
},
},
Out: core.TypeDef{
Type: "trigger",
},
},
},
DelegateDefs: map[string]*core.DelegateDef{},
PropertyDefs: map[string]*core.TypeDef{
"store": {
Type: "string",
},
},
},
opFunc: func(op *core.Operator) {
in := op.Main().In()
out := op.Main().Out()
// Get store
store := op.Property("store").(string)
ms := getMemoryStore(store)
for {
i := in.Pull()
if core.IsMarker(i) {
out.Push(i)
continue
}
pair := i.(map[string]interface{})
ms.mutex.Lock()
ms.items[pair["key"].(string)] = pair["value"]
ms.mutex.Unlock()
out.Push(nil)
}
},
}