Add support for non label-schema labels

This commit is contained in:
Ronald van Zantvoort 2018-05-31 17:21:36 +02:00
parent 1e396b3b9c
commit 3edd750381
No known key found for this signature in database
GPG Key ID: D3DE53B7EFF75061
2 changed files with 15 additions and 1 deletions

View File

@ -171,6 +171,11 @@ func main() {
Usage: "docker repository",
EnvVar: "PLUGIN_REPO",
},
cli.StringSliceFlag{
Name: "Labels",
Usage: "labels",
EnvVar: "PLUGIN_LABELS",
},
cli.StringSliceFlag{
Name: "label-schema",
Usage: "label-schema labels",
@ -242,6 +247,7 @@ func run(c *cli.Context) error {
Pull: c.BoolT("pull-image"),
Compress: c.Bool("compress"),
Repo: c.String("repo"),
Labels: c.StringSlice("labels"),
LabelSchema: c.StringSlice("label-schema"),
NoCache: c.Bool("no-cache"),
},

View File

@ -49,7 +49,8 @@ type (
Pull bool // Docker build pull
Compress bool // Docker build compress
Repo string // Docker build repository
LabelSchema []string // Label schema map
LabelSchema []string // label-schema Label map
Labels []string // Label map
NoCache bool // Docker build no-cache
}
@ -214,6 +215,7 @@ func commandBuild(build Build) *exec.Cmd {
}
labelSchema := []string{
"version=1.0",
fmt.Sprintf("build-date=%s", time.Now().Format(time.RFC3339)),
fmt.Sprintf("vcs-ref=%s", build.Name),
fmt.Sprintf("vcs-url=%s", build.Remote),
@ -227,6 +229,12 @@ func commandBuild(build Build) *exec.Cmd {
args = append(args, "--label", fmt.Sprintf("org.label-schema.%s", label))
}
if len(build.Labels) > 0 {
for _, label := range build.Labels {
args = append(args, "--label", label)
}
}
return exec.Command(dockerExe, args...)
}