This repository has been archived by the owner on Sep 24, 2019. It is now read-only.
/
svc.go
100 lines (76 loc) · 2.02 KB
/
svc.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
package thumbnail
import (
"github.com/vmihailenco/msgpack"
"github.com/zeebe-io/zbc-go/zbc"
"log"
"github.com/olahol/go-imageupload"
"fmt"
"io/ioutil"
"strings"
)
type Payload struct {
Image string `msgpack:"imagePath"`
Watermark string `msgpack:"watermarkPath"`
}
func processTask(msg *zbc.SubscriptionEvent) {
var payload Payload
err := msgpack.Unmarshal(msg.Task.Payload, &payload)
if err != nil {
panic(err)
}
bytes, err := ioutil.ReadFile(payload.Watermark)
if err != nil {
panic(err)
}
image := &imageupload.Image{
Filename: payload.Watermark,
ContentType: "image/png",
Data: bytes,
Size: len(bytes),
}
thumb, err := imageupload.ThumbnailPNG(image, 300, 300)
parts := strings.Split(image.Filename, "/")
filename := parts[len(parts) - 1]
parts = strings.Split(filename, ".")
thumbPath := fmt.Sprintf("/tmp/watermarking/%s-thumb.%s", parts[0], parts[len(parts) - 1])
ioutil.WriteFile(thumbPath, thumb.Data, 0644)
log.Printf("Saved thumbnail to %s\n", thumbPath)
}
func Run() {
client, _ := zbc.NewClient("0.0.0.0:51015")
subscriptionCh, subInfo, err := client.TaskConsumer("default-topic", "thumbnailer", "thumbnail")
if err != nil {
panic(err)
}
credits := subInfo.Credits
log.Println("Subscription opened with", credits, "Credits")
log.Println("Waiting for events ....")
for {
select {
case message := <-subscriptionCh:
credits--;
processTask(message)
response, err := client.CompleteTask(message)
if err != nil {
log.Println("Completing a task went wrong.")
log.Println(err)
}
if response.State == zbc.TaskCompleted {
log.Println("Task completed successfully.")
} else {
log.Println("Task not completed.")
}
if credits < 1 {
response, err := client.IncreaseTaskSubscriptionCredits(subInfo)
if err != nil {
log.Println("Increasing task credits went wrong.")
log.Println(err)
} else {
credits = response.Credits
log.Println("Increased task credits to", credits)
}
}
break
}
}
}