mirror of
https://github.com/kemko/nomad.git
synced 2026-01-01 16:05:42 +03:00
167 lines
3.0 KiB
Go
167 lines
3.0 KiB
Go
// Copyright (c) HashiCorp, Inc.
|
|
// SPDX-License-Identifier: MPL-2.0
|
|
|
|
package jobspec2
|
|
|
|
import (
|
|
"slices"
|
|
"time"
|
|
|
|
"github.com/hashicorp/nomad/api"
|
|
)
|
|
|
|
func normalizeJob(jc *jobConfig) {
|
|
j := jc.Job
|
|
if j.Name == nil {
|
|
j.Name = &jc.JobID
|
|
}
|
|
if j.ID == nil {
|
|
j.ID = &jc.JobID
|
|
}
|
|
|
|
if j.Periodic != nil && (j.Periodic.Spec != nil || j.Periodic.Specs != nil) {
|
|
v := "cron"
|
|
j.Periodic.SpecType = &v
|
|
}
|
|
|
|
normalizeVault(jc.Vault)
|
|
|
|
if len(jc.Tasks) != 0 {
|
|
alone := make([]*api.TaskGroup, 0, len(jc.Tasks))
|
|
for _, t := range jc.Tasks {
|
|
alone = append(alone, &api.TaskGroup{
|
|
Name: &t.Name,
|
|
Tasks: []*api.Task{t},
|
|
})
|
|
}
|
|
alone = append(alone, j.TaskGroups...)
|
|
j.TaskGroups = alone
|
|
}
|
|
|
|
for _, tg := range j.TaskGroups {
|
|
normalizeNetworkPorts(tg.Networks)
|
|
for _, t := range tg.Tasks {
|
|
if t.Resources != nil {
|
|
normalizeNetworkPorts(t.Resources.Networks)
|
|
}
|
|
|
|
normalizeTemplates(t.Templates)
|
|
|
|
// normalize Vault
|
|
normalizeVault(t.Vault)
|
|
|
|
if t.Vault == nil {
|
|
t.Vault = jc.Vault
|
|
}
|
|
|
|
if len(t.Secrets) == 0 {
|
|
t.Secrets = jc.Secrets
|
|
} else {
|
|
t.Secrets = append(t.Secrets, jc.Secrets...)
|
|
}
|
|
|
|
//COMPAT To preserve compatibility with pre-1.7 agents, move the default
|
|
// identity to Task.Identity.
|
|
defaultIdx := -1
|
|
for i, wid := range t.Identities {
|
|
if wid.Name == "" || wid.Name == "default" {
|
|
t.Identity = wid
|
|
defaultIdx = i
|
|
break
|
|
}
|
|
}
|
|
|
|
// If the default identity was found in Identities above, remove it from the
|
|
// slice.
|
|
if defaultIdx >= 0 {
|
|
t.Identities = slices.Delete(t.Identities, defaultIdx, defaultIdx+1)
|
|
}
|
|
}
|
|
}
|
|
}
|
|
|
|
func normalizeVault(v *api.Vault) {
|
|
if v == nil {
|
|
return
|
|
}
|
|
|
|
if v.Env == nil {
|
|
v.Env = pointerOf(true)
|
|
}
|
|
if v.DisableFile == nil {
|
|
v.DisableFile = pointerOf(false)
|
|
}
|
|
if v.ChangeMode == nil {
|
|
v.ChangeMode = pointerOf("restart")
|
|
}
|
|
}
|
|
|
|
func normalizeNetworkPorts(networks []*api.NetworkResource) {
|
|
if networks == nil {
|
|
return
|
|
}
|
|
for _, n := range networks {
|
|
if len(n.DynamicPorts) == 0 {
|
|
continue
|
|
}
|
|
|
|
dynamic := make([]api.Port, 0, len(n.DynamicPorts))
|
|
var reserved []api.Port
|
|
|
|
for _, p := range n.DynamicPorts {
|
|
if p.Value > 0 {
|
|
reserved = append(reserved, p)
|
|
} else {
|
|
dynamic = append(dynamic, p)
|
|
}
|
|
}
|
|
if len(dynamic) == 0 {
|
|
dynamic = nil
|
|
}
|
|
|
|
n.DynamicPorts = dynamic
|
|
n.ReservedPorts = reserved
|
|
}
|
|
|
|
}
|
|
|
|
func normalizeTemplates(templates []*api.Template) {
|
|
if len(templates) == 0 {
|
|
return
|
|
}
|
|
|
|
for _, t := range templates {
|
|
if t.ChangeMode == nil {
|
|
t.ChangeMode = pointerOf("restart")
|
|
}
|
|
if t.Perms == nil {
|
|
t.Perms = pointerOf("0644")
|
|
}
|
|
if t.Splay == nil {
|
|
t.Splay = pointerOf(5 * time.Second)
|
|
}
|
|
if t.ErrMissingKey == nil {
|
|
t.ErrMissingKey = pointerOf(false)
|
|
}
|
|
normalizeChangeScript(t.ChangeScript)
|
|
}
|
|
}
|
|
|
|
func normalizeChangeScript(ch *api.ChangeScript) {
|
|
if ch == nil {
|
|
return
|
|
}
|
|
|
|
if ch.Args == nil {
|
|
ch.Args = []string{}
|
|
}
|
|
|
|
if ch.Timeout == nil {
|
|
ch.Timeout = pointerOf(5 * time.Second)
|
|
}
|
|
|
|
if ch.FailOnError == nil {
|
|
ch.FailOnError = pointerOf(false)
|
|
}
|
|
}
|