Go to file
Chris Blom b4c851b39e
Merge branch 'main' into patch-1
2022-10-05 11:40:49 +02:00
.github/workflows hook up workflow for tests 2022-08-29 16:12:57 +02:00
ext add the smallest test 2022-08-29 16:06:39 +02:00
.gitignore and docs for better setup 2022-08-23 10:25:40 +02:00
CMakeLists.txt make us build in the right place 2022-09-05 16:25:00 +02:00
LICENSE Initial commit 2022-08-21 21:41:01 +02:00
README.md Merge branch 'main' into patch-1 2022-10-05 11:40:49 +02:00
cidr.py Add scripts for tracking single process 2022-08-23 12:59:10 +02:00
cloud.json add the google cloud list 2022-08-23 10:23:42 +02:00
goog-cloud-prefixes.txt add more google prefixes 2022-08-23 10:24:08 +02:00
goog-cloud-prefixes6.txt add more google prefixes 2022-08-23 10:24:08 +02:00
goog-prefixes.txt add preprocessed file 2022-08-21 23:36:55 +02:00
goog-prefixes6.txt add more google prefixes 2022-08-23 10:24:08 +02:00
goog.json initial 2022-08-21 22:48:40 +02:00
ipset-setup.sh and docs for better setup 2022-08-23 10:25:40 +02:00
lpmwrapper.hh abstract out lpmwrapper, add test 2022-08-29 16:17:42 +02:00
make-built-in-config.sh make us build in the right place 2022-09-05 16:25:00 +02:00
netsendmsg.bt Add scripts for tracking single process 2022-08-23 12:59:10 +02:00
teller.cc remove scary error, update docs a bit 2022-09-05 17:08:46 +02:00
teller.conf add unassorted trackers 2022-08-29 17:42:45 +02:00
testrunner.cc add google IPv6 addresses & process them 2022-08-29 17:33:22 +02:00
trackers.conf add unassorted trackers 2022-08-29 17:42:45 +02:00

README.md

googerteller

Audible feedback on just how much your browsing feeds into Google.

By bert@hubertnet.nl / https://berthub.eu/

Makes a little bit of noise any time your computer sends a packet to a tracker or a Google service, which excludes Google Cloud users.

Demo video in this tweet

Blog post with more videos

Installing on OSX:

If need be, install Homebrew via https://brew.sh/ as this will allow you to compile new software. To do so, copy paste the instruction under 'Install Homebrew' into the terminal app (Apple help). This might take quite a while. It will also ask for your password.

Then run:

brew tap robertjakub/teller
brew install --HEAD googerteller

To then start the noise, enter:

sudo tcpdump -nql | teller

And it should work. For the last command, it may also again ask you to enter your password.

How to compile

This will currently only work on Unix derived systems (like Linux, OSX and FreeBSD).

You need a C++ compiler like gcc-c++ and CMake for compiling the binary.

You also need to install libpcaudio (libpcaudio-dev on Debian/Ubuntu, pcaudiolib-devel on Fedora/Red Hat, pcaudiolib on Arch/Manjaro). For OSX this is a bit more work

Then do:

cmake .
make

How to run

Start as:

sudo tcpdump -nql | ./teller

And cry.

Configuration

Tracker data is read from tracker.conf which you should only edit if you've learned about more IP addresses for relevant trackers.

In teller.conf you can edit for each tracker where the noise should end up (left or right channel), and what the frequency should be.

Data source

The list of Google services IP addresses can be found on this Google support page.

Note that this splits out Google services and Google cloud user IP addresses. However, it appears the Google services set includes the cloud IP addresses, so you must check both sets before determining something is in fact a Google service and not a Google customer.

To run on a single process on Linux

Or, to track a single process, fe firefox, start it and run:

sudo bpftrace netsendmsg.bt |
    grep --line-buffered ^$(pgrep firefox) |
    stdbuf -oL cut -f2 | ./cidr.py | ./teller

And cry.

Dependencies

This software gratefully builds on: