Skip to content

Commit

Permalink
Merge 3ee7b17 into 27d2c1f
Browse files Browse the repository at this point in the history
  • Loading branch information
jwilander committed Mar 13, 2017
2 parents 27d2c1f + 3ee7b17 commit d2a0056
Show file tree
Hide file tree
Showing 5 changed files with 77 additions and 6 deletions.
12 changes: 6 additions & 6 deletions api4/api.go
Expand Up @@ -59,13 +59,11 @@ type Routes struct {
OutgoingHooks *mux.Router // 'api/v4/hooks/outgoing'
OutgoingHook *mux.Router // 'api/v4/hooks/outgoing/{hook_id:[A-Za-z0-9]+}'

OAuth *mux.Router // 'api/v4/oauth'

SAML *mux.Router // 'api/v4/saml'

Admin *mux.Router // 'api/v4/admin'

Admin *mux.Router // 'api/v4/admin'
OAuth *mux.Router // 'api/v4/oauth'
SAML *mux.Router // 'api/v4/saml'
Compliance *mux.Router // 'api/v4/compliance'
Cluster *mux.Router // 'api/v4/cluster'

System *mux.Router // 'api/v4/system'

Expand Down Expand Up @@ -137,6 +135,7 @@ func InitApi(full bool) {
BaseRoutes.OAuth = BaseRoutes.ApiRoot.PathPrefix("/oauth").Subrouter()
BaseRoutes.Admin = BaseRoutes.ApiRoot.PathPrefix("/admin").Subrouter()
BaseRoutes.Compliance = BaseRoutes.ApiRoot.PathPrefix("/compliance").Subrouter()
BaseRoutes.Cluster = BaseRoutes.ApiRoot.PathPrefix("/cluster").Subrouter()
BaseRoutes.System = BaseRoutes.ApiRoot.PathPrefix("/system").Subrouter()
BaseRoutes.Preferences = BaseRoutes.User.PathPrefix("/preferences").Subrouter()
BaseRoutes.License = BaseRoutes.ApiRoot.PathPrefix("/license").Subrouter()
Expand All @@ -157,6 +156,7 @@ func InitApi(full bool) {
InitPreference()
InitSaml()
InitCompliance()
InitCluster()

app.Srv.Router.Handle("/api/v4/{anything:.*}", http.HandlerFunc(Handle404))

Expand Down
29 changes: 29 additions & 0 deletions api4/cluster.go
@@ -0,0 +1,29 @@
// Copyright (c) 2017 Mattermost, Inc. All Rights Reserved.
// See License.txt for license information.

package api4

import (
"net/http"

l4g "github.com/alecthomas/log4go"
"github.com/mattermost/platform/app"
"github.com/mattermost/platform/model"
"github.com/mattermost/platform/utils"
)

func InitCluster() {
l4g.Debug(utils.T("api.cluster.init.debug"))

BaseRoutes.Cluster.Handle("/status", ApiSessionRequired(getClusterStatus)).Methods("GET")
}

func getClusterStatus(c *Context, w http.ResponseWriter, r *http.Request) {
if !app.SessionHasPermissionTo(c.Session, model.PERMISSION_MANAGE_SYSTEM) {
c.SetPermissionError(model.PERMISSION_MANAGE_SYSTEM)
return
}

infos := app.GetClusterStatus()
w.Write([]byte(model.ClusterInfosToJson(infos)))
}
22 changes: 22 additions & 0 deletions api4/cluster_test.go
@@ -0,0 +1,22 @@
// Copyright (c) 2017 Mattermost, Inc. All Rights Reserved.
// See License.txt for license information.

package api4

import (
"testing"
)

func TestGetClusterStatus(t *testing.T) {
th := Setup().InitBasic().InitSystemAdmin()

_, resp := th.Client.GetClusterStatus()
CheckForbiddenStatus(t, resp)

infos, resp := th.SystemAdminClient.GetClusterStatus()
CheckNoError(t, resp)

if infos == nil {
t.Fatal("should not be nil")
}
}
4 changes: 4 additions & 0 deletions i18n/en.json
Expand Up @@ -71,6 +71,10 @@
"id": "api.admin.file_read_error",
"translation": "Error reading log file"
},
{
"id": "api.cluster.init.debug",
"translation": "Initializing cluster API routes"
},
{
"id": "api.admin.get_brand_image.not_available.app_error",
"translation": "Custom branding is not configured or supported on this server"
Expand Down
16 changes: 16 additions & 0 deletions model/client4.go
Expand Up @@ -154,6 +154,10 @@ func (c *Client4) GetDatabaseRoute() string {
return fmt.Sprintf("/database")
}

func (c *Client4) GetClusterRoute() string {
return fmt.Sprintf("/cluster")
}

func (c *Client4) GetIncomingWebhooksRoute() string {
return fmt.Sprintf("/hooks/incoming")
}
Expand Down Expand Up @@ -1414,3 +1418,15 @@ func (c *Client4) DownloadComplianceReport(reportId string) ([]byte, *Response)
return data, BuildResponse(rp)
}
}

// Cluster Section

// GetClusterStatus returns the status of all the configured cluster nodes.
func (c *Client4) GetClusterStatus() ([]*ClusterInfo, *Response) {
if r, err := c.DoApiGet(c.GetClusterRoute()+"/status", ""); err != nil {
return nil, &Response{StatusCode: r.StatusCode, Error: err}
} else {
defer closeBody(r)
return ClusterInfosFromJson(r.Body), BuildResponse(r)
}
}

0 comments on commit d2a0056

Please sign in to comment.