(Ad)sorber blocks ads by 'absorbing' and dumbing them into void.
Technically speaking, it adds ad-domains to the hosts file /etc/hosts
with a redirection to a non-existent ip 0.0.0.0
.
You can consider it as AdAway for Linux machines.
- Blocks advertisements system-wide, not only in the browser.
- Prevents annoying anti-adblockers from triggering.
- Update your ad-domain list with domains from external external sources (like https://adaway.org/hosts.txt).
- Automatically update the hosts file with schedulers (cronjob or systemd service).
- Revert to the previous hosts file if the current hosts file contains broken ad-domains.
- White- and blacklist.
root
rights (e.g. withsudo
)- The following should be supported on all distros by default:
/bin/sh
/etc/hosts
curl
orwget
Download Adsorber from releases
or clone it.
Two possibilites:
- Install to system (recommended)
- Portable mode without installation
Adsorber will be placed onto your system (to /usr/local/
).
- Execute the file
./place_files_onto_system.sh
- Run the command
adsorber setup
- Answer the prompts to configure Adsorber
- Finished!
If you have a super custom system you can configure where Adsorber should be placed, edit the relevant lines in place_files_onto_system.sh
and remove_files_from_system.sh
However the default path (/usr/local/
) is the default for external scripts on Linux (see here) and should be fine for most systems.
Placing Adsorber has the advantage to run it independently from the user who downloaded it, preventing broken cronjobs/services as there is no risk that the files/directories of Adsorber will be accidentally deleted or moved.
To reverse the steps (complete uninstall) run the script ./remove_files_from_system
.
This mode will only download the recent ad-domains and merges them into your hosts file.
You won't be able to set a scheduler.
- Execute
./portable_adsorber.sh setup
to generate the config files - Execute
./portable_adsorber.sh setup
again to continue - Finished!
If you want to update your hosts file you need to do it yourself by running ./portable_adsorber.sh update
Portable-mode won't touch the system except for /etc/hosts
which is required to block ad-servers. A backup of it will be created at /etc/hosts.original
.
Usage: adsorber <operation> [<options>|--help]
(Ad)sorber blocks ads by "absorbing" and dumbing them into void.
(with the help of the hosts file)
Operation (required):
setup - setup necessary things needed for Adsorber
e.g., create backup file of hosts file,
create scheduler which updates the host file once a week
However this should've been done automatically.
update - update hosts file with newest ad servers
restore - restore hosts file to its original state
(it does not remove the scheduler, this should be used temporary)
revert - reverts the hosts file to the last applied (previous) host file.
disable - completely remove changes made by Adsorber
e.g., disable scheduler (if set)
restore hosts file to its original state
version - show version of this shell script
help - show this help
Options (optional):
-y, --yes, --assume-yes - answer all prompts with 'yes'
-f, --force - force the update if no /etc/hosts backup
has been created (dangerous)
-h, --help - show specific help of specified operations
(e.g 'adsorber update --help)
--noformatting - turn off coloured and formatted output
Scheduler options (use with 'setup'):
-ns, --no-scheduler - skip scheduler creation
-s, --systemd - setup Systemd as scheduler
-c, --cron - setup Cronjob ...
-H, --hourly - run scheduler once hourly
-D, --daily ... daily
-W, --weekly ... weekly
-M, --monthly ... monthly
-Q, --quarterly ... quarterly (4x a year)
-S, --semiannually ... semiannually (2x a year)
-Y, --yearly ... yearly
Config files are located at: /usr/local/etc/adsorber/
Documentation: https://github.com/stablestud/adsorber
If you encounter any issues please report them to the Github repository.
To run Adsorber one of the following operations must be given as first parameter.
Note: to get further information about a operation run adsorber <operation> --help
You should run this command first.
The command will:
- backup your
/etc/hosts
file to/etc/hosts.original
(if not other specified inadsorber.conf
) - setup a scheduler which updates your hosts file with ad-server domains once a week. (either systemd, cronjob or none)
- fetch the newest ad-server domains in your hosts file. (same as
update
)
Possible options are:
-s, --systemd
-c, --cronjob
-ns, --no-scheduler
-y, --yes, --assume-yes
-h, --help
-H, --hourly
-D, --daily
-W, --weekly
-M, --monthly
-Q, --quarterly
-S, --semiannually
-Y, --yearly
To keep the hosts file up-to-date.
The command will:
- copy the current
/etc/hosts
to/etc/hosts.previous
, if not disabled inadsorber.conf
- download ad-server lists from servers listed in
sources.list
- filter those and apply them to the systems hosts file
/etc/hosts
Possible options are:
-f, --force
-h, --help
To revert to the last applied hosts-file by Adsorber.
The command will:
- copy
/etc/hosts.previous
to/etc/hosts
, overwriting the newest/etc/hosts
.
This is useful if the new hosts file contains less or no ad-domains, because a source was unreachable and you don't want to loose the ad-servers supplied previously from this source.
Possible option:
-h, --help
To restore the hosts file to its original state, without removing the backup and scheduler.
The command will:
- copy
/etc/hosts.original
to/etc/hosts
, overwriting the modified/etc/hosts
by Adsorber.
Important: If Adsorber's scheduler was set-up, it'll re-apply ad-server domains to your hosts file when triggered.
For this reason this command is used to temporary disable Adsorber, e.g. when it's blocking some sites you need to access for a short period of time.
To re-apply run adsorber revert
(for previous host file) or adsorber update
(for updated version).
Possible option:
-h, --help
Completely disable all background tasks (schedulers) and remove all changes made by Adsorber.
The command will:
- disable all schedulers (systemd, cronjob)
- restore the hosts file to it's original state
- remove all leftovers (previous hosts file, etc)
Possible options are:
-y, --yes, --assume-yes
-h, --help
Option is only available with operation setup
.
Adsorber uses Systemd as a scheduler to update your hosts file periodically.
- Setup systemd scheduler, skipping the scheduler prompt.
Files are placed into /etc/systemd/system
by default.
Option is only available with operation setup
.
Adsorber uses Cronjob as a default scheduler to update your hosts file periodically.
- Setup the cron scheduler, skipping the scheduler prompt.
File is placed into /etc/cron.weekly/
by default.
Option is only available with operation setup
.
Tells Adsorber no to install a scheduler.
- Skips the setup of a scheduler, therefore skipping the scheduler prompt.
You'll need to update Adsorber manually with adsorber update
.
Answers all prompts with yes
e.g.,
Do you really want to setup Adsorber?
Do you really want to disable Adsorber?
It'll not answer prompts which may harm your system. But --force
will.
Option is only available with operation setup
.
This will force the script to continue (dangerous) the update e.g.,
- Continues if no backup has been created, overwriting the existing hosts file.
If specified with an operation, it'll show extended help about it.
Disables coloured and formatted output by Adsorber.
Useful for logging to files and output processing by other scripts.
By default the config files are located at /usr/local/etc/adsorber/
.
In portable-mode the config files are being created at the scripts root directory after the first run.
Config files you may want to edit:
adsorber.conf
- general configurationsources.list
- sources to fetch fromwhitelist
- domains which should not be blockedblacklist
- domains which should be always blocked
By default Adsorber uses the following external sources:
- adaway.org (also used by AdAway)
- yoyo.org (also used by AdAway)
To add your own ad-domain sources, just add them to the sources.list
config file.
The schedulers (systemd service, cronjob) will pass their output to the Syslog process.
The syslog can be examined at /var/log/syslog
.
You're free to implement things listed/not listed in TODO.md
to Adsorber.
Any additions are appreciated. :)
MIT License
Copyright (c) 2017 stablestud
Permission is hereby granted, free of charge, to any person obtaining a copy
of this software and associated documentation files (the Software), to deal
in the Software without restriction, including without limitation the rights
to use, copy, modify, merge, publish, distribute, sublicense, and/or sell
copies of the Software, and to permit persons to whom the Software is
furnished to do so, subject to the following conditions:
The above copyright notice and this permission notice shall be included in all
copies or substantial portions of the Software.
THE SOFTWARE IS PROVIDED AS IS, WITHOUT WARRANTY OF ANY KIND, EXPRESS OR
IMPLIED, INCLUDING BUT NOT LIMITED TO THE WARRANTIES OF MERCHANTABILITY,
FITNESS FOR A PARTICULAR PURPOSE AND NONINFRINGEMENT. IN NO EVENT SHALL THE
AUTHORS OR COPYRIGHT HOLDERS BE LIABLE FOR ANY CLAIM, DAMAGES OR OTHER
LIABILITY, WHETHER IN AN ACTION OF CONTRACT, TORT OR OTHERWISE, ARISING FROM,
OUT OF OR IN CONNECTION WITH THE SOFTWARE OR THE USE OR OTHER DEALINGS IN THE
SOFTWARE.