blob: 94d98e34cb1ecafaf83082d9f7a7180e298d5837 [file] [log] [blame]
Jamie Hannaford339394c2014-11-04 16:16:21 +01001package acl
Jamie Hannafordf84f5fc2014-11-04 16:45:28 +01002
3import (
4 "errors"
5 "fmt"
6
Jamie Hannafordf84f5fc2014-11-04 16:45:28 +01007 "github.com/rackspace/gophercloud"
8 "github.com/rackspace/gophercloud/pagination"
Jamie Hannafordf84f5fc2014-11-04 16:45:28 +01009)
10
11// List is the operation responsible for returning a paginated collection of
12// network items that define a load balancer's access list.
13func List(client *gophercloud.ServiceClient, lbID int) pagination.Pager {
14 url := rootURL(client, lbID)
15
16 return pagination.NewPager(client, url, func(r pagination.PageResult) pagination.Page {
17 return AccessListPage{pagination.SinglePageBase(r)}
18 })
19}
20
21// CreateOptsBuilder is the interface responsible for generating the JSON
22// for a Create operation.
23type CreateOptsBuilder interface {
24 ToAccessListCreateMap() (map[string]interface{}, error)
25}
26
27// CreateOpts is a slice of CreateOpt structs, that allow the user to create
28// multiple nodes in a single operation (one node per CreateOpt).
29type CreateOpts []CreateOpt
30
31// CreateOpt represents the options to create a single node.
32type CreateOpt struct {
33 // Required - the IP address or CIDR for item to add to access list.
34 Address string
35
36 // Required - the type of the node. Either ALLOW or DENY.
37 Type Type
38}
39
40// ToAccessListCreateMap converts a slice of options into a map that can be
41// used for the JSON.
42func (opts CreateOpts) ToAccessListCreateMap() (map[string]interface{}, error) {
43 type itemMap map[string]interface{}
44 items := []itemMap{}
45
46 for k, v := range opts {
47 if v.Address == "" {
48 return itemMap{}, fmt.Errorf("Address is a required attribute, none provided for %d CreateOpt element", k)
49 }
50 if v.Type != ALLOW && v.Type != DENY {
51 return itemMap{}, fmt.Errorf("Type must be ALLOW or DENY")
52 }
53
54 item := make(itemMap)
55 item["address"] = v.Address
56 item["type"] = v.Type
57
58 items = append(items, item)
59 }
60
61 return itemMap{"accessList": items}, nil
62}
63
Jamie Hannafordcfe2f282014-11-07 15:11:21 +010064// Create is the operation responsible for adding network items to the access
65// rules for a particular load balancer. If network items already exist, the
66// new item will be appended. A single IP address or subnet range is considered
Jamie Hannaforddfdf0a22014-11-12 11:06:45 +010067// unique and cannot be duplicated.
Jamie Hannafordf84f5fc2014-11-04 16:45:28 +010068func Create(client *gophercloud.ServiceClient, loadBalancerID int, opts CreateOptsBuilder) CreateResult {
69 var res CreateResult
70
71 reqBody, err := opts.ToAccessListCreateMap()
72 if err != nil {
73 res.Err = err
74 return res
75 }
76
Ash Wilson59fb6c42015-02-12 16:21:13 -050077 _, res.Err = client.Request("POST", rootURL(client, loadBalancerID), gophercloud.RequestOpts{
78 JSONBody: &reqBody,
79 OkCodes: []int{202},
Jamie Hannafordf84f5fc2014-11-04 16:45:28 +010080 })
81
82 return res
83}
84
Jamie Hannafordcfe2f282014-11-07 15:11:21 +010085// BulkDelete will delete multiple network items from a load balancer's access
86// list in a single operation.
Jamie Hannafordf84f5fc2014-11-04 16:45:28 +010087func BulkDelete(c *gophercloud.ServiceClient, loadBalancerID int, itemIDs []int) DeleteResult {
88 var res DeleteResult
89
90 if len(itemIDs) > 10 || len(itemIDs) == 0 {
91 res.Err = errors.New("You must provide a minimum of 1 and a maximum of 10 item IDs")
92 return res
93 }
94
95 url := rootURL(c, loadBalancerID)
Jamie Hannaford950561c2014-11-12 11:12:20 +010096 url += gophercloud.IDSliceToQueryString("id", itemIDs)
Jamie Hannafordf84f5fc2014-11-04 16:45:28 +010097
Ash Wilson2199f102015-02-12 16:16:09 -050098 _, res.Err = c.Request("DELETE", url, gophercloud.RequestOpts{
99 OkCodes: []int{202},
Jamie Hannafordf84f5fc2014-11-04 16:45:28 +0100100 })
101
102 return res
103}
Jamie Hannaford43543b22014-11-04 16:47:40 +0100104
Jamie Hannafordcfe2f282014-11-07 15:11:21 +0100105// Delete will remove a single network item from a load balancer's access list.
Jamie Hannaford43543b22014-11-04 16:47:40 +0100106func Delete(c *gophercloud.ServiceClient, lbID, itemID int) DeleteResult {
107 var res DeleteResult
Ash Wilson59fb6c42015-02-12 16:21:13 -0500108 _, res.Err = c.Request("DELETE", resourceURL(c, lbID, itemID), gophercloud.RequestOpts{
109 OkCodes: []int{202},
Jamie Hannaford43543b22014-11-04 16:47:40 +0100110 })
111 return res
112}
Jamie Hannafordef2d9e12014-11-04 16:48:52 +0100113
Jamie Hannafordcfe2f282014-11-07 15:11:21 +0100114// DeleteAll will delete the entire contents of a load balancer's access list,
115// effectively resetting it and allowing all traffic.
Jamie Hannafordef2d9e12014-11-04 16:48:52 +0100116func DeleteAll(c *gophercloud.ServiceClient, lbID int) DeleteResult {
117 var res DeleteResult
Ash Wilson59fb6c42015-02-12 16:21:13 -0500118 _, res.Err = c.Request("DELETE", rootURL(c, lbID), gophercloud.RequestOpts{
119 OkCodes: []int{202},
Jamie Hannafordef2d9e12014-11-04 16:48:52 +0100120 })
121 return res
122}