Ecosyste.ms: Awesome
An open API service indexing awesome lists of open source software.
https://github.com/eth0izzle/Needl
Take back your privacy. Lose yourself in the haystack.
https://github.com/eth0izzle/Needl
privacy python
Last synced: 6 days ago
JSON representation
Take back your privacy. Lose yourself in the haystack.
- Host: GitHub
- URL: https://github.com/eth0izzle/Needl
- Owner: eth0izzle
- License: mit
- Created: 2016-11-14T23:11:18.000Z (almost 8 years ago)
- Default Branch: master
- Last Pushed: 2022-12-07T23:42:44.000Z (almost 2 years ago)
- Last Synced: 2024-08-01T06:21:30.637Z (3 months ago)
- Topics: privacy, python
- Language: Python
- Homepage: https://www.darkport.co.uk
- Size: 9.4 MB
- Stars: 560
- Watchers: 19
- Forks: 55
- Open Issues: 15
-
Metadata Files:
- Readme: README.md
- Contributing: CONTRIBUTING.md
- License: LICENSE
- Code of conduct: CODE_OF_CONDUCT.md
Awesome Lists containing this project
README
# Needl
**Take back your privacy. Lose yourself in the haystack.**
Your ISP is most likely tracking your browsing habits and selling them to marketing agencies (albeit anonymised). Or worse, making your browsing history available to law enforcement at the hint of a Subpoena. **Needl** will generate random Internet traffic in an attempt to conceal your legitimate traffic, essentially making your data the **Needl**e in the haystack and thus harder to find. The goal is to make it harder for your ISP, government, etc to track your browsing history and habits.
It's not perfect. But it's a start. Have an idea? [Get involved](CONTRIBUTING.md)!
![Demo](https://pbs.twimg.com/media/CxeQsH5XAAAp_vN.jpg:large)
Implemented modules:
- **Google**: generates a random search string, searches Google and clicks on a random result.
- **Alexa**: visits a website from the Alexa Top 1 Million list. (**warning**: contains a lot of porn websites)
- **Twitter**: generates a popular English name and visits their profile; performs random keyword searches
- **DNS**: produces random DNS queries from the Alexa Top 1 Million list.
- **Spotify**: random searches for Spotify artistsModule ideas:
- **WhatsApp**
- **Facebook Messenger**## Installation
Needl should work pretty much any Linux system with Python 3.0+ installed.
1. `cd /opt`
2. `git clone https://github.com/eth0izzle/needl.git`
3. `pip3 install -r requirements.txt`
4. Download [ChromeDriver](https://sites.google.com/a/chromium.org/chromedriver/downloads) for your platform (requires Chrome) and place in ./data.
5. `python3 needl.py`## Usage
Needl runs as a daemon and will happily sit in the background chomping away 24/7, 365. Each module (task) has scheduled actions, for example random DNS queries will happen every 1 to 3 minutes. You can configure the intervals within `./data/settings.yaml`.
usage: needl.py [-h] [--datadir DATADIR] [-d] [-v] [--logfile LOGFILE]
[--pidfile PIDFILE]
Take back your privacy. Lose yourself in the haystack.
optional arguments:
-h, --help show this help message and exit
--datadir DATADIR Data directory
-d, --daemon Run as a deamon
-v, --verbose Increase logging
--logfile LOGFILE Log to this file. Default is stdout.
--pidfile PIDFILE Save process PID to this file. Default is /tmp/needl.pid.
Only valid when running as a daemon.## F.A.Qs
1. **Why not just use a VPN/Tor?**
And you should! Needl does not protect your legitimate traffic in any way. It simply generates more.2. **By using Needl will my legitimate traffic be hidden/protected/safe?**
No. This isn't the goal of Needl. It's purpose is to generate more traffic to make it *harder* to identify your legitimate traffic. There's no evidence to suggest this actually works - it's a proof of concept.3. **Can [insert service here] differentiate between Needl and my legitimate requests?**
In theory, yes. [insert service here] can track you with Cookies, Session data or *algorithms*. Needl will tackle this in the future.4. **Where are your tests?!?**
Submit a pull request. _Please_.## Contributing
Check out the [issue tracker](https://github.com/eth0izzle/needl/issues) and see what tickles your fancy.
1. Fork it, baby!
2. Create your feature branch: `git checkout -b my-new-feature`
3. Commit your changes: `git commit -am 'Add some feature'`
4. Push to the branch: `git push origin my-new-feature`
5. Submit a pull request## License
MIT. See LICENSE