Move value of default clone image into shared constant package (#873)

This commit is contained in:
6543 2022-04-06 15:30:49 +02:00 committed by GitHub
parent c3788d943f
commit 58303dd2a7
No known key found for this signature in database
GPG key ID: 4AEE18F83AFDEB23
5 changed files with 35 additions and 23 deletions

View file

@ -101,7 +101,7 @@ var flags = []cli.Flag{
EnvVars: []string{"WOODPECKER_DEFAULT_CLONE_IMAGE"}, EnvVars: []string{"WOODPECKER_DEFAULT_CLONE_IMAGE"},
Name: "default-clone-image", Name: "default-clone-image",
Usage: "The default docker image to be used when cloning the repo", Usage: "The default docker image to be used when cloning the repo",
Value: "woodpeckerci/plugin-git:latest", Value: constant.DefaultCloneImage,
}, },
&cli.StringFlag{ &cli.StringFlag{
EnvVars: []string{"WOODPECKER_DOCS"}, EnvVars: []string{"WOODPECKER_DOCS"},

View file

@ -10,7 +10,7 @@ import (
"strings" "strings"
"github.com/woodpecker-ci/woodpecker/pipeline/backend/types" "github.com/woodpecker-ci/woodpecker/pipeline/backend/types"
"github.com/woodpecker-ci/woodpecker/server" "github.com/woodpecker-ci/woodpecker/shared/constant"
) )
type local struct { type local struct {
@ -56,13 +56,7 @@ func (e *local) Exec(ctx context.Context, proc *types.Step) error {
} }
} }
// Get default clone image if proc.Image == constant.DefaultCloneImage {
defaultCloneImage := "docker.io/woodpeckerci/plugin-git:latest"
if len(server.Config.Pipeline.DefaultCloneImage) > 0 {
defaultCloneImage = server.Config.Pipeline.DefaultCloneImage
}
if proc.Image == defaultCloneImage {
// Default clone step // Default clone step
Command = append(Command, "CI_WORKSPACE="+e.workingdir+"/"+proc.Environment["CI_REPO"]) Command = append(Command, "CI_WORKSPACE="+e.workingdir+"/"+proc.Environment["CI_REPO"])
Command = append(Command, "plugin-git") Command = append(Command, "plugin-git")
@ -81,7 +75,7 @@ func (e *local) Exec(ctx context.Context, proc *types.Step) error {
e.cmd = exec.CommandContext(ctx, "/bin/env", Command...) e.cmd = exec.CommandContext(ctx, "/bin/env", Command...)
// Prepare working directory // Prepare working directory
if proc.Image == defaultCloneImage { if proc.Image == constant.DefaultCloneImage {
e.cmd.Dir = e.workingdir + "/" + proc.Environment["CI_REPO_OWNER"] e.cmd.Dir = e.workingdir + "/" + proc.Environment["CI_REPO_OWNER"]
} else { } else {
e.cmd.Dir = e.workingdir + "/" + proc.Environment["CI_REPO"] e.cmd.Dir = e.workingdir + "/" + proc.Environment["CI_REPO"]
@ -112,6 +106,6 @@ func (e *local) Tail(context.Context, *types.Step) (io.ReadCloser, error) {
// Destroy the pipeline environment. // Destroy the pipeline environment.
func (e *local) Destroy(context.Context, *types.Config) error { func (e *local) Destroy(context.Context, *types.Config) error {
os.RemoveAll(e.cmd.Dir) _ = os.RemoveAll(e.cmd.Dir)
return nil return nil
} }

View file

@ -7,6 +7,7 @@ import (
backend "github.com/woodpecker-ci/woodpecker/pipeline/backend/types" backend "github.com/woodpecker-ci/woodpecker/pipeline/backend/types"
"github.com/woodpecker-ci/woodpecker/pipeline/frontend" "github.com/woodpecker-ci/woodpecker/pipeline/frontend"
"github.com/woodpecker-ci/woodpecker/pipeline/frontend/yaml" "github.com/woodpecker-ci/woodpecker/pipeline/frontend/yaml"
"github.com/woodpecker-ci/woodpecker/shared/constant"
) )
// TODO(bradrydzewski) compiler should handle user-defined volumes from YAML // TODO(bradrydzewski) compiler should handle user-defined volumes from YAML
@ -15,8 +16,7 @@ import (
const ( const (
windowsPrefix = "windows/" windowsPrefix = "windows/"
defaultCloneImage = "woodpeckerci/plugin-git:latest" defaultCloneName = "clone"
defaultCloneName = "clone"
networkDriverNAT = "nat" networkDriverNAT = "nat"
networkDriverBridge = "bridge" networkDriverBridge = "bridge"
@ -121,7 +121,7 @@ func (c *Compiler) Compile(conf *yaml.Config) *backend.Config {
// add default clone step // add default clone step
if !c.local && len(conf.Clone.Containers) == 0 && !conf.SkipClone { if !c.local && len(conf.Clone.Containers) == 0 && !conf.SkipClone {
cloneImage := defaultCloneImage cloneImage := constant.DefaultCloneImage
if len(c.defaultCloneImage) > 0 { if len(c.defaultCloneImage) > 0 {
cloneImage = c.defaultCloneImage cloneImage = c.defaultCloneImage
} }

View file

@ -0,0 +1,27 @@
// Copyright 2022 Woodpecker 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 constant
var PrivilegedPlugins = []string{
"plugins/docker",
"plugins/gcr",
"plugins/ecr",
"woodpeckerci/plugin-docker",
"woodpeckerci/plugin-docker-buildx",
}
const (
DefaultCloneImage = "docker.io/woodpeckerci/plugin-git:latest"
)

View file

@ -1,9 +0,0 @@
package constant
var PrivilegedPlugins = []string{
"plugins/docker",
"plugins/gcr",
"plugins/ecr",
"woodpeckerci/plugin-docker",
"woodpeckerci/plugin-docker-buildx",
}