rulelist

package
v0.108.0-b.53 Latest Latest
Warning

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

Go to latest
Published: Feb 13, 2024 License: GPL-3.0 Imports: 19 Imported by: 0

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

View Source
const DefaultMaxRuleListSize = 64 * datasize.MB

DefaultMaxRuleListSize is the default maximum filtering-rule list size.

View Source
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.

View Source
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) Close added in v0.107.44

func (f *Filter) Close() (err error)

Close closes the underlying rule list.

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.

func NewParser

func NewParser() (p *Parser)

NewParser returns a new filtering-rule parser.

func (*Parser) Parse

func (p *Parser) Parse(dst io.Writer, src io.Reader, buf []byte) (r *ParseResult, err error)

Parse parses data from src into dst using buf during parsing. r is never nil.

type UID added in v0.107.44

type UID uuid.UUID

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

func NewUID() (uid UID, err error)

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

func (id UID) String() (s string)

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.

Jump to

Keyboard shortcuts

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