123456789101112131415161718192021222324252627282930313233343536373839404142434445464748495051525354555657585960616263646566676869707172737475767778798081828384858687888990919293949596979899100101102103104105106107108109110111112113114115116117118119120121122123124125126127128129130131132133134135136137138139140141142143144145146147148149150151152153154155156157158159160161162163164165166167168169170171172173174175176177178179180181182183184185186187188189190191192 |
- // Copyright 2012-2015 Oliver Eilhard. All rights reserved.
- // Use of this source code is governed by a MIT-license.
- // See http://olivere.mit-license.org/license.txt for details.
- package elastic
- import (
- "encoding/json"
- "fmt"
- "net/url"
- "strings"
- "github.com/olivere/elastic/uritemplates"
- )
- // ClusterStateService returns the state of the cluster.
- // It is documented at http://www.elasticsearch.org/guide/en/elasticsearch/reference/1.4/cluster-state.html.
- type ClusterStateService struct {
- client *Client
- pretty bool
- indices []string
- metrics []string
- local *bool
- masterTimeout string
- flatSettings *bool
- }
- // NewClusterStateService creates a new ClusterStateService.
- func NewClusterStateService(client *Client) *ClusterStateService {
- return &ClusterStateService{
- client: client,
- indices: make([]string, 0),
- metrics: make([]string, 0),
- }
- }
- // Index the name of the index. Use _all or an empty string to perform
- // the operation on all indices.
- func (s *ClusterStateService) Index(index string) *ClusterStateService {
- s.indices = make([]string, 0)
- s.indices = append(s.indices, index)
- return s
- }
- // Indices is a list of index names. Use _all or an empty string to
- // perform the operation on all indices.
- func (s *ClusterStateService) Indices(indices ...string) *ClusterStateService {
- s.indices = make([]string, 0)
- s.indices = append(s.indices, indices...)
- return s
- }
- // Metric limits the information returned to the specified metric.
- // It can be one of: version, master_node, nodes, routing_table, metadata,
- // blocks, or customs.
- func (s *ClusterStateService) Metric(metric string) *ClusterStateService {
- s.metrics = make([]string, 0)
- s.metrics = append(s.metrics, metric)
- return s
- }
- // Metrics limits the information returned to the specified metrics.
- // It can be any of: version, master_node, nodes, routing_table, metadata,
- // blocks, or customs.
- func (s *ClusterStateService) Metrics(metrics ...string) *ClusterStateService {
- s.metrics = make([]string, 0)
- s.metrics = append(s.metrics, metrics...)
- return s
- }
- // Local indicates whether to return local information. If it is true,
- // we do not retrieve the state from master node (default: false).
- func (s *ClusterStateService) Local(local bool) *ClusterStateService {
- s.local = &local
- return s
- }
- // MasterTimeout specifies the timeout for connection to master.
- func (s *ClusterStateService) MasterTimeout(masterTimeout string) *ClusterStateService {
- s.masterTimeout = masterTimeout
- return s
- }
- // FlatSettings indicates whether to return settings in flat format (default: false).
- func (s *ClusterStateService) FlatSettings(flatSettings bool) *ClusterStateService {
- s.flatSettings = &flatSettings
- return s
- }
- // buildURL builds the URL for the operation.
- func (s *ClusterStateService) buildURL() (string, url.Values, error) {
- // Build URL
- metrics := strings.Join(s.metrics, ",")
- if metrics == "" {
- metrics = "_all"
- }
- indices := strings.Join(s.indices, ",")
- if indices == "" {
- indices = "_all"
- }
- path, err := uritemplates.Expand("/_cluster/state/{metrics}/{indices}", map[string]string{
- "metrics": metrics,
- "indices": indices,
- })
- if err != nil {
- return "", url.Values{}, err
- }
- // Add query string parameters
- params := url.Values{}
- if s.masterTimeout != "" {
- params.Set("master_timeout", s.masterTimeout)
- }
- if s.flatSettings != nil {
- params.Set("flat_settings", fmt.Sprintf("%v", *s.flatSettings))
- }
- if s.local != nil {
- params.Set("local", fmt.Sprintf("%v", *s.local))
- }
- return path, params, nil
- }
- // Validate checks if the operation is valid.
- func (s *ClusterStateService) Validate() error {
- return nil
- }
- // Do executes the operation.
- func (s *ClusterStateService) Do() (*ClusterStateResponse, error) {
- // Check pre-conditions
- if err := s.Validate(); err != nil {
- return nil, err
- }
- // Get URL for request
- path, params, err := s.buildURL()
- if err != nil {
- return nil, err
- }
- // Get HTTP response
- res, err := s.client.PerformRequest("GET", path, params, nil)
- if err != nil {
- return nil, err
- }
- // Return operation response
- ret := new(ClusterStateResponse)
- if err := json.Unmarshal(res.Body, ret); err != nil {
- return nil, err
- }
- return ret, nil
- }
- // ClusterStateResponse is the response of ClusterStateService.Do.
- type ClusterStateResponse struct {
- ClusterName string `json:"cluster_name"`
- Version int `json:"version"`
- MasterNode string `json:"master_node"`
- Blocks map[string]interface{} `json:"blocks"`
- Nodes map[string]*ClusterStateNode `json:"nodes"`
- Metadata *ClusterStateMetadata `json:"metadata"`
- RoutingTable map[string]*ClusterStateRoutingTable `json:"routing_table"`
- RoutingNodes *ClusterStateRoutingNode `json:"routing_nodes"`
- Allocations []interface{} `json:"allocations"`
- Customs map[string]interface{} `json:"customs"`
- }
- type ClusterStateMetadata struct {
- Templates map[string]interface{} `json:"templates"`
- Indices map[string]interface{} `json:"indices"`
- Repositories map[string]interface{} `json:"repositories"`
- }
- type ClusterStateNode struct {
- State string `json:"state"`
- Primary bool `json:"primary"`
- Node string `json:"node"`
- RelocatingNode *string `json:"relocating_node"`
- Shard int `json:"shard"`
- Index string `json:"index"`
- }
- type ClusterStateRoutingTable struct {
- Indices map[string]interface{} `json:"indices"`
- }
- type ClusterStateRoutingNode struct {
- Unassigned []interface{} `json:"unassigned"`
- Nodes map[string]interface{} `json:"nodes"`
- }
|