generated from streamingriver/template
-
-
Notifications
You must be signed in to change notification settings - Fork 0
/
Copy pathmain.go
93 lines (81 loc) · 1.99 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
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
package main
import (
"bytes"
"context"
"encoding/json"
"fmt"
"log"
"net/http"
"runtime"
"github.com/streamingriver/vitamins/apiserver"
"github.com/streamingriver/vitamins/parser"
)
func main() {
ctx := context.Background()
// TestEventCreated("test", "alpine:latest")
// return
p := parser.New()
p.Register("event-created", func(js string) {
log.Printf("Got EventCreated")
var ec EventCreated
err := json.Unmarshal([]byte(js), &ec)
if err != nil {
log.Printf("Parse json failed with: %v", err)
return
}
equals := false
jss, err := inspect(ctx, ec.Name)
if err != nil {
log.Printf("%v", err)
} else {
equals = Equals(jss.Config.Env, ec.Env)
}
if equals == false {
log.Printf("Deleteting container: %s", ec.Name)
err := delete(ctx, ec.Name)
if err != nil {
log.Printf("%v", err)
} else {
log.Printf("Container deleted: %s", ec.Name)
}
}
log.Printf("equals: %v", equals)
if equals {
// TODO: api call
if ec.ServiceConfig != "" {
buff := bytes.NewBuffer(nil)
buff.Write([]byte("set-config"))
buff.Write([]byte(" "))
buff.Write([]byte(ec.ServiceConfig))
http.DefaultClient.Post(fmt.Sprintf("http://%s:3080", ec.Name), "text/plain", buff)
}
log.Printf("container doesnt changed - nothing todo but, maybe ping service API?")
log.Printf("Calling api: http://%s:3080 with data: (%s)", ec.Name, encode(ec.ServiceConfig))
return
}
log.Printf("Creating container: %s", ec.Name)
err = create(
ctx, // context
ec,
map[string]string{ec.Name: "/data"}, // mounts
)
if err != nil {
log.Printf("%v", err)
return
}
log.Printf("Container %s created", ec.Name)
})
p.Register("event-deleted", func(name string) {
log.Printf("Deleteting container: %s", name)
err := delete(ctx, name)
if err != nil {
log.Printf("Error: %v", err)
return
}
log.Printf("Container %s deleted", name)
})
apiserver := apiserver.NewDefault(p)
apiserver.Listen()
runtime.Goexit()
}
// listContainers(ctx)