npm package discovery and stats viewer.

Discover Tips

  • General search

    [free text search, go nuts!]

  • Package details

    pkg:[package-name]

  • User packages

    @[username]

Sponsor

Optimize Toolset

I’ve always been into building performant and accessible sites, but lately I’ve been taking it extremely seriously. So much so that I’ve been building a tool to help me optimize and monitor the sites that I build to make sure that I’m making an attempt to offer the best experience to those who visit them. If you’re into performant, accessible and SEO friendly sites, you might like it too! You can check it out at Optimize Toolset.

About

Hi, 👋, I’m Ryan Hefner  and I built this site for me, and you! The goal of this site was to provide an easy way for me to check the stats on my npm packages, both for prioritizing issues and updates, and to give me a little kick in the pants to keep up on stuff.

As I was building it, I realized that I was actually using the tool to build the tool, and figured I might as well put this out there and hopefully others will find it to be a fast and useful way to search and browse npm packages as I have.

If you’re interested in other things I’m working on, follow me on Twitter or check out the open source projects I’ve been publishing on GitHub.

I am also working on a Twitter bot for this site to tweet the most popular, newest, random packages from npm. Please follow that account now and it will start sending out packages soon–ish.

Open Software & Tools

This site wouldn’t be possible without the immense generosity and tireless efforts from the people who make contributions to the world and share their work via open source initiatives. Thank you 🙏

© 2024 – Pkg Stats / Ryan Hefner

@blyss/sdk

v0.2.1

Published

Blyss SDK, enabling private retrievals from Blyss buckets

Downloads

108

Readme

The Blyss SDK lets you use homomorphic encryption to retrieve information privately. With it, you can build new kinds of privacy-preserving services, like private password breach checking, private nameserver resolution, and even private Wikipedia.

You can get an API key by signing up, or run a server locally. Detailed documentation is at docs.blyss.dev.

Warning The SDK has not yet been security reviewed, and the public Blyss service is still in beta. Contact us for access to a production-ready service.

Quick start (cloud)

You can quickly try using the SDK with our managed service without downloading anything.

  1. Get an API key by signing up here.
  2. Open this StackBlitz and enter your API key where it says <YOUR API KEY HERE>.
  3. Try adding users to the service using the "Add a user" button. As you add more users, the service will privately intersect each new users's contacts and the already existing users. Every user's list of contacts stays completely private using homomorphic encryption: it never leaves their device unencrypted.

We also have a simpler example using vanilla JS.

Quick start (local)

You can also use the Blyss SDK completely locally.

  1. Clone this repo with git clone [email protected]:blyssprivacy/sdk.git.
  2. Run the server by entering lib/server and running cargo run --release. The server will run on localhost:8008 by default.
  3. Run the client by entering examples/node-local and running npx ts-node main.ts. This will perform some writes and then a private read to your bucket.

Install

JavaScript / Node

To use the Blyss SDK in an existing TypeScript project, install it with npm install @blyss/sdk. Then, import the client with import { Client } from '@blyss/sdk';. If you're using SDK in Node, and prefer not to use ESM, you can instead import it as const blyss = require('@blyss/sdk/node').

Python

From PyPI:

pip install --upgrade blyss

From repo:

  1. cd python from repo root.
  2. pip install --upgrade .

Examples

The examples/ directory has several examples of how to use the Blyss SDK. Running the examples requires an API key.

Browser

The browser example shows how to quickly start using the Blyss SDK from vanilla JavaScript. The blyss-bundle.min.js build output is a single-file JS bundle that binds the library to window.blyss. Including this is a fast way to get started, especially if you prefer to use vanilla JS.

  1. Edit examples/browser-simple/main.js to use your API key.
  2. Run a local HTTP server (we suggest serve) in the repo root.
  3. Go to http://localhost:3000/examples/browser-simple/ in a browser.

React

The React example shows how to use the Blyss SDK in modern client-side JS. It also implements a more complicated application: private contact intersection.

  1. Enter examples/react-complex, and run npm install.
  2. Edit src/App.tsx to use your API key.
  3. Run npm run start.

Node

The Node.js example shows how to use the Blyss SDK in server-side JS. Node 18+ is required.

  1. Enter examples/node, and run npm install.
  2. Edit main.ts to use your API key.
  3. Run ts-node main.ts.

Python

  1. Install blyss.
  2. Enter examples/python.
  3. Run python main.py.

Documentation

All documentation is available at docs.blyss.dev. You can generate the docs by running npm start in docs/.

Contributing

Please feel free to open issues and pull requests! For bugs, try to provide as much context as possible. We are also always open to documentation contributions.

Building from source

JavaScript / Node

  1. Install Node with nvm, Rust with rustup, and wasm-pack.
  2. Run npm install.
  3. Run npm run build.

This will build the complete SDK, including the core Rust libraries in lib/spiral-rs and lib/doublepir

Python

Requires python 3.8+.

  1. Run pip install . in python.

Repository Map

The Blyss SDK is structured as:

  1. lib/,
    • lib/server/, a Rust project containing the open-source Blyss server.
    • lib/spiral-rs/, a Rust crate containing the core cryptographic implementation of the Spiral PIR scheme.
    • lib/doublepir/, a Rust crate containing the core cryptographic implementation of the DoublePIR scheme.
  2. js/, the TypeScript code that implements the user-facing Blyss SDK.
    • js/bridge/, a Rust "bridge" crate that exposes key functionality from spiral-rs and doublepir to the TypeScript code.
  3. python/, the Python version of the SDK.
    • python/src/lib.rs, another Rust "bridge" crate that exposes key functionality from spiral-rs to the Python code.

License

MIT (see LICENSE.md)