rule

package
v0.9.3 Latest Latest
Warning

This package is not in the latest version of its module.

Go to latest
Published: Jul 11, 2021 License: MIT Imports: 9 Imported by: 4

Documentation

Index

Constants

This section is empty.

Variables

View Source
var DefaultRules = []*Rule{}

DefaultRules are the default rules always used. This will be populated by the embed package on init

View Source
var TestRule = Rule{
	Name:         "whitelist",
	Terms:        []string{"whitelist", "white-list", "whitelisted", "white-listed"},
	Alternatives: []string{"allowlist"},
	Severity:     1,
	Options: Options{
		WordBoundary: false,
	},
}

TestRule is only meant to be used in tests. TODO: Use test terms

Functions

This section is empty.

Types

type Options added in v0.4.0

type Options struct {
	WordBoundary bool  `yaml:"word_boundary"`
	IncludeNote  *bool `yaml:"include_note"`
}

Options are options that can be configured and applied on a per-rule basis

type Rule

type Rule struct {
	Name         string   `yaml:"name"`
	Terms        []string `yaml:"terms"`
	Alternatives []string `yaml:"alternatives"`
	Note         string   `yaml:"note"`
	Severity     Severity `yaml:"severity"`
	Options      Options  `yaml:"options"`
	// contains filtered or unexported fields
}

Rule is a linter rule

func (*Rule) CanIgnoreLine added in v0.1.4

func (r *Rule) CanIgnoreLine(line string) bool

CanIgnoreLine returns a boolean value if the line contains the ignore directive. For example, if a line has anywhere, wokeignore:rule=whitelist (should be commented out via whatever the language comment syntax is) it will not report that line in finding with the Rule with the name `whitelist` wokeignore:rule=whitelist

func (*Rule) Disabled added in v0.1.16

func (r *Rule) Disabled() bool

Disabled denotes if the rule is disabled If no terms are provided, this essentially disables the rule which is helpful for disabling default rules. Eventually, there should be a better way to disable a default rule, and then, if a rule has no Terms, it falls back to the Name.

func (*Rule) FindMatchIndexes added in v0.1.14

func (r *Rule) FindMatchIndexes(text string) [][]int

FindMatchIndexes returns the start and end indexes for all rule findings for the text supplied.

func (*Rule) MatchString added in v0.1.14

func (r *Rule) MatchString(s string, wordBoundary bool) bool

MatchString reports whether the string s contains any match of the regular expression re.

func (*Rule) Reason

func (r *Rule) Reason(finding string) string

Reason returns a human-readable reason for the rule finding

func (*Rule) ReasonWithNote

func (r *Rule) ReasonWithNote(finding string) string

ReasonWithNote returns a human-readable reason for the rule finding with an additional note, if defined.

func (*Rule) SetIncludeNote added in v0.9.0

func (r *Rule) SetIncludeNote(includeNote bool)

SetIncludeNote populates IncludeNote attributte in Options Options.IncludeNote is ussed in ReasonWithNote If "include_note" is already defined for the rule in yaml, it will not be overridden

func (*Rule) SetRegexp added in v0.1.13

func (r *Rule) SetRegexp()

SetRegexp populates the regex for matching this rule

type Severity

type Severity int

Severity is a log severity

const (
	// SevError translates to Error
	// This will be the default severity
	SevError Severity = iota
	// SevWarn translates to Warning
	SevWarn
	// SevInfo translates to Info
	SevInfo
)

func NewSeverity

func NewSeverity(s string) Severity

NewSeverity turns a string into a Severity

func (*Severity) Colorize

func (s *Severity) Colorize() string

Colorize returns a the Severity as a colorized string

func (*Severity) MarshalJSON added in v0.2.0

func (s *Severity) MarshalJSON() ([]byte, error)

MarshalJSON to marshal Severity as a string

func (Severity) String

func (s Severity) String() string

func (*Severity) UnmarshalYAML

func (s *Severity) UnmarshalYAML(unmarshal func(interface{}) error) error

UnmarshalYAML to unmarshal severity string

Jump to

Keyboard shortcuts

? : This menu
/ : Search site
f or F : Jump to
y or Y : Canonical URL