Skip to content

Latest commit

 

History

History
106 lines (71 loc) · 4.07 KB

README.md

File metadata and controls

106 lines (71 loc) · 4.07 KB

peercrypt

encrypted online & offline P2P

peercrypt is a Typescript library that enables asymmetric encrypted peer-to-peer communication between mobile & desktop browsers, both while being online and offline. It uses the libsodium library for hybrid encryption and signature verification between peers, peerjs for online connections and the web-push library for anonymously replaying encrypted push message between offline peers. Online connections An anonymous push relay service is needed

Getting started

To see a working example running peercrypt, clone the project and start an example server and client using the following commands:

git clone https://github.com/bosskabouter/peercrypt.git
cd peercrypt && npm i
npx nx run example-server:serve & npx nx run example-client-react:preview:development

Packages

The peercrypt library consists of the following packages:

  • Client packages:
  • (Optional) Server packages:
    • OnlineServer - a WebRTC Signaling server verifies the client's iD
    • OfflineServer - relays encrypted messages to anonymized client's Push Endpoint
  • shared packages:
    • shared - Contains ID with asymmetric signing and encryption keys. Already included in client and server packages
    • BIP (optional) - Optional BIP32 Hierarchical Deterministic wallet Key and BIP39 mnemonic seed recovery phrase

For detailed information about each package, see their respective pages.

Usage: In short

PeerCrypt ID

All participants (client peers as well as server instances) need a PeerCrypt ID key which holds asymmetric keys for signing and encryption purposes, both derived from a common private seed (if provided). The shared library is exported from all client and server packages, but can also be imported directly from "@peercrypt/shared";

import { ID } from '@peercrypt/shared'; // or import from any of the other packages;

const id = await ID.create('(optional) unique strong seed value' + Math.random());

console.info(`Share your public Key: ` + id.pubicIdentifier);
console.warn(`Save your private Seed: ` + id.seed);

An example On- & Offline PeerCrypt server

import { OnlineServer, ID } from '@peercrypt/online-server';
import { OfflineServer } from '@peercrypt/offline-server';

ID.create(process.env.SEED).then((id) => {
  console.log('PeerCrypt Server using public ID: ' + id.pubKey);
  OnlineServer(id);
  OfflineServer(id);
});

prints:

PeerCrypt Server using public ID: 992f3845a60d8687721db5d722ad3875bfcf09facc5ff340b6bd215ff568ac27

An example On- & Offline PeerCrypt Client

import { OnlineClient } from '@peercrypt/online-client';
import { OfflineClient, ID } from '@peercrypt/offline-client';

ID.create('*strong* seed').then(async (id) => {
  console.log('PeerCrypt Client using public ID: ' + id.pubKey);

  const serverPubKey = '992f3845a60d8687721db5d722ad3875bfcf09facc5ff340b6bd215ff568ac27';

  const onlineClient = new OnlineClient(id, serverPubKey);
  const offlineClient = await OfflineClient.register(id, serverPubKey);
});

prints:

PeerCrypt Client using public ID: 112f3845a60d8687721db5d722ad3875bfcf09facc1ff340b6bd215ff568ac27

An example: sending messages

const anotherClientPubKey = '112f3845a60d8687721db5d722ad3875bfcf09facc1ff340b6bd215ff568ac27';

const onlineClient = new OnlineClient(id);
const offlineClient = await OfflineClient.register(id);

TODO: finish

Contributions

Contributions to this project are welcome! If you would like to contribute, please open an issue or pull request on the GitHub repository.

License

peercrypt is open-source software licensed under the MIT license.