post-processor/vagrant-cloud: validate vagrant cloud auth token doing an auth request
This commit is contained in:
parent
95d107a89c
commit
415b886f5b
|
@ -36,7 +36,7 @@ func (v VagrantCloudErrors) FormatErrors() string {
|
||||||
return strings.Join(errs, ". ")
|
return strings.Join(errs, ". ")
|
||||||
}
|
}
|
||||||
|
|
||||||
func (v VagrantCloudClient) New(baseUrl string, token string) *VagrantCloudClient {
|
func (v VagrantCloudClient) New(baseUrl string, token string) (*VagrantCloudClient, error) {
|
||||||
c := &VagrantCloudClient{
|
c := &VagrantCloudClient{
|
||||||
client: &http.Client{
|
client: &http.Client{
|
||||||
Transport: &http.Transport{
|
Transport: &http.Transport{
|
||||||
|
@ -46,7 +46,8 @@ func (v VagrantCloudClient) New(baseUrl string, token string) *VagrantCloudClien
|
||||||
BaseURL: baseUrl,
|
BaseURL: baseUrl,
|
||||||
AccessToken: token,
|
AccessToken: token,
|
||||||
}
|
}
|
||||||
return c
|
|
||||||
|
return c, c.ValidateAuthentication()
|
||||||
}
|
}
|
||||||
|
|
||||||
func decodeBody(resp *http.Response, out interface{}) error {
|
func decodeBody(resp *http.Response, out interface{}) error {
|
||||||
|
@ -65,7 +66,19 @@ func encodeBody(obj interface{}) (io.Reader, error) {
|
||||||
return buf, nil
|
return buf, nil
|
||||||
}
|
}
|
||||||
|
|
||||||
func (v VagrantCloudClient) Get(path string) (*http.Response, error) {
|
func (v *VagrantCloudClient) ValidateAuthentication() error {
|
||||||
|
resp, err := v.Get("authenticate")
|
||||||
|
if err != nil {
|
||||||
|
return err
|
||||||
|
}
|
||||||
|
defer resp.Body.Close()
|
||||||
|
if resp.StatusCode != 200 {
|
||||||
|
return fmt.Errorf("Invalid credentials: %s", resp.Status)
|
||||||
|
}
|
||||||
|
return nil
|
||||||
|
}
|
||||||
|
|
||||||
|
func (v *VagrantCloudClient) Get(path string) (*http.Response, error) {
|
||||||
params := url.Values{}
|
params := url.Values{}
|
||||||
params.Set("access_token", v.AccessToken)
|
params.Set("access_token", v.AccessToken)
|
||||||
reqUrl := fmt.Sprintf("%s/%s?%s", v.BaseURL, path, params.Encode())
|
reqUrl := fmt.Sprintf("%s/%s?%s", v.BaseURL, path, params.Encode())
|
||||||
|
@ -83,7 +96,7 @@ func (v VagrantCloudClient) Get(path string) (*http.Response, error) {
|
||||||
return resp, err
|
return resp, err
|
||||||
}
|
}
|
||||||
|
|
||||||
func (v VagrantCloudClient) Delete(path string) (*http.Response, error) {
|
func (v *VagrantCloudClient) Delete(path string) (*http.Response, error) {
|
||||||
params := url.Values{}
|
params := url.Values{}
|
||||||
params.Set("access_token", v.AccessToken)
|
params.Set("access_token", v.AccessToken)
|
||||||
reqUrl := fmt.Sprintf("%s/%s?%s", v.BaseURL, path, params.Encode())
|
reqUrl := fmt.Sprintf("%s/%s?%s", v.BaseURL, path, params.Encode())
|
||||||
|
@ -101,7 +114,7 @@ func (v VagrantCloudClient) Delete(path string) (*http.Response, error) {
|
||||||
return resp, err
|
return resp, err
|
||||||
}
|
}
|
||||||
|
|
||||||
func (v VagrantCloudClient) Upload(path string, url string) (*http.Response, error) {
|
func (v *VagrantCloudClient) Upload(path string, url string) (*http.Response, error) {
|
||||||
file, err := os.Open(path)
|
file, err := os.Open(path)
|
||||||
|
|
||||||
if err != nil {
|
if err != nil {
|
||||||
|
@ -132,7 +145,7 @@ func (v VagrantCloudClient) Upload(path string, url string) (*http.Response, err
|
||||||
return resp, err
|
return resp, err
|
||||||
}
|
}
|
||||||
|
|
||||||
func (v VagrantCloudClient) Post(path string, body interface{}) (*http.Response, error) {
|
func (v *VagrantCloudClient) Post(path string, body interface{}) (*http.Response, error) {
|
||||||
params := url.Values{}
|
params := url.Values{}
|
||||||
params.Set("access_token", v.AccessToken)
|
params.Set("access_token", v.AccessToken)
|
||||||
reqUrl := fmt.Sprintf("%s/%s?%s", v.BaseURL, path, params.Encode())
|
reqUrl := fmt.Sprintf("%s/%s?%s", v.BaseURL, path, params.Encode())
|
||||||
|
@ -157,7 +170,7 @@ func (v VagrantCloudClient) Post(path string, body interface{}) (*http.Response,
|
||||||
return resp, err
|
return resp, err
|
||||||
}
|
}
|
||||||
|
|
||||||
func (v VagrantCloudClient) Put(path string) (*http.Response, error) {
|
func (v *VagrantCloudClient) Put(path string) (*http.Response, error) {
|
||||||
params := url.Values{}
|
params := url.Values{}
|
||||||
params.Set("access_token", v.AccessToken)
|
params.Set("access_token", v.AccessToken)
|
||||||
reqUrl := fmt.Sprintf("%s/%s?%s", v.BaseURL, path, params.Encode())
|
reqUrl := fmt.Sprintf("%s/%s?%s", v.BaseURL, path, params.Encode())
|
||||||
|
|
|
@ -94,6 +94,13 @@ func (p *PostProcessor) Configure(raws ...interface{}) error {
|
||||||
}
|
}
|
||||||
}
|
}
|
||||||
|
|
||||||
|
// create the HTTP client
|
||||||
|
p.client, err = VagrantCloudClient{}.New(p.config.VagrantCloudUrl, p.config.AccessToken)
|
||||||
|
if err != nil {
|
||||||
|
errs = packer.MultiErrorAppend(
|
||||||
|
errs, fmt.Errorf("Failed to verify authentication token: %v", err))
|
||||||
|
}
|
||||||
|
|
||||||
if len(errs.Errors) > 0 {
|
if len(errs.Errors) > 0 {
|
||||||
return errs
|
return errs
|
||||||
}
|
}
|
||||||
|
@ -118,9 +125,6 @@ func (p *PostProcessor) PostProcess(ui packer.Ui, artifact packer.Artifact) (pac
|
||||||
ui.Message("Warning: Using Vagrant Cloud token found in ATLAS_TOKEN. Please make sure it is correct, or set VAGRANT_CLOUD_TOKEN")
|
ui.Message("Warning: Using Vagrant Cloud token found in ATLAS_TOKEN. Please make sure it is correct, or set VAGRANT_CLOUD_TOKEN")
|
||||||
}
|
}
|
||||||
|
|
||||||
// create the HTTP client
|
|
||||||
p.client = VagrantCloudClient{}.New(p.config.VagrantCloudUrl, p.config.AccessToken)
|
|
||||||
|
|
||||||
// The name of the provider for vagrant cloud, and vagrant
|
// The name of the provider for vagrant cloud, and vagrant
|
||||||
providerName := providerFromBuilderName(artifact.Id())
|
providerName := providerFromBuilderName(artifact.Id())
|
||||||
|
|
||||||
|
|
Loading…
Reference in New Issue