Skip to content

Commit

Permalink
Add image/ssh key structs for explicit type on droplet create.
Browse files Browse the repository at this point in the history
  • Loading branch information
phillbaker committed Mar 21, 2015
1 parent 51284f6 commit f1ccbcd
Show file tree
Hide file tree
Showing 4 changed files with 67 additions and 18 deletions.
4 changes: 3 additions & 1 deletion README.md
Original file line number Diff line number Diff line change
Expand Up @@ -49,7 +49,9 @@ createRequest := &godo.DropletCreateRequest{
Name: dropletName,
Region: "nyc3",
Size: "512mb",
Image: "ubuntu-14-04-x64",
Image: DropletCreateImage{
Slug: "ubuntu-14-04-x64",
},
}

newDroplet, _, err := client.Droplets.Create(createRequest)
Expand Down
51 changes: 41 additions & 10 deletions droplets.go
Original file line number Diff line number Diff line change
@@ -1,6 +1,9 @@
package godo

import "fmt"
import (
"encoding/json"
"fmt"
)

const dropletBasePath = "v2/droplets"

Expand Down Expand Up @@ -56,17 +59,45 @@ type dropletsRoot struct {
Links *Links `json:"links"`
}

// DropletCreateImage identifies an image for the create request. It prefers slug over ID.
type DropletCreateImage struct {
ID int
Slug string
}

func (d DropletCreateImage) MarshalJSON() ([]byte, error) {
if d.Slug != "" {
return json.Marshal(d.Slug)
} else {
return json.Marshal(d.ID)
}
}

// DropletCreateSSHKey identifies a SSH Key for the create request. It prefers fingerprint over ID.
type DropletCreateSSHKey struct {
ID int
Fingerprint string
}

func (d DropletCreateSSHKey) MarshalJSON() ([]byte, error) {
if d.Fingerprint != "" {
return json.Marshal(d.Fingerprint)
} else {
return json.Marshal(d.ID)
}
}

// DropletCreateRequest represents a request to create a droplet.
type DropletCreateRequest struct {
Name string `json:"name"`
Region string `json:"region"`
Size string `json:"size"`
Image string `json:"image"`
SSHKeys []interface{} `json:"ssh_keys"`
Backups bool `json:"backups"`
IPv6 bool `json:"ipv6"`
PrivateNetworking bool `json:"private_networking"`
UserData string `json:"user_data"`
Name string `json:"name"`
Region string `json:"region"`
Size string `json:"size"`
Image DropletCreateImage `json:"image"`
SSHKeys []DropletCreateSSHKey `json:"ssh_keys"`
Backups bool `json:"backups"`
IPv6 bool `json:"ipv6"`
PrivateNetworking bool `json:"private_networking"`
UserData string `json:"user_data"`
}

func (d DropletCreateRequest) String() string {
Expand Down
28 changes: 22 additions & 6 deletions droplets_test.go
Original file line number Diff line number Diff line change
Expand Up @@ -126,16 +126,32 @@ func TestDroplets_Create(t *testing.T) {
Name: "name",
Region: "region",
Size: "size",
Image: "1",
Image: DropletCreateImage{
ID: 1,
},
}

mux.HandleFunc("/v2/droplets", func(w http.ResponseWriter, r *http.Request) {
v := new(DropletCreateRequest)
json.NewDecoder(r.Body).Decode(v)
expected := map[string]interface{}{
"name": "name",
"region": "region",
"size": "size",
"image": float64(1),
"ssh_keys": nil,
"backups": false,
"ipv6": false,
"private_networking": false,
"user_data": "",
}

var v map[string]interface{}
err := json.NewDecoder(r.Body).Decode(&v)
if err != nil {
t.Fatal(err)
}

testMethod(t, r, "POST")
if !reflect.DeepEqual(v, createRequest) {
t.Errorf("Request body = %+v, expected %+v", v, createRequest)
if !reflect.DeepEqual(v, expected) {
t.Errorf("Request body = %#v, expected %#v", v, expected)
}

fmt.Fprintf(w, `{"droplet":{"id":1}, "links":{"actions": [{"id": 1, "href": "http://example.com", "rel": "create"}]}}`)
Expand Down
2 changes: 1 addition & 1 deletion godo_test.go
Original file line number Diff line number Diff line change
Expand Up @@ -79,7 +79,7 @@ func TestNewRequest(t *testing.T) {

inURL, outURL := "/foo", defaultBaseURL+"foo"
inBody, outBody := &DropletCreateRequest{Name: "l"},
`{"name":"l","region":"","size":"","image":"",`+
`{"name":"l","region":"","size":"","image":0,`+
`"ssh_keys":null,"backups":false,"ipv6":false,`+
`"private_networking":false,"user_data":""}`+"\n"
req, _ := c.NewRequest("GET", inURL, inBody)
Expand Down

0 comments on commit f1ccbcd

Please sign in to comment.