0.0.76 • Published 7 days ago

@zkholdem/contracts v0.0.76

Weekly downloads
-
License
-
Repository
-
Last release
7 days ago

ZK Poker Template

Solidity part is forked from Hardhat template and remove some unnecessary files.

Getting Started

Pre Requisites

Before being able to run any command, you need to create a .env file and set a BIP-39 compatible mnemonic as an environment variable. You can follow the example in .env.example. If you don't already have a mnemonic, you can use this website to generate one.

Then, proceed with installing dependencies:

Usage

$ yarn install

Compile

Compile the smart contracts with Hardhat:

$ yarn compile

TypeChain

Compile the smart contracts and generate TypeChain bindings:

$ yarn typechain

Test

Run the tests with Hardhat:

$ yarn test

Lint Solidity

Lint the Solidity code:

$ yarn lint:sol

Lint TypeScript

Lint the TypeScript code:

$ yarn lint:ts

Coverage

Generate the code coverage report:

$ yarn coverage

Report Gas

See the gas usage per unit test and average gas per method call:

$ REPORT_GAS=true yarn test

Clean

Delete the smart contract artifacts, the coverage reports and the Hardhat cache:

$ yarn clean

Deploy

Deploy the contracts to Hardhat Network:

$ yarn deploy --greeting "Bonjour, le monde!"

Workflow

setup

game status: not started

A --> set up the wallet --> call smart contract for registeration

B --> set up the wallet --> call smart contract for registeration ....

shuffle the table

game status: preparing

A: Public X = 1,2,...,52

Public Y = 23,41,...,85

Proof: X to Y is a valid shuffle and encryption

Then, X, Y, and Proof all go to smart contract.

B: a) Fetch X, Y, and Proof from Smart Contract. b) Verify Proof. c) Public Y, Public Z, Proof: Y to Z is a valid shuffle and encryption. d) Send Z, Proof to smart contract.

Similarly, we have C, D, E, ...

check: no user left --> game status: ready, otherwise not ready

P.S: users can shuffle twice in the single round

competition

On Smart Contract, there is a game logic who should draw & play a card.

Suppose we have A, B, C, D, E and this round should be A to draw a card.

Now, suppose we have shuffled and masked deck Z = z1, z2, ..., zn on smart contract.

Again, suppose z1 has been drawed before, we should draw z2 now.

Given z2, ask E to decrypt first, and send decrypted card value and the proof of correctness to the smart contract; then D decrypt, then C, B, and finally A decrypt. Once A decrypt, A does not need to send the card value and proof of correctness.

Later, when A want to play this card, A need to send the card value and proof to smart contract.

prompt design in text:

For an user: 1. Prompt tells him generate the pk, zk ..., and save to the local storage 2. Prompt tells him join a game, if he agrees with Y, he will be registered to the deployed contract 3. Prompt show up the status of other users, if all users joined, prompt shows Shuffle the table 4. Prompt tells who is to shuffle the table, when it's his turn he shuffles. when all users finish this, prompt show game starts 5. Prompt tells who is to reveal the card, when it's his turn he shuffles. when all users finish this, prompt show game starts 6. Prompt tells him all users have revealed their cards, and show up the winner of this round. 7. end, and we can start from 4., another round begins

Data type requirements

u256[] or byte32[], all the data types should be in the array of 32 bytes

0.0.76

7 days ago

0.0.75

1 month ago

0.0.74

2 months ago

0.0.73

3 months ago

0.0.70

4 months ago

0.0.71

4 months ago

0.0.69

4 months ago

0.0.68

5 months ago

0.0.67

5 months ago

0.0.65

5 months ago

0.0.64-pre-mainnet

5 months ago

0.0.61-eos

5 months ago

0.0.64

5 months ago

0.0.40

9 months ago

0.0.41

9 months ago

0.0.42

9 months ago

0.0.43

9 months ago

0.0.44

9 months ago

0.0.45

9 months ago

0.0.37

9 months ago

0.0.38

9 months ago

0.0.39

9 months ago

0.0.30

10 months ago

0.0.31

10 months ago

0.0.32

10 months ago

0.0.34

10 months ago

0.0.35

9 months ago

0.0.36

9 months ago

0.0.26

10 months ago

0.0.27

10 months ago

0.0.28

10 months ago

0.0.29

10 months ago

0.0.62

6 months ago

0.0.63

6 months ago

0.0.21

11 months ago

0.0.22

11 months ago

0.0.23

10 months ago

0.0.24

10 months ago

0.0.25

10 months ago

0.0.60

7 months ago

0.0.61

6 months ago

0.0.59

7 months ago

0.0.51

8 months ago

0.0.52

8 months ago

0.0.53

8 months ago

0.0.54

7 months ago

0.0.55

7 months ago

0.0.56

7 months ago

0.0.58

7 months ago

0.0.50

8 months ago

0.0.48

9 months ago

0.0.20

11 months ago

0.0.16

11 months ago

0.0.17

11 months ago

0.0.19

11 months ago

0.0.15

11 months ago

0.0.14

11 months ago

0.0.13

11 months ago

0.0.12-linea-debug

11 months ago

0.0.11-linea-debug

11 months ago

0.0.11

11 months ago

0.0.10

12 months ago

0.0.9

12 months ago

0.0.6

12 months ago

0.0.8

12 months ago

0.0.5

12 months ago

0.0.4

12 months ago

0.0.3

12 months ago

0.0.2

12 months ago

0.0.1

12 months ago