Documentation ¶
Overview ¶
Package rulelist contains the implementation of the standard rule-list filter that wraps an urlfilter filtering-engine.
TODO(a.garipov): Add a new update worker.
Index ¶
Constants ¶
const DefaultMaxRuleListSize = 64 * datasize.MB
DefaultMaxRuleListSize is the default maximum filtering-rule list size.
const DefaultRuleBufSize = 1024
DefaultRuleBufSize is the default length of a buffer used to read a line with a filtering rule, in bytes.
TODO(a.garipov): Consider using datasize.ByteSize. It is currently only used as an int.
const ErrHTML errors.Error = "data is HTML, not plain text"
ErrHTML is returned by Parser.Parse if the data is likely to be HTML.
TODO(a.garipov): This error is currently returned to the UI. Stop that and make it all-lowercase.
Variables ¶
This section is empty.
Functions ¶
This section is empty.
Types ¶
type Filter ¶ added in v0.107.44
type Filter struct {
// contains filtered or unexported fields
}
Filter contains information about a single rule-list filter.
TODO(a.garipov): Use.
func NewFilter ¶ added in v0.107.44
func NewFilter(c *FilterConfig) (f *Filter, err error)
NewFilter creates a new rule-list filter. The filter is not refreshed, so a refresh should be performed before use.
func (*Filter) Refresh ¶ added in v0.107.44
func (f *Filter) Refresh( ctx context.Context, parseBuf []byte, cli *http.Client, cacheDir string, maxSize datasize.ByteSize, ) (parseRes *ParseResult, err error)
Refresh updates the data in the rule-list filter. parseBuf is the initial buffer used to parse information from the data. cli and maxSize are only used when f is a URL-based list.
type FilterConfig ¶ added in v0.107.44
type FilterConfig struct { // URL is the URL of this rule-list filter. Supported schemes are: // - http // - https // - file URL *url.URL // Name is the human-readable name of this rule-list filter. If not set, it // is either taken from the rule-list data or generated synthetically from // the UID. Name string // UID is the unique ID of this rule-list filter. UID UID // URLFilterID is used for working with package urlfilter. URLFilterID URLFilterID // Enabled, if true, means that this rule-list filter is used for filtering. Enabled bool }
FilterConfig contains the configuration for a Filter.
type ParseResult ¶
type ParseResult struct { // Title is the title contained within the filtering-rule list, if any. Title string // RulesCount is the number of rules in the list. It excludes empty lines // and comments. RulesCount int // BytesWritten is the number of bytes written to dst. BytesWritten int // Checksum is the CRC-32 checksum of the rules content. That is, excluding // empty lines and comments. Checksum uint32 }
ParseResult contains information about the results of parsing a filtering-rule list by Parser.Parse.
type Parser ¶
type Parser struct {
// contains filtered or unexported fields
}
Parser is a filtering-rule parser that collects data, such as the checksum and the title, as well as counts rules and removes comments.
type UID ¶ added in v0.107.44
UID is the type for the unique IDs of filtering-rule lists.
func MustNewUID ¶ added in v0.107.44
func MustNewUID() (uid UID)
MustNewUID is a wrapper around NewUID that panics if there is an error.
func NewUID ¶ added in v0.107.44
NewUID returns a new filtering-rule list UID. Any error returned is an error from the cryptographic randomness reader.
func (UID) String ¶ added in v0.107.44
String implements the fmt.Stringer interface for UID.
type URLFilterID ¶ added in v0.107.44
type URLFilterID = int
URLFilterID is a semantic type-alias for IDs used for working with package urlfilter.