Compare commits

..

No commits in common. "master" and "1.2.2" have entirely different histories.

View File

@ -5,7 +5,6 @@ import (
"bufio" "bufio"
"bytes" "bytes"
"errors" "errors"
"fmt"
"io" "io"
"io/ioutil" "io/ioutil"
"net/http" "net/http"
@ -26,7 +25,7 @@ const (
versionedTerraformFolder = "/.versionedTerraform" versionedTerraformFolder = "/.versionedTerraform"
) )
// getLatestMajorRelease() returns the latest major release from Version //getLatestMajorRelease() returns the latest major release from Version
func (v *Version) getLatestMajorRelease() { func (v *Version) getLatestMajorRelease() {
for _, release := range v.availableVersions { for _, release := range v.availableVersions {
if release.majorVersion == v.Version.majorVersion && if release.majorVersion == v.Version.majorVersion &&
@ -38,7 +37,7 @@ func (v *Version) getLatestMajorRelease() {
} }
} }
// getGreatestRelease() returns less than release //getGreatestRelease() returns less than release
func (v *Version) getOneLessRelease() { func (v *Version) getOneLessRelease() {
var vSlice []Version var vSlice []Version
@ -61,7 +60,7 @@ func (v *Version) getOneLessRelease() {
} }
} }
// getLatestRelease returns the latest release from Version //getLatestRelease returns the latest release from Version
func (v *Version) getLatestRelease() { func (v *Version) getLatestRelease() {
for _, release := range v.availableVersions { for _, release := range v.availableVersions {
if release.majorVersion > v.Version.majorVersion && if release.majorVersion > v.Version.majorVersion &&
@ -82,8 +81,8 @@ func (v *Version) getLatestRelease() {
} }
} }
// InstallTerraformVersion installs the defined terraform Version in the application //InstallTerraformVersion installs the defined terraform Version in the application
// configuration directory //configuration directory
func (v *Version) InstallTerraformVersion() error { func (v *Version) InstallTerraformVersion() error {
homeDir, _ := os.UserHomeDir() homeDir, _ := os.UserHomeDir()
suffix := fileSuffix suffix := fileSuffix
@ -91,59 +90,56 @@ func (v *Version) InstallTerraformVersion() error {
if v.Version.IsLessThan(*minV) { if v.Version.IsLessThan(*minV) {
suffix = alternateSuffix suffix = alternateSuffix
} }
url := hashicorpUrl + resp, err := http.Get(hashicorpUrl +
v.Version.ToString() + v.Version.ToString() +
"/" + terraformPrefix + "/" + terraformPrefix +
v.Version.ToString() + v.Version.ToString() +
suffix suffix)
resp, err := http.Get(url)
if err != nil { if err != nil {
return fmt.Errorf("failed to download Terraform: %v", err) return err
} }
defer resp.Body.Close() defer resp.Body.Close()
body, err := ioutil.ReadAll(resp.Body) body, err := ioutil.ReadAll(resp.Body)
if err != nil { if err != nil {
return fmt.Errorf("failed to read response body: %v", err) return err
} }
zipReader, err := zip.NewReader(bytes.NewReader(body), int64(len(body))) zipReader, err := zip.NewReader(bytes.NewReader(body), int64(len(body)))
if err != nil { if err != nil {
return fmt.Errorf("failed to create zip reader: %v", err) return err
} }
versionedFileName := homeDir + versionedTerraformFolder + "/" + terraformPrefix + v.Version.ToString() versionedFileName := homeDir + versionedTerraformFolder + "/" + terraformPrefix + v.Version.ToString()
versionedFile, err := os.OpenFile(versionedFileName, os.O_WRONLY|os.O_CREATE|os.O_TRUNC, 0755) versionedFile, err := os.OpenFile(versionedFileName, os.O_WRONLY, 0755)
if os.IsNotExist(err) {
versionedFile, err = os.OpenFile(versionedFileName, os.O_RDWR|os.O_CREATE|os.O_TRUNC, 0755)
if err != nil { if err != nil {
return fmt.Errorf("failed to create output file: %v", err) return err
}
}
if err != nil {
return err
} }
defer versionedFile.Close() defer versionedFile.Close()
for _, zipFile := range zipReader.File { for _, zipFile := range zipReader.File {
if zipFile.Name != "terraform" {
continue
}
zr, err := zipFile.Open() zr, err := zipFile.Open()
if err != nil { if err != nil {
return fmt.Errorf("failed to open zip file: %v", err) return err
} }
defer zr.Close() unzippedFileBytes, _ := ioutil.ReadAll(zr)
_, err = io.Copy(versionedFile, zr) _, err = versionedFile.Write(unzippedFileBytes)
if err != nil { if err != nil {
return fmt.Errorf("failed to write terraform binary: %v", err) return err
} }
zr.Close()
break
} }
return nil return nil
} }
// NewVersion creates a new Version using sem versioning for determining the //NewVersion creates a new Version using sem versioning for determining the
// latest release //latest release
func NewVersion(_version string, _vList []string) *Version { func NewVersion(_version string, _vList []string) *Version {
v := new(Version) v := new(Version)
v.Version = *NewSemVersion(_version) v.Version = *NewSemVersion(_version)
@ -206,7 +202,7 @@ func NewVersion(_version string, _vList []string) *Version {
return v return v
} }
// GetVersionList returns a list of available versions from hashicorp's release page //GetVersionList returns a list of available versions from hashicorp's release page
func GetVersionList() ([]string, error) { func GetVersionList() ([]string, error) {
var versionList []string var versionList []string
resp, err := http.Get(hashicorpUrl) resp, err := http.Get(hashicorpUrl)
@ -238,7 +234,7 @@ func GetVersionList() ([]string, error) {
return versionList, nil return versionList, nil
} }
// removeSpacesVersion removes spaces from Version string for parsing //removeSpacesVersion removes spaces from Version string for parsing
func removeSpacesVersion(v string) string { func removeSpacesVersion(v string) string {
splitV := strings.Split(v, " ") splitV := strings.Split(v, " ")
var returnString string var returnString string
@ -249,12 +245,12 @@ func removeSpacesVersion(v string) string {
return strings.TrimSpace(returnString) return strings.TrimSpace(returnString)
} }
// VersionToString returns string of a Version //VersionToString returns string of a Version
func (v *Version) VersionToString() string { func (v *Version) VersionToString() string {
return v.Version.ToString() return v.Version.ToString()
} }
// isVersionGreater returns true if v1 is greater than v2 //isVersionGreater returns true if v1 is greater than v2
func isVersionGreater(v1 Version, v2 Version) bool { func isVersionGreater(v1 Version, v2 Version) bool {
if v1.Version.majorVersion != v2.Version.majorVersion { if v1.Version.majorVersion != v2.Version.majorVersion {
if v1.Version.majorVersion > v2.Version.majorVersion { if v1.Version.majorVersion > v2.Version.majorVersion {