From 64e4f4bbccff3104c6e3f2701530fddc83049758 Mon Sep 17 00:00:00 2001 From: AgustinBadi Date: Mon, 29 Jan 2024 19:28:13 -0300 Subject: [PATCH] First commit --- .github/workflows/tests.yml | 20 ++++++++++++++ .gitignore | 6 ++++ README.md | 55 +++++++++++++++++++++++++++++++++++++ aiken.lock | 15 ++++++++++ aiken.toml | 14 ++++++++++ lib/ak-381/groth16.ak | 25 +++++++++++++++++ 6 files changed, 135 insertions(+) create mode 100644 .github/workflows/tests.yml create mode 100644 .gitignore create mode 100644 README.md create mode 100644 aiken.lock create mode 100644 aiken.toml create mode 100644 lib/ak-381/groth16.ak diff --git a/.github/workflows/tests.yml b/.github/workflows/tests.yml new file mode 100644 index 0000000..8913685 --- /dev/null +++ b/.github/workflows/tests.yml @@ -0,0 +1,20 @@ +name: Tests + +on: + push: + branches: ["main"] + pull_request: + +jobs: + build: + runs-on: ubuntu-latest + steps: + - uses: actions/checkout@v3 + + - uses: aiken-lang/setup-aiken@v0.1.0 + with: + version: v1 + + - run: aiken fmt --check + - run: aiken check -D + - run: aiken build diff --git a/.gitignore b/.gitignore new file mode 100644 index 0000000..ff7811b --- /dev/null +++ b/.gitignore @@ -0,0 +1,6 @@ +# Aiken compilation artifacts +artifacts/ +# Aiken's project working directory +build/ +# Aiken's default documentation export +docs/ diff --git a/README.md b/README.md new file mode 100644 index 0000000..dcca831 --- /dev/null +++ b/README.md @@ -0,0 +1,55 @@ +# ak-381 + +Write validators in the `validators` folder, and supporting functions in the `lib` folder using `.ak` as a file extension. + +For example, as `validators/always_true.ak` + +```gleam +validator { + fn spend(_datum: Data, _redeemer: Data, _context: Data) -> Bool { + True + } +} +``` + +## Building + +```sh +aiken build +``` + +## Testing + +You can write tests in any module using the `test` keyword. For example: + +```gleam +test foo() { + 1 + 1 == 2 +} +``` + +To run all tests, simply do: + +```sh +aiken check +``` + +To run only tests matching the string `foo`, do: + +```sh +aiken check -m foo +``` + +## Documentation + +If you're writing a library, you might want to generate an HTML documentation for it. + +Use: + +```sh +aiken docs +``` + +## Resources + +Find more on the [Aiken's user manual](https://aiken-lang.org). diff --git a/aiken.lock b/aiken.lock new file mode 100644 index 0000000..0a72eb3 --- /dev/null +++ b/aiken.lock @@ -0,0 +1,15 @@ +# This file was generated by Aiken +# You typically do not need to edit this file + +[[requirements]] +name = "aiken-lang/stdlib" +version = "1.7.0" +source = "github" + +[[packages]] +name = "aiken-lang/stdlib" +version = "1.7.0" +requirements = [] +source = "github" + +[etags] diff --git a/aiken.toml b/aiken.toml new file mode 100644 index 0000000..e520b02 --- /dev/null +++ b/aiken.toml @@ -0,0 +1,14 @@ +name = "modulo-p/ak-381" +version = "0.0.0" +license = "Apache-2.0" +description = "Aiken contracts for project 'modulo-p/ak-381'" + +[repository] +user = "modulo-p" +project = "ak-381" +platform = "github" + +[[dependencies]] +name = "aiken-lang/stdlib" +version = "1.7.0" +source = "github" diff --git a/lib/ak-381/groth16.ak b/lib/ak-381/groth16.ak new file mode 100644 index 0000000..a7200f7 --- /dev/null +++ b/lib/ak-381/groth16.ak @@ -0,0 +1,25 @@ +use aiken/builtin.{bls12_381_final_verify, bls12_381_miller_loop} + +type VerificationKey { + nPublic: Int, + vkAlpha: List, + vkBeta: List>, + vkGamma: List>, + vkDelta: List>, + vkAlphaBeta: List>>, + vkIC: List>, +} + +type Proof { + piA: List, + piB: List>, + piC: List, +} + +pub fn pairing(alfa: G1, beta: G2) -> Bool { + todo +} + +pub fn groth_verify(vk: VerificationKey, proof: Proof) -> Bool { + todo +}