Skip to content

Commit

Permalink
release: embed image replacements
Browse files Browse the repository at this point in the history
  • Loading branch information
davidweisse committed May 31, 2024
1 parent b26cf71 commit acce2e8
Show file tree
Hide file tree
Showing 6 changed files with 15 additions and 2 deletions.
5 changes: 4 additions & 1 deletion .github/workflows/release.yml
Original file line number Diff line number Diff line change
Expand Up @@ -244,10 +244,13 @@ jobs:
'select(.kind == "Deployment") | .spec.template.metadata.annotations["io.katacontainers.config.agent.policy"]' |
base64 -d | sha256sum | cut -d " " -f1 > cli/cmd/assets/coordinator-policy-hash
cp image-replacements.txt cli/cmd/assets/image-replacements.txt
git config --global user.name "edgelessci"
git config --global user.email "[email protected]"
git add cli/cmd/assets/coordinator-policy-hash
git diff --staged --quiet || git commit -m "release: update coordinator policy hash"
git add cli/cmd/assets/image-replacements.txt
git diff --staged --quiet || git commit -m "release: update cli assets"
- name: Build CLI
run: |
nix build -L .#cli-release
Expand Down
1 change: 1 addition & 0 deletions cli/cmd/assets/image-replacements.txt
Original file line number Diff line number Diff line change
@@ -0,0 +1 @@
# THIS FILE IS REPLACED DURING RELEASE BUILD TO INCLUDE UPDATED IMAGE REFERENCES
2 changes: 2 additions & 0 deletions cli/cmd/common.go
Original file line number Diff line number Diff line change
Expand Up @@ -34,6 +34,8 @@ var (
defaultGenpolicySettings []byte
//go:embed assets/genpolicy-rules.rego
defaultRules []byte
//go:embed assets/image-replacements.txt
releaseImageReplacements []byte
// DefaultCoordinatorPolicyHash is derived from the coordinator release candidate and injected at release build time.
//
// It is intentionally left empty for dev builds.
Expand Down
6 changes: 6 additions & 0 deletions cli/cmd/generate.go
Original file line number Diff line number Diff line change
Expand Up @@ -287,6 +287,7 @@ func injectInitializer(paths []string, logger *slog.Logger) error {

func patchTargets(paths []string, imageReplacementsFile string, logger *slog.Logger) error {
var replacements map[string]string
var err error
if imageReplacementsFile != "" {
f, err := os.Open(imageReplacementsFile)
if err != nil {
Expand All @@ -298,6 +299,11 @@ func patchTargets(paths []string, imageReplacementsFile string, logger *slog.Log
if err != nil {
return fmt.Errorf("could not parse image definition file %s: %w", imageReplacementsFile, err)
}
} else {
replacements, err = kuberesource.ImageReplacementsFromFile(bytes.NewReader(releaseImageReplacements))
if err != nil {
return fmt.Errorf("could not parse release image definitions %s: %w", releaseImageReplacements, err)
}
}
for _, path := range paths {
data, err := os.ReadFile(path)
Expand Down
2 changes: 1 addition & 1 deletion internal/kuberesource/lookup.go
Original file line number Diff line number Diff line change
Expand Up @@ -17,7 +17,7 @@ var replacementRE = regexp.MustCompile(`(?P<image>[^\s=]+)\s*=\s*(?P<replacement
// The file is expected to contain newline-separated pairs of images and their intended
// replacement, separated by an = sign. Empty lines and lines starting with the pound character
// are ignored. This file is populated by container image build rules in the justfile.
func ImageReplacementsFromFile(file io.ReadCloser) (map[string]string, error) {
func ImageReplacementsFromFile(file io.Reader) (map[string]string, error) {
m := make(map[string]string)

scanner := bufio.NewScanner(file)
Expand Down
1 change: 1 addition & 0 deletions packages/by-name/contrast/package.nix
Original file line number Diff line number Diff line change
Expand Up @@ -52,6 +52,7 @@ buildGoModule rec {
fileset = fileset.unions [
(path.append root "go.mod")
(path.append root "go.sum")
(path.append root "cli/cmd/assets/image-replacements.txt")
(fileset.difference
(fileset.fileFilter (file: hasSuffix ".go" file.name) root)
(fileset.unions [
Expand Down

0 comments on commit acce2e8

Please sign in to comment.