Skip to content

Latest commit

 

History

History
 
 

group

Folders and files

NameName
Last commit message
Last commit date

parent directory

..
 
 
 
 
 
 
 
 
 
 
 
 
 
 

Semaphore group

A library to create and manage Semaphore groups.

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

This library is an abstraction of @zk-kit/incremental-merkle-tree. The main goal is to make it easier to create offchain groups, which are also used to generate Semaphore proofs. Semaphore groups are actually incremental Merkle trees, and the group members are tree leaves. Since the Merkle tree implementation we are using is a binary tree, the maximum number of members of a group is equal to 2^treeDepth.

🛠 Install

npm or yarn

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

npm i @semaphore-protocol/group

or yarn:

yarn add @semaphore-protocol/group

📜 Usage

# new Group(groupId: Member, treeDepth = 20): Group

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

// Group with max 1048576 members (20^²).
const group1 = new Group(1)

// Group with max 65536 members (16^²).
const group2 = new Group(1, 16)

// Group with max 16777216 members (24^²).
const group3 = new Group(1, 24)

// Group with a list of predefined members.
const identity1 = new Identity()
const identity2 = new Identity()
const identity3 = new Identity()

const group3 = new Group(1, 16, [identity1.commitment, identity2.commitment, identity3.commitment])

# addMember(identityCommitment: Member)

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

const identity = new Identity()
const commitment = identity.generateCommitment()

group.addMember(commitment)

# removeMember(index: number)

group.removeMember(0)

# indexOf(member: Member): number

group.indexOf(commitment) // 0

# generateMerkleProof(index: number): MerkleProof

const proof = group.generateMerkleProof(0)