Browse Source

Merge branch 'kegan/github-starter-links' into kegan/jira-starter-links

pull/28/head
Kegan Dougal 9 years ago
parent
commit
c651293452
  1. 27
      src/github.com/matrix-org/go-neb/matrix/types.go
  2. 43
      src/github.com/matrix-org/go-neb/services/github/github.go

27
src/github.com/matrix-org/go-neb/matrix/types.go

@ -1,6 +1,7 @@
package matrix package matrix
import ( import (
"encoding/json"
"html" "html"
"regexp" "regexp"
) )
@ -114,3 +115,29 @@ func GetHTMLMessage(msgtype, htmlText string) HTMLMessage {
FormattedBody: htmlText, FormattedBody: htmlText,
} }
} }
// StarterLinkMessage represents a message with a starter_link custom data.
type StarterLinkMessage struct {
Body string
Link string
}
// MarshalJSON converts this message into actual event content JSON.
func (m StarterLinkMessage) MarshalJSON() ([]byte, error) {
var data map[string]string
if m.Link != "" {
data = map[string]string{
"org.matrix.neb.starter_link": m.Link,
}
}
msg := struct {
MsgType string `json:"msgtype"`
Body string `json:"body"`
Data map[string]string `json:"data,omitempty"`
}{
"m.notice", m.Body, data,
}
return json.Marshal(msg)
}

43
src/github.com/matrix-org/go-neb/services/github/github.go

@ -28,6 +28,7 @@ type githubService struct {
ClientUserID string ClientUserID string
RealmID string RealmID string
SecretToken string SecretToken string
StarterLink string
Rooms map[string]struct { // room_id => {} Rooms map[string]struct { // room_id => {}
Repos map[string]struct { // owner/repo => { events: ["push","issue","pull_request"] } Repos map[string]struct { // owner/repo => { events: ["push","issue","pull_request"] }
Events []string Events []string
@ -45,17 +46,14 @@ func (s *githubService) RoomIDs() []string {
} }
return keys return keys
} }
func (s *githubService) Plugin(roomID string) plugin.Plugin {
return plugin.Plugin{
Commands: []plugin.Command{
plugin.Command{
Path: []string{"github", "create"},
Command: func(roomID, userID string, args []string) (interface{}, error) {
func (s *githubService) cmdGithubCreate(roomID, userID string, args []string) (interface{}, error) {
cli := s.githubClientFor(userID, false) cli := s.githubClientFor(userID, false)
if cli == nil { if cli == nil {
// TODO: send starter link
return &matrix.TextMessage{"m.notice",
userID + " : You have not linked your Github account."}, nil
return matrix.StarterLinkMessage{
Body: "You need to OAuth with Github before you can create issues.",
Link: s.StarterLink,
}, nil
} }
if len(args) < 2 { if len(args) < 2 {
@ -95,13 +93,9 @@ func (s *githubService) Plugin(roomID string) plugin.Plugin {
} }
return matrix.TextMessage{"m.notice", fmt.Sprintf("Created issue: %s", *issue.HTMLURL)}, nil return matrix.TextMessage{"m.notice", fmt.Sprintf("Created issue: %s", *issue.HTMLURL)}, nil
},
},
},
Expansions: []plugin.Expansion{
plugin.Expansion{
Regexp: ownerRepoIssueRegex,
Expand: func(roomID, userID, matchingText string) interface{} {
}
func (s *githubService) expandIssue(roomID, userID, matchingText string) interface{} {
cli := s.githubClientFor(userID, true) cli := s.githubClientFor(userID, true)
owner, repo, num, err := ownerRepoNumberFromText(matchingText) owner, repo, num, err := ownerRepoNumberFromText(matchingText)
if err != nil { if err != nil {
@ -124,6 +118,23 @@ func (s *githubService) Plugin(roomID string) plugin.Plugin {
"m.notice", "m.notice",
fmt.Sprintf("%s : %s", *i.HTMLURL, *i.Title), fmt.Sprintf("%s : %s", *i.HTMLURL, *i.Title),
} }
}
func (s *githubService) Plugin(roomID string) plugin.Plugin {
return plugin.Plugin{
Commands: []plugin.Command{
plugin.Command{
Path: []string{"github", "create"},
Command: func(roomID, userID string, args []string) (interface{}, error) {
return s.cmdGithubCreate(roomID, userID, args)
},
},
},
Expansions: []plugin.Expansion{
plugin.Expansion{
Regexp: ownerRepoIssueRegex,
Expand: func(roomID, userID, matchingText string) interface{} {
return s.expandIssue(roomID, userID, matchingText)
}, },
}, },
}, },

Loading…
Cancel
Save