HeadlessContentBlocker
extends FastHtmlTag
in package
Initialize a new headless content blocker.
Table of Contents
Constants
- TAG_ATTRIBUTE_MAP_LINKABLE = 'linkable'
- The tag-attribute map for the usual links like `script[src],link[href],iframe[href]`.
Properties
- $afterSetupCallbacks : mixed
- $allowMultipleBlockerResults : mixed
- $beforeMatchCallbacks : mixed
- $beforeSetBlockedInResultCallback : mixed
- $blockables : array<string|int, AbstractBlockable>
- List of blocked elements.
- $blockablesToHostsCache : mixed
- $blockableStringExpressionCallback : mixed
- $blockedMatchCallbacks : mixed
- $checkResultCallbacks : mixed
- $finderToMatcher : mixed
- $inlineStyleBlockRuleByCallback : mixed
- $inlineStyleDummyUrlPath : mixed
- $inlineStyleModifyDocumentsByCallback : mixed
- $inlineStyleShouldBeExtractedByCallback : mixed
- $isSetup : mixed
- $keepAlwaysAttributes : mixed
- $keepAlwaysAttributesByCallback : mixed
- $keepAlwaysAttributesIfClass : mixed
- $markupChain : mixed
- $markupPool : array<string|int, Markup>
- Pool of all found markups.
- $notBlockedMatchCallbacks : mixed
- $plugins : array<string|int, array<string|int, AbstractPlugin>>
- List of registered plugins pointing to their object instance.
- $replaceAlwaysAttributes : mixed
- $rerunExceptions : array<string|int, RerunOnMatchException>
- See `processMatch`.
- $selectorSyntaxFindersTagMatrix : array<string, array<string, array<string|int, SelectorSyntaxFinder>>>
- This array holds instances of SelectorSyntaxFinder indexed by their associated tag.
- $selectorSyntaxMap : array<string|int, string>
- Selector syntax map.
- $setupCallbacks : mixed
- $skipInlineScriptVariableAssignments : mixed
- $skipInlineScriptVariableAssignmentsByCallback : mixed
- $tagAttributeMap : mixed
- $visualParentCallback : mixed
- $visualParentIfClass : mixed
Methods
- __construct() : mixed
- C'tor.
- addAfterSetupCallback() : mixed
- Add a callable after the content blocker got setup.
- addBeforeMatchCallback() : mixed
- Add a callable before a match got found (this does not mean that the match is blocked!).
- addBeforeSetBlockedInResultCallback() : mixed
- Add a callable before an blockable and expression gets added to a `BlockedResult`.
- addBlockables() : mixed
- Add a blockable item. In general, this are the URLs and elements you want to block.
- addBlockableStringExpressionCallback() : mixed
- Allows to modify the passed string expression to a blockable.
- addBlockedMatchCallback() : mixed
- Add a callable after a blocked match got found so you can alter the match again. Parameters: `BlockedResult $result, AbstractMatcher $matcher, AbstractMatch $match`.
- addCheckResultCallback() : mixed
- Add a callable after a match got found and the matcher decided if it should be blocked or not.
- addFinder() : mixed
- When adding a finder, save the instances of `SelectorSyntaxFinder`.
- addInlineStyleBlockRuleCallback() : mixed
- Add a callable after a blocked inline CSS rule got found, and we need to decide to block it or not.
- addInlineStyleModifyDocumentsCallback() : mixed
- Add a callable after a blocked inline style got found, parsed and you can modify the `Document` instance.
- addInlineStyleShouldBeExtractedCallback() : mixed
- Add a callable after a blocked inline style got found and skip creation of a second document with blocked URLs.
- addKeepAlwaysAttributes() : mixed
- In some cases we need to keep the attributes as original instead of prefix it with `consent-original-`.
- addKeepAlwaysAttributesCallback() : mixed
- Add a callable after a match got found and the matcher decided if it should be blocked or not.
- addKeepAlwaysAttributesIfClass() : mixed
- See `addKeepAlwaysAttributes`, but consider the keep only if the found match has a given class.
- addNotBlockedMatchCallback() : mixed
- Add a callable after a blocked match got not found, but a match. Parameters: `BlockedResult $result, AbstractMatcher $matcher, AbstractMatch $match`.
- addPlugin() : mixed
- Register a complete plugin to this headless content blocker.
- addReplaceAlwaysAttributes() : mixed
- A set of HTML tags => attribute names which should always prefix with `consent-original-`.
- addSelectorSyntaxMap() : mixed
- Respect additional selector-syntax as blockable candiates. All mentioned attributes will be checked with the defined blockables.
- addSetupCallback() : mixed
- Add a callable before the content blocker gets setup.
- addSkipInlineScriptVariableAssignments() : mixed
- Do not block inline scripts starting with `var $variableName =`.
- addSkipInlineScriptVariableAssignmentsCallback() : mixed
- Add a callable after a match got found and skip a script by custom variable name.
- addTagAttributeMap() : mixed
- Respect additional tags and attributes for a given map. For example, there is the `self::TAG_ATTRIBUTE_MAP_LINKABLE` map which respects known linkable tags like `script[src],link[href],iframe[href]`.
- addVisualParentCallback() : mixed
- Decide a visual parent for an individual match.
- addVisualParentIfClass() : mixed
- See `Constants::HTML_ATTRIBUTE_VISUAL_PARENT` for more details about this mechanism.
- blockablesToHosts() : mixed
- Create an expression => regular expression cache for all available URLs in available blockables.
- findOriginalMarkup() : mixed
- Find the original markup from a given markup without any transformations.
- findPotentialSelectorSyntaxFindersForMatch() : array<string|int, SelectorSyntaxFinder>
- Find potential selector syntax finders for a given match. You need to use `matchesAttributes` on the match to check if the match is covered by the returned finders.
- getBlockableById() : mixed
- Get blockable by blocker ID.
- getBlockableRulesStartingWith() : array<string|int, array<string|int, mixed>>
- Get blockable rules starting with a given string. This does only work for non-Selector-Syntax expressions.
- getBlockables() : mixed
- Getter.
- getFinderToMatcher() : mixed
- Getter.
- getInlineStyleDummyUrlPath() : mixed
- Getter.
- getKeepAlwaysAttributes() : mixed
- Getter.
- getKeepAlwaysAttributesIfClass() : mixed
- Getter.
- getMarkupPool() : mixed
- Getter.
- getPlugins() : mixed
- Getter.
- getPluginsByClassName() : mixed
- Getter.
- getReplaceAlwaysAttributes() : mixed
- Getter.
- getSelectorSyntaxMap() : mixed
- Getter.
- getSkipInlineScriptVariableAssignments() : mixed
- Getter.
- getTagAttributeMap() : mixed
- Getter.
- getVisualParentIfClass() : mixed
- Getter.
- isAllowMultipleBlockerResults() : mixed
- Getter.
- processMatch() : mixed
- A match got found from one of our finders. Run plugins and hooks.
- removeBlockedMatchCallback() : mixed
- Remove a callback added through `addBlockedMatchCallback`.
- runBeforeSetBlockedInResultCallback() : bool
- Run registered callbacks before a blockable and expression gets added to a `BlockedResult`.
- runBlockableStringExpressionCallback() : mixed
- Run registered blockable string expression callbacks.
- runCheckResultCallback() : BlockedResult
- Run registered check-result callbacks.
- runInlineStyleBlockRuleCallback() : BlockedResult
- Run registered check-result callbacks.
- runInlineStyleModifyDocumentsCallback() : mixed
- Run registered callbacks to not extract blocked CSS rules to a second document.
- runInlineStyleShouldBeExtractedByCallback() : bool
- Run registered callbacks to not extract blocked CSS rules to a second document.
- runKeepAlwaysAttributesCallback() : array<string|int, string>
- Run registered keep-always-attributes callbacks.
- runSkipInlineScriptVariableAssignmentsCallback() : array<string|int, string>
- Run registered skip-inline-names callbacks.
- runVisualParentCallback() : mixed
- Run registered check-result callbacks.
- setAllowMultipleBlockerResults() : mixed
- If you pass `true`, the generated `BlockedResult` will contain multiple results and will not break after the first found blockable to block.
- setBlockables() : mixed
- Set blockable items. In general, this are the URLs and elements you want to block.
- setInlineStyleDummyUrlPath() : mixed
- When blocking CSS inline styles, we replace URLs with dummy URLs and we cannot rely on data-uri's as we need to pass parameters, too.
- setup() : mixed
- Setup the content blocker mechanism. You need to use this before you `modifyAny/modifyHtml` your content!
- init() : mixed
- Add a callback which should throw an `Exception` when the content blocker is not setup.
- persistMarkupChain() : mixed
- Persist the markup chain so we can reconstruct the original match in the scanner.
- runAfterSetupCallback() : mixed
- Run registered after-setup callbacks.
- runBeforeMatchCallback() : mixed
- Run registered before-match callbacks.
- runBlockedMatchCallback() : mixed
- Run registered blocked-match callbacks.
- runNotBlockedMatchCallback() : mixed
- Run registered not-blocked-match callbacks.
- runSetupCallback() : mixed
- Run registered setup callbacks.
Constants
TAG_ATTRIBUTE_MAP_LINKABLE
The tag-attribute map for the usual links like `script[src],link[href],iframe[href]`.
public
mixed
TAG_ATTRIBUTE_MAP_LINKABLE
= 'linkable'
Properties
$afterSetupCallbacks
private
mixed
$afterSetupCallbacks
= []
$allowMultipleBlockerResults
private
mixed
$allowMultipleBlockerResults
= false
$beforeMatchCallbacks
private
mixed
$beforeMatchCallbacks
= []
$beforeSetBlockedInResultCallback
private
mixed
$beforeSetBlockedInResultCallback
= []
$blockables
List of blocked elements.
private
array<string|int, AbstractBlockable>
$blockables
= []
$blockablesToHostsCache
private
mixed
$blockablesToHostsCache
= null
$blockableStringExpressionCallback
private
mixed
$blockableStringExpressionCallback
= []
$blockedMatchCallbacks
private
mixed
$blockedMatchCallbacks
= []
$checkResultCallbacks
private
mixed
$checkResultCallbacks
= []
$finderToMatcher
private
mixed
$finderToMatcher
$inlineStyleBlockRuleByCallback
private
mixed
$inlineStyleBlockRuleByCallback
= []
$inlineStyleDummyUrlPath
private
mixed
$inlineStyleDummyUrlPath
= null
$inlineStyleModifyDocumentsByCallback
private
mixed
$inlineStyleModifyDocumentsByCallback
= []
$inlineStyleShouldBeExtractedByCallback
private
mixed
$inlineStyleShouldBeExtractedByCallback
= []
$isSetup
private
mixed
$isSetup
= false
$keepAlwaysAttributes
private
mixed
$keepAlwaysAttributes
= []
$keepAlwaysAttributesByCallback
private
mixed
$keepAlwaysAttributesByCallback
= []
$keepAlwaysAttributesIfClass
private
mixed
$keepAlwaysAttributesIfClass
= []
$markupChain
private
mixed
$markupChain
= []
$markupPool
Pool of all found markups.
private
array<string|int, Markup>
$markupPool
= []
$notBlockedMatchCallbacks
private
mixed
$notBlockedMatchCallbacks
= []
$plugins
List of registered plugins pointing to their object instance.
private
array<string|int, array<string|int, AbstractPlugin>>
$plugins
= []
$replaceAlwaysAttributes
private
mixed
$replaceAlwaysAttributes
= ['iframe' => ['sandbox'], 'script' => ['type'], 'style' => ['type']]
$rerunExceptions
See `processMatch`.
private
array<string|int, RerunOnMatchException>
$rerunExceptions
= []
$selectorSyntaxFindersTagMatrix
This array holds instances of SelectorSyntaxFinder indexed by their associated tag.
private
array<string, array<string, array<string|int, SelectorSyntaxFinder>>>
$selectorSyntaxFindersTagMatrix
= []
Each entry is an array containing the first attribute of the finder and the finder instance itself.
Why? Get possible selector syntax finders for a match. See also findPotentialSelectorSyntaxFindersForMatch
.
$selectorSyntaxMap
Selector syntax map.
private
array<string|int, string>
$selectorSyntaxMap
= []
$setupCallbacks
private
mixed
$setupCallbacks
= []
$skipInlineScriptVariableAssignments
private
mixed
$skipInlineScriptVariableAssignments
= []
$skipInlineScriptVariableAssignmentsByCallback
private
mixed
$skipInlineScriptVariableAssignmentsByCallback
= []
$tagAttributeMap
private
mixed
$tagAttributeMap
= [self::TAG_ATTRIBUTE_MAP_LINKABLE => ['tags' => ['script', 'link', 'iframe', 'embed', 'img', 'video', 'source', 'audio'], 'attr' => ['href', 'data-src', 'src', 'poster']]]
$visualParentCallback
private
mixed
$visualParentCallback
= []
$visualParentIfClass
private
mixed
$visualParentIfClass
= []
Methods
__construct()
C'tor.
public
__construct() : mixed
addAfterSetupCallback()
Add a callable after the content blocker got setup.
public
addAfterSetupCallback(callable $callback) : mixed
Parameters
- $callback : callable
addBeforeMatchCallback()
Add a callable before a match got found (this does not mean that the match is blocked!).
public
addBeforeMatchCallback(callable $callback) : mixed
Parameters: AbstractMatcher $matcher, AbstractMatch $match
.
Parameters
- $callback : callable
addBeforeSetBlockedInResultCallback()
Add a callable before an blockable and expression gets added to a `BlockedResult`.
public
addBeforeSetBlockedInResultCallback(callable $callback) : mixed
Parameters
- $callback : callable
addBlockables()
Add a blockable item. In general, this are the URLs and elements you want to block.
public
addBlockables(array<string|int, AbstractBlockable> $blockables) : mixed
Parameters
- $blockables : array<string|int, AbstractBlockable>
addBlockableStringExpressionCallback()
Allows to modify the passed string expression to a blockable.
public
addBlockableStringExpressionCallback(callable $callback) : mixed
Parameters: string $expression, Blockable $blockable
.
This function needs to return a string
!
Parameters
- $callback : callable
addBlockedMatchCallback()
Add a callable after a blocked match got found so you can alter the match again. Parameters: `BlockedResult $result, AbstractMatcher $matcher, AbstractMatch $match`.
public
addBlockedMatchCallback(callable $callback) : mixed
Parameters
- $callback : callable
addCheckResultCallback()
Add a callable after a match got found and the matcher decided if it should be blocked or not.
public
addCheckResultCallback(callable $callback) : mixed
Parameters: BlockedResult $result, AbstractMatcher $matcher, AbstractMatch $match
.
This function needs to return a BlockedResult
instance.
Parameters
- $callback : callable
addFinder()
When adding a finder, save the instances of `SelectorSyntaxFinder`.
public
addFinder(AbstractFinder $finder) : mixed
Parameters
- $finder : AbstractFinder
addInlineStyleBlockRuleCallback()
Add a callable after a blocked inline CSS rule got found, and we need to decide to block it or not.
public
addInlineStyleBlockRuleCallback(callable $callback) : mixed
Parameters: BlockedResult $extract, string $url, StyleInlineMatcher $matcher, StyleInlineMatch $match
.
Parameters
- $callback : callable
addInlineStyleModifyDocumentsCallback()
Add a callable after a blocked inline style got found, parsed and you can modify the `Document` instance.
public
addInlineStyleModifyDocumentsCallback(callable $callback) : mixed
Parameters: boolean $extract, StyleInlineMatcher $matcher, StyleInlineMatch $match
.
Parameters
- $callback : callable
addInlineStyleShouldBeExtractedCallback()
Add a callable after a blocked inline style got found and skip creation of a second document with blocked URLs.
public
addInlineStyleShouldBeExtractedCallback(callable $callback) : mixed
Parameters: boolean $extract, StyleInlineMatcher $matcher, StyleInlineMatch $match
.
This function needs to return a boolean
array!
Parameters
- $callback : callable
addKeepAlwaysAttributes()
In some cases we need to keep the attributes as original instead of prefix it with `consent-original-`.
public
addKeepAlwaysAttributes(array<string|int, string> $attributes) : mixed
Keep in mind, that no external data should be loaded if the attribute is set!
Parameters
- $attributes : array<string|int, string>
addKeepAlwaysAttributesCallback()
Add a callable after a match got found and the matcher decided if it should be blocked or not.
public
addKeepAlwaysAttributesCallback(callable $callback) : mixed
Parameters: string[] $keepAttributes, AbstractMatcher $matcher, AbstractMatch $match
.
This function needs to return a string[]
array!
Parameters
- $callback : callable
addKeepAlwaysAttributesIfClass()
See `addKeepAlwaysAttributes`, but consider the keep only if the found match has a given class.
public
addKeepAlwaysAttributesIfClass(array<string|int, array<string|int, string>> $classToAttributesMap) : mixed
Parameters
- $classToAttributesMap : array<string|int, array<string|int, string>>
addNotBlockedMatchCallback()
Add a callable after a blocked match got not found, but a match. Parameters: `BlockedResult $result, AbstractMatcher $matcher, AbstractMatch $match`.
public
addNotBlockedMatchCallback(callable $callback) : mixed
Parameters
- $callback : callable
addPlugin()
Register a complete plugin to this headless content blocker.
public
addPlugin(string $pluginName) : mixed
Parameters
- $pluginName : string
-
The class name of the plugin (extended from
AbstractPlugin
)
addReplaceAlwaysAttributes()
A set of HTML tags => attribute names which should always prefix with `consent-original-`.
public
addReplaceAlwaysAttributes(array<string|int, array<string|int, string>> $tagToAttributesMap) : mixed
Parameters
- $tagToAttributesMap : array<string|int, array<string|int, string>>
Tags
addSelectorSyntaxMap()
Respect additional selector-syntax as blockable candiates. All mentioned attributes will be checked with the defined blockables.
public
addSelectorSyntaxMap(array<string|int, string> $selectorSyntax) : mixed
For example, a[href][class*="my-class"]
will check if href
got blocked through a blockable, and additionally if the class
matches my-class
.
Parameters
- $selectorSyntax : array<string|int, string>
addSetupCallback()
Add a callable before the content blocker gets setup.
public
addSetupCallback(callable $callback) : mixed
Parameters
- $callback : callable
addSkipInlineScriptVariableAssignments()
Do not block inline scripts starting with `var $variableName =`.
public
addSkipInlineScriptVariableAssignments(array<string|int, string> $names) : mixed
Parameters
- $names : array<string|int, string>
addSkipInlineScriptVariableAssignmentsCallback()
Add a callable after a match got found and skip a script by custom variable name.
public
addSkipInlineScriptVariableAssignmentsCallback(callable $callback) : mixed
Parameters: string[] $variableNames, ScriptInlineMatcher $matcher, ScriptInlineMatch $match
.
This function needs to return a string[]
array!
Parameters
- $callback : callable
addTagAttributeMap()
Respect additional tags and attributes for a given map. For example, there is the `self::TAG_ATTRIBUTE_MAP_LINKABLE` map which respects known linkable tags like `script[src],link[href],iframe[href]`.
public
addTagAttributeMap(array<string|int, string> $tags[, array<string|int, string> $attributes = [] ][, string $mapName = self::TAG_ATTRIBUTE_MAP_LINKABLE ]) : mixed
Parameters
- $tags : array<string|int, string>
-
Additional tags to consider for the passed map
- $attributes : array<string|int, string> = []
-
Additional tags to consider for the passed map
- $mapName : string = self::TAG_ATTRIBUTE_MAP_LINKABLE
-
Default is
self::TAG_ATTRIBUTE_MAP_LINKABLE
addVisualParentCallback()
Decide a visual parent for an individual match.
public
addVisualParentCallback(callable $callback) : mixed
Parameters: boolean|string|number $useVisualParent, AbstractMatcher $matcher, AbstractMatch $match
.
This function needs to return a boolean|string|number
array!
Parameters
- $callback : callable
addVisualParentIfClass()
See `Constants::HTML_ATTRIBUTE_VISUAL_PARENT` for more details about this mechanism.
public
addVisualParentIfClass(array<string|int, array<string|int, string>> $classToVisualParent) : mixed
Parameters
- $classToVisualParent : array<string|int, array<string|int, string>>
blockablesToHosts()
Create an expression => regular expression cache for all available URLs in available blockables.
public
blockablesToHosts([bool $contains = true ][, array<string|int, AbstractBlockable> $useBlockables = null ]) : mixed
Parameters
- $contains : bool = true
- $useBlockables : array<string|int, AbstractBlockable> = null
findOriginalMarkup()
Find the original markup from a given markup without any transformations.
public
findOriginalMarkup(Markup $markup) : mixed
Parameters
- $markup : Markup
findPotentialSelectorSyntaxFindersForMatch()
Find potential selector syntax finders for a given match. You need to use `matchesAttributes` on the match to check if the match is covered by the returned finders.
public
findPotentialSelectorSyntaxFindersForMatch(string $tag, array<string|int, string> $attributeNames) : array<string|int, SelectorSyntaxFinder>
Parameters
- $tag : string
- $attributeNames : array<string|int, string>
Return values
array<string|int, SelectorSyntaxFinder>getBlockableById()
Get blockable by blocker ID.
public
getBlockableById(int $id) : mixed
Parameters
- $id : int
getBlockableRulesStartingWith()
Get blockable rules starting with a given string. This does only work for non-Selector-Syntax expressions.
public
getBlockableRulesStartingWith(string $prefix[, bool $onlyExpressions = false ][, array<string|int, AbstractBlockable> $blockables = null ]) : array<string|int, array<string|int, mixed>>
Example: avf_exclude_assets:avia_google_maps_api_script
-> search by avf_exclude_assets:
and it will return
an array with [['expression' => 'avia_google_maps_api_script', 'blockable' => AbstractBlockable instance]]
.
Parameters
- $prefix : string
- $onlyExpressions : bool = false
- $blockables : array<string|int, AbstractBlockable> = null
Return values
array<string|int, array<string|int, mixed>>getBlockables()
Getter.
public
getBlockables() : mixed
getFinderToMatcher()
Getter.
public
getFinderToMatcher() : mixed
getInlineStyleDummyUrlPath()
Getter.
public
getInlineStyleDummyUrlPath() : mixed
getKeepAlwaysAttributes()
Getter.
public
getKeepAlwaysAttributes() : mixed
getKeepAlwaysAttributesIfClass()
Getter.
public
getKeepAlwaysAttributesIfClass() : mixed
getMarkupPool()
Getter.
public
& getMarkupPool() : mixed
This also allows you to clear the markup pool by using = []
to the retrieved reference.
getPlugins()
Getter.
public
getPlugins() : mixed
Tags
getPluginsByClassName()
Getter.
public
getPluginsByClassName(string $className) : mixed
Parameters
- $className : string
Tags
getReplaceAlwaysAttributes()
Getter.
public
getReplaceAlwaysAttributes() : mixed
getSelectorSyntaxMap()
Getter.
public
getSelectorSyntaxMap() : mixed
Tags
getSkipInlineScriptVariableAssignments()
Getter.
public
getSkipInlineScriptVariableAssignments() : mixed
getTagAttributeMap()
Getter.
public
getTagAttributeMap() : mixed
getVisualParentIfClass()
Getter.
public
getVisualParentIfClass() : mixed
isAllowMultipleBlockerResults()
Getter.
public
isAllowMultipleBlockerResults() : mixed
processMatch()
A match got found from one of our finders. Run plugins and hooks.
public
processMatch(AbstractMatcher $matcher, AbstractMatch $match) : mixed
Parameters
- $matcher : AbstractMatcher
- $match : AbstractMatch
removeBlockedMatchCallback()
Remove a callback added through `addBlockedMatchCallback`.
public
removeBlockedMatchCallback(callable $callback) : mixed
Parameters
- $callback : callable
Tags
runBeforeSetBlockedInResultCallback()
Run registered callbacks before a blockable and expression gets added to a `BlockedResult`.
public
runBeforeSetBlockedInResultCallback(BlockedResult $result, AbstractBlockable $blockable, string $expression, AbstractMatcher $matcher) : bool
Parameters
- $result : BlockedResult
- $blockable : AbstractBlockable
- $expression : string
- $matcher : AbstractMatcher
Return values
boolrunBlockableStringExpressionCallback()
Run registered blockable string expression callbacks.
public
runBlockableStringExpressionCallback(string $expression, AbstractBlockable $blockable) : mixed
Parameters
- $expression : string
- $blockable : AbstractBlockable
runCheckResultCallback()
Run registered check-result callbacks.
public
runCheckResultCallback(BlockedResult $result, AbstractMatcher $matcher, AbstractMatch $match) : BlockedResult
Parameters
- $result : BlockedResult
- $matcher : AbstractMatcher
- $match : AbstractMatch
Return values
BlockedResultrunInlineStyleBlockRuleCallback()
Run registered check-result callbacks.
public
runInlineStyleBlockRuleCallback(BlockedResult $result, string $url, AbstractMatcher $matcher, AbstractMatch $match) : BlockedResult
Parameters
- $result : BlockedResult
- $url : string
- $matcher : AbstractMatcher
- $match : AbstractMatch
Return values
BlockedResultrunInlineStyleModifyDocumentsCallback()
Run registered callbacks to not extract blocked CSS rules to a second document.
public
runInlineStyleModifyDocumentsCallback(Document $document, Document $extractedDocument, StyleInlineMatcher $matcher, StyleInlineMatch $match) : mixed
Parameters
- $document : Document
- $extractedDocument : Document
- $matcher : StyleInlineMatcher
- $match : StyleInlineMatch
runInlineStyleShouldBeExtractedByCallback()
Run registered callbacks to not extract blocked CSS rules to a second document.
public
runInlineStyleShouldBeExtractedByCallback(bool $extract, StyleInlineMatcher $matcher, StyleInlineMatch $match) : bool
Parameters
- $extract : bool
- $matcher : StyleInlineMatcher
- $match : StyleInlineMatch
Return values
boolrunKeepAlwaysAttributesCallback()
Run registered keep-always-attributes callbacks.
public
runKeepAlwaysAttributesCallback(array<string|int, string> $keepAttributes, AbstractMatcher $matcher, AbstractMatch $match) : array<string|int, string>
Parameters
- $keepAttributes : array<string|int, string>
- $matcher : AbstractMatcher
- $match : AbstractMatch
Return values
array<string|int, string>runSkipInlineScriptVariableAssignmentsCallback()
Run registered skip-inline-names callbacks.
public
runSkipInlineScriptVariableAssignmentsCallback(array<string|int, string> $names, ScriptInlineMatcher $matcher, ScriptInlineMatch $match) : array<string|int, string>
Parameters
- $names : array<string|int, string>
- $matcher : ScriptInlineMatcher
- $match : ScriptInlineMatch
Return values
array<string|int, string>runVisualParentCallback()
Run registered check-result callbacks.
public
runVisualParentCallback(bool|string|number $visualParent, AbstractMatcher $matcher, AbstractMatch $match) : mixed
Parameters
- $visualParent : bool|string|number
- $matcher : AbstractMatcher
- $match : AbstractMatch
setAllowMultipleBlockerResults()
If you pass `true`, the generated `BlockedResult` will contain multiple results and will not break after the first found blockable to block.
public
setAllowMultipleBlockerResults(bool $status) : mixed
Parameters
- $status : bool
setBlockables()
Set blockable items. In general, this are the URLs and elements you want to block.
public
setBlockables(array<string|int, AbstractBlockable> $blockables) : mixed
Parameters
- $blockables : array<string|int, AbstractBlockable>
setInlineStyleDummyUrlPath()
When blocking CSS inline styles, we replace URLs with dummy URLs and we cannot rely on data-uri's as we need to pass parameters, too.
public
setInlineStyleDummyUrlPath(string $urlPath) : mixed
Default: https://assets.devowl.io/packages/devowl-wp/headless-content-blocker/
In the folder there need to exist the following two files: dummy.css
, dummy.png
.
Parameters
- $urlPath : string
Tags
setup()
Setup the content blocker mechanism. You need to use this before you `modifyAny/modifyHtml` your content!
public
setup() : mixed
init()
Add a callback which should throw an `Exception` when the content blocker is not setup.
protected
init() : mixed
persistMarkupChain()
Persist the markup chain so we can reconstruct the original match in the scanner.
protected
persistMarkupChain(string $originalMatch, AbstractMatch $match) : mixed
Parameters
- $originalMatch : string
- $match : AbstractMatch
runAfterSetupCallback()
Run registered after-setup callbacks.
protected
runAfterSetupCallback() : mixed
runBeforeMatchCallback()
Run registered before-match callbacks.
protected
runBeforeMatchCallback(AbstractMatcher $matcher, AbstractMatch $match) : mixed
Parameters
- $matcher : AbstractMatcher
- $match : AbstractMatch
runBlockedMatchCallback()
Run registered blocked-match callbacks.
protected
runBlockedMatchCallback(BlockedResult $result, AbstractMatcher $matcher, AbstractMatch $match) : mixed
Parameters
- $result : BlockedResult
- $matcher : AbstractMatcher
- $match : AbstractMatch
runNotBlockedMatchCallback()
Run registered not-blocked-match callbacks.
protected
runNotBlockedMatchCallback(BlockedResult $result, AbstractMatcher $matcher, AbstractMatch $match) : mixed
Parameters
- $result : BlockedResult
- $matcher : AbstractMatcher
- $match : AbstractMatch
runSetupCallback()
Run registered setup callbacks.
protected
runSetupCallback() : mixed