mirror of https://github.com/helm/helm
You can not select more than 25 topics
Topics must start with a letter or number, can include dashes ('-') and can be up to 35 characters long.
113 lines
3.0 KiB
113 lines
3.0 KiB
/*
|
|
Copyright The Helm Authors.
|
|
|
|
Licensed under the Apache License, Version 2.0 (the "License");
|
|
you may not use this file except in compliance with the License.
|
|
You may obtain a copy of the License at
|
|
|
|
http://www.apache.org/licenses/LICENSE-2.0
|
|
|
|
Unless required by applicable law or agreed to in writing, software
|
|
distributed under the License is distributed on an "AS IS" BASIS,
|
|
WITHOUT WARRANTIES OR CONDITIONS OF ANY KIND, either express or implied.
|
|
See the License for the specific language governing permissions and
|
|
limitations under the License.
|
|
*/
|
|
|
|
package action
|
|
|
|
import (
|
|
"io"
|
|
"strings"
|
|
|
|
"helm.sh/helm/v3/pkg/cli"
|
|
"helm.sh/helm/v3/pkg/pusher"
|
|
"helm.sh/helm/v3/pkg/registry"
|
|
"helm.sh/helm/v3/pkg/uploader"
|
|
)
|
|
|
|
// Push is the action for uploading a chart.
|
|
//
|
|
// It provides the implementation of 'helm push'.
|
|
type Push struct {
|
|
Settings *cli.EnvSettings
|
|
cfg *Configuration
|
|
certFile string
|
|
keyFile string
|
|
caFile string
|
|
insecureSkipTLSverify bool
|
|
plainHTTP bool
|
|
out io.Writer
|
|
}
|
|
|
|
// PushOpt is a type of function that sets options for a push action.
|
|
type PushOpt func(*Push)
|
|
|
|
// WithPushConfig sets the cfg field on the push configuration object.
|
|
func WithPushConfig(cfg *Configuration) PushOpt {
|
|
return func(p *Push) {
|
|
p.cfg = cfg
|
|
}
|
|
}
|
|
|
|
// WithTLSClientConfig sets the certFile, keyFile, and caFile fields on the push configuration object.
|
|
func WithTLSClientConfig(certFile, keyFile, caFile string) PushOpt {
|
|
return func(p *Push) {
|
|
p.certFile = certFile
|
|
p.keyFile = keyFile
|
|
p.caFile = caFile
|
|
}
|
|
}
|
|
|
|
// WithInsecureSkipTLSVerify determines if a TLS Certificate will be checked
|
|
func WithInsecureSkipTLSVerify(insecureSkipTLSVerify bool) PushOpt {
|
|
return func(p *Push) {
|
|
p.insecureSkipTLSverify = insecureSkipTLSVerify
|
|
}
|
|
}
|
|
|
|
// WithPlainHTTP configures the use of plain HTTP connections.
|
|
func WithPlainHTTP(plainHTTP bool) PushOpt {
|
|
return func(p *Push) {
|
|
p.plainHTTP = plainHTTP
|
|
}
|
|
}
|
|
|
|
// WithPushOptWriter sets the registryOut field on the push configuration object.
|
|
func WithPushOptWriter(out io.Writer) PushOpt {
|
|
return func(p *Push) {
|
|
p.out = out
|
|
}
|
|
}
|
|
|
|
// NewPushWithOpts creates a new push, with configuration options.
|
|
func NewPushWithOpts(opts ...PushOpt) *Push {
|
|
p := &Push{}
|
|
for _, fn := range opts {
|
|
fn(p)
|
|
}
|
|
return p
|
|
}
|
|
|
|
// Run executes 'helm push' against the given chart archive.
|
|
func (p *Push) Run(chartRef string, remote string) (string, error) {
|
|
var out strings.Builder
|
|
|
|
c := uploader.ChartUploader{
|
|
Out: &out,
|
|
Pushers: pusher.All(p.Settings),
|
|
Options: []pusher.Option{
|
|
pusher.WithTLSClientConfig(p.certFile, p.keyFile, p.caFile),
|
|
pusher.WithInsecureSkipTLSVerify(p.insecureSkipTLSverify),
|
|
pusher.WithPlainHTTP(p.plainHTTP),
|
|
},
|
|
}
|
|
|
|
if registry.IsOCI(remote) {
|
|
// Don't use the default registry client if tls options are set.
|
|
c.Options = append(c.Options, pusher.WithRegistryClient(p.cfg.RegistryClient))
|
|
}
|
|
|
|
return out.String(), c.UploadTo(chartRef, remote)
|
|
}
|