From 812cbf3d46f50a4dfbcdae21bac3b90eb3126595 Mon Sep 17 00:00:00 2001 From: Colin Roberts Date: Tue, 5 Nov 2024 16:05:06 -0700 Subject: [PATCH] clean up JSON and fix NIVC test --- .../json_extract_value_1024b.circom | 2 +- .../json_extract_value_512b.circom | 2 +- circuits/json/nivc/extractor.circom | 3 +-- circuits/test/full/full.test.ts | 24 ++++++------------- 4 files changed, 10 insertions(+), 21 deletions(-) diff --git a/builds/target_1024b/json_extract_value_1024b.circom b/builds/target_1024b/json_extract_value_1024b.circom index 7f4d122..fffbc10 100644 --- a/builds/target_1024b/json_extract_value_1024b.circom +++ b/builds/target_1024b/json_extract_value_1024b.circom @@ -2,4 +2,4 @@ pragma circom 2.1.9; include "../../circuits/json/nivc/extractor.circom"; -component main { public [step_in] } = MaskExtractFinal(1024, 10, 50); \ No newline at end of file +component main { public [step_in] } = MaskExtractFinal(1024, 50); \ No newline at end of file diff --git a/builds/target_512b/json_extract_value_512b.circom b/builds/target_512b/json_extract_value_512b.circom index a7fa283..600cc0a 100644 --- a/builds/target_512b/json_extract_value_512b.circom +++ b/builds/target_512b/json_extract_value_512b.circom @@ -2,4 +2,4 @@ pragma circom 2.1.9; include "../../circuits/json/nivc/extractor.circom"; -component main { public [step_in] } = MaskExtractFinal(512, 10, 50); \ No newline at end of file +component main { public [step_in] } = MaskExtractFinal(512, 50); \ No newline at end of file diff --git a/circuits/json/nivc/extractor.circom b/circuits/json/nivc/extractor.circom index 95220ab..32b4b1a 100644 --- a/circuits/json/nivc/extractor.circom +++ b/circuits/json/nivc/extractor.circom @@ -3,9 +3,8 @@ pragma circom 2.1.9; include "circomlib/circuits/gates.circom"; include "@zk-email/circuits/utils/array.circom"; -template MaskExtractFinal(DATA_BYTES, MAX_STACK_HEIGHT, MAX_VALUE_LENGTH) { +template MaskExtractFinal(DATA_BYTES, MAX_VALUE_LENGTH) { // ------------------------------------------------------------------------------------------------------------------ // - assert(MAX_STACK_HEIGHT >= 2); var TOTAL_BYTES_ACROSS_NIVC = DATA_BYTES * 2 + 4; // aes pt/ct + ctr // ------------------------------------------------------------------------------------------------------------------ // signal input step_in[TOTAL_BYTES_ACROSS_NIVC]; diff --git a/circuits/test/full/full.test.ts b/circuits/test/full/full.test.ts index cca96e1..380d862 100644 --- a/circuits/test/full/full.test.ts +++ b/circuits/test/full/full.test.ts @@ -49,8 +49,7 @@ describe("NIVC_FULL", async () => { const DATA_BYTES = 320; const MAX_STACK_HEIGHT = 5; - const PER_ITERATION_DATA_LENGTH = MAX_STACK_HEIGHT * 2 + 2; - const TOTAL_BYTES_ACROSS_NIVC = DATA_BYTES * (PER_ITERATION_DATA_LENGTH + 1) + 1; + const TOTAL_BYTES_ACROSS_NIVC = DATA_BYTES * 2 + 4; const MAX_HEADER_NAME_LENGTH = 20; const MAX_HEADER_VALUE_LENGTH = 35; @@ -69,37 +68,30 @@ describe("NIVC_FULL", async () => { aesCircuit = await circomkit.WitnessTester("AESGCTRFOLD", { file: "aes-gcm/nivc/aes-gctr-nivc", template: "AESGCTRFOLD", - params: [DATA_BYTES, MAX_STACK_HEIGHT], + params: [DATA_BYTES], }); console.log("#constraints (AES-GCTR):", await aesCircuit.getConstraintCount()); httpParseAndLockStartLineCircuit = await circomkit.WitnessTester(`ParseAndLockStartLine`, { file: "http/nivc/parse_and_lock_start_line", template: "ParseAndLockStartLine", - params: [DATA_BYTES, MAX_STACK_HEIGHT, MAX_BEGINNING_LENGTH, MAX_MIDDLE_LENGTH, MAX_FINAL_LENGTH], + params: [DATA_BYTES, MAX_BEGINNING_LENGTH, MAX_MIDDLE_LENGTH, MAX_FINAL_LENGTH], }); console.log("#constraints (HTTP-PARSE-AND-LOCK-START-LINE):", await httpParseAndLockStartLineCircuit.getConstraintCount()); lockHeaderCircuit = await circomkit.WitnessTester(`LockHeader`, { file: "http/nivc/lock_header", template: "LockHeader", - params: [DATA_BYTES, MAX_STACK_HEIGHT, MAX_HEADER_NAME_LENGTH, MAX_HEADER_VALUE_LENGTH], + params: [DATA_BYTES, MAX_HEADER_NAME_LENGTH, MAX_HEADER_VALUE_LENGTH], }); console.log("#constraints (HTTP-LOCK-HEADER):", await lockHeaderCircuit.getConstraintCount()); bodyMaskCircuit = await circomkit.WitnessTester(`BodyMask`, { file: "http/nivc/body_mask", template: "HTTPMaskBodyNIVC", - params: [DATA_BYTES, MAX_STACK_HEIGHT], + params: [DATA_BYTES], }); console.log("#constraints (HTTP-BODY-MASK):", await bodyMaskCircuit.getConstraintCount()); - parse_circuit = await circomkit.WitnessTester(`JsonParseNIVC`, { - file: "json/nivc/parse", - template: "JsonParseNIVC", - params: [DATA_BYTES, MAX_STACK_HEIGHT], - }); - console.log("#constraints (JSON-PARSE):", await parse_circuit.getConstraintCount()); - json_mask_arr_circuit = await circomkit.WitnessTester(`JsonMaskArrayIndexNIVC`, { file: "json/nivc/masker", template: "JsonMaskArrayIndexNIVC", @@ -117,7 +109,7 @@ describe("NIVC_FULL", async () => { extract_value_circuit = await circomkit.WitnessTester(`JsonMaskExtractFinal`, { file: "json/nivc/extractor", template: "MaskExtractFinal", - params: [DATA_BYTES, MAX_STACK_HEIGHT, MAX_VALUE_LENGTH], + params: [DATA_BYTES, MAX_VALUE_LENGTH], }); console.log("#constraints (JSON-MASK-EXTRACT-FINAL):", await extract_value_circuit.getConstraintCount()); }); @@ -175,9 +167,7 @@ describe("NIVC_FULL", async () => { let value = toByte("\"Taylor Swift\""); - let json_parse = await parse_circuit.compute({ step_in: bodyMaskOut }, ["step_out"]); - - let json_extract_key0 = await json_mask_object_circuit.compute({ step_in: json_parse.step_out, key: key0, keyLen: key0Len }, ["step_out"]); + let json_extract_key0 = await json_mask_object_circuit.compute({ step_in: bodyMaskOut, key: key0, keyLen: key0Len }, ["step_out"]); let json_num = json_extract_key0.step_out as number[]; console.log("json_extract_key0", json_num);