Browse Source

List possible GH repos on /getSession

Add an Info() method to pull out info about an auth session.
pull/29/head
Kegan Dougal 9 years ago
parent
commit
34eca3984f
  1. 4
      src/github.com/matrix-org/go-neb/api.go
  2. 29
      src/github.com/matrix-org/go-neb/realms/github/github.go
  3. 5
      src/github.com/matrix-org/go-neb/realms/jira/jira.go
  4. 51
      src/github.com/matrix-org/go-neb/services/github/client/client.go
  5. 20
      src/github.com/matrix-org/go-neb/services/github/github.go
  6. 1
      src/github.com/matrix-org/go-neb/types/types.go

4
src/github.com/matrix-org/go-neb/api.go

@ -295,6 +295,6 @@ func (h *getSessionHandler) OnIncomingRequest(req *http.Request) (interface{}, *
return &struct { return &struct {
ID string ID string
Authenticated bool Authenticated bool
Session types.AuthSession
}{session.ID(), session.Authenticated(), session}, nil
Session interface{}
}{session.ID(), session.Authenticated(), session.Info()}, nil
} }

29
src/github.com/matrix-org/go-neb/realms/github/github.go

@ -5,7 +5,9 @@ import (
"encoding/hex" "encoding/hex"
"encoding/json" "encoding/json"
log "github.com/Sirupsen/logrus" log "github.com/Sirupsen/logrus"
"github.com/google/go-github/github"
"github.com/matrix-org/go-neb/database" "github.com/matrix-org/go-neb/database"
"github.com/matrix-org/go-neb/services/github/client"
"github.com/matrix-org/go-neb/types" "github.com/matrix-org/go-neb/types"
"io/ioutil" "io/ioutil"
"net/http" "net/http"
@ -37,6 +39,33 @@ func (s *GithubSession) Authenticated() bool {
return s.AccessToken != "" return s.AccessToken != ""
} }
// Info returns a list of possible repositories that this session can integrate with.
func (s *GithubSession) Info() interface{} {
logger := log.WithFields(log.Fields{
"user_id": s.userID,
"realm_id": s.realmID,
})
cli := client.New(s.AccessToken)
// query for a list of possible projects
rs, _, err := cli.Repositories.List("", &github.RepositoryListOptions{
Type: "all",
})
if err != nil {
logger.WithError(err).Print("Failed to query github projects on github.com")
return nil
}
var repos []client.TrimmedRepository
for _, r := range rs {
repos = append(repos, client.TrimRepository(r))
}
return struct {
Repos []client.TrimmedRepository
}{repos}
}
// UserID returns the user_id who authorised with Github // UserID returns the user_id who authorised with Github
func (s *GithubSession) UserID() string { func (s *GithubSession) UserID() string {
return s.userID return s.userID

5
src/github.com/matrix-org/go-neb/realms/jira/jira.go

@ -52,6 +52,11 @@ func (s *JIRASession) Authenticated() bool {
return s.AccessToken != "" && s.AccessSecret != "" return s.AccessToken != "" && s.AccessSecret != ""
} }
// Info returns nothing
func (s *JIRASession) Info() interface{} {
return nil
}
// UserID returns the ID of the user performing the authentication. // UserID returns the ID of the user performing the authentication.
func (s *JIRASession) UserID() string { func (s *JIRASession) UserID() string {
return s.userID return s.userID

51
src/github.com/matrix-org/go-neb/services/github/client/client.go

@ -0,0 +1,51 @@
package client
import (
"github.com/google/go-github/github"
"golang.org/x/oauth2"
)
// TrimmedRepository represents a cut-down version of github.Repository with only the keys the end-user is
// likely to want.
type TrimmedRepository struct {
Name *string `json:"name"`
Description *string `json:"description"`
Private *bool `json:"private"`
HTMLURL *string `json:"html_url"`
CreatedAt *github.Timestamp `json:"created_at"`
UpdatedAt *github.Timestamp `json:"updated_at"`
PushedAt *github.Timestamp `json:"pushed_at"`
Fork *bool `json:"fork"`
FullName *string `json:"full_name"`
Permissions *map[string]bool `json:"permissions"`
}
// TrimRepository trims a github repo into important fields only.
func TrimRepository(repo *github.Repository) TrimmedRepository {
return TrimmedRepository{
Name: repo.Name,
Description: repo.Description,
Private: repo.Private,
HTMLURL: repo.HTMLURL,
CreatedAt: repo.CreatedAt,
UpdatedAt: repo.UpdatedAt,
PushedAt: repo.PushedAt,
Permissions: repo.Permissions,
Fork: repo.Fork,
FullName: repo.FullName,
}
}
// New returns a github Client which can perform Github API operations.
// If `token` is empty, a non-authenticated client will be created. This should be
// used sparingly where possible as you only get 60 requests/hour like that (IP locked).
func New(token string) *github.Client {
var tokenSource oauth2.TokenSource
if token != "" {
tokenSource = oauth2.StaticTokenSource(
&oauth2.Token{AccessToken: token},
)
}
httpCli := oauth2.NewClient(oauth2.NoContext, tokenSource)
return github.NewClient(httpCli)
}

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

@ -8,9 +8,9 @@ import (
"github.com/matrix-org/go-neb/matrix" "github.com/matrix-org/go-neb/matrix"
"github.com/matrix-org/go-neb/plugin" "github.com/matrix-org/go-neb/plugin"
"github.com/matrix-org/go-neb/realms/github" "github.com/matrix-org/go-neb/realms/github"
"github.com/matrix-org/go-neb/services/github/client"
"github.com/matrix-org/go-neb/services/github/webhook" "github.com/matrix-org/go-neb/services/github/webhook"
"github.com/matrix-org/go-neb/types" "github.com/matrix-org/go-neb/types"
"golang.org/x/oauth2"
"net/http" "net/http"
"regexp" "regexp"
"strconv" "strconv"
@ -290,9 +290,9 @@ func (s *githubService) githubClientFor(userID string, allowUnauth bool) *github
}).Print("Failed to get token for user") }).Print("Failed to get token for user")
} }
if token != "" { if token != "" {
return githubClient(token)
return client.New(token)
} else if allowUnauth { } else if allowUnauth {
return githubClient("")
return client.New("")
} else { } else {
return nil return nil
} }
@ -322,20 +322,6 @@ func getTokenForUser(realmID, userID string) (string, error) {
return ghSession.AccessToken, nil return ghSession.AccessToken, nil
} }
// githubClient returns a github Client which can perform Github API operations.
// If `token` is empty, a non-authenticated client will be created. This should be
// used sparingly where possible as you only get 60 requests/hour like that (IP locked).
func githubClient(token string) *github.Client {
var tokenSource oauth2.TokenSource
if token != "" {
tokenSource = oauth2.StaticTokenSource(
&oauth2.Token{AccessToken: token},
)
}
httpCli := oauth2.NewClient(oauth2.NoContext, tokenSource)
return github.NewClient(httpCli)
}
// ownerRepoNumberFromText parses a GH issue string that looks like 'owner/repo#11' // ownerRepoNumberFromText parses a GH issue string that looks like 'owner/repo#11'
// into its constituient parts. Returns: owner, repo, issue#. // into its constituient parts. Returns: owner, repo, issue#.
func ownerRepoNumberFromText(ownerRepoNumberText string) (string, string, int, error) { func ownerRepoNumberFromText(ownerRepoNumberText string) (string, string, int, error) {

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

@ -124,4 +124,5 @@ type AuthSession interface {
UserID() string UserID() string
RealmID() string RealmID() string
Authenticated() bool Authenticated() bool
Info() interface{}
} }
Loading…
Cancel
Save