From 45df4d0d9b577fecee798d672695fe24ff57fb1b Mon Sep 17 00:00:00 2001 From: mo khan Date: Tue, 15 Jul 2025 16:37:08 -0600 Subject: feat: migrate from Cedar to SpiceDB authorization system This is a major architectural change that replaces the Cedar policy-based authorization system with SpiceDB's relation-based authorization. Key changes: - Migrate from Rust to Go implementation - Replace Cedar policies with SpiceDB schema and relationships - Switch from envoy `ext_authz` with Cedar to SpiceDB permission checks - Update build system and dependencies for Go ecosystem - Maintain Envoy integration for external authorization This change enables more flexible permission modeling through SpiceDB's Google Zanzibar inspired relation-based system, supporting complex hierarchical permissions that were difficult to express in Cedar. Breaking change: Existing Cedar policies and Rust-based configuration will no longer work and need to be migrated to SpiceDB schema. --- vendor/github.com/google/yamlfmt/engine/output.go | 148 ++++++++++++++++++++++ 1 file changed, 148 insertions(+) create mode 100644 vendor/github.com/google/yamlfmt/engine/output.go (limited to 'vendor/github.com/google/yamlfmt/engine/output.go') diff --git a/vendor/github.com/google/yamlfmt/engine/output.go b/vendor/github.com/google/yamlfmt/engine/output.go new file mode 100644 index 00000000..c6a2e9e2 --- /dev/null +++ b/vendor/github.com/google/yamlfmt/engine/output.go @@ -0,0 +1,148 @@ +// Copyright 2024 Google LLC +// +// Licensed under the Apache License, Version 2.0 (the "License"); +// you may not use this file except in compliance with the License. +// You may obtain a copy of the License at +// +// http://www.apache.org/licenses/LICENSE-2.0 +// +// Unless required by applicable law or agreed to in writing, software +// distributed under the License is distributed on an "AS IS" BASIS, +// WITHOUT WARRANTIES OR CONDITIONS OF ANY KIND, either express or implied. +// See the License for the specific language governing permissions and +// limitations under the License. + +package engine + +import ( + "encoding/json" + "fmt" + "sort" + "strings" + + "github.com/google/yamlfmt" + "github.com/google/yamlfmt/internal/gitlab" +) + +type EngineOutputFormat string + +const ( + EngineOutputDefault EngineOutputFormat = "default" + EngineOutputSingeLine EngineOutputFormat = "line" + EngineOutputGitlab EngineOutputFormat = "gitlab" +) + +func getEngineOutput(t EngineOutputFormat, operation yamlfmt.Operation, files yamlfmt.FileDiffs, quiet bool, verbose bool) (fmt.Stringer, error) { + switch t { + case EngineOutputDefault: + return engineOutput{Operation: operation, Files: files, Quiet: quiet, Verbose: verbose}, nil + case EngineOutputSingeLine: + return engineOutputSingleLine{Operation: operation, Files: files, Quiet: quiet}, nil + case EngineOutputGitlab: + return engineOutputGitlab{Operation: operation, Files: files, Compact: quiet}, nil + + } + return nil, fmt.Errorf("unknown output type: %s", t) +} + +type engineOutput struct { + Operation yamlfmt.Operation + Files yamlfmt.FileDiffs + Quiet bool + Verbose bool +} + +func (eo engineOutput) String() string { + var msg string + switch eo.Operation { + case yamlfmt.OperationFormat: + // Formatting only produces output in verbose mode. + if !eo.Verbose { + return "" + } + + msg = "The following files were modified:\n" + msg += eo.Files.StrOutputQuiet() + return msg + case yamlfmt.OperationLint: + msg = "The following formatting differences were found:" + if eo.Quiet { + msg = "The following files had formatting differences:" + } + case yamlfmt.OperationDry: + if len(eo.Files) > 0 { + if eo.Quiet { + msg = "The following files would be formatted:" + } + } else { + return "No files will be formatted." + } + } + var result string + if msg != "" { + result += fmt.Sprintf("%s\n\n", msg) + } + if eo.Quiet { + result += eo.Files.StrOutputQuiet() + } else { + result += fmt.Sprintf("%s\n", eo.Files.StrOutput()) + } + return result +} + +type engineOutputSingleLine struct { + Operation yamlfmt.Operation + Files yamlfmt.FileDiffs + Quiet bool +} + +func (eosl engineOutputSingleLine) String() string { + var msg string + for _, fileDiff := range eosl.Files { + msg += fmt.Sprintf("%s: formatting difference found\n", fileDiff.Path) + } + return msg +} + +type engineOutputGitlab struct { + Operation yamlfmt.Operation + Files yamlfmt.FileDiffs + Compact bool +} + +func (eo engineOutputGitlab) String() string { + var findings []gitlab.CodeQuality + + for _, file := range eo.Files { + if cq, ok := gitlab.NewCodeQuality(*file); ok { + findings = append(findings, cq) + } + } + + if len(findings) == 0 { + return "" + } + + sort.Sort(byPath(findings)) + + var b strings.Builder + enc := json.NewEncoder(&b) + + if !eo.Compact { + enc.SetIndent("", " ") + } + + if err := enc.Encode(findings); err != nil { + panic(err) + } + return b.String() +} + +// byPath is used to sort by Location.Path. +type byPath []gitlab.CodeQuality + +func (b byPath) Len() int { return len(b) } +func (b byPath) Less(i, j int) bool { return b[i].Location.Path < b[j].Location.Path } +func (b byPath) Swap(i, j int) { + b[i].Location.Path, b[j].Location.Path = b[j].Location.Path, b[i].Location.Path +} -- cgit v1.2.3