Private Decentralized Communication Network
You can not select more than 25 topics Topics must start with a letter or number, can include dashes ('-') and can be up to 35 characters long.
 
 
 
 
 
Kevin Froman 572e29f5d5 bumped network version and main version, lots of test work and some stability improvements 9 months ago
.github Create greetings.yml 1 year ago
.vscode added vscode files 10 months ago
docs Update todo 10 months ago
install added install readme disclaimer and don't log max thread messages to terminal 1 year ago
scripts bumped network version and main version, lots of test work and some stability improvements 9 months ago
src bumped network version and main version, lots of test work and some stability improvements 9 months ago
static-data bumped network version and main version, lots of test work and some stability improvements 9 months ago
tests bumped network version and main version, lots of test work and some stability improvements 9 months ago
.dockerignore * cache pip requirements in dockerfile 2 years ago
.env change env to 3.8 11 months ago
.gitignore added vscode files 10 months ago
.gitlab-ci.yml use python docker for CI instead of ubuntu 11 months ago
.onionr.yml Rename AUR package to onionr-git 1 year ago
AUTHORS.MD * started endpoint for non-app specific control of direct connections 1 year ago
CODE_OF_CONDUCT.md refactored onionr commands and other small adjustments 1 year ago
CONTRIBUTING.md fixed some bugs 1 year ago
Dockerfile change dockerfile to python image, remove unnecessary apt installs 11 months ago
ISSUE_TEMPLATE.md Create an issue template 2 years ago
LICENSE.txt Update LICENSE.txt 1 year ago
Makefile moved to niceware from mnemonic 1 year ago
README.md updated readme 10 months ago
SECURITY.md moved tests to parent directory 1 year ago
make-release.sh added site lister 10 months ago
onionr.sh renamed onionr dir and bugfixes/linting progress 1 year ago
requirements-dev.in added requirements files for devs 10 months ago
requirements-dev.txt added requirements files for devs 10 months ago
requirements-notifications.in boards now load async 1 year ago
requirements-notifications.txt boards now load async 1 year ago
requirements.in added support to wipe data directory on exit 10 months ago
requirements.txt added support to wipe data directory on exit 10 months ago
run-windows-dev.bat renamed onionr dir and bugfixes/linting progress 1 year ago
run-windows.bat renamed onionr dir and bugfixes/linting progress 1 year ago
run_tests.sh bumped network version and main version, lots of test work and some stability improvements 9 months ago
setprofile.sh Merge Tempblocks 2 years ago
start-daemon.sh added restart command 1 year ago

README.md

Privacy Respecting Communication Network 📡

Anonymous social platform, mail, file sharing.

current stored block count

Install Features Screenshots
Docs/web copy Get involved Onionr.net/.onion

The main repository for this software is at https://GitLab.com/beardog/Onionr/

The GitHub repository is a mirror, do not submit PRs or issues there.

About

Onionr (“Onion Relay”) is a decentralized/distributed peer-to-peer communication network, designed to be anonymous and resistant to (meta)data analysis, spam, and corruption.

Onionr stores data in independent packages referred to as ‘blocks’. The blocks are distributed to all interested nodes. Blocks and user IDs cannot be easily proven to have been created by a particular user. Even if there is enough evidence to believe that a specific user created a block, nodes still operate behind Tor or I2P and as such cannot be trivially unmasked. Anonymity is achieved by a stateless network, with no given indication of what node a block originates from. Through message mixing and key privacy, it is intended to be nigh impossible to discover the identity of a message creator or recipient.

Via long-term traffic analysis, a well funded adversary may discover the most probable node(s) to be creating a set of related blocks, however doing so would only lead them to a node behind Tor or I2P. As the first node that a block appears on is almost always not the creator of the block, there is plausible deniability regarding the true creator of the block.

Onionr gives the individual the ability to speak freely, without fear of surveillance and censorship.

Users are identified by ed25519/curve25519 public keys, which can be used to sign blocks or send encrypted data.

Onionr can be used for mail, as a social network, instant messenger, file sharing software, or for encrypted group discussion.

The whitepaper is available here.

Tor stinks slide image

Main Features

Onionr ships with various application plugins ready for use out of the box:

Currently usable:

  • Mail
  • Public anonymous chat/message board
  • Simple webpage hosting - Will be greatly extended
  • File sharing (Work in progress)

Not yet usable:

  • Instant messaging

Watch the talk from BSidesPDX 2019

improving anonymous networking talk link

Screenshots

Node statistics page screenshot

Home screen

Friend/contact manager screenshot

Friend/contact manager

Encrypted, metadata-masking mail application screenshot

Encrypted, metadata-masking mail application. One of the first distributed mail systems to have basic forward secrecy.

Documentation

More docs coming soon.

Install and Run on Linux

The following applies to Ubuntu Bionic. Other distros may have different package or command names.

$ sudo apt install python3-pip python3-dev tor

  • Have python3.7+, python3-pip, Tor (daemon, not browser) installed. python3-dev is recommended.
  • Clone the git repo: $ git clone https://gitlab.com/beardog/onionr
  • cd into install direction: $ cd onionr/
  • Install the Python dependencies (virtualenv strongly recommended): $ pip3 install --require-hashes -r requirements.txt
  • (Optional): Install desktop notification dependencies: $ pip3 install --require-hashes -r requirements-notifications.txt

(--require-hashes is intended to prevent exploitation via compromise of PyPi/CA certificates)

Run Onionr

  • Run Onionr normally: $ ./onionr.sh start
  • Run Onionr in background as daemon: $ ./start-daemon.sh
  • Open Onionr web interface $ ./onionr.sh openhome
  • Gracefully stop Onionr from CLI $ ./onionr.sh stop

Contact

Email: beardog [ at ] mailbox.org

Onionr Mail: particularizing-zabaione-defuze-iodizer-saucepan-patientest-sell-waken-chifforobe-embonpoint-aquanaut-chambermaid-barky-fumer-jolt-biotic

Help out

Everyone is welcome to contribute. Help is wanted for the following:

  • Development (Get in touch first)
    • Creation of a shared lib for use from other languages and faster proof-of-work
    • Android and IOS development
    • Windows and Mac support (already partially supported, testers needed)
    • Bug fixes and development of new features
  • Testing
  • Translations/localizations
  • UI/UX design
  • Running stable nodes
  • Security review/audit
  • Automatic I2P setup

Contribute money:

Donating at least $3 gets you cool Onionr stickers. Get in touch if you want them.

sticker

Bitcoin: 1onion55FXzm6h8KQw3zFw2igpHcV7LPq (Contact us for a unique address or for other coins)

Monero: 4B5BA24d1P3R5aWEpkGY5TP7buJJcn2aSGBVRQCHhpiahxeB4aWsu15XwmuTjC6VF62NApZeJGTS248RMVECP8aW73Uj2ax

USD (Card/Paypal): Ko-Fi

Note: probably not tax deductible

Security

Onionr is alpha software. This means it is unstable, probably insecure, and experimental.

No matter how good Onionr and other software gets, there will always be ways for clever or well-funded adversaries to break your security.

Onionr does not protect your identity if you associate your user ID with your name either on Onionr or elsewhere.

Do not rely on Onionr or any other software to hold up if your life or liberty are at stake.

Licenses and Branding

Onionr is published under the GNU GPL v3 license, except for the logo.

The Tor Project and I2P developers do not own, create, or endorse this project, and are not otherwise involved.

Tor is a trademark for the Tor Project. We do not own it.

The Onionr logo was created by Anhar Ismail under the Creative Commons Attribution 4.0 International License.

If you modify and redistribute our code (“forking”), please use a different logo and project name to avoid confusion. Please do not use the project name or logo in a way that makes it seem like we endorse you without our permission.