-
Notifications
You must be signed in to change notification settings - Fork 0
/
Copy pathexample.go
67 lines (57 loc) · 1.21 KB
/
example.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
package main
import (
"async-queue/backends"
"async-queue/broker"
"async-queue/consumer"
"async-queue/producer"
"flag"
"github.com/satori/go.uuid"
"log"
)
const (
EmailTask = "send_email"
)
var TaskMap = map[string]interface{}{
EmailTask: new(Email),
}
type Email struct {
Id string `json:"id"`
Body string `json:"body"`
}
func (e *Email) RunTask(params map[string]interface{}) error {
if emailId, ok := params["id"].(string); ok {
e.Id = emailId
}
if emailBody, ok := params["body"].(string); ok {
e.Body = emailBody
}
log.Printf("Sending email: %+v", e)
return nil
}
func main() {
appType := flag.String("--type", "app","")
if *appType == "app" {
startApp()
} else {
startConsumer()
}
}
func startConsumer() {
backend := getBackend()
c := consumer.NewConsumer(backend)
c.RegisterTasks(TaskMap)
c.RunConsumer()
}
func startApp() {
backend := getBackend()
p := producer.NewProducer(backend)
// Enqueue email tasks
for i := 0; i < 20; i++ {
taskId := uuid.NewV1()
params := map[string]interface{}{"id": "[email protected]", "body": "Example email"}
p.EnqueueTask(EmailTask, params, taskId.String())
}
}
func getBackend() broker.QueueBackendManager {
return backends.NewSQSService()
}