tag v0.155.0 Tagger: imagebuilder-bot <imagebuilder-bots+imagebuilder-bot@redhat.com> Changes with 0.155.0 ---------------- * Fedora 43: add shadow-utils when LockRoot is enabled, update cloud-init service name (osbuild/images#1618) * Author: Achilleas Koutsou, Reviewers: Gianluca Zuccarelli, Michael Vogt * Update osbuild dependency commit ID to latest (osbuild/images#1609) * Author: SchutzBot, Reviewers: Achilleas Koutsou, Simon de Vlieger, Tomáš Hozza * Update snapshots to 20250626 (osbuild/images#1623) * Author: SchutzBot, Reviewers: Achilleas Koutsou, Simon de Vlieger * distro/rhel9: xz compress azure-cvm image type [HMS-8587] (osbuild/images#1620) * Author: Achilleas Koutsou, Reviewers: Simon de Vlieger, Tomáš Hozza * distro/rhel: introduce new image type: Azure SAP Apps [HMS-8738] (osbuild/images#1612) * Author: Achilleas Koutsou, Reviewers: Simon de Vlieger, Tomáš Hozza * distro/rhel: move ansible-core to sap_extras_pkgset (osbuild/images#1624) * Author: Achilleas Koutsou, Reviewers: Brian C. Lane, Tomáš Hozza * github/create-tag: allow passing the version when run manually (osbuild/images#1621) * Author: Achilleas Koutsou, Reviewers: Lukáš Zapletal, Tomáš Hozza * rhel9: move image-config into pure YAML (HMS-8593) (osbuild/images#1616) * Author: Michael Vogt, Reviewers: Achilleas Koutsou, Simon de Vlieger * test: split manifest checksums into separate files (osbuild/images#1625) * Author: Achilleas Koutsou, Reviewers: Simon de Vlieger, Tomáš Hozza — Somewhere on the Internet, 2025-06-30 --- tag v0.156.0 Tagger: imagebuilder-bot <imagebuilder-bots+imagebuilder-bot@redhat.com> Changes with 0.156.0 ---------------- * Many: delete repositories for EOL distributions (HMS-7044) (osbuild/images#1607) * Author: Tomáš Hozza, Reviewers: Michael Vogt, Simon de Vlieger * RHSM/facts: add 'image-builder CLI' API type (osbuild/images#1640) * Author: Tomáš Hozza, Reviewers: Brian C. Lane, Simon de Vlieger * Update dependencies 2025-06-29 (osbuild/images#1628) * Author: SchutzBot, Reviewers: Simon de Vlieger, Tomáš Hozza * Update osbuild dependency commit ID to latest (osbuild/images#1627) * Author: SchutzBot, Reviewers: Simon de Vlieger, Tomáš Hozza * [RFC] image: drop `InstallWeakDeps` from image.DiskImage (osbuild/images#1642) * Author: Michael Vogt, Reviewers: Brian C. Lane, Simon de Vlieger, Tomáš Hozza * build(deps): bump the go-deps group across 1 directory with 3 updates (osbuild/images#1632) * Author: dependabot[bot], Reviewers: SchutzBot, Tomáš Hozza * distro/rhel10: xz compress azure-cvm image type (osbuild/images#1638) * Author: Achilleas Koutsou, Reviewers: Brian C. Lane, Simon de Vlieger * distro: cleanup/refactor distro/{defs,generic} (HMS-8744) (osbuild/images#1570) * Author: Michael Vogt, Reviewers: Simon de Vlieger, Tomáš Hozza * distro: remove some hardcoded values from generic/images.go (osbuild/images#1636) * Author: Michael Vogt, Reviewers: Simon de Vlieger, Tomáš Hozza * distro: small tweaks for the YAML based imagetypes (osbuild/images#1622) * Author: Michael Vogt, Reviewers: Brian C. Lane, Simon de Vlieger * fedora/wsl: packages and locale (osbuild/images#1635) * Author: Simon de Vlieger, Reviewers: Michael Vogt, Tomáš Hozza * image/many: make compression more generic (osbuild/images#1634) * Author: Simon de Vlieger, Reviewers: Brian C. Lane, Michael Vogt * manifest: handle content template name with spaces (osbuild/images#1641) * Author: Bryttanie, Reviewers: Brian C. Lane, Michael Vogt, Tomáš Hozza * many: implement gzip (osbuild/images#1633) * Author: Simon de Vlieger, Reviewers: Michael Vogt, Tomáš Hozza * rhel/azure: set GRUB_TERMINAL based on architecture [RHEL-91383] (osbuild/images#1626) * Author: Achilleas Koutsou, Reviewers: Simon de Vlieger, Tomáš Hozza — Somewhere on the Internet, 2025-07-07 ---
107 lines
2.5 KiB
Go
107 lines
2.5 KiB
Go
package spiffeid
|
|
|
|
import (
|
|
"fmt"
|
|
"strings"
|
|
)
|
|
|
|
// FormatPath builds a path by formatting the given formatting string with
|
|
// the given args (i.e. fmt.Sprintf). The resulting path must be valid or
|
|
// an error is returned.
|
|
func FormatPath(format string, args ...interface{}) (string, error) {
|
|
path := fmt.Sprintf(format, args...)
|
|
if err := ValidatePath(path); err != nil {
|
|
return "", err
|
|
}
|
|
return path, nil
|
|
}
|
|
|
|
// JoinPathSegments joins one or more path segments into a slash separated
|
|
// path. Segments cannot contain slashes. The resulting path must be valid or
|
|
// an error is returned. If no segments are provided, an empty string is
|
|
// returned.
|
|
func JoinPathSegments(segments ...string) (string, error) {
|
|
var builder strings.Builder
|
|
for _, segment := range segments {
|
|
if err := ValidatePathSegment(segment); err != nil {
|
|
return "", err
|
|
}
|
|
builder.WriteByte('/')
|
|
builder.WriteString(segment)
|
|
}
|
|
return builder.String(), nil
|
|
}
|
|
|
|
// ValidatePath validates that a path string is a conformant path for a SPIFFE
|
|
// ID.
|
|
// See https://github.com/spiffe/spiffe/blob/main/standards/SPIFFE-ID.md#22-path
|
|
func ValidatePath(path string) error {
|
|
switch {
|
|
case path == "":
|
|
return nil
|
|
case path[0] != '/':
|
|
return errNoLeadingSlash
|
|
}
|
|
|
|
segmentStart := 0
|
|
segmentEnd := 0
|
|
for ; segmentEnd < len(path); segmentEnd++ {
|
|
c := path[segmentEnd]
|
|
if c == '/' {
|
|
switch path[segmentStart:segmentEnd] {
|
|
case "/":
|
|
return errEmptySegment
|
|
case "/.", "/..":
|
|
return errDotSegment
|
|
}
|
|
segmentStart = segmentEnd
|
|
continue
|
|
}
|
|
if !isValidPathSegmentChar(c) {
|
|
return errBadPathSegmentChar
|
|
}
|
|
}
|
|
|
|
switch path[segmentStart:segmentEnd] {
|
|
case "/":
|
|
return errTrailingSlash
|
|
case "/.", "/..":
|
|
return errDotSegment
|
|
}
|
|
return nil
|
|
}
|
|
|
|
// ValidatePathSegment validates that a string is a conformant segment for
|
|
// inclusion in the path for a SPIFFE ID.
|
|
// See https://github.com/spiffe/spiffe/blob/main/standards/SPIFFE-ID.md#22-path
|
|
func ValidatePathSegment(segment string) error {
|
|
switch segment {
|
|
case "":
|
|
return errEmptySegment
|
|
case ".", "..":
|
|
return errDotSegment
|
|
}
|
|
for i := 0; i < len(segment); i++ {
|
|
if !isValidPathSegmentChar(segment[i]) {
|
|
return errBadPathSegmentChar
|
|
}
|
|
}
|
|
return nil
|
|
}
|
|
|
|
func isValidPathSegmentChar(c uint8) bool {
|
|
switch {
|
|
case c >= 'a' && c <= 'z':
|
|
return true
|
|
case c >= 'A' && c <= 'Z':
|
|
return true
|
|
case c >= '0' && c <= '9':
|
|
return true
|
|
case c == '-', c == '.', c == '_':
|
|
return true
|
|
case isBackcompatPathChar(c):
|
|
return true
|
|
default:
|
|
return false
|
|
}
|
|
}
|