Documentation ¶
Index ¶
- func FilterIgnoredPaths(paths, ignore []string, checkFileExists bool, rootDir string) ([]string, error)
- func FindBundleRootDirectories(path string) ([]string, error)
- func FindConfig(path string) (*os.File, error)
- func FindRegalDirectory(path string) (*os.File, error)
- func GetPotentialRoots(paths ...string) ([]string, error)
- func GlobalDir() string
- func ToMap(config Config) map[string]any
- type Builtin
- type Capabilities
- type Category
- type Config
- type Decl
- type Default
- type Defaults
- type ExtraAttributes
- type Features
- type Ignore
- type Project
- type RemoteFeatures
- type Rule
Constants ¶
This section is empty.
Variables ¶
This section is empty.
Functions ¶
func FilterIgnoredPaths ¶ added in v0.8.0
func FindBundleRootDirectories ¶ added in v0.26.0
FindBundleRootDirectories finds all bundle root directories from the provided path, which **must** be an absolute path. Bundle root directories may be found either by:
- Configuration (`project.roots`) - By the presence of a .manifest file anywhere under the path - By the presence of a .regal directory anywhere under or above the path ... TODO (anders): might reconsider "above"?
All returned paths are absolute paths. If the provided path itself is determined to be a bundle root directory it will be included in the result.
func FindRegalDirectory ¶
FindRegalDirectory searches for a .regal directory first in the directory of path, and if not found, in the parent directory, and if not found, in the parent's parent directory, and so on.
func GetPotentialRoots ¶ added in v0.26.0
Types ¶
type Capabilities ¶ added in v0.12.0
type Capabilities struct { Builtins map[string]*Builtin `json:"builtins" yaml:"builtins"` FutureKeywords []string `json:"future_keywords" yaml:"future_keywords"` Features []string `json:"features" yaml:"features"` }
func CapabilitiesForThisVersion ¶ added in v0.12.0
func CapabilitiesForThisVersion() *Capabilities
CapabilitiesForThisVersion returns the capabilities for the current OPA version Regal depends on.
type Config ¶
type Config struct { Rules map[string]Category `json:"rules" yaml:"rules"` Ignore Ignore `json:"ignore,omitempty" yaml:"ignore,omitempty"` Capabilities *Capabilities `json:"capabilities,omitempty" yaml:"capabilities,omitempty"` // Defaults state is loaded from configuration under rules and so is not (un)marshalled // in the same way. Defaults Defaults `json:"-" yaml:"-"` Features *Features `json:"features,omitempty" yaml:"features,omitempty"` CapabilitiesURL string `json:"capabilities_url,omitempty" yaml:"capabilities_url,omitempty"` Project *Project `json:"project,omitempty" yaml:"project,omitempty"` }
func LoadConfigWithDefaultsFromBundle ¶ added in v0.24.0
func (Config) MarshalYAML ¶ added in v0.19.0
func (*Config) UnmarshalYAML ¶ added in v0.12.0
type Default ¶ added in v0.19.0
type Default struct {
Level string `json:"level" yaml:"level"`
}
Default represents global or category settings for rules, currently only the level is supported.
type Defaults ¶ added in v0.19.0
Defaults is used to store information about global and category defaults for rules.
type ExtraAttributes ¶
type Features ¶ added in v0.24.0
type Features struct {
Remote *RemoteFeatures `json:"remote,omitempty" yaml:"remote,omitempty"`
}
type Ignore ¶ added in v0.5.0
type Ignore struct {
Files []string `json:"files,omitempty" yaml:"files,omitempty"`
}
type RemoteFeatures ¶ added in v0.24.0
type RemoteFeatures struct {
CheckVersion bool `json:"check-version,omitempty" yaml:"check-version,omitempty"`
}
type Rule ¶
type Rule struct { Level string Ignore *Ignore `json:"ignore,omitempty" yaml:"ignore,omitempty"` Extra ExtraAttributes }