Skip to content

Commit

Permalink
cli: create default policy setting file, rego and manifest on generate
Browse files Browse the repository at this point in the history
If files do not exist yet, generate will write default files.
  • Loading branch information
malt3 committed Jan 11, 2024
1 parent bad9ea6 commit 3fae49c
Show file tree
Hide file tree
Showing 9 changed files with 1,437 additions and 1,121 deletions.
12 changes: 12 additions & 0 deletions cli/constants.go
Original file line number Diff line number Diff line change
@@ -1,8 +1,20 @@
package main

import (
_ "embed"
)

const (
coordRootPEMFilename = "coordinator-root.pem"
coordIntermPEMFilename = "mesh-root.pem"
manifestFilename = "manifest.json"
rulesFilename = "rules.rego"
verifyDir = "./verify"
)

var (
//go:embed genpolicy-msft.json
defaultGenpolicySettings []byte
//go:embed rules.rego
defaultRules []byte
)
44 changes: 43 additions & 1 deletion cli/generate.go
Original file line number Diff line number Diff line change
Expand Up @@ -4,6 +4,7 @@ import (
"bytes"
"context"
"crypto/sha256"
_ "embed"
"encoding/json"
"errors"
"fmt"
Expand Down Expand Up @@ -65,7 +66,11 @@ func runGenerate(cmd *cobra.Command, args []string) error {
return fmt.Errorf("failed to create policy map: %w", err)
}

manifestData, err := os.ReadFile(flags.manifestPath)
defaultManifestData, err := json.MarshalIndent(&manifest.Manifest{}, "", " ")
if err != nil {
return fmt.Errorf("failed to marshal default manifest: %w", err)
}
manifestData, err := readFileOrCreateWithDefault(flags.manifestPath, defaultManifestData)
if err != nil {
return fmt.Errorf("failed to read manifest file: %w", err)
}
Expand Down Expand Up @@ -136,6 +141,12 @@ func filterNonCoCoRuntime(runtimeClassName string, paths []string, logger *slog.
}

func generatePolicies(ctx context.Context, regoPath, policyPath string, yamlPaths []string, logger *slog.Logger) error {
if err := createFileWithDefault(filepath.Join(regoPath, policyPath), defaultGenpolicySettings); err != nil {
return fmt.Errorf("creating default policy file: %w", err)
}
if err := createFileWithDefault(filepath.Join(regoPath, rulesFilename), defaultRules); err != nil {
return fmt.Errorf("creating default policy.rego file: %w", err)
}
for _, yamlPath := range yamlPaths {
policyHash, err := generatePolicyForFile(ctx, regoPath, policyPath, yamlPath, logger)
if err != nil {
Expand Down Expand Up @@ -202,3 +213,34 @@ func parseGenerateFlags(cmd *cobra.Command) (*generateFlags, error) {
manifestPath: manifestPath,
}, nil
}

// readFileOrCreateWithDefault reads the file at path,
// or creates it with the default value if it doesn't exist.
func readFileOrCreateWithDefault(path string, deflt []byte) ([]byte, error) {
data, err := os.ReadFile(path)
if err == nil {
return data, nil
}
if !os.IsNotExist(err) {
return nil, err
}
if err := os.WriteFile(path, deflt, 0o644); err != nil {
return nil, err
}
return deflt, nil
}

// createFileWithDefault creates the file at path with the default value,
// if it doesn't exist.
func createFileWithDefault(path string, deflt []byte) error {
file, err := os.OpenFile(path, os.O_WRONLY|os.O_CREATE|os.O_EXCL, 0o644)
if os.IsExist(err) {
return nil
}
if err != nil {
return err
}
defer file.Close()
_, err = file.Write(deflt)
return err
}
File renamed without changes.
File renamed without changes.
Loading

0 comments on commit 3fae49c

Please sign in to comment.