From 0e6e23de65f56ffd49d2d4ad42d5e21dadaa6cc0 Mon Sep 17 00:00:00 2001 From: Justin Traglia <95511699+jtraglia@users.noreply.github.com> Date: Tue, 21 Feb 2023 09:57:25 -0600 Subject: [PATCH] Update csharp bindings (#146) --- .github/workflows/csharp-bindings-build.yml | 19 +- bindings/csharp/Ckzg.Bindings/Ckzg.cs | 134 +++++++----- bindings/csharp/Ckzg.Test/Ckzg.Test.csproj | 2 +- bindings/csharp/Ckzg.Test/E2eTests.cs | 225 +++++++++++++++++--- bindings/csharp/Makefile | 88 ++++---- bindings/csharp/ckzg.c | 16 -- bindings/csharp/ckzg.h | 10 +- 7 files changed, 334 insertions(+), 160 deletions(-) diff --git a/.github/workflows/csharp-bindings-build.yml b/.github/workflows/csharp-bindings-build.yml index 663dda5..50b88ae 100644 --- a/.github/workflows/csharp-bindings-build.yml +++ b/.github/workflows/csharp-bindings-build.yml @@ -13,20 +13,15 @@ jobs: strategy: matrix: target: - - clang: x86_64-linux - native: linux-x64 + - native: linux-x64 host: ubuntu-latest - - clang: arm64-linux - native: linux-arm64 + - native: linux-arm64 host: ubuntu-latest - - clang: arm64-darwin - native: osx-arm64 + - native: osx-arm64 host: macos-latest - - clang: x86_64-darwin - native: osx-x64 + - native: osx-x64 host: macos-latest - - clang: x86_64-win - native: win-x64 + - native: win-x64 host: windows-latest steps: - uses: ilammy/msvc-dev-cmd@v1 @@ -34,7 +29,7 @@ jobs: with: submodules: recursive - name: Build native library for ${{ matrix.target.native }} - run: cd bindings/csharp && make -B ckzg CSHARP_PLATFORM=${{ matrix.target.native }} CLANG_PLATFORM=${{ matrix.target.clang }} + run: cd bindings/csharp && make -B ckzg CSHARP_PLATFORM=${{ matrix.target.native }} - name: Upload artifacts uses: actions/upload-artifact@v3 with: @@ -76,7 +71,7 @@ jobs: - name: Test run: cd bindings/csharp && dotnet test --configuration Release --no-restore - name: Build - run: cd bindings/csharp && dotnet build -p:Version=0.1.1.${{github.run_number}} --configuration Release --no-restore -o build + run: cd bindings/csharp && dotnet build -p:Version=0.1.1.${{github.run_number}} --configuration Release --no-restore - name: Upload package uses: actions/upload-artifact@v3 with: diff --git a/bindings/csharp/Ckzg.Bindings/Ckzg.cs b/bindings/csharp/Ckzg.Bindings/Ckzg.cs index 8511589..9d37ade 100644 --- a/bindings/csharp/Ckzg.Bindings/Ckzg.cs +++ b/bindings/csharp/Ckzg.Bindings/Ckzg.cs @@ -5,10 +5,18 @@ namespace Ckzg; public class Ckzg { - public const int CommitmentLength = 48; - public const int BlobElementLength = 32; - public const int BlobLength = BlobElementLength * 4096; - public const int ProofLength = 48; + public const int BytesPerFieldElement = 32; + public const int BytesPerBlob = BytesPerFieldElement * 4096; + public const int BytesPerCommitment = 48; + public const int BytesPerProof = 48; + + public enum Ret + { + Ok, + BadArgs, + Error, + Malloc + } static Ckzg() => AssemblyLoadContext.Default.ResolvingUnmanagedDll += (assembly, path) => NativeLibrary.Load($"runtimes/{( RuntimeInformation.IsOSPlatform(OSPlatform.Linux) ? "linux" : @@ -20,59 +28,12 @@ public class Ckzg _ => "" }}/native/{path}.{(RuntimeInformation.IsOSPlatform(OSPlatform.Windows) ? "dll" : "so")}"); - /// - /// Calculates commitment for the blob - /// - /// Preallocated buffer of bytes to receive the commitment - /// Flatten array of blob elements - /// Trusted setup settings - /// Returns error code or 0 if successful - [DllImport("ckzg", EntryPoint = "blob_to_kzg_commitment", CallingConvention = CallingConvention.Cdecl)] - public unsafe static extern int BlobToKzgCommitment(byte* commitment, byte* blob, IntPtr ts); - - - /// - /// Calculates aggregated proof for the blobs - /// - /// Preallocated buffer of bytes to receive the proof - /// Blobs as a flatten byte array - /// Blobs count - /// Trusted setup settings - /// Returns error code or 0 if successful - [DllImport("ckzg", EntryPoint = "compute_aggregate_kzg_proof", CallingConvention = CallingConvention.Cdecl)] - public unsafe static extern int ComputeAggregatedKzgProof(byte* proof, byte* blobs, int count, IntPtr ts); - - - /// - /// Verify aggregated proof and commitments for the given blobs - /// - /// Blobs as a flatten byte array - /// Commitments as a flatten byte array - /// Blobs and commitments count - /// - /// Trusted setup settings - /// Returns error code or 0 if the proof is correct - [DllImport("ckzg", EntryPoint = "verify_aggregate_kzg_proof_wrap", CallingConvention = CallingConvention.Cdecl)] - public unsafe static extern int VerifyAggregatedKzgProof(byte* blobs, byte* commitments_bytes, int count, byte* aggregated_proof_bytes, IntPtr ts); - - /// - /// Verify the proof by point evaluation for the given commitment - /// - /// Commitment - /// Z - /// Y - /// Proof - /// Trusted setup settings - /// Returns error code or 0 if the proof is correct - [DllImport("ckzg", EntryPoint = "verify_kzg_proof_wrap", CallingConvention = CallingConvention.Cdecl)] - public unsafe static extern int VerifyKzgProof(byte* commitment_bytes, byte* z_bytes, byte* y_bytes, byte* proof_bytes, IntPtr ts); - /// /// Load trusted setup settings from file /// /// Settings file path /// Trusted setup settings as a pointer or 0 in case of failure - [DllImport("ckzg", EntryPoint = "load_trusted_setup_wrap")] // free result with free_trusted_setup() + [DllImport("ckzg", EntryPoint = "load_trusted_setup_wrap")] public static extern IntPtr LoadTrustedSetup(string filename); /// @@ -81,5 +42,74 @@ public class Ckzg /// Trusted setup settings [DllImport("ckzg", EntryPoint = "free_trusted_setup_wrap", CallingConvention = CallingConvention.Cdecl)] public static extern void FreeTrustedSetup(IntPtr ts); + + /// + /// Calculates commitment for the blob + /// + /// Preallocated buffer of bytes to receive the commitment + /// Flatten array of blob elements + /// Trusted setup settings + /// Returns error code or 0 if successful + [DllImport("ckzg", EntryPoint = "blob_to_kzg_commitment", CallingConvention = CallingConvention.Cdecl)] + public unsafe static extern Ret BlobToKzgCommitment(byte* commitment, byte* blob, IntPtr ts); + + /// + /// Compute KZG proof at point `z` for the polynomial represented by `blob`. + /// + /// Preallocated buffer of bytes to receive the proof + /// Blob byte array + /// + /// Trusted setup settings + /// Returns error code or 0 if successful + [DllImport("ckzg", EntryPoint = "compute_kzg_proof", CallingConvention = CallingConvention.Cdecl)] + public unsafe static extern Ret ComputeKzgProof(byte* proof, byte* blob, byte* z_bytes, IntPtr ts); + + /// + /// Given a blob, return the KZG proof that is used to verify it against the commitment. + /// + /// Preallocated buffer of bytes to receive the proof + /// Blob byte array + /// Trusted setup settings + /// Returns error code or 0 if successful + [DllImport("ckzg", EntryPoint = "compute_blob_kzg_proof", CallingConvention = CallingConvention.Cdecl)] + public unsafe static extern Ret ComputeBlobKzgProof(byte* proof, byte* blob, IntPtr ts); + + /// + /// + /// + /// True if the proof is valid + /// + /// + /// + /// + /// Trusted setup settings + /// + [DllImport("ckzg", EntryPoint = "verify_kzg_proof", CallingConvention = CallingConvention.Cdecl)] + public unsafe static extern Ret VerifyKzgProof(bool* result, byte* commitment_bytes, byte* z_bytes, byte* y_bytes, byte* proof_bytes, IntPtr ts); + + /// + /// Given a blob and a KZG proof, verify that the blob data corresponds to the provided commitment. + /// + /// True if the proof is valid + /// + /// + /// + /// Trusted setup settings + /// + [DllImport("ckzg", EntryPoint = "verify_blob_kzg_proof", CallingConvention = CallingConvention.Cdecl)] + public unsafe static extern Ret VerifyBlobKzgProof(bool* result, byte* blob, byte* commitment_bytes, byte* proof_bytes, IntPtr ts); + + /// + /// Given a list of blobs and blob KZG proofs, verify that they correspond to the provided commitments. + /// + /// True if the proofs are valid + /// Blobs as a flattened byte array + /// Commitments as a flattened byte array + /// Proofs as a flattened byte array + /// The number of blobs/commitments/proofs + /// Trusted setup settings + /// + [DllImport("ckzg", EntryPoint = "verify_blob_kzg_proof_batch", CallingConvention = CallingConvention.Cdecl)] + public unsafe static extern Ret VerifyBlobKzgProofBatch(bool* result, byte* blobs, byte* commitments_bytes, byte* proofs_bytes, int count, IntPtr ts); } diff --git a/bindings/csharp/Ckzg.Test/Ckzg.Test.csproj b/bindings/csharp/Ckzg.Test/Ckzg.Test.csproj index c41d633..dd34fe9 100644 --- a/bindings/csharp/Ckzg.Test/Ckzg.Test.csproj +++ b/bindings/csharp/Ckzg.Test/Ckzg.Test.csproj @@ -24,6 +24,6 @@ Always - + diff --git a/bindings/csharp/Ckzg.Test/E2eTests.cs b/bindings/csharp/Ckzg.Test/E2eTests.cs index 1391ee0..526e187 100644 --- a/bindings/csharp/Ckzg.Test/E2eTests.cs +++ b/bindings/csharp/Ckzg.Test/E2eTests.cs @@ -1,57 +1,218 @@ using NUnit.Framework; +using System.IO; namespace Ckzg.Test; [TestFixture] public class BasicKzgTests { - private IntPtr _ts; + private IntPtr ts; + + const string TestDir = "../../../../../../tests"; + string BlobToKZGCommitmentTests = Path.Join(TestDir, "blob_to_kzg_commitment"); + string ComputeKzgProofTests = Path.Join(TestDir, "compute_kzg_proof"); + string ComputeBlobKzgProofTests = Path.Join(TestDir, "compute_blob_kzg_proof"); + string VerifyKzgProofTests = Path.Join(TestDir, "verify_kzg_proof"); + string VerifyBlobKzgProofTests = Path.Join(TestDir, "verify_blob_kzg_proof"); + string VerifyBlobKzgProofBatchTests = Path.Join(TestDir, "verify_blob_kzg_proof_batch"); + + public static byte[] StringToByteArray(string hex) + { + return Enumerable.Range(0, hex.Length) + .Where(x => x % 2 == 0) + .Select(x => Convert.ToByte(hex.Substring(x, 2), 16)) + .ToArray(); + } + + public static byte[] GetBytes(String path) + { + string hex = System.IO.File.ReadAllText(path); + return StringToByteArray(hex); + } + + public static byte[] GetFlatBytes(String path) + { + List files = Directory.GetFiles(path).ToList(); + files.Sort(); + List filesBytes = new List(); + foreach (String file in files) + { + filesBytes.Add(GetBytes(file)); + } + + byte[] flatBytes = new byte[filesBytes.Sum(b => b.Length)]; + int offset = 0; + foreach (byte[] bytes in filesBytes) + { + System.Buffer.BlockCopy(bytes, 0, flatBytes, offset, bytes.Length); + offset += bytes.Length; + } + + return flatBytes; + } + + public static bool GetBoolean(String path) + { + return System.IO.File.ReadAllText(path).Contains("true"); + } [SetUp] public void Setup() { - _ts = Ckzg.LoadTrustedSetup("trusted_setup.txt"); - Assert.That(_ts, Is.Not.EqualTo(IntPtr.Zero)); + ts = Ckzg.LoadTrustedSetup("trusted_setup.txt"); + Assert.That(ts, Is.Not.EqualTo(IntPtr.Zero)); } - [TestCase(0xff, 1, -1)] - [TestCase(0x73, 1, -1)] - [TestCase(0x72, 0, 0)] - [TestCase(0x00, 0, 0)] - public unsafe void Test_Computes_And_Verifies(byte highByteValue, int expectedProofComputed, int expectedProofVerified) + [TearDown] + public void Teardown() { - byte[] blob = Enumerable.Range(0, 4096 * 32).Select(x => x % 32 == 31 ? highByteValue : (byte)(x % 256)).ToArray(); + Ckzg.FreeTrustedSetup(ts); + } - byte[] proof = new byte[48]; - byte[] commitment = new byte[48]; - fixed (byte* commitmentPtr = commitment, blobPtr = blob, proofPtr = proof) + [TestCase] + public unsafe void TestBlobToKzgCommitment() + { + foreach (String test in Directory.GetDirectories(BlobToKZGCommitmentTests)) { - int proofComputed = Ckzg.ComputeAggregatedKzgProof(proofPtr, blobPtr, 1, _ts); - Assert.That(proofComputed, Is.EqualTo(expectedProofComputed)); - - Ckzg.BlobToKzgCommitment(commitmentPtr, blobPtr, _ts); - int proofVerified = Ckzg.VerifyAggregatedKzgProof(blobPtr, commitmentPtr, 1, proofPtr, _ts); - Assert.That(proofVerified, Is.EqualTo(expectedProofVerified)); - - Ckzg.FreeTrustedSetup(_ts); + byte[] commitment = new byte[48]; + byte[] blob = GetBytes(Path.Join(test, "blob.txt")); + fixed (byte *pCommitment = commitment, pBlob = blob) + { + Ckzg.Ret ret = Ckzg.BlobToKzgCommitment(pCommitment, pBlob, ts); + if (ret == Ckzg.Ret.Ok) + { + byte[] expectedCommitment = GetBytes(Path.Join(test, "commitment.txt")); + Assert.That(commitment, Is.EqualTo(expectedCommitment)); + } + else + { + Assert.False(System.IO.File.Exists(Path.Join(test, "commitment.txt"))); + } + } } } [TestCase] - public unsafe void Test_PointEvaluationPrecompile_Verifies() + public unsafe void TestComputeKzgProof() { - byte[] commitment = new byte[48]; - commitment[0] = 0xc0; - byte[] x = new byte[32]; - byte[] y = new byte[32]; - byte[] proof = new byte[48]; - proof[0] = 0xc0; - - fixed (byte* commitmentPtr = commitment, xPtr = x, yPtr = y, proofPtr = proof) + foreach (String test in Directory.GetDirectories(ComputeKzgProofTests)) { - int result = Ckzg.VerifyKzgProof(commitmentPtr, xPtr, yPtr, proofPtr, _ts); - Ckzg.FreeTrustedSetup(_ts); - Assert.That(result, Is.EqualTo(0)); + byte[] proof = new byte[48]; + byte[] blob = GetBytes(Path.Join(test, "blob.txt")); + byte[] inputPoint = GetBytes(Path.Join(test, "input_point.txt")); + fixed (byte *pProof = proof, pBlob = blob, pInputPoint = inputPoint) + { + Ckzg.Ret ret = Ckzg.ComputeKzgProof(pProof, pBlob, pInputPoint, ts); + if (ret == Ckzg.Ret.Ok) + { + byte[] expectedProof = GetBytes(Path.Join(test, "proof.txt")); + Assert.That(proof, Is.EqualTo(expectedProof)); + } + else + { + Assert.False(System.IO.File.Exists(Path.Join(test, "proof.txt"))); + } + } + } + } + + [TestCase] + public unsafe void TestComputeBlobKzgProof() + { + foreach (String test in Directory.GetDirectories(ComputeBlobKzgProofTests)) + { + byte[] proof = new byte[48]; + byte[] blob = GetBytes(Path.Join(test, "blob.txt")); + fixed (byte *pProof = proof, pBlob = blob) + { + Ckzg.Ret ret = Ckzg.ComputeBlobKzgProof(pProof, pBlob, ts); + if (ret == Ckzg.Ret.Ok) + { + byte[] expectedProof = GetBytes(Path.Join(test, "proof.txt")); + Assert.That(proof, Is.EqualTo(expectedProof)); + } + else + { + Assert.False(System.IO.File.Exists(Path.Join(test, "proof.txt"))); + } + } + } + } + + [TestCase] + public unsafe void TestVerifyKzgProof() + { + foreach (String test in Directory.GetDirectories(VerifyKzgProofTests)) + { + bool ok = false; + byte[] commitment = GetBytes(Path.Join(test, "commitment.txt")); + byte[] inputPoint = GetBytes(Path.Join(test, "input_point.txt")); + byte[] claimedValue = GetBytes(Path.Join(test, "claimed_value.txt")); + byte[] proof = GetBytes(Path.Join(test, "proof.txt")); + fixed (byte *pCommitment = commitment, pInputPoint = inputPoint, pClaimedValue = claimedValue, pProof = proof) + { + Ckzg.Ret ret = Ckzg.VerifyKzgProof(&ok, pCommitment, pInputPoint, pClaimedValue, pProof, ts); + if (ret == Ckzg.Ret.Ok) + { + bool expectedOk = GetBoolean(Path.Join(test, "ok.txt")); + Assert.That(ok, Is.EqualTo(expectedOk)); + } + else + { + Assert.False(System.IO.File.Exists(Path.Join(test, "ok.txt"))); + } + } + } + } + + [TestCase] + public unsafe void TestVerifyBlobKzgProof() + { + foreach (String test in Directory.GetDirectories(VerifyBlobKzgProofTests)) + { + bool ok = false; + byte[] blob = GetBytes(Path.Join(test, "blob.txt")); + byte[] commitment = GetBytes(Path.Join(test, "commitment.txt")); + byte[] proof = GetBytes(Path.Join(test, "proof.txt")); + fixed (byte *pBlob = blob, pCommitment = commitment, pProof = proof) + { + Ckzg.Ret ret = Ckzg.VerifyBlobKzgProof(&ok, pBlob, pCommitment, pProof, ts); + if (ret == Ckzg.Ret.Ok) + { + bool expectedOk = GetBoolean(Path.Join(test, "ok.txt")); + Assert.That(ok, Is.EqualTo(expectedOk)); + } + else + { + Assert.False(System.IO.File.Exists(Path.Join(test, "ok.txt"))); + } + } + } + } + + [TestCase] + public unsafe void TestVerifyBlobKzgProofBatch() + { + foreach (String test in Directory.GetDirectories(VerifyBlobKzgProofBatchTests)) + { + bool ok = false; + byte[] blobs = GetFlatBytes(Path.Join(test, "blobs")); + byte[] commitments = GetFlatBytes(Path.Join(test, "commitments")); + byte[] proofs = GetFlatBytes(Path.Join(test, "proofs")); + int count = blobs.Length / Ckzg.BytesPerBlob; + fixed (byte *pBlobs = blobs, pCommitments = commitments, pProofs = proofs) + { + Ckzg.Ret ret = Ckzg.VerifyBlobKzgProofBatch(&ok, pBlobs, pCommitments, pProofs, count, ts); + if (ret == Ckzg.Ret.Ok) + { + bool expectedOk = GetBoolean(Path.Join(test, "ok.txt")); + Assert.That(ok, Is.EqualTo(expectedOk)); + } + else + { + Assert.False(System.IO.File.Exists(Path.Join(test, "ok.txt"))); + } + } } } } \ No newline at end of file diff --git a/bindings/csharp/Makefile b/bindings/csharp/Makefile index b94e455..d5fa3dc 100644 --- a/bindings/csharp/Makefile +++ b/bindings/csharp/Makefile @@ -1,54 +1,54 @@ -INCLUDE_DIRS = ../../src ../../blst/bindings - -FIELD_ELEMENTS_PER_BLOB ?= 4096 - ifeq ($(OS),Windows_NT) - BLST_BUILDSCRIPT=./build.bat - BLST_OBJ=blst.lib - TESTS_EXECUTABLE=test_ckzg.exe - CSHARP_PLATFORM?=win-x64 - CLANG_PLATFROM?=x86_64-win - CLANG_FLAGS= - CLANG_EXECUTABLE=clang - CKZG_LIBRARY_PATH=Ckzg.Bindings\runtimes\$(CSHARP_PLATFORM)\native\ckzg.dll + BLST_BUILDSCRIPT = ./build.bat + BLST_OBJ = blst.lib + CSHARP_PLATFORM ?= win-x64 + CLANG_EXECUTABLE = clang + CKZG_LIBRARY_PATH = Ckzg.Bindings\runtimes\$(CSHARP_PLATFORM)\native\ckzg.dll else - BLST_BUILDSCRIPT=./build.sh - BLST_OBJ=libblst.a - TESTS_EXECUTABLE=./test_ckzg - CSHARP_PLATFORM?=linux-x64 - CLANG_PLATFORM?=x86_64-linux - CLANG_FLAGS=-fPIC - CLANG_EXECUTABLE=cc - CKZG_LIBRARY_PATH=Ckzg.Bindings/runtimes/$(CSHARP_PLATFORM)/native/ckzg.so + BLST_BUILDSCRIPT = ./build.sh + BLST_OBJ = libblst.a + CLANG_EXECUTABLE = clang + + UNAME_S := $(shell uname -s) + UNAME_M := $(shell uname -m) + ifeq ($(UNAME_S),Linux) + ifeq ($(UNAME_M),x86_64) + CSHARP_PLATFORM ?= linux-x64 + else + CSHARP_PLATFORM ?= linux-arm64 + endif + endif + ifeq ($(UNAME_S),Darwin) + ifeq ($(UNAME_M),arm64) + CSHARP_PLATFORM ?= osx-arm64 + else + CSHARP_PLATFORM ?= osx-x64 + endif + endif + + CKZG_LIBRARY_PATH = Ckzg.Bindings/runtimes/$(CSHARP_PLATFORM)/native/ckzg.so endif -CLANG_FLAGS += -DFIELD_ELEMENTS_PER_BLOB=$(FIELD_ELEMENTS_PER_BLOB) +FIELD_ELEMENTS_PER_BLOB ?= 4096 +INCLUDE_DIRS = ../../src ../../blst/bindings +TARGETS = ckzg.c ../../src/c_kzg_4844.c ../../blst/$(BLST_OBJ) -TARGETS=ckzg.c ../../src/c_kzg_4844.c ../../blst/$(BLST_OBJ) +CFLAGS += -O2 -Wall -Wextra -shared +CFLAGS += -DFIELD_ELEMENTS_PER_BLOB=$(FIELD_ELEMENTS_PER_BLOB) +CFLAGS += ${addprefix -I,${INCLUDE_DIRS}} -.blst: +.PHONY: all +all: blst ckzg ckzg-dotnet + +.PHONY: blst +blst: cd ../../blst && $(BLST_BUILDSCRIPT) -.ckzg: - $(CLANG_EXECUTABLE) -O -Wall -shared $(CLANG_FLAGS) ${addprefix -I,${INCLUDE_DIRS}} -o $(CKZG_LIBRARY_PATH) $(TARGETS) +.PHONY: ckzg +ckzg: blst + $(CLANG_EXECUTABLE) $(CFLAGS) -o $(CKZG_LIBRARY_PATH) $(TARGETS) -# Ckzg library -ckzg: - @make .blst - @make .ckzg - -# E2e tests as an executable -test: - @make .blst - $(CLANG_EXECUTABLE) -O -w -Wall $(CLANG_FLAGS) ${addprefix -I,${INCLUDE_DIRS}} -o $(TESTS_EXECUTABLE) kzg_tests.c $(TARGETS) - -# E2e tests are built and run -run-test: - @make test - $(TESTS_EXECUTABLE) - -# Makes a build and a nuget package just for windows or linux -# To build full package - use ckzg command on every plaform and dotnet build -ckzg-dotnet: - @make ckzg +.PHONY: ckzg-dotnet +ckzg-dotnet: ckzg dotnet build + dotnet test diff --git a/bindings/csharp/ckzg.c b/bindings/csharp/ckzg.c index a297733..c8a34d5 100644 --- a/bindings/csharp/ckzg.c +++ b/bindings/csharp/ckzg.c @@ -23,19 +23,3 @@ void free_trusted_setup_wrap(KZGSettings *s) { free_trusted_setup(s); free(s); } - -int verify_aggregate_kzg_proof_wrap(const Blob *blobs, const Bytes48 *commitments_bytes, size_t n, const Bytes48 *aggregated_proof_bytes, const KZGSettings *s) { - bool b; - C_KZG_RET ret = verify_aggregate_kzg_proof(&b, blobs, commitments_bytes, n, aggregated_proof_bytes, s); - if (ret != C_KZG_OK) return -1; - - return b ? 0 : 1; -} - -int verify_kzg_proof_wrap(const Bytes48 *commitment_bytes, const Bytes32 *z_bytes, const Bytes32 *y_bytes, const Bytes48 *proof_bytes, KZGSettings *s) { - bool out; - if (verify_kzg_proof(&out, commitment_bytes, z_bytes, y_bytes, proof_bytes, s) != C_KZG_OK) - return -2; - - return out ? 0 : 1; -} diff --git a/bindings/csharp/ckzg.h b/bindings/csharp/ckzg.h index 9a5e5d9..8b7e565 100644 --- a/bindings/csharp/ckzg.h +++ b/bindings/csharp/ckzg.h @@ -15,8 +15,12 @@ DLLEXPORT void free_trusted_setup_wrap(KZGSettings *s); DLLEXPORT C_KZG_RET blob_to_kzg_commitment(KZGCommitment *out, const Blob *blob, const KZGSettings *s); -DLLEXPORT int verify_aggregate_kzg_proof_wrap(const Blob blobs[], const Bytes48 *commitments_bytes, size_t n, const Bytes48 *aggregated_proof_bytes, const KZGSettings *s); +DLLEXPORT C_KZG_RET compute_kzg_proof(KZGProof *out, const Blob *blob, const Bytes32 *z_bytes, const KZGSettings *s); -DLLEXPORT C_KZG_RET compute_aggregate_kzg_proof(KZGProof *out, const Blob blobs[], size_t n, const KZGSettings *s); +DLLEXPORT C_KZG_RET compute_blob_kzg_proof(KZGProof *out, const Blob *blob, const KZGSettings *s); -DLLEXPORT int verify_kzg_proof_wrap(const Bytes48 *commitment_bytes, const Bytes32 *z_bytes, const Bytes32 *y_bytes, const Bytes48 *proof_bytes, KZGSettings *s); +DLLEXPORT C_KZG_RET verify_kzg_proof(bool *result, const Bytes48 *commitments_bytes, const Bytes32 *z_bytes, const Bytes32 *y_bytes, const Bytes48 *proof_bytes, const KZGSettings *s); + +DLLEXPORT C_KZG_RET verify_blob_kzg_proof(bool *result, const Blob *blob, const Bytes48 *commitment_bytes, const Bytes48 *proof_bytes, const KZGSettings *s); + +DLLEXPORT C_KZG_RET verify_blob_kzg_proof_batch(bool *result, const Blob *blobs, const Bytes48 *commitments_bytes, const Bytes48 *proofs_bytes, size_t count, const KZGSettings *s);