Merge pull request #302 from mitchellh/do-encode-params

builder/digitalocean: better handling of url params in api requests
This commit is contained in:
Mitchell Hashimoto 2013-08-16 11:01:40 -07:00
commit 9b6e4ac92c
1 changed files with 25 additions and 17 deletions

View File

@ -53,10 +53,9 @@ func (d DigitalOceanClient) New(client string, key string) *DigitalOceanClient {
// Creates an SSH Key and returns it's id // Creates an SSH Key and returns it's id
func (d DigitalOceanClient) CreateKey(name string, pub string) (uint, error) { func (d DigitalOceanClient) CreateKey(name string, pub string) (uint, error) {
// Escape the public key params := url.Values{}
pub = url.QueryEscape(pub) params.Set("name", name)
params.Set("ssh_pub_key", pub)
params := fmt.Sprintf("name=%v&ssh_pub_key=%v", name, pub)
body, err := NewRequest(d, "ssh_keys/new", params) body, err := NewRequest(d, "ssh_keys/new", params)
if err != nil { if err != nil {
@ -72,15 +71,18 @@ func (d DigitalOceanClient) CreateKey(name string, pub string) (uint, error) {
// Destroys an SSH key // Destroys an SSH key
func (d DigitalOceanClient) DestroyKey(id uint) error { func (d DigitalOceanClient) DestroyKey(id uint) error {
path := fmt.Sprintf("ssh_keys/%v/destroy", id) path := fmt.Sprintf("ssh_keys/%v/destroy", id)
_, err := NewRequest(d, path, "") _, err := NewRequest(d, path, url.Values{})
return err return err
} }
// Creates a droplet and returns it's id // Creates a droplet and returns it's id
func (d DigitalOceanClient) CreateDroplet(name string, size uint, image uint, region uint, keyId uint) (uint, error) { func (d DigitalOceanClient) CreateDroplet(name string, size uint, image uint, region uint, keyId uint) (uint, error) {
params := fmt.Sprintf( params := url.Values{}
"name=%v&image_id=%v&size_id=%v&region_id=%v&ssh_key_ids=%v", params.Set("name", name)
name, image, size, region, keyId) params.Set("size_id", fmt.Sprintf("%v", size))
params.Set("image_id", fmt.Sprintf("%v", image))
params.Set("region_id", fmt.Sprintf("%v", region))
params.Set("ssh_key_ids", fmt.Sprintf("%v", keyId))
body, err := NewRequest(d, "droplets/new", params) body, err := NewRequest(d, "droplets/new", params)
if err != nil { if err != nil {
@ -96,7 +98,7 @@ func (d DigitalOceanClient) CreateDroplet(name string, size uint, image uint, re
// Destroys a droplet // Destroys a droplet
func (d DigitalOceanClient) DestroyDroplet(id uint) error { func (d DigitalOceanClient) DestroyDroplet(id uint) error {
path := fmt.Sprintf("droplets/%v/destroy", id) path := fmt.Sprintf("droplets/%v/destroy", id)
_, err := NewRequest(d, path, "") _, err := NewRequest(d, path, url.Values{})
return err return err
} }
@ -104,7 +106,7 @@ func (d DigitalOceanClient) DestroyDroplet(id uint) error {
func (d DigitalOceanClient) PowerOffDroplet(id uint) error { func (d DigitalOceanClient) PowerOffDroplet(id uint) error {
path := fmt.Sprintf("droplets/%v/power_off", id) path := fmt.Sprintf("droplets/%v/power_off", id)
_, err := NewRequest(d, path, "") _, err := NewRequest(d, path, url.Values{})
return err return err
} }
@ -112,7 +114,9 @@ func (d DigitalOceanClient) PowerOffDroplet(id uint) error {
// Creates a snaphot of a droplet by it's ID // Creates a snaphot of a droplet by it's ID
func (d DigitalOceanClient) CreateSnapshot(id uint, name string) error { func (d DigitalOceanClient) CreateSnapshot(id uint, name string) error {
path := fmt.Sprintf("droplets/%v/snapshot", id) path := fmt.Sprintf("droplets/%v/snapshot", id)
params := fmt.Sprintf("name=%v", name)
params := url.Values{}
params.Set("name", name)
_, err := NewRequest(d, path, params) _, err := NewRequest(d, path, params)
@ -121,7 +125,7 @@ func (d DigitalOceanClient) CreateSnapshot(id uint, name string) error {
// Returns all available images. // Returns all available images.
func (d DigitalOceanClient) Images() ([]Image, error) { func (d DigitalOceanClient) Images() ([]Image, error) {
resp, err := NewRequest(d, "images", "") resp, err := NewRequest(d, "images", url.Values{})
if err != nil { if err != nil {
return nil, err return nil, err
} }
@ -137,7 +141,7 @@ func (d DigitalOceanClient) Images() ([]Image, error) {
// Destroys an image by its ID. // Destroys an image by its ID.
func (d DigitalOceanClient) DestroyImage(id uint) error { func (d DigitalOceanClient) DestroyImage(id uint) error {
path := fmt.Sprintf("images/%d/destroy", id) path := fmt.Sprintf("images/%d/destroy", id)
_, err := NewRequest(d, path, "") _, err := NewRequest(d, path, url.Values{})
return err return err
} }
@ -145,7 +149,7 @@ func (d DigitalOceanClient) DestroyImage(id uint) error {
func (d DigitalOceanClient) DropletStatus(id uint) (string, string, error) { func (d DigitalOceanClient) DropletStatus(id uint) (string, string, error) {
path := fmt.Sprintf("droplets/%v", id) path := fmt.Sprintf("droplets/%v", id)
body, err := NewRequest(d, path, "") body, err := NewRequest(d, path, url.Values{})
if err != nil { if err != nil {
return "", "", err return "", "", err
} }
@ -165,10 +169,14 @@ func (d DigitalOceanClient) DropletStatus(id uint) (string, string, error) {
// Sends an api request and returns a generic map[string]interface of // Sends an api request and returns a generic map[string]interface of
// the response. // the response.
func NewRequest(d DigitalOceanClient, path string, params string) (map[string]interface{}, error) { func NewRequest(d DigitalOceanClient, path string, params url.Values) (map[string]interface{}, error) {
client := d.client client := d.client
url := fmt.Sprintf("%s/%s?%s&client_id=%s&api_key=%s",
DIGITALOCEAN_API_URL, path, params, d.ClientID, d.APIKey) // Add the authentication parameters
params.Set("client_id", d.ClientID)
params.Set("api_key", d.APIKey)
url := fmt.Sprintf("%s/%s?%s", DIGITALOCEAN_API_URL, path, params.Encode())
var decodedResponse map[string]interface{} var decodedResponse map[string]interface{}