2015-04-20 19:04:13 +00:00
|
|
|
package api
|
|
|
|
|
2020-12-12 00:50:19 +00:00
|
|
|
import (
|
|
|
|
"context"
|
|
|
|
"time"
|
|
|
|
)
|
2018-07-24 22:49:55 +00:00
|
|
|
|
2015-04-20 19:04:13 +00:00
|
|
|
func (c *Sys) Leader() (*LeaderResponse, error) {
|
|
|
|
r := c.c.NewRequest("GET", "/v1/sys/leader")
|
2018-07-24 22:49:55 +00:00
|
|
|
|
|
|
|
ctx, cancelFunc := context.WithCancel(context.Background())
|
|
|
|
defer cancelFunc()
|
|
|
|
resp, err := c.c.RawRequestWithContext(ctx, r)
|
2015-04-20 19:04:13 +00:00
|
|
|
if err != nil {
|
|
|
|
return nil, err
|
|
|
|
}
|
|
|
|
defer resp.Body.Close()
|
|
|
|
|
|
|
|
var result LeaderResponse
|
|
|
|
err = resp.DecodeJSON(&result)
|
|
|
|
return &result, err
|
|
|
|
}
|
|
|
|
|
|
|
|
type LeaderResponse struct {
|
2020-12-12 00:50:19 +00:00
|
|
|
HAEnabled bool `json:"ha_enabled"`
|
|
|
|
IsSelf bool `json:"is_self"`
|
|
|
|
ActiveTime time.Time `json:"active_time"`
|
|
|
|
LeaderAddress string `json:"leader_address"`
|
|
|
|
LeaderClusterAddress string `json:"leader_cluster_address"`
|
|
|
|
PerfStandby bool `json:"performance_standby"`
|
|
|
|
PerfStandbyLastRemoteWAL uint64 `json:"performance_standby_last_remote_wal"`
|
|
|
|
LastWAL uint64 `json:"last_wal"`
|
|
|
|
RaftCommittedIndex uint64 `json:"raft_committed_index,omitempty"`
|
|
|
|
RaftAppliedIndex uint64 `json:"raft_applied_index,omitempty"`
|
2015-04-20 19:04:13 +00:00
|
|
|
}
|