Documentation ¶
Index ¶
- Variables
- func BuildSchemaSetFromPolicies(policies map[string]*ast.Module, paths []string, fsys fs.FS, ...) (*ast.SchemaSet, bool, error)
- func BuiltinNamespaces() []string
- func GetInputsContents(inputs []Input) []any
- func IsBuiltinNamespace(namespace string) bool
- func IsDotFile(name string) bool
- func IsJSONFile(name string) bool
- func IsRegoFile(name string) bool
- func LoadEmbeddedLibraries() (map[string]*ast.Module, error)
- func LoadEmbeddedPolicies() (map[string]*ast.Module, error)
- func LoadPoliciesFromDirs(target fs.FS, paths ...string) (map[string]*ast.Module, error)
- func NewEngineMetadata(schema string, meta map[string]any) (*scan.EngineMetadata, error)
- func RegisterRegoRules(modules map[string]*ast.Module)
- func WithCustomSchemas(schemas map[string][]byte) options.ScannerOption
- func WithDataDirs(paths ...string) options.ScannerOption
- func WithDataFilesystem(fsys fs.FS) options.ScannerOption
- func WithDisabledCheckIDs(ids ...string) options.ScannerOption
- func WithEmbeddedLibraries(include bool) options.ScannerOption
- func WithEmbeddedPolicies(include bool) options.ScannerOption
- func WithFrameworks(frameworks ...framework.Framework) options.ScannerOption
- func WithIncludeDeprecatedChecks(enabled bool) options.ScannerOption
- func WithPerResultTracing(enabled bool) options.ScannerOption
- func WithPolicyDirs(paths ...string) options.ScannerOption
- func WithPolicyFilesystem(fsys fs.FS) options.ScannerOption
- func WithPolicyNamespaces(namespaces ...string) options.ScannerOption
- func WithPolicyReader(readers ...io.Reader) options.ScannerOption
- func WithRegoErrorLimits(limit int) options.ScannerOption
- func WithTrace(w io.Writer) options.ScannerOption
- type DynamicMetadata
- type Input
- type InputOptions
- type MetadataRetriever
- type Scanner
- type Selector
- type StaticMetadata
- type SubType
Constants ¶
This section is empty.
Variables ¶
View Source
var LoadAndRegister = sync.OnceFunc(func() { modules, err := LoadEmbeddedPolicies() if err != nil { panic(err) } loadedLibs, err := LoadEmbeddedLibraries() if err != nil { panic(err) } for name, policy := range loadedLibs { modules[name] = policy } RegisterRegoRules(modules) })
Functions ¶
func BuiltinNamespaces ¶ added in v0.51.0
func BuiltinNamespaces() []string
func GetInputsContents ¶
func IsBuiltinNamespace ¶ added in v0.51.0
func IsJSONFile ¶
func IsRegoFile ¶
func LoadPoliciesFromDirs ¶
func NewEngineMetadata ¶
func RegisterRegoRules ¶
func WithCustomSchemas ¶ added in v0.56.0
func WithCustomSchemas(schemas map[string][]byte) options.ScannerOption
func WithDataDirs ¶ added in v0.56.0
func WithDataDirs(paths ...string) options.ScannerOption
func WithDataFilesystem ¶ added in v0.56.0
func WithDataFilesystem(fsys fs.FS) options.ScannerOption
func WithDisabledCheckIDs ¶ added in v0.56.0
func WithDisabledCheckIDs(ids ...string) options.ScannerOption
WithDisabledCheckIDs disables checks by their ID (ID field in metadata)
func WithEmbeddedLibraries ¶ added in v0.56.0
func WithEmbeddedLibraries(include bool) options.ScannerOption
func WithEmbeddedPolicies ¶ added in v0.56.0
func WithEmbeddedPolicies(include bool) options.ScannerOption
func WithFrameworks ¶ added in v0.58.0
func WithFrameworks(frameworks ...framework.Framework) options.ScannerOption
func WithIncludeDeprecatedChecks ¶ added in v0.58.0
func WithIncludeDeprecatedChecks(enabled bool) options.ScannerOption
func WithPerResultTracing ¶ added in v0.56.0
func WithPerResultTracing(enabled bool) options.ScannerOption
func WithPolicyDirs ¶ added in v0.56.0
func WithPolicyDirs(paths ...string) options.ScannerOption
func WithPolicyFilesystem ¶ added in v0.56.0
func WithPolicyFilesystem(fsys fs.FS) options.ScannerOption
func WithPolicyNamespaces ¶ added in v0.56.0
func WithPolicyNamespaces(namespaces ...string) options.ScannerOption
WithPolicyNamespaces - namespaces which indicate rego policies containing enforced rules
func WithPolicyReader ¶ added in v0.56.0
func WithPolicyReader(readers ...io.Reader) options.ScannerOption
func WithRegoErrorLimits ¶ added in v0.56.0
func WithRegoErrorLimits(limit int) options.ScannerOption
Types ¶
type DynamicMetadata ¶
type InputOptions ¶
type InputOptions struct {
Selectors []Selector
}
type MetadataRetriever ¶
type MetadataRetriever struct {
// contains filtered or unexported fields
}
func NewMetadataRetriever ¶
func NewMetadataRetriever(compiler *ast.Compiler) *MetadataRetriever
func (*MetadataRetriever) RetrieveMetadata ¶
func (m *MetadataRetriever) RetrieveMetadata(ctx context.Context, module *ast.Module, contents ...any) (*StaticMetadata, error)
type Scanner ¶
type Scanner struct {
// contains filtered or unexported fields
}
func NewScanner ¶
func NewScanner(source types.Source, opts ...options.ScannerOption) *Scanner
type StaticMetadata ¶
type StaticMetadata struct { Deprecated bool ID string AVDID string Title string ShortCode string Aliases []string Description string Severity string RecommendedActions string PrimaryURL string References []string InputOptions InputOptions Package string Frameworks map[framework.Framework][]string Provider string Service string Library bool CloudFormation *scan.EngineMetadata Terraform *scan.EngineMetadata }
func NewStaticMetadata ¶
func NewStaticMetadata(pkgPath string, inputOpt InputOptions) *StaticMetadata
func (*StaticMetadata) FromAnnotations ¶
func (sm *StaticMetadata) FromAnnotations(annotations *ast.Annotations) error
func (StaticMetadata) ToRule ¶
func (m StaticMetadata) ToRule() scan.Rule
Source Files ¶
Click to show internal directories.
Click to hide internal directories.