mirror of
https://github.com/woodpecker-ci/woodpecker.git
synced 2025-01-11 01:55:27 +00:00
make escalated plugins, volumes, networks configurable
This commit is contained in:
parent
a2440a0d46
commit
30b561636f
4 changed files with 28 additions and 9 deletions
|
@ -64,6 +64,23 @@ var serverCmd = cli.Command{
|
||||||
Usage: "cache duration",
|
Usage: "cache duration",
|
||||||
Value: time.Minute * 15,
|
Value: time.Minute * 15,
|
||||||
},
|
},
|
||||||
|
cli.StringSliceFlag{
|
||||||
|
EnvVar: "DRONE_ESCALATE",
|
||||||
|
Name: "escalate",
|
||||||
|
Value: &cli.StringSlice{
|
||||||
|
"plugins/docker",
|
||||||
|
"plugins/gcr",
|
||||||
|
"plugins/ecr",
|
||||||
|
},
|
||||||
|
},
|
||||||
|
cli.StringSliceFlag{
|
||||||
|
EnvVar: "DRONE_VOLUME",
|
||||||
|
Name: "volume",
|
||||||
|
},
|
||||||
|
cli.StringSliceFlag{
|
||||||
|
EnvVar: "DRONE_NETWORK",
|
||||||
|
Name: "network",
|
||||||
|
},
|
||||||
cli.StringFlag{
|
cli.StringFlag{
|
||||||
EnvVar: "DRONE_AGENT_SECRET,DRONE_SECRET",
|
EnvVar: "DRONE_AGENT_SECRET,DRONE_SECRET",
|
||||||
Name: "agent-secret",
|
Name: "agent-secret",
|
||||||
|
|
|
@ -17,7 +17,7 @@ func NewRemote(endpoint string) model.SenderService {
|
||||||
}
|
}
|
||||||
|
|
||||||
func (p *plugin) SenderAllowed(user *model.User, repo *model.Repo, build *model.Build) (bool, error) {
|
func (p *plugin) SenderAllowed(user *model.User, repo *model.Repo, build *model.Build) (bool, error) {
|
||||||
path := fmt.Sprintf("%s/sender/%s/%s/%s", p.endpoint, repo.Owner, repo.Name, build.Sender)
|
path := fmt.Sprintf("%s/senders/%s/%s/%s/verify", p.endpoint, repo.Owner, repo.Name, build.Sender)
|
||||||
err := internal.Send("POST", path, build, nil)
|
err := internal.Send("POST", path, build, nil)
|
||||||
if err != nil {
|
if err != nil {
|
||||||
return false, err
|
return false, err
|
||||||
|
@ -26,22 +26,22 @@ func (p *plugin) SenderAllowed(user *model.User, repo *model.Repo, build *model.
|
||||||
}
|
}
|
||||||
|
|
||||||
func (p *plugin) SenderCreate(repo *model.Repo, sender *model.Sender) error {
|
func (p *plugin) SenderCreate(repo *model.Repo, sender *model.Sender) error {
|
||||||
path := fmt.Sprintf("%s/sender/%s/%s", p.endpoint, repo.Owner, repo.Name)
|
path := fmt.Sprintf("%s/senders/%s/%s", p.endpoint, repo.Owner, repo.Name)
|
||||||
return internal.Send("POST", path, sender, nil)
|
return internal.Send("POST", path, sender, nil)
|
||||||
}
|
}
|
||||||
|
|
||||||
func (p *plugin) SenderUpdate(repo *model.Repo, sender *model.Sender) error {
|
func (p *plugin) SenderUpdate(repo *model.Repo, sender *model.Sender) error {
|
||||||
path := fmt.Sprintf("%s/sender/%s/%s", p.endpoint, repo.Owner, repo.Name)
|
path := fmt.Sprintf("%s/senders/%s/%s", p.endpoint, repo.Owner, repo.Name)
|
||||||
return internal.Send("PUT", path, sender, nil)
|
return internal.Send("PUT", path, sender, nil)
|
||||||
}
|
}
|
||||||
|
|
||||||
func (p *plugin) SenderDelete(repo *model.Repo, login string) error {
|
func (p *plugin) SenderDelete(repo *model.Repo, login string) error {
|
||||||
path := fmt.Sprintf("%s/sender/%s/%s/%s", p.endpoint, repo.Owner, repo.Name, login)
|
path := fmt.Sprintf("%s/senders/%s/%s/%s", p.endpoint, repo.Owner, repo.Name, login)
|
||||||
return internal.Send("DELETE", path, nil, nil)
|
return internal.Send("DELETE", path, nil, nil)
|
||||||
}
|
}
|
||||||
|
|
||||||
func (p *plugin) SenderList(repo *model.Repo) ([]*model.Sender, error) {
|
func (p *plugin) SenderList(repo *model.Repo) ([]*model.Sender, error) {
|
||||||
path := fmt.Sprintf("%s/sender/%s/%s", p.endpoint, repo.Owner, repo.Name)
|
path := fmt.Sprintf("%s/senders/%s/%s", p.endpoint, repo.Owner, repo.Name)
|
||||||
out := []*model.Sender{}
|
out := []*model.Sender{}
|
||||||
err := internal.Send("GET", path, nil, out)
|
err := internal.Send("GET", path, nil, out)
|
||||||
return out, err
|
return out, err
|
||||||
|
|
|
@ -51,6 +51,9 @@ func Store(cli *cli.Context) gin.HandlerFunc {
|
||||||
server.Config.Server.Pass = cli.String("agent-secret")
|
server.Config.Server.Pass = cli.String("agent-secret")
|
||||||
server.Config.Server.Host = cli.String("server-host")
|
server.Config.Server.Host = cli.String("server-host")
|
||||||
server.Config.Server.Port = cli.String("server-addr")
|
server.Config.Server.Port = cli.String("server-addr")
|
||||||
|
server.Config.Pipeline.Networks = cli.StringSlice("network")
|
||||||
|
server.Config.Pipeline.Volumes = cli.StringSlice("volumes")
|
||||||
|
server.Config.Pipeline.Privileged = cli.StringSlice("escalate")
|
||||||
// server.Config.Server.Open = cli.Bool("open")
|
// server.Config.Server.Open = cli.Bool("open")
|
||||||
// server.Config.Server.Orgs = sliceToMap(cli.StringSlice("orgs"))
|
// server.Config.Server.Orgs = sliceToMap(cli.StringSlice("orgs"))
|
||||||
// server.Config.Server.Admins = sliceToMap(cli.StringSlice("admin"))
|
// server.Config.Server.Admins = sliceToMap(cli.StringSlice("admin"))
|
||||||
|
|
|
@ -456,8 +456,9 @@ func (b *builder) Build() ([]*buildItem, error) {
|
||||||
|
|
||||||
ir := compiler.New(
|
ir := compiler.New(
|
||||||
compiler.WithEnviron(environ),
|
compiler.WithEnviron(environ),
|
||||||
// TODO ability to customize the escalated plugins
|
compiler.WithEscalated(Config.Pipeline.Privileged...),
|
||||||
compiler.WithEscalated("plugins/docker", "plugins/gcr", "plugins/ecr"),
|
compiler.WithVolumes(Config.Pipeline.Volumes...),
|
||||||
|
compiler.WithNetworks(Config.Pipeline.Networks...),
|
||||||
compiler.WithLocal(false),
|
compiler.WithLocal(false),
|
||||||
compiler.WithOption(
|
compiler.WithOption(
|
||||||
compiler.WithNetrc(
|
compiler.WithNetrc(
|
||||||
|
@ -478,8 +479,6 @@ func (b *builder) Build() ([]*buildItem, error) {
|
||||||
),
|
),
|
||||||
compiler.WithEnviron(proc.Environ),
|
compiler.WithEnviron(proc.Environ),
|
||||||
compiler.WithProxy(),
|
compiler.WithProxy(),
|
||||||
// TODO ability to set global volumes for things like certs
|
|
||||||
compiler.WithVolumes(),
|
|
||||||
compiler.WithWorkspaceFromURL("/drone", b.Curr.Link),
|
compiler.WithWorkspaceFromURL("/drone", b.Curr.Link),
|
||||||
compiler.WithMetadata(metadata),
|
compiler.WithMetadata(metadata),
|
||||||
).Compile(parsed)
|
).Compile(parsed)
|
||||||
|
|
Loading…
Reference in a new issue