mirror of https://github.com/matrix-org/go-neb.git
Kegsay
9 years ago
committed by
GitHub
5 changed files with 117 additions and 0 deletions
-
4src/github.com/matrix-org/go-neb/api.go
-
1src/github.com/matrix-org/go-neb/goneb.go
-
4src/github.com/matrix-org/go-neb/realms/github/github.go
-
107src/github.com/matrix-org/go-neb/realms/jira/jira.go
-
1src/github.com/matrix-org/go-neb/types/types.go
@ -0,0 +1,107 @@ |
|||
package realms |
|||
|
|||
import ( |
|||
"crypto/rsa" |
|||
"crypto/x509" |
|||
"encoding/json" |
|||
"encoding/pem" |
|||
"errors" |
|||
log "github.com/Sirupsen/logrus" |
|||
"github.com/matrix-org/go-neb/types" |
|||
"net/http" |
|||
) |
|||
|
|||
type jiraRealm struct { |
|||
id string |
|||
privateKey *rsa.PrivateKey |
|||
JIRAEndpoint string |
|||
ConsumerName string |
|||
ConsumerKey string |
|||
ConsumerSecret string |
|||
PublicKeyPEM string // clobbered based on PrivateKeyPEM
|
|||
PrivateKeyPEM string |
|||
} |
|||
|
|||
func (r *jiraRealm) ID() string { |
|||
return r.id |
|||
} |
|||
|
|||
func (r *jiraRealm) Type() string { |
|||
return "jira" |
|||
} |
|||
|
|||
func (r *jiraRealm) Register() error { |
|||
if r.ConsumerName == "" || r.ConsumerKey == "" || r.ConsumerSecret == "" || r.PrivateKeyPEM == "" { |
|||
return errors.New("ConsumerName, ConsumerKey, ConsumerSecret, PrivateKeyPEM must be specified.") |
|||
} |
|||
log.Print("Registering..") |
|||
// Make sure the private key PEM is actually a private key.
|
|||
err := r.parsePrivateKey() |
|||
if err != nil { |
|||
return err |
|||
} |
|||
|
|||
// TODO: Check to see if JIRA endpoint is valid and known
|
|||
|
|||
return nil |
|||
} |
|||
|
|||
func (r *jiraRealm) RequestAuthSession(userID string, req json.RawMessage) interface{} { |
|||
return nil |
|||
} |
|||
|
|||
func (r *jiraRealm) OnReceiveRedirect(w http.ResponseWriter, req *http.Request) { |
|||
|
|||
} |
|||
|
|||
func (r *jiraRealm) AuthSession(id, userID, realmID string) types.AuthSession { |
|||
return nil |
|||
} |
|||
|
|||
func (r *jiraRealm) parsePrivateKey() error { |
|||
pk, err := loadPrivateKey(r.PrivateKeyPEM) |
|||
if err != nil { |
|||
return err |
|||
} |
|||
pub, err := publicKeyAsPEM(pk) |
|||
if err != nil { |
|||
return err |
|||
} |
|||
r.PublicKeyPEM = pub |
|||
r.privateKey = pk |
|||
return nil |
|||
} |
|||
|
|||
func loadPrivateKey(privKeyPEM string) (*rsa.PrivateKey, error) { |
|||
// Decode PEM to grab the private key type
|
|||
block, _ := pem.Decode([]byte(privKeyPEM)) |
|||
if block == nil { |
|||
return nil, errors.New("No PEM formatted block found") |
|||
} |
|||
|
|||
priv, err := x509.ParsePKCS1PrivateKey(block.Bytes) |
|||
if err != nil { |
|||
return nil, err |
|||
} |
|||
return priv, nil |
|||
} |
|||
|
|||
func publicKeyAsPEM(pkey *rsa.PrivateKey) (string, error) { |
|||
// https://github.com/golang-samples/cipher/blob/master/crypto/rsa_keypair.go
|
|||
der, err := x509.MarshalPKIXPublicKey(&pkey.PublicKey) |
|||
if err != nil { |
|||
return "", err |
|||
} |
|||
block := pem.Block{ |
|||
Type: "PUBLIC KEY", |
|||
Headers: nil, |
|||
Bytes: der, |
|||
} |
|||
return string(pem.EncodeToMemory(&block)), nil |
|||
} |
|||
|
|||
func init() { |
|||
types.RegisterAuthRealm(func(realmID string) types.AuthRealm { |
|||
return &jiraRealm{id: realmID} |
|||
}) |
|||
} |
Reference in new issue
xxxxxxxxxx