Documentation

Blocker
in package
Uses UtilsProvider

Block common HTML tags!

Table of Contents

Constants

BUTTON_CLICKED_IDENTIFIER  = 'unblock'
DEPENDANT_VISIBILITY_CONTAINERS  = [ '[role="tabpanel"]', // [Plugin Comp] https://wordpress.org/plugins/essential-addons-for-elementor-lite/ '.eael-tab-content-item', // [Plugin Comp] https://de.wordpress.org/plugins/wp-contact-slider/ '.wpcs_content_inner', // [Plugin Comp] OptimizePress '.op3-contenttoggleitem-content', '.op3-popoverlay-content', // [Plugin Comp] Popup Maker '.pum-overlay', // [Plugin Comp] Elementor Pro Popups '[data-elementor-type="popup"]', // [Plugin Comp] https://ultimateblocks.com/content-toggle-accordion-block/ '.wp-block-ub-content-toggle-accordion-content-wrap', // [Plugin Comp] Impreza '.w-popup-wrap', // [Plugin Comp] Oxygen Builder '.oxy-lightbox_inner[data-inner-content=true]', '.oxy-pro-accordion_body', '.oxy-tab-content', // [Plugin Comp] https://wordpress.org/plugins/kadence-blocks/ '.kt-accordion-panel', // [Plugin Comp] WP Bakery Tabs '.vc_tta-panel-body', // [Plugin Comp] Magnific popup '.mfp-hide', // [Plugin Comp] Thrive Architect lightbox 'div[id^="tve_thrive_lightbox_"]', // [Plugin Comp] Bricks '.brxe-xpromodalnestable', ]
See `dependantVisibilityContainers` parameter in `createVisual` for more information.
DISABLE_DEDUPLICATE_EXCEPTIONS  = [ // [Plugin Comp] Divi Builder '.et_pb_video_slider', ]
See `disableDeduplicateExceptions` parameter in `createVisual` for more information.
FORCE_TIME_COMMENT_QUERY_ARG  = 'rcb-calc-time'
Force to output the needed computing time at the end of the page for debug purposes.
OB_START_PLUGINS_LOADED_PRIORITY  = (PHP_INT_MAX - 1) * -1
VISUAL_PARENT_SELECTORS  = [ // [Plugin Comp] Divi Builder '.et_pb_video_box' => 1, '.et_pb_video_slider:has(>.et_pb_slider_carousel %s)' => 'self', // [Theme Comp] Astra Theme (Gutenberg Block) '.ast-oembed-container' => 1, // [Plugin Comp] WP Bakery '.wpb_video_wrapper' => 1, // [Plugin Comp] GoodLayers page builder '.gdlr-core-pbf-background-wrap' => 1, ]
See `visualParentSelectors` parameter in `findVisualParent` for more information.

Properties

$blockedHandles  : mixed
A list of handles which got blocked. They are lazily detected through e.g. `sgo_js_minify_exclude`.
$headlessContentBlocker  : HeadlessContentBlocker
See `HeadlessContentBlocker`
$processedOutputBufferHtmlHashes  : mixed
A list of MD5 hashes of HTML strings which got successfully processed. This allows you to run `registerOutputBuffer` multiple times.

Methods

autoptimize_filter_css_exclude()  : mixed
Exclude blocked styles from autoptimize inline aggregation.
avf_exclude_assets()  : mixed
Exclude blocked styles and scripts
closeOutputBuffer()  : mixed
Close a output buffer. This is not necessarily needed as PHP automatically closes them, but in some cases it is needed to make the modified content available to previously read output buffers in e.g.
getHeadlessContentBlocker()  : mixed
Get `HeadlessContentBlocker` instance.
getPluginConstantPrefix()  : string
Get the prefix of this plugin so composer packages can dynamically build other constant values on it.
instance()  : mixed
New instance.
modifyOEmbedHtmlToKeepOriginalUrl()  : mixed
Modify the HTML of an oEmbed HTML and keep the original pasted URL as attribute so our headless content blocker can generate an image preview from the original URL.
modifyUrlToSkipContentBlocker()  : mixed
Modify any URL and add a query argument to skip the content blocker mechanism.
ob_start()  : mixed
Event for ob_start.
registerOutputBuffer()  : mixed
Apply the content blocker attributes to the output buffer when it is enabled.
replace()  : mixed
Apply content blockers to a given HTML. It also supports JSON output.
sgo_css_minify_exclude()  : mixed
Exclude blocked styles from SiteGround Optimizer optimizations.
sgo_js_minify_exclude()  : mixed
Exclude blocked scripts from SiteGround Optimizer optimizations.
createBlockables()  : array<string|int, AbstractBlockable>
Get all available blockables.
isAdminAjaxAction()  : mixed
Allows to modify content within a `admin-ajax.php` action.
isCurrentRequestException()  : mixed
Check if the current request should not load any blocking mechanism depending on a special condition.
isEnabled()  : mixed
Check if content blocker is enabled on the current request.
iterateBlockedHandles()  : mixed
Iterate over all dependencies and add them to the blocked handles list if they are not already in the list.
__construct()  : mixed
C'tor.

Constants

BUTTON_CLICKED_IDENTIFIER

public mixed BUTTON_CLICKED_IDENTIFIER = 'unblock'

DEPENDANT_VISIBILITY_CONTAINERS

See `dependantVisibilityContainers` parameter in `createVisual` for more information.

public mixed DEPENDANT_VISIBILITY_CONTAINERS = [ '[role="tabpanel"]', // [Plugin Comp] https://wordpress.org/plugins/essential-addons-for-elementor-lite/ '.eael-tab-content-item', // [Plugin Comp] https://de.wordpress.org/plugins/wp-contact-slider/ '.wpcs_content_inner', // [Plugin Comp] OptimizePress '.op3-contenttoggleitem-content', '.op3-popoverlay-content', // [Plugin Comp] Popup Maker '.pum-overlay', // [Plugin Comp] Elementor Pro Popups '[data-elementor-type="popup"]', // [Plugin Comp] https://ultimateblocks.com/content-toggle-accordion-block/ '.wp-block-ub-content-toggle-accordion-content-wrap', // [Plugin Comp] Impreza '.w-popup-wrap', // [Plugin Comp] Oxygen Builder '.oxy-lightbox_inner[data-inner-content=true]', '.oxy-pro-accordion_body', '.oxy-tab-content', // [Plugin Comp] https://wordpress.org/plugins/kadence-blocks/ '.kt-accordion-panel', // [Plugin Comp] WP Bakery Tabs '.vc_tta-panel-body', // [Plugin Comp] Magnific popup '.mfp-hide', // [Plugin Comp] Thrive Architect lightbox 'div[id^="tve_thrive_lightbox_"]', // [Plugin Comp] Bricks '.brxe-xpromodalnestable', ]

DISABLE_DEDUPLICATE_EXCEPTIONS

See `disableDeduplicateExceptions` parameter in `createVisual` for more information.

public mixed DISABLE_DEDUPLICATE_EXCEPTIONS = [ // [Plugin Comp] Divi Builder '.et_pb_video_slider', ]

FORCE_TIME_COMMENT_QUERY_ARG

Force to output the needed computing time at the end of the page for debug purposes.

public mixed FORCE_TIME_COMMENT_QUERY_ARG = 'rcb-calc-time'

OB_START_PLUGINS_LOADED_PRIORITY

public mixed OB_START_PLUGINS_LOADED_PRIORITY = (PHP_INT_MAX - 1) * -1

VISUAL_PARENT_SELECTORS

See `visualParentSelectors` parameter in `findVisualParent` for more information.

public mixed VISUAL_PARENT_SELECTORS = [ // [Plugin Comp] Divi Builder '.et_pb_video_box' => 1, '.et_pb_video_slider:has(>.et_pb_slider_carousel %s)' => 'self', // [Theme Comp] Astra Theme (Gutenberg Block) '.ast-oembed-container' => 1, // [Plugin Comp] WP Bakery '.wpb_video_wrapper' => 1, // [Plugin Comp] GoodLayers page builder '.gdlr-core-pbf-background-wrap' => 1, ]

Properties

$blockedHandles

A list of handles which got blocked. They are lazily detected through e.g. `sgo_js_minify_exclude`.

private mixed $blockedHandles = ['js' => [], 'css' => []]

$processedOutputBufferHtmlHashes

A list of MD5 hashes of HTML strings which got successfully processed. This allows you to run `registerOutputBuffer` multiple times.

private mixed $processedOutputBufferHtmlHashes = []

Methods

avf_exclude_assets()

Exclude blocked styles and scripts

public avf_exclude_assets(array<string|int, mixed> $assets) : mixed
Parameters
$assets : array<string|int, mixed>

closeOutputBuffer()

Close a output buffer. This is not necessarily needed as PHP automatically closes them, but in some cases it is needed to make the modified content available to previously read output buffers in e.g.

public closeOutputBuffer() : mixed

earlier WordPress hook lifecycle.

getHeadlessContentBlocker()

Get `HeadlessContentBlocker` instance.

public getHeadlessContentBlocker() : mixed

getPluginConstantPrefix()

Get the prefix of this plugin so composer packages can dynamically build other constant values on it.

public getPluginConstantPrefix() : string
Tags
codeCoverageIgnore

It only returns a string with the constant prefix

Return values
string

instance()

New instance.

public static instance() : mixed
Tags
codeCoverageIgnore

modifyUrlToSkipContentBlocker()

Modify any URL and add a query argument to skip the content blocker mechanism.

public modifyUrlToSkipContentBlocker(string $url) : mixed
Parameters
$url : string

ob_start()

Event for ob_start.

public ob_start(string $response) : mixed
Parameters
$response : string

registerOutputBuffer()

Apply the content blocker attributes to the output buffer when it is enabled.

public registerOutputBuffer() : mixed

You can start this output buffer multiple times as it is safe to avoid execution of same strings multiple times for the headless content blocker (e.g. multiple WordPress hook lifecycle).

replace()

Apply content blockers to a given HTML. It also supports JSON output.

public replace(string $html) : mixed

If you want to use this functionality in your plugin, please use the filter Consent/Block/HTML instead!

Parameters
$html : string

sgo_css_minify_exclude()

Exclude blocked styles from SiteGround Optimizer optimizations.

public sgo_css_minify_exclude(array<string|int, string> $excluded_handles) : mixed
Parameters
$excluded_handles : array<string|int, string>

sgo_js_minify_exclude()

Exclude blocked scripts from SiteGround Optimizer optimizations.

public sgo_js_minify_exclude(array<string|int, string> $excluded_handles) : mixed
Parameters
$excluded_handles : array<string|int, string>

isAdminAjaxAction()

Allows to modify content within a `admin-ajax.php` action.

protected isAdminAjaxAction() : mixed

isCurrentRequestException()

Check if the current request should not load any blocking mechanism depending on a special condition.

protected isCurrentRequestException() : mixed

isEnabled()

Check if content blocker is enabled on the current request.

protected isEnabled() : mixed

iterateBlockedHandles()

Iterate over all dependencies and add them to the blocked handles list if they are not already in the list.

protected iterateBlockedHandles(WP_Dependencies $dependencies) : mixed
Parameters
$dependencies : WP_Dependencies

__construct()

C'tor.

private __construct() : mixed
Tags
codeCoverageIgnore

        
On this page

Search results