mirror of https://github.com/matrix-org/go-neb.git
Browse Source
Merge pull request #98 from matrix-org/kegan/config-yaml
Merge pull request #98 from matrix-org/kegan/config-yaml
Support config.yaml in addition to HTTP endpointskegan/tests
Kegsay
8 years ago
committed by
GitHub
8 changed files with 419 additions and 65 deletions
-
106config.sample.yaml
-
84src/github.com/matrix-org/go-neb/api/api.go
-
9src/github.com/matrix-org/go-neb/clients/clients.go
-
61src/github.com/matrix-org/go-neb/database/db.go
-
11src/github.com/matrix-org/go-neb/database/schema.go
-
157src/github.com/matrix-org/go-neb/goneb.go
-
30src/github.com/matrix-org/go-neb/handlers.go
-
22src/github.com/matrix-org/go-neb/types/types.go
@ -0,0 +1,106 @@ |
|||
# Go-NEB Configuration File |
|||
# |
|||
# This file provides an alternative way to configure Go-NEB which does not involve HTTP APIs. |
|||
# |
|||
# This file can be supplied to go-neb by the environment variable `CONFIG_FILE=config.yaml`. |
|||
# It will force Go-NEB to operate in "config" mode. This means: |
|||
# - Go-NEB will ONLY use the data contained inside this file. |
|||
# - All of Go-NEB's /admin HTTP listeners will be disabled. You will be unable to add new services at runtime. |
|||
# - The environment variable `DATABASE_URL` will be ignored and an in-memory database will be used instead. |
|||
# |
|||
# This file is broken down into 4 sections which matches the following HTTP APIs: |
|||
# - /configureClient |
|||
# - /configureAuthRealm |
|||
# - /configureService |
|||
# - /requestAuthSession (redirects not supported) |
|||
|
|||
# The list of clients which Go-NEB is aware of. |
|||
# Delete or modify this list as appropriate. |
|||
# See the docs for /configureClient for the full list of options. |
|||
clients: |
|||
- UserID: "@goneb:localhost" |
|||
AccessToken: "MDASDASJDIASDJASDAFGFRGER" |
|||
HomeserverURL: "http://localhost:8008" |
|||
Sync: true |
|||
AutoJoinRooms: true |
|||
DisplayName: "Go-NEB!" |
|||
|
|||
- UserID: "@another_goneb:localhost" |
|||
AccessToken: "MDASDASJDIASDJASDAFGFRGER" |
|||
HomeserverURL: "http://localhost:8008" |
|||
Sync: false |
|||
AutoJoinRooms: false |
|||
DisplayName: "Go-NEB!" |
|||
|
|||
# The list of realms which Go-NEB is aware of. |
|||
# Delete or modify this list as appropriate. |
|||
# See the docs for /configureAuthRealm for the full list of options. |
|||
realms: |
|||
- ID: "github_realm" |
|||
Type: "github" |
|||
Config: {} # No need for client ID or Secret as Go-NEB isn't generating OAuth URLs |
|||
|
|||
# The list of *authenticated* sessions which Go-NEB is aware of. |
|||
# Delete or modify this list as appropriate. |
|||
# The full list of options are shown below: there is no single HTTP endpoint |
|||
# which maps to this section. |
|||
sessions: |
|||
- SessionID: "your_github_session" |
|||
RealmID: "github_realm" |
|||
UserID: "@YOUR_USER_ID:localhost" |
|||
Config: |
|||
# Populate these fields by generating a "Personal Access Token" on github.com |
|||
AccessToken: "YOUR_GITHUB_ACCESS_TOKEN" |
|||
Scopes: "admin:org_hook,admin:repo_hook,repo,user" |
|||
|
|||
|
|||
# The list of services which Go-NEB is aware of. |
|||
# Delete or modify this list as appropriate. |
|||
# See the docs for /configureService for the full list of options. |
|||
services: |
|||
- ID: "giphy_service" |
|||
Type: "giphy" |
|||
UserID: "@goneb:localhost" # requires a Syncing client |
|||
Config: |
|||
api_key: "qwg4672vsuyfsfe" |
|||
|
|||
- ID: "guggy_service" |
|||
Type: "guggy" |
|||
UserID: "@goneb:localhost" # requires a Syncing client |
|||
Config: |
|||
api_key: "2356saaqfhgfe" |
|||
|
|||
- ID: "rss_service" |
|||
Type: "rssbot" |
|||
UserID: "@another_goneb:localhost" |
|||
Config: |
|||
feeds: |
|||
"http://lorem-rss.herokuapp.com/feed?unit=second&interval=60": |
|||
rooms: ["!qmElAGdFYCHoCJuaNt:localhost"] |
|||
|
|||
- ID: "github_cmd_service" |
|||
Type: "github" |
|||
UserID: "@goneb:localhost" # requires a Syncing client |
|||
Config: |
|||
RealmID: "github_realm" |
|||
|
|||
# Make sure your BASE_URL can be accessed by Github! |
|||
- ID: "github_webhook_service" |
|||
Type: "github-webhook" |
|||
UserID: "@another_goneb:localhost" |
|||
Config: |
|||
RealmID: "github_realm" |
|||
ClientUserID: "@YOUR_USER_ID:localhost" # needs to be an authenticated user so Go-NEB can create webhooks. |
|||
Rooms: |
|||
"!someroom:id": |
|||
Repos: |
|||
"matrix-org/synapse": |
|||
Events: ["push", "issues"] |
|||
"matrix-org/dendron": |
|||
Events: ["pull_request"] |
|||
"!anotherroom:id": |
|||
Repos: |
|||
"matrix-org/synapse": |
|||
Events: ["push", "issues"] |
|||
"matrix-org/dendron": |
|||
Events: ["pull_request"] |
@ -0,0 +1,84 @@ |
|||
package api |
|||
|
|||
import ( |
|||
"encoding/json" |
|||
"errors" |
|||
"net/url" |
|||
) |
|||
|
|||
// ConfigureAuthRealmRequest is a request to /configureAuthRealm
|
|||
type ConfigureAuthRealmRequest struct { |
|||
ID string |
|||
Type string |
|||
Config json.RawMessage |
|||
} |
|||
|
|||
// ConfigureServiceRequest is a request to /configureService
|
|||
type ConfigureServiceRequest struct { |
|||
ID string |
|||
Type string |
|||
UserID string |
|||
Config json.RawMessage |
|||
} |
|||
|
|||
// A ClientConfig is the configuration for a matrix client for a bot to use. It is
|
|||
// a request to /configureClient
|
|||
type ClientConfig struct { |
|||
UserID string // The matrix UserId to connect with.
|
|||
HomeserverURL string // A URL with the host and port of the matrix server. E.g. https://matrix.org:8448
|
|||
AccessToken string // The matrix access token to authenticate the requests with.
|
|||
Sync bool // True to start a sync stream for this user
|
|||
AutoJoinRooms bool // True to automatically join all rooms for this user
|
|||
DisplayName string // The display name to set for the matrix client
|
|||
} |
|||
|
|||
// SessionRequest are usually multi-stage things so this type only exists for the config form
|
|||
type SessionRequest struct { |
|||
SessionID string |
|||
RealmID string |
|||
UserID string |
|||
Config json.RawMessage |
|||
} |
|||
|
|||
// ConfigFile represents config.sample.yaml
|
|||
type ConfigFile struct { |
|||
Clients []ClientConfig |
|||
Realms []ConfigureAuthRealmRequest |
|||
Services []ConfigureServiceRequest |
|||
Sessions []SessionRequest |
|||
} |
|||
|
|||
// Check validates the /configureService request
|
|||
func (c *ConfigureServiceRequest) Check() error { |
|||
if c.ID == "" || c.Type == "" || c.UserID == "" || c.Config == nil { |
|||
return errors.New(`Must supply an "ID", a "Type", a "UserID" and a "Config"`) |
|||
} |
|||
return nil |
|||
} |
|||
|
|||
// Check validates the /configureAuthRealm request
|
|||
func (c *ConfigureAuthRealmRequest) Check() error { |
|||
if c.ID == "" || c.Type == "" || c.Config == nil { |
|||
return errors.New(`Must supply a "ID", a "Type" and a "Config"`) |
|||
} |
|||
return nil |
|||
} |
|||
|
|||
// Check validates the session config request
|
|||
func (c *SessionRequest) Check() error { |
|||
if c.SessionID == "" || c.UserID == "" || c.RealmID == "" || c.Config == nil { |
|||
return errors.New(`Must supply a "SessionID", a "RealmID", a "UserID" and a "Config"`) |
|||
} |
|||
return nil |
|||
} |
|||
|
|||
// Check that the client has the correct fields.
|
|||
func (c *ClientConfig) Check() error { |
|||
if c.UserID == "" || c.HomeserverURL == "" || c.AccessToken == "" { |
|||
return errors.New(`Must supply a "UserID", a "HomeserverURL", and an "AccessToken"`) |
|||
} |
|||
if _, err := url.Parse(c.HomeserverURL); err != nil { |
|||
return err |
|||
} |
|||
return nil |
|||
} |
Write
Preview
Loading…
Cancel
Save
Reference in new issue