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.
109 lines
3.2 KiB
109 lines
3.2 KiB
/*
|
|
Copyright 2016 The Kubernetes Authors All rights reserved.
|
|
|
|
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 chartutil
|
|
|
|
import (
|
|
"fmt"
|
|
"io/ioutil"
|
|
"os"
|
|
"path/filepath"
|
|
|
|
"k8s.io/helm/pkg/proto/hapi/chart"
|
|
)
|
|
|
|
const (
|
|
// ChartfileName is the default Chart file name.
|
|
ChartfileName = "Chart.yaml"
|
|
// ValuesfileName is the default values file name.
|
|
ValuesfileName = "values.yaml"
|
|
// TemplatesDir is the relative directory name for templates.
|
|
TemplatesDir = "templates"
|
|
// ChartsDir is the relative directory name for charts dependencies.
|
|
ChartsDir = "charts"
|
|
// IgnorefileName is the name of the Helm ignore file.
|
|
IgnorefileName = ".helmignore"
|
|
)
|
|
|
|
const defaultValues = `# Default values for %s.
|
|
# This is a YAML-formatted file.
|
|
# Declare name/value pairs to be passed into your templates.
|
|
# name: value
|
|
`
|
|
|
|
const defaultIgnore = `# Patterns to ignore when building packages.
|
|
# This supports shell glob matching, relative path matching, and
|
|
# negation (prefixed with !). Only one pattern per line.
|
|
.DS_Store
|
|
.git
|
|
`
|
|
|
|
// Create creates a new chart in a directory.
|
|
//
|
|
// Inside of dir, this will create a directory based on the name of
|
|
// chartfile.Name. It will then write the Chart.yaml into this directory and
|
|
// create the (empty) appropriate directories.
|
|
//
|
|
// The returned string will point to the newly created directory. It will be
|
|
// an absolute path, even if the provided base directory was relative.
|
|
//
|
|
// If dir does not exist, this will return an error.
|
|
// If Chart.yaml or any directories cannot be created, this will return an
|
|
// error. In such a case, this will attempt to clean up by removing the
|
|
// new chart directory.
|
|
func Create(chartfile *chart.Metadata, dir string) (string, error) {
|
|
path, err := filepath.Abs(dir)
|
|
if err != nil {
|
|
return path, err
|
|
}
|
|
|
|
if fi, err := os.Stat(path); err != nil {
|
|
return path, err
|
|
} else if !fi.IsDir() {
|
|
return path, fmt.Errorf("no such directory %s", path)
|
|
}
|
|
|
|
n := chartfile.Name
|
|
cdir := filepath.Join(path, n)
|
|
if fi, err := os.Stat(cdir); err == nil && !fi.IsDir() {
|
|
return cdir, fmt.Errorf("file %s already exists and is not a directory", cdir)
|
|
}
|
|
if err := os.MkdirAll(cdir, 0755); err != nil {
|
|
return cdir, err
|
|
}
|
|
|
|
if err := SaveChartfile(filepath.Join(cdir, ChartfileName), chartfile); err != nil {
|
|
return cdir, err
|
|
}
|
|
|
|
val := []byte(fmt.Sprintf(defaultValues, chartfile.Name))
|
|
if err := ioutil.WriteFile(filepath.Join(cdir, ValuesfileName), val, 0644); err != nil {
|
|
return cdir, err
|
|
}
|
|
|
|
val = []byte(defaultIgnore)
|
|
if err := ioutil.WriteFile(filepath.Join(cdir, IgnorefileName), val, 0644); err != nil {
|
|
return cdir, err
|
|
}
|
|
|
|
for _, d := range []string{TemplatesDir, ChartsDir} {
|
|
if err := os.MkdirAll(filepath.Join(cdir, d), 0755); err != nil {
|
|
return cdir, err
|
|
}
|
|
}
|
|
return cdir, nil
|
|
}
|