Files
semaphore/packages/identity
cedoor 7bcc44c645 chore: v3.9.0
Former-commit-id: 900da9cef5
2023-04-28 12:27:48 +01:00
..
2022-09-16 16:50:30 +02:00
2023-04-28 12:27:48 +01:00
2023-04-26 12:37:09 +01:00
2022-09-16 16:50:30 +02:00

Semaphore identity

A library to create Semaphore identities.

Github license NPM version Downloads Documentation typedoc Linter eslint Code style prettier

This library provides a class that can be used to create identities compatible with the Semaphore circuits. Each identity contains two secret values: trapdoor and nullifier, and one public value: commitment. The Poseidon hash of the secret values is the identity secret, and its hash is the identity commitment.

🛠 Install

npm or yarn

Install the @semaphore-protocol/identity package with npm:

npm i @semaphore-protocol/identity

or yarn:

yarn add @semaphore-protocol/identity

📜 Usage

# new Identity(identityOrMessage?: string): Identity

import { Identity } from "@semaphore-protocol/identity"

// The identity can be generated randomly.
const identity1 = new Identity()

// Deterministically from a secret message.
const identity2 = new Identity("secret-message")

// Or it can be retrieved from an existing identity.
const identity3 = new Identity(identity1.toString())

// Trapdoor, nullifier and commitment are the attributes (e.g. JS getters).
const { trapdoor, nullifier, commitment } = identity1