-
Notifications
You must be signed in to change notification settings - Fork 21
/
Copy pathdeviceStatus.go
117 lines (103 loc) · 3.5 KB
/
deviceStatus.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
112
113
114
115
116
117
// SPDX-FileCopyrightText: 2017 Comcast Cable Communications Management, LLC
// SPDX-License-Identifier: Apache-2.0
package main
import (
"fmt"
"strconv"
"time"
"github.com/xmidt-org/webpa-common/v2/convey"
"github.com/xmidt-org/webpa-common/v2/device"
"github.com/xmidt-org/wrp-go/v3"
"github.com/xmidt-org/wrp-go/v3/wrpmeta"
)
func statusMetadata(d device.Interface) map[string]string {
metadata, allFieldsPresent := wrpmeta.NewBuilder().Apply(
d.Convey(),
wrpmeta.Field{From: "boot-time", To: "/boot-time"},
wrpmeta.Field{From: "hw-model", To: "/hw-model"},
wrpmeta.Field{From: "hw-manufacturer", To: "/hw-manufacturer"},
wrpmeta.Field{From: "hw-serial-number", To: "/hw-serial-number"},
wrpmeta.Field{From: "hw-last-reboot-reason", To: "/hw-last-reboot-reason"},
wrpmeta.Field{From: "fw-name", To: "/fw-name"},
wrpmeta.Field{From: "last-reconnect-reason", To: "/last-reconnect-reason"},
wrpmeta.Field{From: "webpa-last-reconnect-reason", To: "/last-reconnect-reason"},
wrpmeta.Field{From: "webpa-protocol", To: "/protocol"},
wrpmeta.Field{From: "webpa-interface-used", To: "/interface-used"},
wrpmeta.Field{From: "boot-time-retry-wait", To: "/boot-time-retry-wait"}).
Set("/trust", strconv.Itoa(d.Metadata().TrustClaim())).
Build()
if allFieldsPresent {
metadata["/compliance"] = d.ConveyCompliance().String()
} else {
metadata["/compliance"] = convey.MissingFields.String()
}
metadata["/hw-deviceid"] = string(d.ID())
return metadata
}
func statusEventType(id device.ID, subtype string) string {
return fmt.Sprintf("device-status/%s/%s", id, subtype)
}
func onlinePayload(t time.Time, d device.Interface) []byte {
return []byte(fmt.Sprintf(`{
"id": "%s",
"ts": "%s"
}`, d.ID(), t.Format(time.RFC3339Nano)))
}
func newOnlineMessage(source string, d device.Interface) (string, *wrp.Message) {
eventType := statusEventType(d.ID(), "online")
t := time.Now()
m := &wrp.Message{
Type: wrp.SimpleEventMessageType,
Source: source,
Destination: "event:" + eventType,
ContentType: wrp.MimeTypeJson,
PartnerIDs: []string{d.Metadata().PartnerIDClaim()},
SessionID: d.Metadata().SessionID(),
Metadata: statusMetadata(d),
Payload: onlinePayload(t, d),
}
updateTimestampMetadata(m, t)
return m.FindEventStringSubMatch(), m
}
func offlinePayload(t time.Time, d device.Interface) []byte {
statistics := d.Statistics()
return []byte(fmt.Sprintf(`{
"id": "%s",
"ts": "%s",
"bytes-sent": %d,
"messages-sent": %d,
"bytes-received": %d,
"messages-received": %d,
"connected-at": "%s",
"up-time": "%s",
"reason-for-closure": "%s"
}`, d.ID(),
t.Format(time.RFC3339Nano),
statistics.BytesSent(),
statistics.MessagesSent(),
statistics.BytesReceived(),
statistics.MessagesReceived(),
statistics.ConnectedAt().Format(time.RFC3339Nano),
statistics.UpTime(),
d.CloseReason(),
))
}
func newOfflineMessage(source string, d device.Interface) (string, *wrp.Message) {
eventType := statusEventType(d.ID(), "offline")
t := time.Now()
m := &wrp.Message{
Type: wrp.SimpleEventMessageType,
Source: source,
Destination: "event:" + eventType,
ContentType: wrp.MimeTypeJson,
PartnerIDs: []string{d.Metadata().PartnerIDClaim()},
SessionID: d.Metadata().SessionID(),
Metadata: statusMetadata(d),
Payload: offlinePayload(t, d),
}
updateTimestampMetadata(m, t)
return m.FindEventStringSubMatch(), m
}
func updateTimestampMetadata(m *wrp.Message, t time.Time) {
m.Metadata[device.WRPTimestampMetadataKey] = t.Format(time.RFC3339Nano)
}