AdGuard Browser Extension for Chrome MV3
As MV2 extensions are being phased out in the Chrome Web Store, Chrome users may need to switch to MV3 extensions that are compatible with Chrome’s new API Manifest V3. Our thoughts on this topic are extensively discussed on our blog.
Our MV3 extension effectively blocks ads and trackers while seamlessly managing social widgets, banners, and video ads. Most users will not notice any operational differences, but there are some limitations and changes to be aware of.
Where to find our extensions
The MV3 version has replaced our old extension in the Chrome Web Store.
The beta version of MV3 will still be available in the Chrome Web Store.
The old beta extension will be renamed to AdGuard Ad Blocker MV2 and will be supported until Google phases it out.
Main changes in features and settings
- No auto and manual filter updates. The options Auto-update filters and Check filters update are no longer available in the Filters tab. Since some of the rules are now applied in DNR form, we can’t update filters on request, only through the full process of updating the extension along with the review in the stores. 
- Filtering log  - Due to DNR restrictions, we can’t show exactly which rule worked, but we will provide an “assumed rule that was triggered” based on our engine. For precise information, you’ll need to install the “unpacked” form of the extension in your browser yourself. You’ll find detailed instructions on how to do this in a separate article. 
- Tracking protection (formerly known as Stealth mode)  - There are no Cookies section, along with Self-destruction of first-party cookies and Self-destruction of third-party cookies since we cannot set the TTL of cookies using declarative rules. 
- Phishing & malware protection is no longer available in the general settings. To protect yourself from malicious websites and scams, enable the appropriate Security filters in the Filters tab.  
Limitations
Maximum number of rules and filters
Manifest V3 imposes limits on static and regex rules per extension. Users may receive notifications when these limits are exceeded.


Basically, Manifest V3 divides rules into static (built-in) and dynamic, with strict limits in place.
Static rules: minimum 30,000 rules per extension, with a cumulative limit of 330,000 for all extensions installed by a single user.
For regex rules, the limit is set at 1,000 per extension.
The maximum number of simultaneously enabled filters is 50.
Dynamic rules: a strict cap of 5,000 rules is imposed, which includes a maximum of 1,000 regex rules.
If this limit is exceeded, only 5,000 converted rules will be applied in the following order: first Allowlist, then User rules and finally Custom filters.
Converted rules are rules that have been transformed to DNR format using the declarative converter. During this conversion process, some rules may overwrite others (
$badfilter), some may be combined ($removeparam), resulting in a list of rules with a slightly different order.From this list of converted rules, we will only use 5,000 rules. The rest of them will be displayed in the editor, but not applied.
Here's how a rule with a basic modifier is converted to a declarative rule:
||example.org^$script,third-party,domain=example.com
is converted to
[
    {
        "id": 1,
        "action": {
            "type": "block"
        },
        "condition": {
            "urlFilter": "||example.org^",
            "domainType": "thirdParty",
            "initiatorDomains": [
                "example.com"
            ],
            "resourceTypes": [
                "script"
            ]
        },
        "priority": 302
    }
]
More examples can be found on GitHub.
Network rule modifiers
Network rule modifiers have limitations: some of them cannot be implemented in MV3, or can only be implemented with restrictions.
More details about the limitations can be found on GitHub. For further information on modifiers, please refer to our Knowledge base.