Skip to content

An online registry of regexes needed for certain ZK Email proofs, that can be imported into any frontend in one line.

Notifications You must be signed in to change notification settings

zkemail/zk-regex-registry

Folders and files

NameName
Last commit message
Last commit date

Latest commit

 

History

88 Commits
 
 
 
 
 
 
 
 
 
 
 
 

Repository files navigation

Introduction

ZK Regex Registry is an app that pools together all community created ZK Regex patterns (most for ZK Email use-cases). Project is funded by the zk-email team.

Examples

Home Screen home screen

Try out the pattern try page

Features

  • Users can upload ZK Regex Patterns using a simple JSON formatted markup (see example)
  • Users can test their ZK Email Regex Patterns directly on the UI (with the option of directly pulling emails privately from their Google accounts)
  • App generates the circom circuit and an example project for testing
  • App generates the assets required for proving (e.g. r1cs, wasm, zkey, vkey) and provides an API to download them
  • Includes a React SDK to embed into your application for proof generation (see SDK)

Project Structure

root
--- packages
------- app (NextJS application for the registry frontend)
------- sdk (React SDK)
--- scripts (Some helper scripts to help with testing)

Getting Started

Install dependencies required for building circuits

  1. circom - installation instructions
  2. zk-regex - installation instructions

Copy and rename the environment variables

cp .env.local.exmaple .env.local
# update the .env.local file
export $(cat .env.local | xargs)
DATABASE_URL=postgres://postgres:password@0.0.0.0:5432/myapp
# Secret token used for admin endpoints
SECRET_TOKEN=zkregexregistry
# Gmail client ID for Oauth
NEXT_PUBLIC_GOOGLE_CLIENT_ID=
# Full path to the output dir that will store generated code and circuit
GENERATED_OUTPUT_DIR=
# Path to the ptau file used for circuit generation
PTAU_PATH=

# Private key for deploying contracts
PRIVATE_KEY=
# RPC URL for deploying contracts
RPC_URL=
# DKIM Registry address
DKIM_REGISTRY=
# Chain ID
CHAIN_ID=

Run the database and seed it

# Using docker compose is the easiest
docker compose up -d db
yarn prisma db push
yarn tsx prisma/seed.ts

Second, run the development server:

cd packages/app
yarn install
yarn dev

Third, run the proof worker

yarn proof-gen

Lastly, run the circuit generator

yarn circuit-gen

Open http://localhost:3000 with your browser to see the result.

About

An online registry of regexes needed for certain ZK Email proofs, that can be imported into any frontend in one line.

Resources

Stars

Watchers

Forks

Releases

No releases published

Packages

No packages published