If you want to make AdGuard better by creating new rules, follow the instructions below to make your ideas come to life faster!
Here's what you need to do before you start working on the repo.
Steps for contributors:
- If you don't have a GitHub account, create one.
- Install Git, Node.js and Yarn. These are essential tools for working with the repo.
- Install Visual Studio Code with the "Adblock" syntax plugin. We recommend using this editor to write filter rules.
- Fork the original repo and clone your fork (since you don't have write access to the original repo). If you don't know how to do it, please read this guide.
- Install dependencies by running
yarn
in the root of the repo. This will install AGLint and Husky. After the installation is complete, it will also callpostinstall
script that will install Husky pre-commit hook which will run AGLint on your changes before you commit them and will prevent you from committing if there are any errors. - Create a new branch for your changes. Please use the following naming
convention:
fix/123
where123
is the issue number you're working on. - Make your changes, test them and put them in the proper file or section of the file. Please read the Repository structure section below to learn more about the structure of the repo.
- If everything is fine, commit your changes. Please always make separate branches and commits for different issues and don't mix them in one. It is easier to manage and review them that way.
- Push your new branch to your fork. This will create a new branch in your fork with the same name as the one you created locally and doesn't affect the original repo at this point.
- Create a pull request from your fork to this repo and wait for the review. AGLint will run automatically on your PR and will report any errors. If there are any errors, fix them and push your changes to your fork. If AGLint passes, your PR will be reviewed by a maintainer.
- If the review is successful, your changes will be merged into the
master
branch.
Steps for maintainers:
- Installation and initial setup are the same as for contributors, but you don't need to fork the repo.
- If you want to skip Husky pre-commit hook locally, use
git commit --no-verify -m "commit message"
but it is not recommended. - If you want to skip check on GitHub Actions, add
[skip ci]
to the commit message.
- Make your changes and commit them.
- Each commit should be linked to an issue. The commit message should look
like the examples below. That way, the issue will be closed automatically
once the commit is merged into the
master
branch.Fix #123 example.org
where123
is the issue number andexample.org
is the website from the issue.Fix #123 comment
wherecomment
is your comment for additional fixes in the pull request.
Before you begin, please read and understand the current filters policy we adhere to. One of its most important points is the quality requirements.
The next step is creating rules.
- There is an official documentation that can help you.
- When you're done with creating rules, please take a look at the similar ones in the filters. This may help you to make a better version of the rule.
AdGuard filters are compiled from files in this repository. This is an automated process that is periodically run by scripts in the FiltersRegistry repo. In this repository, each filter list is divided into several files, and each file has its own purpose. If you're adding a new rule, make sure it is added to the proper file or section of the file.
General requirements for submitting rules: don't add rules to the beginning of the file, start entering them from line 4, for example. If you add rules with a task comment or hints, put them next to the same structure in the file.
- Purpose: this filter blocks various kinds of ads mostly on English-language and multilingual sites.
- Base folder
- Notes: The AdGuard Base filter includes Easylist if you use
AdGuard products, so there's no need to add rules which are already in
Easylist
.
- Purpose: this filter blocks various kinds of ads on mobile version of sites and in mobile apps.
- Mobile folder
- Purpose: this filter hides your actions online and helps avoid tracking.
- Tracking Protection folder
- Purpose: this filter removes various kinds of tracking parameters from sites.
- URL Tracking folder
- Purpose: this filter blocks various kinds of social widgets from sites.
- Social folder
-
Purpose: this filter blocks irritating elements on web pages including cookie notices, third-party widgets and in-page pop-ups.
-
Contains the following AdGuard filters: Cookie Notices, Popups, Mobile App Banners, Other Annoyances and Widgets:
-
Cookie Notices
Purpose: this filter blocks cookie notices on web pages.
-
Mobile App Banners
- Purpose: this filter blocks irritating banners that promote mobile apps of websites.
- MobileApp folder
-
Popups
- Purpose: this filter blocks all kinds of pop-ups that are not necessary for websites' operation.
- Popups folder
-
Widgets
- Purpose: this filter blocks annoying third-party widgets: online assistants, live support chats, etc.
- Widgets folder
-
Other Annoyances
- Purpose: this filter blocks irritating elements on web pages that do not fall under the popular categories of annoyances.
- Other folder
-
- Purpose: this filter serves to test some new filtering rules that can potentially cause conflicts and mess with websites' work. In case these rules perform without any issues, they get added to main filters.
- Experimental folder
- Purpose: this filter unblocks search engine result that may be useful to users.
- UsefulAdsFilter folder
- Purpose: this filter blocks various kinds of ads on Russian-language sites.
- Russian folder
- Purpose: this filter blocks various kinds of ads on Ukrainian-language sites.
- Ukrainian folder
- Purpose: this filter blocks various kinds of ads on Chinese-language sites.
- Chinese folder
- Notes: The AdGuard Chinese filter includes Easylist China
if you use AdGuard products, so there's no need to add rules which are already
in
Easylist China
.
- Purpose: this filter blocks various kinds of ads on Dutch-language sites.
- Dutch folder
- Purpose: this filter blocks various kinds of ads on French-language sites.
- French folder
- Notes: The AdGuard French filter includes Liste FR if you use
AdGuard products, so there's no need to add rules which are already in
Liste FR
.
- Purpose: this filter blocks various kinds of ads on German-language sites.
- German folder
- Notes: The AdGuard German filter includes Easylist Germany
if you use AdGuard products, so there's no need to add rules which are already
in
Easylist Germany
.
- Purpose: this filter blocks various kinds of ads on Japanese-language sites.
- Japanese folder
- Purpose: this filter blocks various kinds of ads on Spanish-language and Portuguese-language sites.
- Spanish folder
- Purpose: this filter blocks various kinds of ads on Turkish-language sites.
- Turkish folder