123456789101112131415161718192021222324252627282930313233343536373839404142434445464748495051525354555657585960616263646566676869707172737475767778798081828384858687888990919293949596979899100101102103104105106107108109110111112113114115116117118119120121122123124125126127128129130131132133134135136137138139140141142 |
- package storageos
- import (
- "encoding/json"
- "errors"
- "net/http"
- "net/url"
- "github.com/storageos/go-api/types"
- )
- var (
- // RuleAPIPrefix is a partial path to the HTTP endpoint.
- RuleAPIPrefix = "rules"
- // ErrNoSuchRule is the error returned when the rule does not exist.
- ErrNoSuchRule = errors.New("no such rule")
- // ErrRuleInUse is the error returned when the rule requested to be removed is still in use.
- ErrRuleInUse = errors.New("rule in use and cannot be removed")
- )
- // RuleList returns the list of available rules.
- func (c *Client) RuleList(opts types.ListOptions) ([]*types.Rule, error) {
- listOpts := doOptions{
- fieldSelector: opts.FieldSelector,
- labelSelector: opts.LabelSelector,
- namespace: opts.Namespace,
- context: opts.Context,
- }
- if opts.LabelSelector != "" {
- query := url.Values{}
- query.Add("labelSelector", opts.LabelSelector)
- listOpts.values = query
- }
- resp, err := c.do("GET", RuleAPIPrefix, listOpts)
- if err != nil {
- return nil, err
- }
- defer resp.Body.Close()
- var rules []*types.Rule
- if err := json.NewDecoder(resp.Body).Decode(&rules); err != nil {
- return nil, err
- }
- return rules, nil
- }
- // Rule returns a rule by its reference.
- func (c *Client) Rule(namespace string, ref string) (*types.Rule, error) {
- path, err := namespacedRefPath(namespace, RuleAPIPrefix, ref)
- if err != nil {
- return nil, err
- }
- resp, err := c.do("GET", path, doOptions{})
- if err != nil {
- if e, ok := err.(*Error); ok && e.Status == http.StatusNotFound {
- return nil, ErrNoSuchRule
- }
- return nil, err
- }
- defer resp.Body.Close()
- var rule types.Rule
- if err := json.NewDecoder(resp.Body).Decode(&rule); err != nil {
- return nil, err
- }
- return &rule, nil
- }
- // RuleCreate creates a rule on the server and returns the new object.
- func (c *Client) RuleCreate(opts types.RuleCreateOptions) (*types.Rule, error) {
- path, err := namespacedPath(opts.Namespace, RuleAPIPrefix)
- if err != nil {
- return nil, err
- }
- resp, err := c.do("POST", path, doOptions{
- data: opts,
- // namespace: opts.Namespace,
- context: opts.Context,
- })
- if err != nil {
- return nil, err
- }
- var rule types.Rule
- if err := json.NewDecoder(resp.Body).Decode(&rule); err != nil {
- return nil, err
- }
- return &rule, nil
- }
- // RuleUpdate updates a rule on the server.
- func (c *Client) RuleUpdate(opts types.RuleUpdateOptions) (*types.Rule, error) {
- ref := opts.Name
- if IsUUID(opts.ID) {
- ref = opts.ID
- }
- path, err := namespacedRefPath(opts.Namespace, RuleAPIPrefix, ref)
- if err != nil {
- return nil, err
- }
- resp, err := c.do("PUT", path, doOptions{
- data: opts,
- context: opts.Context,
- })
- if err != nil {
- return nil, err
- }
- defer resp.Body.Close()
- var rule types.Rule
- if err := json.NewDecoder(resp.Body).Decode(&rule); err != nil {
- return nil, err
- }
- return &rule, nil
- }
- // RuleDelete removes a rule by its reference.
- func (c *Client) RuleDelete(opts types.DeleteOptions) error {
- deleteOpts := doOptions{
- namespace: opts.Namespace,
- force: opts.Force,
- context: opts.Context,
- }
- resp, err := c.do("DELETE", RuleAPIPrefix+"/"+opts.Name, deleteOpts)
- if err != nil {
- if e, ok := err.(*Error); ok {
- if e.Status == http.StatusNotFound {
- return ErrNoSuchRule
- }
- if e.Status == http.StatusConflict {
- return ErrRuleInUse
- }
- }
- return nil
- }
- defer resp.Body.Close()
- return nil
- }
|