/
handler_circleci_out.go
129 lines (112 loc) · 3.99 KB
/
handler_circleci_out.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
118
119
120
121
122
123
124
125
126
127
128
129
package circleci
import (
"encoding/json"
"fmt"
"github.com/grokify/chathooks/src/config"
"github.com/grokify/chathooks/src/handlers"
"github.com/grokify/chathooks/src/models"
cc "github.com/grokify/commonchat"
)
const (
DisplayName = "Circlecl"
HandlerKey = "circleci"
MessageDirection = "out"
DocumentationURL = "https://circleci.com/docs/1.0/configuration/#notify"
MessageBodyType = models.JSON
)
func NewHandler() handlers.Handler {
return handlers.Handler{MessageBodyType: MessageBodyType, Normalize: Normalize}
}
func Normalize(cfg config.Configuration, bytes []byte) (cc.Message, error) {
ccMsg := cc.NewMessage()
iconURL, err := cfg.GetAppIconURL(HandlerKey)
if err == nil {
ccMsg.IconURL = iconURL.String()
}
src, err := CircleciOutMessageFromBytes(bytes)
if err != nil {
return ccMsg, err
}
ccMsg.Activity = fmt.Sprintf("Build %v", src.Status)
ccMsg.Title = fmt.Sprintf("[Build #%v](%s) for [**%s/%s**](%s) %s",
src.BuildNum, src.BuildURL, src.Reponame, src.Branch, src.VCSURL, src.Status)
attachment := cc.NewAttachment()
if len(src.Subject) > 0 {
if len(src.BuildURL) > 0 {
attachment.AddField(cc.Field{
Title: "Subject",
Value: fmt.Sprintf("[%v](%v)", src.Subject, src.BuildURL)})
} else {
attachment.AddField(cc.Field{
Title: "Subject",
Value: src.Subject})
}
}
if len(src.Branch) > 0 {
attachment.AddField(cc.Field{
Title: "Branch",
Value: src.Branch})
}
if len(src.Username) > 0 {
attachment.AddField(cc.Field{
Title: "Username",
Value: src.Username})
}
if len(src.CommitterName) > 0 {
attachment.AddField(cc.Field{
Title: "Committer",
Value: src.CommitterName})
}
ccMsg.AddAttachment(attachment)
return ccMsg, nil
}
type CircleciOutPayload struct {
Payload CircleciOutMessage `json:"payload,omitempty"`
}
type CircleciOutMessage struct {
VCSURL string `json:"vcs_url,omitempty"`
BuildURL string `json:"build_url,omitempty"`
BuildNum int64 `json:"build_num,omitempty"`
Branch string `json:"branch,omitempty"`
VCSRevision string `json:"vcs_revision,omitempty"`
CommitterName string `json:"committer_name,omitempty"`
CommitterEmail string `json:"committer_email,omitempty"`
Subject string `json:"subject,omitempty"`
Body string `json:"body,omitempty"`
Why string `json:"why,omitempty"`
DontBuild interface{} `json:"dont_build,omitempty"`
QueuedAt string `json:"queued_at,omitempty"`
StartTime string `json:"start_time,omitempty"`
StopTime string `json:"stop_time,omitempty"`
BuildTimeMillis int64 `json:"build_time_millis,omitempty"`
Username string `json:"username,omitempty"`
Reponame string `json:"reponame,omitempty"`
Lifecycle string `json:"lifecycle,omitempty"`
Outcome string `json:"outcome,omitempty"`
Status string `json:"status,omitempty"`
RetryOf interface{} `json:"retry_of,omitempty"`
Steps []interface{} `json:"steps,omitempty"`
}
type CircleciOutStep struct {
Name string `json:"name,omitempty"`
Actions []CircleciOutAction `json:"actions,omitempty"`
}
type CircleciOutAction struct {
BashCommand interface{} `json:"bash_command,omitempty"`
RunTimeMillis int64 `json:"run_time_millis,omitempty"`
StartTime string `json:"start_time,omitempty"`
EndTime string `json:"end_time,omitempty"`
Name string `json:"name,omitempty"`
ExitCode interface{} `json:"exit_cide,omitempty"`
Type string `json:"type,omitempty"`
Index int64 `json:"index,omitempty"`
Status string `json:"status,omitempty"`
}
func CircleciOutMessageFromBytes(bytes []byte) (CircleciOutMessage, error) {
resp := CircleciOutPayload{}
err := json.Unmarshal(bytes, &resp)
if err != nil {
return CircleciOutMessage{}, err
}
return resp.Payload, nil
}