/zkcir

Cloud-based compiler for zero knowledge proofs. Built in partnership with @Veridise

Primary LanguageRust

zkcir

Build Status

Zero knowledge proofs are implemented in various frameworks, each with its own unique syntax and features. This leads to expensive context switching for cryptographic security analysts. This IR enables security analysis over a framework-agnostic environment.

CLI Usage

  • Use rust nightly
    • rustup install nightly
    • rustup default nightly
  • Install CLI
    • Run cargo install --branch main --git https://github.com/chriscerie/zkcir zkcir-cli
    • Alternatively clone repo and run cargo install --path zkcir-cli
  • Clone and run on a plonky2 circuit like https://github.com/chriscerie/plonky2-example
    • Run zkcir --json --source -- --example square_root
  • To see possible args, run zkcir --help

Online Compiler - AWS Deployment

We offer a self-hosted web app solution. To use, first deploy the app with AWS CDK.

  • Update cdk resources as needed to fit your scalability requirements
  • Add 0 issue "amazon.com" CAA to domain record
  • Deploy CDK
    • While deploying, approve certificate request
  • Get application load balancer's DNS name from console and add as CNAME record

Internally fargate will compile the rust project with patched dependencies and store the executable in S3. It then sends the presigned url to lambda without access to other services and outbound internet to act as a sandboxed environment. Lambda then gets the executable and runs it, returning the resulting IR.

Features

Built in code editor and compiler

Static analyzer

Git hosting and SSH key support

Gotchas

  • Detecting a value was randomly generated is naive and can false positive. It stores the randomly generated values and marks any value that matches as random.
  • Frameworks are moving targets. See the forks for the actual versions of the target dependencies.

File Structure

Folder Description Role
cdk Infra-as-code with AWS CDK Online compiler
common Internal shared code All
compile_lambda Sandboxed AWS lambda function to execute circuit code Online compiler
core_ecs User-facing web backend Online compiler
frontend User-facing web frontend Online compiler
zkcir Rust library to construct AST of the IR Library
zkcir-cli CLI to compile circuits to IR locally CLI