|
|
@ -23,6 +23,7 @@ These dependencies are expressed as interfaces so that alternate implementations
|
|
|
|
package environment
|
|
|
|
package environment
|
|
|
|
|
|
|
|
|
|
|
|
import (
|
|
|
|
import (
|
|
|
|
|
|
|
|
"errors"
|
|
|
|
"io"
|
|
|
|
"io"
|
|
|
|
|
|
|
|
|
|
|
|
"k8s.io/helm/pkg/chartutil"
|
|
|
|
"k8s.io/helm/pkg/chartutil"
|
|
|
@ -31,11 +32,9 @@ import (
|
|
|
|
"k8s.io/helm/pkg/proto/hapi/chart"
|
|
|
|
"k8s.io/helm/pkg/proto/hapi/chart"
|
|
|
|
"k8s.io/helm/pkg/storage"
|
|
|
|
"k8s.io/helm/pkg/storage"
|
|
|
|
"k8s.io/helm/pkg/storage/driver"
|
|
|
|
"k8s.io/helm/pkg/storage/driver"
|
|
|
|
|
|
|
|
"k8s.io/kubernetes/pkg/client/unversioned"
|
|
|
|
)
|
|
|
|
)
|
|
|
|
|
|
|
|
|
|
|
|
// UseConfigMaps is a feature flags to toggle use of configmaps storage driver.
|
|
|
|
|
|
|
|
const UseConfigMaps = false
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
// TillerNamespace is the namespace tiller is running in.
|
|
|
|
// TillerNamespace is the namespace tiller is running in.
|
|
|
|
const TillerNamespace = "kube-system"
|
|
|
|
const TillerNamespace = "kube-system"
|
|
|
|
|
|
|
|
|
|
|
@ -135,6 +134,9 @@ type KubeClient interface {
|
|
|
|
// reader must contain a YAML stream (one or more YAML documents separated
|
|
|
|
// reader must contain a YAML stream (one or more YAML documents separated
|
|
|
|
// by "\n---\n").
|
|
|
|
// by "\n---\n").
|
|
|
|
Update(namespace string, originalReader, modifiedReader io.Reader) error
|
|
|
|
Update(namespace string, originalReader, modifiedReader io.Reader) error
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
// APIClient gets a raw API client for Kubernetes.
|
|
|
|
|
|
|
|
APIClient() (unversioned.Interface, error)
|
|
|
|
}
|
|
|
|
}
|
|
|
|
|
|
|
|
|
|
|
|
// PrintingKubeClient implements KubeClient, but simply prints the reader to
|
|
|
|
// PrintingKubeClient implements KubeClient, but simply prints the reader to
|
|
|
@ -143,6 +145,14 @@ type PrintingKubeClient struct {
|
|
|
|
Out io.Writer
|
|
|
|
Out io.Writer
|
|
|
|
}
|
|
|
|
}
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
// APIClient always returns an error.
|
|
|
|
|
|
|
|
//
|
|
|
|
|
|
|
|
// The printing client does not have access to a Kubernetes client at all. So it
|
|
|
|
|
|
|
|
// will always return an error if the client is accessed.
|
|
|
|
|
|
|
|
func (p *PrintingKubeClient) APIClient() (unversioned.Interface, error) {
|
|
|
|
|
|
|
|
return nil, errors.New("no API client found")
|
|
|
|
|
|
|
|
}
|
|
|
|
|
|
|
|
|
|
|
|
// Create prints the values of what would be created with a real KubeClient.
|
|
|
|
// Create prints the values of what would be created with a real KubeClient.
|
|
|
|
func (p *PrintingKubeClient) Create(ns string, r io.Reader) error {
|
|
|
|
func (p *PrintingKubeClient) Create(ns string, r io.Reader) error {
|
|
|
|
_, err := io.Copy(p.Out, r)
|
|
|
|
_, err := io.Copy(p.Out, r)
|
|
|
@ -196,23 +206,9 @@ func New() *Environment {
|
|
|
|
GoTplEngine: e,
|
|
|
|
GoTplEngine: e,
|
|
|
|
}
|
|
|
|
}
|
|
|
|
|
|
|
|
|
|
|
|
kbc := kube.New(nil)
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
var sd *storage.Storage
|
|
|
|
|
|
|
|
if UseConfigMaps {
|
|
|
|
|
|
|
|
c, err := kbc.Client()
|
|
|
|
|
|
|
|
if err != nil {
|
|
|
|
|
|
|
|
// panic because we cant initliaze driver with no client
|
|
|
|
|
|
|
|
panic(err)
|
|
|
|
|
|
|
|
}
|
|
|
|
|
|
|
|
sd = storage.Init(driver.NewConfigMaps(c.ConfigMaps(TillerNamespace)))
|
|
|
|
|
|
|
|
} else {
|
|
|
|
|
|
|
|
sd = storage.Init(driver.NewMemory())
|
|
|
|
|
|
|
|
}
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
return &Environment{
|
|
|
|
return &Environment{
|
|
|
|
EngineYard: ey,
|
|
|
|
EngineYard: ey,
|
|
|
|
Releases: sd, //storage.Init(driver.NewMemory()),
|
|
|
|
Releases: storage.Init(driver.NewMemory()),
|
|
|
|
KubeClient: kbc, //kube.New(nil), //&PrintingKubeClient{Out: os.Stdout},
|
|
|
|
KubeClient: kube.New(nil),
|
|
|
|
}
|
|
|
|
}
|
|
|
|
}
|
|
|
|
}
|
|
|
|