84c9110a24
Bumps [github.com/hashicorp/terraform-plugin-sdk/v2](https://github.com/hashicorp/terraform-plugin-sdk) from 2.24.1 to 2.26.0. - [Release notes](https://github.com/hashicorp/terraform-plugin-sdk/releases) - [Changelog](https://github.com/hashicorp/terraform-plugin-sdk/blob/main/CHANGELOG.md) - [Commits](https://github.com/hashicorp/terraform-plugin-sdk/compare/v2.24.1...v2.26.0) --- updated-dependencies: - dependency-name: github.com/hashicorp/terraform-plugin-sdk/v2 dependency-type: direct:production update-type: version-update:semver-minor ... Signed-off-by: dependabot[bot] <support@github.com>
151 lines
3.4 KiB
Go
151 lines
3.4 KiB
Go
package releases
|
|
|
|
import (
|
|
"context"
|
|
"fmt"
|
|
"io/ioutil"
|
|
"log"
|
|
"os"
|
|
"path/filepath"
|
|
"time"
|
|
|
|
"github.com/hashicorp/go-version"
|
|
"github.com/hashicorp/hc-install/internal/pubkey"
|
|
rjson "github.com/hashicorp/hc-install/internal/releasesjson"
|
|
isrc "github.com/hashicorp/hc-install/internal/src"
|
|
"github.com/hashicorp/hc-install/internal/validators"
|
|
"github.com/hashicorp/hc-install/product"
|
|
)
|
|
|
|
// ExactVersion installs the given Version of product
|
|
// to OS temp directory, or to InstallDir (if not empty)
|
|
type ExactVersion struct {
|
|
Product product.Product
|
|
Version *version.Version
|
|
InstallDir string
|
|
Timeout time.Duration
|
|
|
|
SkipChecksumVerification bool
|
|
|
|
// ArmoredPublicKey is a public PGP key in ASCII/armor format to use
|
|
// instead of built-in pubkey to verify signature of downloaded checksums
|
|
ArmoredPublicKey string
|
|
|
|
apiBaseURL string
|
|
logger *log.Logger
|
|
pathsToRemove []string
|
|
}
|
|
|
|
func (*ExactVersion) IsSourceImpl() isrc.InstallSrcSigil {
|
|
return isrc.InstallSrcSigil{}
|
|
}
|
|
|
|
func (ev *ExactVersion) SetLogger(logger *log.Logger) {
|
|
ev.logger = logger
|
|
}
|
|
|
|
func (ev *ExactVersion) log() *log.Logger {
|
|
if ev.logger == nil {
|
|
return discardLogger
|
|
}
|
|
return ev.logger
|
|
}
|
|
|
|
func (ev *ExactVersion) Validate() error {
|
|
if !validators.IsProductNameValid(ev.Product.Name) {
|
|
return fmt.Errorf("invalid product name: %q", ev.Product.Name)
|
|
}
|
|
|
|
if !validators.IsBinaryNameValid(ev.Product.BinaryName()) {
|
|
return fmt.Errorf("invalid binary name: %q", ev.Product.BinaryName())
|
|
}
|
|
|
|
if ev.Version == nil {
|
|
return fmt.Errorf("unknown version")
|
|
}
|
|
|
|
return nil
|
|
}
|
|
|
|
func (ev *ExactVersion) Install(ctx context.Context) (string, error) {
|
|
timeout := defaultInstallTimeout
|
|
if ev.Timeout > 0 {
|
|
timeout = ev.Timeout
|
|
}
|
|
ctx, cancelFunc := context.WithTimeout(ctx, timeout)
|
|
defer cancelFunc()
|
|
|
|
if ev.pathsToRemove == nil {
|
|
ev.pathsToRemove = make([]string, 0)
|
|
}
|
|
|
|
dstDir := ev.InstallDir
|
|
if dstDir == "" {
|
|
var err error
|
|
dirName := fmt.Sprintf("%s_*", ev.Product.Name)
|
|
dstDir, err = ioutil.TempDir("", dirName)
|
|
if err != nil {
|
|
return "", err
|
|
}
|
|
ev.pathsToRemove = append(ev.pathsToRemove, dstDir)
|
|
ev.log().Printf("created new temp dir at %s", dstDir)
|
|
}
|
|
ev.log().Printf("will install into dir at %s", dstDir)
|
|
|
|
rels := rjson.NewReleases()
|
|
if ev.apiBaseURL != "" {
|
|
rels.BaseURL = ev.apiBaseURL
|
|
}
|
|
rels.SetLogger(ev.log())
|
|
pv, err := rels.GetProductVersion(ctx, ev.Product.Name, ev.Version)
|
|
if err != nil {
|
|
return "", err
|
|
}
|
|
|
|
d := &rjson.Downloader{
|
|
Logger: ev.log(),
|
|
VerifyChecksum: !ev.SkipChecksumVerification,
|
|
ArmoredPublicKey: pubkey.DefaultPublicKey,
|
|
BaseURL: rels.BaseURL,
|
|
}
|
|
if ev.ArmoredPublicKey != "" {
|
|
d.ArmoredPublicKey = ev.ArmoredPublicKey
|
|
}
|
|
if ev.apiBaseURL != "" {
|
|
d.BaseURL = ev.apiBaseURL
|
|
}
|
|
|
|
zipFilePath, err := d.DownloadAndUnpack(ctx, pv, dstDir)
|
|
if zipFilePath != "" {
|
|
ev.pathsToRemove = append(ev.pathsToRemove, zipFilePath)
|
|
}
|
|
if err != nil {
|
|
return "", err
|
|
}
|
|
|
|
execPath := filepath.Join(dstDir, ev.Product.BinaryName())
|
|
|
|
ev.pathsToRemove = append(ev.pathsToRemove, execPath)
|
|
|
|
ev.log().Printf("changing perms of %s", execPath)
|
|
err = os.Chmod(execPath, 0o700)
|
|
if err != nil {
|
|
return "", err
|
|
}
|
|
|
|
return execPath, nil
|
|
}
|
|
|
|
func (ev *ExactVersion) Remove(ctx context.Context) error {
|
|
if ev.pathsToRemove != nil {
|
|
for _, path := range ev.pathsToRemove {
|
|
err := os.RemoveAll(path)
|
|
if err != nil {
|
|
return err
|
|
}
|
|
}
|
|
}
|
|
|
|
return nil
|
|
}
|