This is mdns-filoxy, the mDNS filter proxy!
Project description
mdns-filoxy
This is mdns-filoxy, the mDNS filter proxy!
Table of contents
Introduction
Welcome to mdns-filoxy, the mDNS filter proxy.
What is it for?
mdns-filoxy allows you to send configured mDNS service queries out a specified interface, cache the response, and
then listen for further queries and answer them on a different interface.
This is particularly useful when you (rather smartly) put your IoT devices in a different network/VLAN to your "main" network. I have my Sonos speakers setup this way, and without some form of proxy, I simply cannot talk to them anymore, because of their odd use of mDNS and SSDP, and 14,000 other convoluted methods to reach their ecosystem.
But isn't that what avahi-daemon et al are for?!
avahi-daemon does have a reflector mode, and there are other packages like mdns-repeater. The issue is that they
both
listen for queries and then just re-send them out other interfaces. avahi-daemon even lets you filter reflections,
but they don't allow you to control the direction of the reflecting.
Furthermore, in the case where you have some other server on the same networks, with two or more interfaces bound to it,
systemd can have
a rather major meltdown whilst it tries to think for you and
choose unique mDNS names. A good example of this is Home Assistant's HAOS.
systemd behaves badly with mdns repeaters too.
Draw me a picture
Ok. Lets pretend you have a phone that sits in a VLAN, connected to a firewall interface called eth0 (known as the
dest-interface). Lets further pretend your Sonos speaker is in another VLAN, connected to iot0 (known as the
--source-interface).
When mdns-filoxy starts, it will bind to the specified interfaces, and on the source interface will query for the
chosen services (--mdns-services):
flowchart LR
Firewall -->|iot0| mc[Multicast to VLAN
query for mdns-services] --> sonos[Speakers respond]-->|iot0 reply| Firewall
mdns-filoxy caches that response, and then lies in wait, ready to respond to any queries that arrive on eth0.
Once mdns-filoxy is up and listening, here's the sequence of events:
flowchart LR
phone[Phone
Sonos app
launched] --> mc[Multicast to VLAN
query for _sonos._tcp.local.] -->|eth0| Firewall -->|eth0 reply| phone
Notice that the queries and responses aren't bi-directional, and this is intentional. The software is meant to give minimal assistance to mDNS/IoT devices to get bootstrapped and then on with whatever other evil protocol(s) they use.
What's with the name?!
filoxy is my blend of "filter" and "proxy", as that's basically what this software does.
Installation
The recommended way to install mdns-filoxy is to use pipx.
After getting pipx installed, simply run:
username@host:~$ pipx install mdns-filoxy
[!WARNING] Please don't use pip system-wide.
You can of course also install it using classic virtualenvs.
License
mdns-filoxy is distributed under the terms of the MIT license.
Project details
Download files
Download the file for your platform. If you're not sure which to choose, learn more about installing packages.
Source Distribution
Built Distribution
Filter files by name, interpreter, ABI, and platform.
If you're not sure about the file name format, learn more about wheel file names.
Copy a direct link to the current filters
File details
Details for the file mdns_filoxy-1.0.5.tar.gz.
File metadata
- Download URL: mdns_filoxy-1.0.5.tar.gz
- Upload date:
- Size: 1.4 MB
- Tags: Source
- Uploaded using Trusted Publishing? Yes
- Uploaded via: twine/6.1.0 CPython/3.13.7
File hashes
| Algorithm | Hash digest | |
|---|---|---|
| SHA256 |
18cad40026cc80297203167289ce9b88bc36361fdb0c546e258afd162908c3c3
|
|
| MD5 |
8eea42ada6b63a69480acecaa83e9aea
|
|
| BLAKE2b-256 |
b2ff8d5fa9a693c3e2e9b050a389e82e85fc4664518d19dab07206c949f31874
|
Provenance
The following attestation bundles were made for mdns_filoxy-1.0.5.tar.gz:
Publisher:
python-publish.yml on lingfish/mdns-filoxy
-
Statement:
-
Statement type:
https://in-toto.io/Statement/v1 -
Predicate type:
https://docs.pypi.org/attestations/publish/v1 -
Subject name:
mdns_filoxy-1.0.5.tar.gz -
Subject digest:
18cad40026cc80297203167289ce9b88bc36361fdb0c546e258afd162908c3c3 - Sigstore transparency entry: 840297458
- Sigstore integration time:
-
Permalink:
lingfish/mdns-filoxy@c88f4f38566a47b397b43f79fc4d14c739758b97 -
Branch / Tag:
refs/tags/1.0.5 - Owner: https://github.com/lingfish
-
Access:
public
-
Token Issuer:
https://token.actions.githubusercontent.com -
Runner Environment:
github-hosted -
Publication workflow:
python-publish.yml@c88f4f38566a47b397b43f79fc4d14c739758b97 -
Trigger Event:
release
-
Statement type:
File details
Details for the file mdns_filoxy-1.0.5-py3-none-any.whl.
File metadata
- Download URL: mdns_filoxy-1.0.5-py3-none-any.whl
- Upload date:
- Size: 6.4 kB
- Tags: Python 3
- Uploaded using Trusted Publishing? Yes
- Uploaded via: twine/6.1.0 CPython/3.13.7
File hashes
| Algorithm | Hash digest | |
|---|---|---|
| SHA256 |
5190986542598ee0843e9cca7ce7733c34e2e37b4f9ca10c14779f53b45b8677
|
|
| MD5 |
125e15ab27bd27142e6d0d97ca6c77f0
|
|
| BLAKE2b-256 |
05f201936a8a433ee98e56691fc6fde5a347e4ab0f3eb51189790c6187839113
|
Provenance
The following attestation bundles were made for mdns_filoxy-1.0.5-py3-none-any.whl:
Publisher:
python-publish.yml on lingfish/mdns-filoxy
-
Statement:
-
Statement type:
https://in-toto.io/Statement/v1 -
Predicate type:
https://docs.pypi.org/attestations/publish/v1 -
Subject name:
mdns_filoxy-1.0.5-py3-none-any.whl -
Subject digest:
5190986542598ee0843e9cca7ce7733c34e2e37b4f9ca10c14779f53b45b8677 - Sigstore transparency entry: 840297492
- Sigstore integration time:
-
Permalink:
lingfish/mdns-filoxy@c88f4f38566a47b397b43f79fc4d14c739758b97 -
Branch / Tag:
refs/tags/1.0.5 - Owner: https://github.com/lingfish
-
Access:
public
-
Token Issuer:
https://token.actions.githubusercontent.com -
Runner Environment:
github-hosted -
Publication workflow:
python-publish.yml@c88f4f38566a47b397b43f79fc4d14c739758b97 -
Trigger Event:
release
-
Statement type: