aboutsummaryrefslogtreecommitdiff
path: root/weed/server/raft_server_handlers.go
diff options
context:
space:
mode:
authorChris Lu <chris.lu@gmail.com>2019-03-06 12:10:45 -0800
committerChris Lu <chris.lu@gmail.com>2019-03-06 12:10:45 -0800
commit4773497d2c2a96990cd68e841675405db26353cb (patch)
tree8f0a676cec0d01468a622afa64a67585d99c2746 /weed/server/raft_server_handlers.go
parente71e0db5b7bb3001caeb8ec1da31028a3a5b9b42 (diff)
downloadseaweedfs-4773497d2c2a96990cd68e841675405db26353cb.tar.xz
seaweedfs-4773497d2c2a96990cd68e841675405db26353cb.zip
add back "/cluster/status"
fix https://github.com/chrislusf/seaweedfs/issues/870
Diffstat (limited to 'weed/server/raft_server_handlers.go')
-rw-r--r--weed/server/raft_server_handlers.go22
1 files changed, 22 insertions, 0 deletions
diff --git a/weed/server/raft_server_handlers.go b/weed/server/raft_server_handlers.go
new file mode 100644
index 000000000..fd38cb977
--- /dev/null
+++ b/weed/server/raft_server_handlers.go
@@ -0,0 +1,22 @@
+package weed_server
+
+import (
+ "net/http"
+)
+
+type ClusterStatusResult struct {
+ IsLeader bool `json:"IsLeader,omitempty"`
+ Leader string `json:"Leader,omitempty"`
+ Peers []string `json:"Peers,omitempty"`
+}
+
+func (s *RaftServer) StatusHandler(w http.ResponseWriter, r *http.Request) {
+ ret := ClusterStatusResult{
+ IsLeader: s.topo.IsLeader(),
+ Peers: s.Peers(),
+ }
+ if leader, e := s.topo.Leader(); e == nil {
+ ret.Leader = leader
+ }
+ writeJsonQuiet(w, r, http.StatusOK, ret)
+}