20 Commits

Author SHA1 Message Date
Artem
318aaf8cd5 modified sdk release script, changelog and version bump, 2025-09-02 14:55:10 +04:00
Artem
317be4697a changelog and version bumps 2025-07-31 21:30:16 +04:00
attemka
e9973f62d9 fix(sdk): bumped lean-imt version for SDK (#96) 2025-07-24 18:07:10 +04:00
moebius
6bf4b9aa55 chore: replace hypersync with hyperpc 2025-03-06 17:58:25 +01:00
moebius
4548a03ce0 fix: fix envio ver 2025-02-24 15:37:02 +01:00
moebius
b158c7da70 feat: data provider, optimizations to history retrieval 2025-02-21 13:30:26 +01:00
Artem
aa0b074a1c fixed types on sdk package 2025-02-19 00:11:05 +07:00
Artem
af5bd7618d version bump 2025-02-18 23:23:34 +07:00
Artem
370e82d41b transferred sdk package to 0xbow namespace 2025-02-18 22:36:19 +07:00
moebius
6ae88dbe5d fix: miscellaneous fixes (#88) 2025-02-17 19:52:57 +01:00
bezze
f3e9e35e0b test: relayer unit testing (#77) 2025-02-10 09:26:07 +00:00
moebius
2555543d88 chore: publish to gpr (#78) 2025-02-10 09:08:21 +00:00
Turtle
16c0852e26 fix: sdk package name (#75) 2025-02-07 23:42:41 +01:00
moebius
7dc386cc18 fix: sdk release task (#71) 2025-02-07 13:22:39 +00:00
bezze
b6f58e6887 feat: relayer data checks and sdk integration (#58)
The core functionality of the feature takes place at
`packages/relayer/src/services/privacyPoolRelayer.service.ts` in the
`validateWithdrawal` function. There we check in order:
1. Decode Withdrawal.data and check feeReceiver ==
CONFIGURED_FEE_RECEIVER && feeBPS == CONFIGURED_FEE_BPS
2. Hash (Withdrawal || Scope) and check hash == Proof.context
3. Verify proof with SDK.verifyProof(Proof)
4. Call Entrypoint.scopeToPool() to get asset pool
5. Call Pool.ASSET() to get withdrawn asset
6. Check proof.withdrawnAmount() >=
CONFIGURED_MINIMUM_AMOUNT[withdrawn_asset]

If everything is ok, we call the Entrypoint.relay() with the user's
proof.

I've added examples for the config files `env.example`,
`withdraw_amount.example.json`. The first one are environment variables
to be defined in the server's environment. The second one contains a
mapping of the mimimum withdraw limits for the different supported
assets. There's an env var that should contain a path to this file.

Added a `Dockerfile` and a `docker-compose.yml` to the relayer to test
it or use it in dev flows. The circuit artifacts are loaded as volumes,
so before starting the docker-compose, you should run `yarn present`
from the circuits package dir to group all the artifacts and make them
easily accesible.

Additionally added a small package in
`/packages/relayer/test/integration/relay` that can be built and run to
test the relayer.
2025-02-05 14:24:29 +00:00
bezze
cc4cd8f13f feat: relayer basic implementation (#53)
There are a lot of TODOs related to code quality, mostly happy path
assumptions, input sanitization, error handling and tests. Feature wise
it's missing the contract interaction (should be straight forward once
it's implemented in the SDK) and the sqlite database for request
tracking.
2025-01-31 19:01:11 +00:00
moebius
e32e76d398 chore: integrate SDK into contracts tests (#47)
Co-authored-by: Lempire <61431140+lempire123@users.noreply.github.com>
2025-01-28 16:19:32 +00:00
TITI
7559502b36 feat: SDK base implementation (#31)
Description:
- Implementation for crypto operations
- Proof generation
- Merkle inclusion proofs

---------

Co-authored-by: casiojapi <casiopilled@gmail.com>
Co-authored-by: moebius <0xmoebius@protonmail.com>
2025-01-24 11:28:26 +00:00
bezze
7e2881573b feat: adding rollup bundler and a minimal groth16 prover interface (#32)
Because the SDK is meant to run both in web and nodejs I focused
bundling for those two targets. I chose Rollup.js as a bundler because
it is commonly used for bundling libraries and achives a decent tradeoff
between speed and flexibility.

The nodejs bundle will have the artifacts embedded in the package, while
the web bundle will need to have the artifacts being hosted at
/artifacts/{artifact_name}. The API for the circuits has an async
initializer that abstracts away the platform and loads the binaries.
Once initialized, the `circuits` object is used to initialize the
`ZkOps` class that uses the loaded binaries under the hood.

Observation: ~~currently, to build the bundle, the scripts assume you
have all the circuits artifacts at `src/circuits/artifacts`. The PR was
getting too big so I'll relax that assumption later.~~
EDIT: Build will now succeed without the artifacts because building them
in the ci/cd was way out of scope. I provided a script to install the
artifacts to the bundle build for local testing.

Usage example:

```typescript
import { ZkOps, circuits } from "@privacy-pool-core/sdk";

; (async () => {

    await circuits.downloadArtifacts("latest");
    const zkOps = new ZkOps(circuits);
    const input = {
        value: "1",
        label: BigInt("0"),
        nullifier: BigInt("123"),
        secret: BigInt("456"),
    };

    let r = await zkOps.proveCommitment(input);
    console.log(r)

})()
```
2025-01-23 08:14:21 +00:00
moebius
b81ed7bc34 feat: add SDK package (#12)
This PR introduces the template for the SDK package.
2025-01-08 13:30:40 +00:00