|
@ -26,7 +26,7 @@ type githubService struct { |
|
|
id string |
|
|
id string |
|
|
serviceUserID string |
|
|
serviceUserID string |
|
|
webhookEndpointURL string |
|
|
webhookEndpointURL string |
|
|
ClientUserID string |
|
|
|
|
|
|
|
|
ClientUserID string // optional; required for webhooks
|
|
|
RealmID string |
|
|
RealmID string |
|
|
SecretToken string |
|
|
SecretToken string |
|
|
HandleCommands bool |
|
|
HandleCommands bool |
|
@ -193,8 +193,8 @@ func (s *githubService) OnReceiveWebhook(w http.ResponseWriter, req *http.Reques |
|
|
w.WriteHeader(200) |
|
|
w.WriteHeader(200) |
|
|
} |
|
|
} |
|
|
func (s *githubService) Register() error { |
|
|
func (s *githubService) Register() error { |
|
|
if s.RealmID == "" || s.ClientUserID == "" { |
|
|
|
|
|
return fmt.Errorf("RealmID and ClientUserID are required") |
|
|
|
|
|
|
|
|
if s.RealmID == "" { |
|
|
|
|
|
return fmt.Errorf("RealmID is required") |
|
|
} |
|
|
} |
|
|
// check realm exists
|
|
|
// check realm exists
|
|
|
realm, err := database.GetServiceDB().LoadAuthRealm(s.RealmID) |
|
|
realm, err := database.GetServiceDB().LoadAuthRealm(s.RealmID) |
|
@ -206,12 +206,14 @@ func (s *githubService) Register() error { |
|
|
return fmt.Errorf("Realm is of type '%s', not 'github'", realm.Type()) |
|
|
return fmt.Errorf("Realm is of type '%s', not 'github'", realm.Type()) |
|
|
} |
|
|
} |
|
|
|
|
|
|
|
|
// In order to register the GH service, you must have authed with GH.
|
|
|
|
|
|
|
|
|
if s.ClientUserID != "" { |
|
|
|
|
|
// In order to register the GH service as a client, you must have authed with GH.
|
|
|
cli := s.githubClientFor(s.ClientUserID, false) |
|
|
cli := s.githubClientFor(s.ClientUserID, false) |
|
|
if cli == nil { |
|
|
if cli == nil { |
|
|
return fmt.Errorf( |
|
|
return fmt.Errorf( |
|
|
"User %s does not have a Github auth session with realm %s.", s.ClientUserID, realm.ID()) |
|
|
"User %s does not have a Github auth session with realm %s.", s.ClientUserID, realm.ID()) |
|
|
} |
|
|
} |
|
|
|
|
|
} |
|
|
|
|
|
|
|
|
log.Infof("%+v", s) |
|
|
log.Infof("%+v", s) |
|
|
|
|
|
|
|
@ -219,6 +221,17 @@ func (s *githubService) Register() error { |
|
|
} |
|
|
} |
|
|
|
|
|
|
|
|
func (s *githubService) PostRegister(oldService types.Service) { |
|
|
func (s *githubService) PostRegister(oldService types.Service) { |
|
|
|
|
|
// PostRegister handles creating/destroying webhooks, which is only valid if this service
|
|
|
|
|
|
// is configured on behalf of a client.
|
|
|
|
|
|
if s.ClientUserID == "" { |
|
|
|
|
|
if len(s.Rooms) != 0 { |
|
|
|
|
|
log.WithFields(log.Fields{ |
|
|
|
|
|
"Rooms": s.Rooms, |
|
|
|
|
|
}).Error("Empty ClientUserID but a webhook config was supplied.") |
|
|
|
|
|
} |
|
|
|
|
|
return |
|
|
|
|
|
} |
|
|
|
|
|
|
|
|
cli := s.githubClientFor(s.ClientUserID, false) |
|
|
cli := s.githubClientFor(s.ClientUserID, false) |
|
|
if cli == nil { |
|
|
if cli == nil { |
|
|
log.Errorf("PostRegister: %s does not have a github session", s.ClientUserID) |
|
|
log.Errorf("PostRegister: %s does not have a github session", s.ClientUserID) |
|
|