Ecosyste.ms: Awesome
An open API service indexing awesome lists of open source software.
https://github.com/annervisser/gnome-dns-switcher
Gnome appindicator (toolbar icon) tool to switch between different DNS servers
https://github.com/annervisser/gnome-dns-switcher
appindicator dns gnome linux networkmanager nmcli
Last synced: 2 months ago
JSON representation
Gnome appindicator (toolbar icon) tool to switch between different DNS servers
- Host: GitHub
- URL: https://github.com/annervisser/gnome-dns-switcher
- Owner: annervisser
- License: gpl-3.0
- Created: 2021-01-26T20:58:13.000Z (almost 4 years ago)
- Default Branch: main
- Last Pushed: 2024-06-20T08:55:30.000Z (7 months ago)
- Last Synced: 2024-10-12T02:48:12.241Z (3 months ago)
- Topics: appindicator, dns, gnome, linux, networkmanager, nmcli
- Language: Python
- Homepage:
- Size: 104 KB
- Stars: 10
- Watchers: 3
- Forks: 0
- Open Issues: 2
-
Metadata Files:
- Readme: README.md
- License: LICENSE
Awesome Lists containing this project
README
# Gnome appindicator dns switcher
![](https://img.shields.io/github/v/tag/annervisser/gnome-dns-switcher?style=for-the-badge&logo=github&label=GitHub&link=https%3A%2F%2Fgithub.com%2Fannervisser%2Fgnome-dns-switcher)
![](https://img.shields.io/pypi/v/gnome-dns-switcher?style=for-the-badge&logo=python&logoColor=white&link=https%3A%2F%2Fpypi.org%2Fproject%2Fgnome-dns-switcher%2F)
- GitHub: https://github.com/annervisser/gnome-dns-switcher
- PyPi: https://pypi.org/project/gnome-dns-switcher/
---Gnome appindicator (toolbar icon) tool to quickly switch between different DNS servers
- Easily available in your toolbox
- Config file to specify DNS servers
Supports multiple connections and switching them separately
- Utility button to restart NetworkManager![gds](https://github.com/annervisser/gnome-dns-switcher/assets/5613416/56e66264-5f35-4385-9a47-b8827906e631)
💻 Screenshots
![](./screenshots/menu.png)
#### Easily available in your toolbar
![](./screenshots/appindicator.png)#### Shows you what it's done, no surprises
![](./screenshots/notification.png)#### Supports multiple connections and switching them separately
![](./screenshots/menu_multiple_connections.png)## Setup
Install dependencies
```shell
# Install pipx:
sudo apt install pipx# Add pipx path to your .bashrc
pipx ensurepath# Install dependencies to run this application
sudo apt install python3-dev libcairo2-dev libgirepository1.0-dev python3-gi python3-gi-cairo gir1.2-gtk-3.0 gir1.2-appindicator3-0.1
```Install gnome-dns-switcher
```shell
pipx install gnome-dns-switcher# Generate a default configuration
gnome-dns-switcher generate-config# Modify the config to your needs. See config documentation below
edit ~/.config/gnome-dns-switcher.yml
```## Usage
### Start the app in the background
Simply add ` &` after your command
```shell
gnome-dns-switcher &
```### Specify a different configuration file (default is `~/.config/gnome-dns-switcher.yml`)
```shell
gnome-dns-switcher --config /path/to/config.yml
```### Add to startup applications
```shell
# Sleep 10 seconds before starting to prevent starting up
# before network connections have been made
bash -c 'sleep 10 && gnome-dns-switcher --config ~/.config/gnome-dns-switcher.yml'
```## Config
The config file allows you to specify which DNS servers to show and what devices are visible.
By default, gnome-dns-switcher looks for a config file at `~/.config/gnome-dns-switcher.yml`To generate and example configuration, you can run `gnome-dns-switcher generate-config`
### The generated configuration will look like this:
```yaml
servers: # DNS Server options to show
# DHCP is always shown as the first option
Quad9: 9.9.9.9
CloudFlare: [1.1.1.1, 1.0.0.1]
Google DNS:
- 8.8.8.8
- 8.8.4.4
devices: [] # Specify device names here if you want to hide certain devices (ip link show)
```#### `servers` A list of servers that can be switched between
- The name is only used for displaying
- You can define one or more ips, as a yaml array or as a comma-seperated string#### `devices` Which devices to show (optional)
- optional, will display all non-bridge connections if not present or empty
- one or more devices to show in the switcher
- List all your devices by running `ip link show` in a terminal## Development
### Setup
Set up virtualenv:
```shell
virtualenv venv
source venv/bin/activate
```Install dependencies:
```shell
python setup.py install
pip install vext vext.gi
```### Running
```shell
python -m gnome_dns_switcher
```### Useful links
- https://gjs-docs.gnome.org/