minio/vendor/gopkg.in/olivere/elastic.v3/plugins.go
Harshavardhana f248089523 api: Implement bucket notification. (#2271)
* Implement basic S3 notifications through queues

Supports multiple queues and three basic queue types:

1. NilQueue -- messages don't get sent anywhere
2. LogQueue -- messages get logged
3. AmqpQueue -- messages are sent to an AMQP queue

* api: Implement bucket notification.

Supports two different queue types

- AMQP
- ElasticSearch.

* Add support for redis
2016-07-23 22:51:12 -07:00

39 lines
891 B
Go

// 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
// HasPlugin indicates whether the cluster has the named plugin.
func (c *Client) HasPlugin(name string) (bool, error) {
plugins, err := c.Plugins()
if err != nil {
return false, nil
}
for _, plugin := range plugins {
if plugin == name {
return true, nil
}
}
return false, nil
}
// Plugins returns the list of all registered plugins.
func (c *Client) Plugins() ([]string, error) {
stats, err := c.ClusterStats().Do()
if err != nil {
return nil, err
}
if stats == nil {
return nil, err
}
if stats.Nodes == nil {
return nil, err
}
var plugins []string
for _, plugin := range stats.Nodes.Plugins {
plugins = append(plugins, plugin.Name)
}
return plugins, nil
}