2014-06-16 15:53:37 -04:00
|
|
|
package vagrantcloud
|
|
|
|
|
|
|
|
import (
|
|
|
|
"bytes"
|
|
|
|
"encoding/json"
|
|
|
|
"fmt"
|
|
|
|
"io"
|
|
|
|
"log"
|
|
|
|
"net/http"
|
|
|
|
"net/url"
|
2014-06-24 15:58:45 -04:00
|
|
|
"os"
|
2014-06-16 15:53:37 -04:00
|
|
|
"strings"
|
|
|
|
)
|
|
|
|
|
|
|
|
type VagrantCloudClient struct {
|
|
|
|
// The http client for communicating
|
|
|
|
client *http.Client
|
|
|
|
|
|
|
|
// The base URL of the API
|
|
|
|
BaseURL string
|
|
|
|
|
|
|
|
// Access token
|
|
|
|
AccessToken string
|
|
|
|
}
|
|
|
|
|
2014-06-23 15:48:51 -04:00
|
|
|
type VagrantCloudErrors struct {
|
|
|
|
Errors map[string][]string `json:"errors"`
|
|
|
|
}
|
|
|
|
|
|
|
|
func (v VagrantCloudErrors) FormatErrors() string {
|
|
|
|
errs := make([]string, 0)
|
|
|
|
for e := range v.Errors {
|
|
|
|
msg := fmt.Sprintf("%s %s", e, strings.Join(v.Errors[e], ","))
|
|
|
|
errs = append(errs, msg)
|
|
|
|
}
|
|
|
|
return strings.Join(errs, ". ")
|
|
|
|
}
|
|
|
|
|
2014-06-16 15:53:37 -04:00
|
|
|
func (v VagrantCloudClient) New(baseUrl string, token string) *VagrantCloudClient {
|
|
|
|
c := &VagrantCloudClient{
|
|
|
|
client: &http.Client{
|
|
|
|
Transport: &http.Transport{
|
|
|
|
Proxy: http.ProxyFromEnvironment,
|
|
|
|
},
|
|
|
|
},
|
|
|
|
BaseURL: baseUrl,
|
|
|
|
AccessToken: token,
|
|
|
|
}
|
|
|
|
return c
|
|
|
|
}
|
|
|
|
|
|
|
|
func decodeBody(resp *http.Response, out interface{}) error {
|
|
|
|
defer resp.Body.Close()
|
|
|
|
dec := json.NewDecoder(resp.Body)
|
|
|
|
return dec.Decode(out)
|
|
|
|
}
|
|
|
|
|
|
|
|
// encodeBody is used to encode a request body
|
|
|
|
func encodeBody(obj interface{}) (io.Reader, error) {
|
|
|
|
buf := bytes.NewBuffer(nil)
|
|
|
|
enc := json.NewEncoder(buf)
|
|
|
|
if err := enc.Encode(obj); err != nil {
|
|
|
|
return nil, err
|
|
|
|
}
|
|
|
|
return buf, nil
|
|
|
|
}
|
|
|
|
|
2014-06-20 11:20:27 -04:00
|
|
|
func (v VagrantCloudClient) Get(path string) (*http.Response, error) {
|
|
|
|
params := url.Values{}
|
|
|
|
params.Set("access_token", v.AccessToken)
|
2014-06-23 15:48:51 -04:00
|
|
|
reqUrl := fmt.Sprintf("%s/%s?%s", v.BaseURL, path, params.Encode())
|
2014-06-16 15:53:37 -04:00
|
|
|
|
2014-06-20 11:20:27 -04:00
|
|
|
// Scrub API key for logs
|
|
|
|
scrubbedUrl := strings.Replace(reqUrl, v.AccessToken, "ACCESS_TOKEN", -1)
|
|
|
|
log.Printf("Post-Processor Vagrant Cloud API GET: %s", scrubbedUrl)
|
2014-06-16 15:53:37 -04:00
|
|
|
|
2014-06-20 11:20:27 -04:00
|
|
|
req, err := http.NewRequest("GET", reqUrl, nil)
|
2014-06-24 15:58:45 -04:00
|
|
|
req.Header.Add("Content-Type", "application/json")
|
2014-06-20 11:20:27 -04:00
|
|
|
resp, err := v.client.Do(req)
|
2014-06-16 15:53:37 -04:00
|
|
|
|
2014-12-16 01:11:36 -05:00
|
|
|
log.Printf("Post-Processor Vagrant Cloud API Response: \n\n%+v", resp)
|
2014-06-16 15:53:37 -04:00
|
|
|
|
2014-06-20 11:20:27 -04:00
|
|
|
return resp, err
|
2014-06-16 15:53:37 -04:00
|
|
|
}
|
|
|
|
|
2014-06-20 11:20:27 -04:00
|
|
|
func (v VagrantCloudClient) Delete(path string) (*http.Response, error) {
|
2014-06-16 15:53:37 -04:00
|
|
|
params := url.Values{}
|
|
|
|
params.Set("access_token", v.AccessToken)
|
2014-06-23 15:48:51 -04:00
|
|
|
reqUrl := fmt.Sprintf("%s/%s?%s", v.BaseURL, path, params.Encode())
|
2014-06-16 15:53:37 -04:00
|
|
|
|
|
|
|
// Scrub API key for logs
|
|
|
|
scrubbedUrl := strings.Replace(reqUrl, v.AccessToken, "ACCESS_TOKEN", -1)
|
2014-06-20 11:20:27 -04:00
|
|
|
log.Printf("Post-Processor Vagrant Cloud API DELETE: %s", scrubbedUrl)
|
2014-06-16 15:53:37 -04:00
|
|
|
|
2014-06-20 11:20:27 -04:00
|
|
|
req, err := http.NewRequest("DELETE", reqUrl, nil)
|
2014-06-24 15:58:45 -04:00
|
|
|
req.Header.Add("Content-Type", "application/json")
|
2014-06-16 15:53:37 -04:00
|
|
|
resp, err := v.client.Do(req)
|
|
|
|
|
2014-12-16 01:11:36 -05:00
|
|
|
log.Printf("Post-Processor Vagrant Cloud API Response: \n\n%+v", resp)
|
2014-06-16 15:53:37 -04:00
|
|
|
|
|
|
|
return resp, err
|
|
|
|
}
|
|
|
|
|
2014-06-24 15:58:45 -04:00
|
|
|
func (v VagrantCloudClient) Upload(path string, url string) (*http.Response, error) {
|
|
|
|
file, err := os.Open(path)
|
|
|
|
|
|
|
|
if err != nil {
|
|
|
|
return nil, fmt.Errorf("Error opening file for upload: %s", err)
|
|
|
|
}
|
|
|
|
|
2017-06-12 18:01:19 -04:00
|
|
|
fi, err := file.Stat()
|
|
|
|
|
|
|
|
if err != nil {
|
|
|
|
return nil, fmt.Errorf("Error stating file for upload: %s", err)
|
|
|
|
}
|
|
|
|
|
2014-06-24 15:58:45 -04:00
|
|
|
defer file.Close()
|
|
|
|
|
2017-06-12 14:07:33 -04:00
|
|
|
request, err := http.NewRequest("PUT", url, file)
|
2014-06-24 15:58:45 -04:00
|
|
|
|
|
|
|
if err != nil {
|
|
|
|
return nil, fmt.Errorf("Error preparing upload request: %s", err)
|
|
|
|
}
|
|
|
|
|
|
|
|
log.Printf("Post-Processor Vagrant Cloud API Upload: %s %s", path, url)
|
|
|
|
|
2017-06-12 18:01:19 -04:00
|
|
|
request.ContentLength = fi.Size()
|
2014-06-24 15:58:45 -04:00
|
|
|
resp, err := v.client.Do(request)
|
|
|
|
|
2014-12-16 01:11:36 -05:00
|
|
|
log.Printf("Post-Processor Vagrant Cloud Upload Response: \n\n%+v", resp)
|
2014-06-24 15:58:45 -04:00
|
|
|
|
|
|
|
return resp, err
|
|
|
|
}
|
|
|
|
|
2014-06-20 11:20:27 -04:00
|
|
|
func (v VagrantCloudClient) Post(path string, body interface{}) (*http.Response, error) {
|
|
|
|
params := url.Values{}
|
|
|
|
params.Set("access_token", v.AccessToken)
|
2014-06-23 15:48:51 -04:00
|
|
|
reqUrl := fmt.Sprintf("%s/%s?%s", v.BaseURL, path, params.Encode())
|
|
|
|
|
2014-06-20 11:20:27 -04:00
|
|
|
encBody, err := encodeBody(body)
|
|
|
|
|
|
|
|
if err != nil {
|
|
|
|
return nil, fmt.Errorf("Error encoding body for request: %s", err)
|
|
|
|
}
|
2014-06-16 15:53:37 -04:00
|
|
|
|
|
|
|
// Scrub API key for logs
|
2014-06-20 11:20:27 -04:00
|
|
|
scrubbedUrl := strings.Replace(reqUrl, v.AccessToken, "ACCESS_TOKEN", -1)
|
|
|
|
log.Printf("Post-Processor Vagrant Cloud API POST: %s. \n\n Body: %s", scrubbedUrl, encBody)
|
|
|
|
|
|
|
|
req, err := http.NewRequest("POST", reqUrl, encBody)
|
2014-06-23 15:48:51 -04:00
|
|
|
req.Header.Add("Content-Type", "application/json")
|
2014-06-20 11:20:27 -04:00
|
|
|
|
|
|
|
resp, err := v.client.Do(req)
|
|
|
|
|
2014-12-16 01:11:36 -05:00
|
|
|
log.Printf("Post-Processor Vagrant Cloud API Response: \n\n%+v", resp)
|
2014-06-20 11:20:27 -04:00
|
|
|
|
|
|
|
return resp, err
|
2014-06-16 15:53:37 -04:00
|
|
|
}
|
2014-06-24 15:58:45 -04:00
|
|
|
|
|
|
|
func (v VagrantCloudClient) Put(path string) (*http.Response, error) {
|
|
|
|
params := url.Values{}
|
|
|
|
params.Set("access_token", v.AccessToken)
|
|
|
|
reqUrl := fmt.Sprintf("%s/%s?%s", v.BaseURL, path, params.Encode())
|
|
|
|
|
|
|
|
// Scrub API key for logs
|
|
|
|
scrubbedUrl := strings.Replace(reqUrl, v.AccessToken, "ACCESS_TOKEN", -1)
|
|
|
|
log.Printf("Post-Processor Vagrant Cloud API PUT: %s", scrubbedUrl)
|
|
|
|
|
|
|
|
req, err := http.NewRequest("PUT", reqUrl, nil)
|
|
|
|
req.Header.Add("Content-Type", "application/json")
|
|
|
|
|
|
|
|
resp, err := v.client.Do(req)
|
|
|
|
|
2014-12-16 01:11:36 -05:00
|
|
|
log.Printf("Post-Processor Vagrant Cloud API Response: \n\n%+v", resp)
|
2014-06-24 15:58:45 -04:00
|
|
|
|
|
|
|
return resp, err
|
|
|
|
}
|