Skip to content
Merged
Show file tree
Hide file tree
Changes from all commits
Commits
File filter

Filter by extension

Filter by extension

Conversations
Failed to load comments.
Loading
Jump to
Jump to file
Failed to load files.
Loading
Diff view
Diff view
8 changes: 4 additions & 4 deletions pkg/pr/lua.go
Original file line number Diff line number Diff line change
@@ -1,6 +1,7 @@
package pr

import (
"encoding/json"
"fmt"
iofs "io/fs"
"os"
Expand All @@ -11,7 +12,6 @@ import (
"dario.cat/mergo"
"github.com/pluralsh/polly/luautils"
lua "github.com/yuin/gopher-lua"
"k8s.io/apimachinery/pkg/util/json"
)

func executeLua(spec *PrTemplateSpec, ctx map[string]interface{}) error {
Expand Down Expand Up @@ -83,12 +83,12 @@ func merge(spec *PrTemplateSpec, new map[string]interface{}) error {
return err
}

newSpec := PrTemplateSpec{}
if err := json.Unmarshal(jsonStr, &newSpec); err != nil {
newSpec := &PrTemplateSpecMirror{}
if err := json.Unmarshal(jsonStr, newSpec); err != nil {
return err
}

return mergo.Merge(spec, newSpec, mergo.WithAppendSlice, mergo.WithOverride)
return mergo.Merge(spec, newSpec.Convert(), mergo.WithAppendSlice, mergo.WithOverride)
}

func luaFolder(parent, folder string) (string, error) {
Expand Down
74 changes: 74 additions & 0 deletions pkg/pr/types.go
Original file line number Diff line number Diff line change
Expand Up @@ -5,6 +5,7 @@ import (
"strings"

console "github.com/pluralsh/console/go/client"
"github.com/pluralsh/polly/algorithms"
"sigs.k8s.io/yaml"
)

Expand Down Expand Up @@ -147,3 +148,76 @@ func BuildContracts(path string) (*PrContracts, error) {

return pr, err
}

type PrTemplateSpecMirror struct {
Updates *UpdateSpecMirror `json:"updates"`
Creates *CreateSpec `json:"creates"`
Deletes *DeleteSpec `json:"deletes"`
Lua *LuaSpecMirror `json:"lua"`
}

func (p *PrTemplateSpecMirror) Convert() *PrTemplateSpec {
if p == nil {
return nil
}
return &PrTemplateSpec{
Updates: p.Updates.Convert(),
Creates: p.Creates,
Deletes: p.Deletes,
Lua: p.Lua.Convert(),
}
}

type LuaSpecMirror struct {
ExternalDir string `json:"externalDir"`
External bool `json:"external"`
Script string `json:"script"`
Folder string `json:"folder"`
}

func (p *LuaSpecMirror) Convert() *LuaSpec {
if p == nil {
return nil
}
return &LuaSpec{
ExternalDir: p.ExternalDir,
External: p.External,
Script: p.Script,
Folder: p.Folder,
}
}

func (p *UpdateSpecMirror) Convert() *UpdateSpec {
if p == nil {
return nil
}

return &UpdateSpec{
Regexes: p.Regexes,
Files: p.Files,
ReplaceTemplate: p.ReplaceTemplate,
Yq: p.Yq,
MatchStrategy: p.MatchStrategy,
RegexReplacements: p.RegexReplacements,
YamlOverlays: algorithms.Map(p.YamlOverlays, func(y YamlOverlayMirror) YamlOverlay {
return YamlOverlay(y)
}),
}
}

type UpdateSpecMirror struct {
Regexes []string `json:"regexes"`
Files []string `json:"files"`
ReplaceTemplate string `json:"replaceTemplate"`
Yq string `json:"yq"`
MatchStrategy string `json:"matchStrategy"`
RegexReplacements []RegexReplacement `json:"regexReplacements"`
YamlOverlays []YamlOverlayMirror `json:"yamlOverlays"`
}

type YamlOverlayMirror struct {
File string `json:"file"`
Yaml string `json:"yaml"`
ListMerge ListMerge `json:"listMerge"`
Templated bool `json:"templated"`
}
Loading