Sync Eero DHCP client list to AdGuard Home
Install from PyPI using pip
, you may need to use pip3
depending on your installation:
pip install eero-adguard-sync
eag-sync is a command-line program to sync your Eero DHCP client list to AdGuard Home, note that it is a one-way sync from Eero to AdGuard. It requires Python interpreter version 3.7+.
To run a sync process run the eag-sync sync
command, you can find a full list of options below. Sample usage:
eag-sync sync
You may be prompted for an Eero email or SMS code the first time you run this program. Your credentials never leave your computer, all processing is done client side.
To clear all locally cached credentials run the clear
command:
eag-sync clear
Usage: eag-sync [OPTIONS] COMMAND [ARGS]...
Options:
--version Show the version and exit.
--help Show this message and exit.
Commands:
sync
clear
Usage: eag-sync sync [OPTIONS]
Options:
--adguard-host TEXT AdGuard Home host IP address
--adguard-user TEXT AdGuard Home username
--adguard-password TEXT AdGuard Home password
--eero-user TEXT Eero email address or phone number
-d, --delete Delete AdGuard clients not found in Eero DHCP list
-y, --confirm Skip interactive confirmation
-o, --overwrite Delete all AdGuard clients before sync
--help Show this message and exit.
Usage: eag-sync clear [OPTIONS]
Options:
-y, --confirm Skip interactive confirmation
--help Show this message and exit.
To enable tab completion you will need to configure your preferred shell to use it. Currently bash
and zsh
are supported.
This configuration is totally optional, but may be useful if you use eag-sync
often.
Add the following to ~/.bashrc
:
eval "$(_EAG_SYNC_COMPLETE=bash_source eag-sync)"
Add the following to ~/.zshrc
:
eval "$(_EAG_SYNC_COMPLETE=zsh_source eag-sync)"
A Docker image that executes eag-sync sync
on a cron
schedule is available on Docker Hub with the tag amickael/eero-adguard-sync
. Some environment variables are required when running a container, see the table below for details.
You can also build the image locally using the Dockerfile
located in /docker
.
Variable | Name | Notes | Required | Default |
---|---|---|---|---|
EAG_EERO_COOKIE | Eero session cookie value | Eero session cookie value from output of eag-sync sync --debug |
Yes | |
EAG_ADGUARD_HOST | AdGuard host IP address | Yes | ||
EAG_ADGUARD_USER | AdGuard admin username | Yes | ||
EAG_ADGUARD_PASS | AdGuard admin password | Yes | ||
EAG_SYNC_FLAGS | eag-sync sync command flags |
Sync flags without the dash, e.g. EAG_SYNC_FLAGS="d" Note: -y is always appended |
No | -y |
EAG_CRON_SCHEDULE | Sync schedule in cron syntax | See crontab.guru for examples | No | 0 0 * * * |