|
|
@ -17,6 +17,7 @@ package getter
|
|
|
|
|
|
|
|
|
|
|
|
import (
|
|
|
|
import (
|
|
|
|
"bytes"
|
|
|
|
"bytes"
|
|
|
|
|
|
|
|
"fmt"
|
|
|
|
"os"
|
|
|
|
"os"
|
|
|
|
"os/exec"
|
|
|
|
"os/exec"
|
|
|
|
"path/filepath"
|
|
|
|
"path/filepath"
|
|
|
@ -62,6 +63,12 @@ type pluginGetter struct {
|
|
|
|
opts options
|
|
|
|
opts options
|
|
|
|
}
|
|
|
|
}
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
func (p *pluginGetter) setupOptionsEnv(env []string) []string {
|
|
|
|
|
|
|
|
env = append(env, fmt.Sprintf("HELM_PLUGIN_USERNAME=%s", p.opts.username))
|
|
|
|
|
|
|
|
env = append(env, fmt.Sprintf("HELM_PLUGIN_PASSWORD=%s", p.opts.password))
|
|
|
|
|
|
|
|
return env
|
|
|
|
|
|
|
|
}
|
|
|
|
|
|
|
|
|
|
|
|
// Get runs downloader plugin command
|
|
|
|
// Get runs downloader plugin command
|
|
|
|
func (p *pluginGetter) Get(href string, options ...Option) (*bytes.Buffer, error) {
|
|
|
|
func (p *pluginGetter) Get(href string, options ...Option) (*bytes.Buffer, error) {
|
|
|
|
for _, opt := range options {
|
|
|
|
for _, opt := range options {
|
|
|
@ -71,7 +78,7 @@ func (p *pluginGetter) Get(href string, options ...Option) (*bytes.Buffer, error
|
|
|
|
argv := append(commands[1:], p.opts.certFile, p.opts.keyFile, p.opts.caFile, href)
|
|
|
|
argv := append(commands[1:], p.opts.certFile, p.opts.keyFile, p.opts.caFile, href)
|
|
|
|
prog := exec.Command(filepath.Join(p.base, commands[0]), argv...)
|
|
|
|
prog := exec.Command(filepath.Join(p.base, commands[0]), argv...)
|
|
|
|
plugin.SetupPluginEnv(p.settings, p.name, p.base)
|
|
|
|
plugin.SetupPluginEnv(p.settings, p.name, p.base)
|
|
|
|
prog.Env = os.Environ()
|
|
|
|
prog.Env = p.setupOptionsEnv(os.Environ())
|
|
|
|
buf := bytes.NewBuffer(nil)
|
|
|
|
buf := bytes.NewBuffer(nil)
|
|
|
|
prog.Stdout = buf
|
|
|
|
prog.Stdout = buf
|
|
|
|
prog.Stderr = os.Stderr
|
|
|
|
prog.Stderr = os.Stderr
|
|
|
|