2017-03-05 07:56:08 +00:00
|
|
|
package compiler
|
|
|
|
|
|
|
|
import (
|
|
|
|
"fmt"
|
|
|
|
"path"
|
2022-10-24 14:31:06 +00:00
|
|
|
"path/filepath"
|
2017-04-10 10:39:50 +00:00
|
|
|
"strings"
|
2017-03-05 07:56:08 +00:00
|
|
|
|
2021-11-23 14:36:52 +00:00
|
|
|
"github.com/rs/zerolog/log"
|
|
|
|
|
2021-11-26 02:34:48 +00:00
|
|
|
backend "github.com/woodpecker-ci/woodpecker/pipeline/backend/types"
|
2021-09-24 11:18:34 +00:00
|
|
|
"github.com/woodpecker-ci/woodpecker/pipeline/frontend/yaml"
|
2022-10-03 17:25:43 +00:00
|
|
|
"github.com/woodpecker-ci/woodpecker/pipeline/frontend/yaml/compiler/settings"
|
2017-03-05 07:56:08 +00:00
|
|
|
)
|
|
|
|
|
2017-07-21 21:52:52 +00:00
|
|
|
func (c *Compiler) createProcess(name string, container *yaml.Container, section string) *backend.Step {
|
2017-03-05 07:56:08 +00:00
|
|
|
var (
|
|
|
|
detached bool
|
|
|
|
workingdir string
|
|
|
|
|
2021-12-01 13:22:06 +00:00
|
|
|
workspace = fmt.Sprintf("%s_default:%s", c.prefix, c.base)
|
|
|
|
privileged = container.Privileged
|
|
|
|
networkMode = container.NetworkMode
|
|
|
|
ipcMode = container.IpcMode
|
2017-03-05 07:56:08 +00:00
|
|
|
// network = container.Network
|
|
|
|
)
|
|
|
|
|
|
|
|
networks := []backend.Conn{
|
2021-10-12 07:25:13 +00:00
|
|
|
{
|
2017-03-05 07:56:08 +00:00
|
|
|
Name: fmt.Sprintf("%s_default", c.prefix),
|
2017-05-16 10:50:06 +00:00
|
|
|
Aliases: []string{container.Name},
|
2017-03-05 07:56:08 +00:00
|
|
|
},
|
|
|
|
}
|
2017-04-10 16:27:34 +00:00
|
|
|
for _, network := range c.networks {
|
|
|
|
networks = append(networks, backend.Conn{
|
|
|
|
Name: network,
|
|
|
|
})
|
|
|
|
}
|
2017-03-05 07:56:08 +00:00
|
|
|
|
2017-03-19 09:07:21 +00:00
|
|
|
var volumes []string
|
|
|
|
if !c.local {
|
|
|
|
volumes = append(volumes, workspace)
|
2017-03-05 07:56:08 +00:00
|
|
|
}
|
2017-03-19 09:07:21 +00:00
|
|
|
volumes = append(volumes, c.volumes...)
|
2017-03-05 07:56:08 +00:00
|
|
|
for _, volume := range container.Volumes.Volumes {
|
|
|
|
volumes = append(volumes, volume.String())
|
|
|
|
}
|
|
|
|
|
|
|
|
// append default environment variables
|
|
|
|
environment := map[string]string{}
|
|
|
|
for k, v := range container.Environment {
|
|
|
|
environment[k] = v
|
|
|
|
}
|
|
|
|
for k, v := range c.env {
|
|
|
|
switch v {
|
|
|
|
case "", "0", "false":
|
|
|
|
continue
|
|
|
|
default:
|
|
|
|
environment[k] = v
|
|
|
|
}
|
|
|
|
}
|
|
|
|
|
|
|
|
environment["CI_WORKSPACE"] = path.Join(c.base, c.path)
|
|
|
|
|
2017-07-21 21:52:52 +00:00
|
|
|
if section == "services" || container.Detached {
|
|
|
|
detached = true
|
2017-03-05 07:56:08 +00:00
|
|
|
}
|
|
|
|
|
2021-11-23 14:36:52 +00:00
|
|
|
if !detached || len(container.Commands) != 0 {
|
2022-10-24 14:31:06 +00:00
|
|
|
workingdir = c.stepWorkdir(container)
|
2017-03-05 07:56:08 +00:00
|
|
|
}
|
|
|
|
|
2021-11-23 14:36:52 +00:00
|
|
|
if !detached {
|
2022-10-27 02:21:07 +00:00
|
|
|
pluginSecrets := secretMap{}
|
|
|
|
for name, secret := range c.secrets {
|
|
|
|
if secret.Available(container) {
|
|
|
|
pluginSecrets[name] = secret
|
|
|
|
}
|
|
|
|
}
|
|
|
|
|
|
|
|
if err := settings.ParamsToEnv(container.Settings, environment, pluginSecrets.toStringMap()); err != nil {
|
2021-11-23 14:36:52 +00:00
|
|
|
log.Error().Err(err).Msg("paramsToEnv")
|
|
|
|
}
|
2017-03-05 07:56:08 +00:00
|
|
|
}
|
|
|
|
|
2017-07-21 21:52:52 +00:00
|
|
|
if matchImage(container.Image, c.escalated...) {
|
|
|
|
privileged = true
|
|
|
|
}
|
|
|
|
|
2017-04-06 16:04:25 +00:00
|
|
|
authConfig := backend.Auth{
|
|
|
|
Username: container.AuthConfig.Username,
|
|
|
|
Password: container.AuthConfig.Password,
|
|
|
|
Email: container.AuthConfig.Email,
|
|
|
|
}
|
|
|
|
for _, registry := range c.registries {
|
2022-08-26 18:00:11 +00:00
|
|
|
if matchHostname(container.Image, registry.Hostname) {
|
2017-04-06 16:04:25 +00:00
|
|
|
authConfig.Username = registry.Username
|
|
|
|
authConfig.Password = registry.Password
|
|
|
|
authConfig.Email = registry.Email
|
|
|
|
break
|
|
|
|
}
|
|
|
|
}
|
|
|
|
|
2017-04-10 10:39:50 +00:00
|
|
|
for _, requested := range container.Secrets.Secrets {
|
|
|
|
secret, ok := c.secrets[strings.ToLower(requested.Source)]
|
2022-10-27 02:21:07 +00:00
|
|
|
if ok && secret.Available(container) {
|
2017-04-10 10:39:50 +00:00
|
|
|
environment[strings.ToUpper(requested.Target)] = secret.Value
|
|
|
|
}
|
|
|
|
}
|
|
|
|
|
2017-06-22 19:06:28 +00:00
|
|
|
memSwapLimit := int64(container.MemSwapLimit)
|
|
|
|
if c.reslimit.MemSwapLimit != 0 {
|
|
|
|
memSwapLimit = c.reslimit.MemSwapLimit
|
|
|
|
}
|
|
|
|
memLimit := int64(container.MemLimit)
|
|
|
|
if c.reslimit.MemLimit != 0 {
|
|
|
|
memLimit = c.reslimit.MemLimit
|
|
|
|
}
|
|
|
|
shmSize := int64(container.ShmSize)
|
|
|
|
if c.reslimit.ShmSize != 0 {
|
|
|
|
shmSize = c.reslimit.ShmSize
|
|
|
|
}
|
|
|
|
cpuQuota := int64(container.CPUQuota)
|
|
|
|
if c.reslimit.CPUQuota != 0 {
|
|
|
|
cpuQuota = c.reslimit.CPUQuota
|
|
|
|
}
|
|
|
|
cpuShares := int64(container.CPUShares)
|
|
|
|
if c.reslimit.CPUShares != 0 {
|
|
|
|
cpuShares = c.reslimit.CPUShares
|
|
|
|
}
|
|
|
|
cpuSet := container.CPUSet
|
|
|
|
if c.reslimit.CPUSet != "" {
|
|
|
|
cpuSet = c.reslimit.CPUSet
|
|
|
|
}
|
|
|
|
|
2022-08-14 17:32:49 +00:00
|
|
|
// all constraints must exclude success.
|
|
|
|
onSuccess := container.When.IsEmpty() ||
|
|
|
|
!container.When.ExcludesStatus("success")
|
|
|
|
// at least one constraint must include the status failure.
|
|
|
|
onFailure := container.When.IncludesStatus("failure")
|
|
|
|
|
2017-03-05 07:56:08 +00:00
|
|
|
return &backend.Step{
|
2022-06-16 21:11:27 +00:00
|
|
|
Name: name,
|
2017-03-05 07:56:08 +00:00
|
|
|
Alias: container.Name,
|
2022-08-26 18:00:11 +00:00
|
|
|
Image: container.Image,
|
2017-03-05 07:56:08 +00:00
|
|
|
Pull: container.Pull,
|
|
|
|
Detached: detached,
|
|
|
|
Privileged: privileged,
|
|
|
|
WorkingDir: workingdir,
|
|
|
|
Environment: environment,
|
|
|
|
Labels: container.Labels,
|
2022-10-30 23:26:49 +00:00
|
|
|
Commands: container.Commands,
|
2017-03-05 07:56:08 +00:00
|
|
|
ExtraHosts: container.ExtraHosts,
|
|
|
|
Volumes: volumes,
|
2017-09-08 00:43:33 +00:00
|
|
|
Tmpfs: container.Tmpfs,
|
2017-03-05 07:56:08 +00:00
|
|
|
Devices: container.Devices,
|
|
|
|
Networks: networks,
|
|
|
|
DNS: container.DNS,
|
|
|
|
DNSSearch: container.DNSSearch,
|
2017-06-22 19:06:28 +00:00
|
|
|
MemSwapLimit: memSwapLimit,
|
|
|
|
MemLimit: memLimit,
|
|
|
|
ShmSize: shmSize,
|
2017-11-17 22:49:01 +00:00
|
|
|
Sysctls: container.Sysctls,
|
2017-06-22 19:06:28 +00:00
|
|
|
CPUQuota: cpuQuota,
|
|
|
|
CPUShares: cpuShares,
|
|
|
|
CPUSet: cpuSet,
|
2017-04-06 16:04:25 +00:00
|
|
|
AuthConfig: authConfig,
|
2022-08-14 17:32:49 +00:00
|
|
|
OnSuccess: onSuccess,
|
|
|
|
OnFailure: onFailure,
|
|
|
|
NetworkMode: networkMode,
|
|
|
|
IpcMode: ipcMode,
|
2017-03-05 07:56:08 +00:00
|
|
|
}
|
|
|
|
}
|
2022-10-24 14:31:06 +00:00
|
|
|
|
|
|
|
func (c *Compiler) stepWorkdir(container *yaml.Container) string {
|
|
|
|
if filepath.IsAbs(container.Directory) {
|
|
|
|
return container.Directory
|
|
|
|
}
|
|
|
|
return filepath.Join(c.base, c.path, container.Directory)
|
|
|
|
}
|