-
Notifications
You must be signed in to change notification settings - Fork 0
/
Copy pathmain.go
111 lines (84 loc) · 2.12 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
94
95
96
97
98
99
100
101
102
103
104
105
106
107
108
109
110
111
package main
import (
"flag"
"fmt"
"log"
"strings"
"time"
"github.com/fatih/color"
"github.com/go-stomp/stomp"
)
var (
host string
port int
subname string
)
func main() {
log.SetFlags(log.Flags() | log.Lshortfile)
flag.IntVar(&port, "port", 61613, "STOMP connection port")
flag.StringVar(&host, "host", "localhost", "STOMP connection host or IP")
flag.StringVar(&subname, "subscribe", "/topic/fedora", "Queue or topic to subscribe to")
flag.Parse()
for err := perform(listen); err != nil; err = perform(listen) {
log.Println("Task error, restarting", err)
}
}
func perform(task func(*stomp.Conn) error) (err error) {
var conn *stomp.Conn
// Try infinitely to connect
for conn, err = connect(); err != nil; conn, err = connect() {
log.Println("Could not connect!", err)
time.Sleep(1 * time.Second)
}
defer func() {
if e := conn.Disconnect(); e != nil {
log.Println("Error disconnecting: ", e)
}
}()
return task(conn)
}
func connect() (*stomp.Conn, error) {
return stomp.Dial("tcp", fmt.Sprint(host, ":", port),
stomp.ConnOpt.AcceptVersion(stomp.V12),
stomp.ConnOpt.HeartBeat(10*time.Second, 5*time.Second))
}
func listen(conn *stomp.Conn) (err error) {
sub, err := conn.Subscribe(subname, stomp.AckClient)
if err != nil {
return fmt.Errorf("Could not subscribe to %s: %v", subname, err)
}
log.Println("Subscribed to", subname)
defer func() {
sub.Unsubscribe()
}()
for msg := range sub.C {
fmt.Println()
for i := 0; i < msg.Header.Len(); i++ {
key, val := msg.Header.GetAt(i)
printHeader(fmt.Sprintf("%s = %s", key, val))
}
printBody(string(msg.Body[:]))
if msg.ShouldAck() {
err = conn.Ack(msg)
if err != nil {
log.Println("Could not Ack message", msg.Destination, err)
}
}
}
return
}
func printHeader(txt string) {
line := color.New(color.FgCyan)
if strings.HasPrefix(txt, "org.fcrepo") {
line.Add(color.Bold)
}
colorPrint(line, txt)
}
func printBody(txt string) {
colorPrint(color.New(color.FgRed, color.FgYellow, color.Bold), txt)
}
func colorPrint(c *color.Color, txt string) {
if _, err := c.Println(txt); err != nil {
fmt.Println(txt)
}
}