diff --git a/packages/apis/src/decomposed_defs/email_addr_with_name.json b/packages/apis/src/decomposed_defs/email_addr_with_name.json deleted file mode 100644 index 999ea3e..0000000 --- a/packages/apis/src/decomposed_defs/email_addr_with_name.json +++ /dev/null @@ -1,16 +0,0 @@ -{ - "parts": [ - { - "is_public": false, - "regex_def": "[^\r\n]+<" - }, - { - "is_public": true, - "regex_def": "[A-Za-z0-9!#$%&'*+=?\\-\\^_`{|}~./@]+@[a-zA-Z0-9.\\-]+" - }, - { - "is_public": false, - "regex_def": ">" - } - ] -} \ No newline at end of file diff --git a/packages/apis/src/decomposed_defs/from_addr.json b/packages/apis/src/decomposed_defs/from_addr.json index 82fefdd..6753257 100644 --- a/packages/apis/src/decomposed_defs/from_addr.json +++ b/packages/apis/src/decomposed_defs/from_addr.json @@ -10,7 +10,7 @@ }, { "is_public": true, - "regex_def": "[A-Za-z0-9!#$%&'*+=?\\-\\^_`{|}~./@]+@[A-Za-z0-9.\\-]+" + "regex_def": "[^<>]+" }, { "is_public": false, diff --git a/packages/apis/src/decomposed_defs/to_addr.json b/packages/apis/src/decomposed_defs/to_addr.json index 9c7a4b1..394a26b 100644 --- a/packages/apis/src/decomposed_defs/to_addr.json +++ b/packages/apis/src/decomposed_defs/to_addr.json @@ -10,7 +10,7 @@ }, { "is_public": true, - "regex_def": "[A-Za-z0-9!#$%&'*+=?\\-\\^_`{|}~./@]+@[a-zA-Z0-9.\\-]+" + "regex_def": "[^<>]+" }, { "is_public": false, diff --git a/packages/apis/src/extract_substrs.rs b/packages/apis/src/extract_substrs.rs index fea936e..18e1a92 100644 --- a/packages/apis/src/extract_substrs.rs +++ b/packages/apis/src/extract_substrs.rs @@ -89,12 +89,12 @@ pub fn extract_email_domain_idxes( extract_substr_idxes(input_str, &serde_json::from_str(regex_config).unwrap()) } -pub fn extract_email_addr_with_name_idxes( - input_str: &str, -) -> Result, ExtractSubstrssError> { - let regex_config = include_str!("./decomposed_defs/email_addr_with_name.json"); - extract_substr_idxes(input_str, &serde_json::from_str(regex_config).unwrap()) -} +// pub fn extract_email_addr_with_name_idxes( +// input_str: &str, +// ) -> Result, ExtractSubstrssError> { +// let regex_config = include_str!("./decomposed_defs/email_addr_with_name.json"); +// extract_substr_idxes(input_str, &serde_json::from_str(regex_config).unwrap()) +// } pub fn extract_from_all_idxes( input_str: &str, @@ -166,20 +166,20 @@ mod test { assert_eq!(idxes, vec![(17, 38)]); } - #[test] - fn test_email_addr_with_name_valid1() { - let input_str = "from:dummy@a.com "; - let idxes = extract_email_addr_with_name_idxes(input_str).unwrap(); - assert_eq!(idxes, vec![(18, 39)]); - } - - #[test] - fn test_email_addr_with_name_valid2() { - // "末神 奏宙" has 13 bytes. - let input_str = "from:\"末神 奏宙\" "; - let idxes = extract_email_addr_with_name_idxes(input_str).unwrap(); - assert_eq!(idxes, vec![(22, 43)]); - } + // #[test] + // fn test_email_addr_with_name_valid1() { + // let input_str = "from:dummy@a.com "; + // let idxes = extract_email_addr_with_name_idxes(input_str).unwrap(); + // assert_eq!(idxes, vec![(18, 39)]); + // } + + // #[test] + // fn test_email_addr_with_name_valid2() { + // // "末神 奏宙" has 13 bytes. + // let input_str = "from:\"末神 奏宙\" "; + // let idxes = extract_email_addr_with_name_idxes(input_str).unwrap(); + // assert_eq!(idxes, vec![(22, 43)]); + // } #[test] fn test_email_from_all_valid() { diff --git a/packages/apis/src/wasm.rs b/packages/apis/src/wasm.rs index 5ce405a..9e5b0ff 100644 --- a/packages/apis/src/wasm.rs +++ b/packages/apis/src/wasm.rs @@ -47,12 +47,12 @@ pub fn extractEmailDomainIdxes(inputStr: &str) -> Array { extractSubstrIdxes(inputStr, JsValue::from_str(regex_config)) } -#[wasm_bindgen] -#[allow(non_snake_case)] -pub fn extractEmailAddrWithNameIdxes(inputStr: &str) -> Array { - let regex_config = include_str!("./decomposed_defs/email_addr_with_name.json"); - extractSubstrIdxes(inputStr, JsValue::from_str(regex_config)) -} +// #[wasm_bindgen] +// #[allow(non_snake_case)] +// pub fn extractEmailAddrWithNameIdxes(inputStr: &str) -> Array { +// let regex_config = include_str!("./decomposed_defs/email_addr_with_name.json"); +// extractSubstrIdxes(inputStr, JsValue::from_str(regex_config)) +// } #[wasm_bindgen] #[allow(non_snake_case)] diff --git a/packages/circom/circuits/common/email_addr_with_name_regex.circom b/packages/circom/circuits/common/email_addr_with_name_regex.circom index 9e6e781..94302f8 100644 --- a/packages/circom/circuits/common/email_addr_with_name_regex.circom +++ b/packages/circom/circuits/common/email_addr_with_name_regex.circom @@ -1,7 +1,7 @@ pragma circom 2.1.5; include "@zk-email/zk-regex-circom/circuits/regex_helpers.circom"; -include "./reversed_email_addr_with_name_regex.circom"; +include "./reversed_bracket_regex.circom"; template EmailAddrWithNameRegex(msg_bytes) { signal input msg[msg_bytes]; @@ -13,7 +13,7 @@ template EmailAddrWithNameRegex(msg_bytes) { for(var i=0; i?\r\n" - } - ] -} \ No newline at end of file diff --git a/packages/circom/circuits/common/from_addr_regex.circom b/packages/circom/circuits/common/from_addr_regex.circom index 302c8d3..105d648 100644 --- a/packages/circom/circuits/common/from_addr_regex.circom +++ b/packages/circom/circuits/common/from_addr_regex.circom @@ -1,9 +1,9 @@ pragma circom 2.1.5; -include "@zk-email/zk-regex-circom/circuits/regex_helpers.circom"; -include "@zk-email/zk-regex-circom/circuits/common/from_all_regex.circom"; -include "@zk-email/zk-regex-circom/circuits/common/email_addr_regex.circom"; -include "@zk-email/zk-regex-circom/circuits/common/email_addr_with_name_regex.circom"; +include "../regex_helpers.circom"; +include "./from_all_regex.circom"; +include "./email_addr_regex.circom"; +include "./email_addr_with_name_regex.circom"; template FromAddrRegex(msg_bytes) { diff --git a/packages/circom/circuits/common/reversed_email_addr_with_name.json b/packages/circom/circuits/common/reversed_bracket.json similarity index 74% rename from packages/circom/circuits/common/reversed_email_addr_with_name.json rename to packages/circom/circuits/common/reversed_bracket.json index 4c363a9..55ffaab 100644 --- a/packages/circom/circuits/common/reversed_email_addr_with_name.json +++ b/packages/circom/circuits/common/reversed_bracket.json @@ -6,7 +6,7 @@ }, { "is_public": true, - "regex_def": "[a-zA-Z0-9.\\-]+@[A-Za-z0-9!#$%&'*+=?\\-\\^_`{|}~./@]+" + "regex_def": "[^<>]+" }, { "is_public": false, diff --git a/packages/circom/circuits/common/reversed_bracket_regex.circom b/packages/circom/circuits/common/reversed_bracket_regex.circom new file mode 100644 index 0000000..7d0470b --- /dev/null +++ b/packages/circom/circuits/common/reversed_bracket_regex.circom @@ -0,0 +1,553 @@ +pragma circom 2.1.5; + +include "@zk-email/zk-regex-circom/circuits/regex_helpers.circom"; + +// regex: >[^<>]+<.* +template ReversedBracketRegex(msg_bytes) { + signal input msg[msg_bytes]; + signal output out; + + var num_bytes = msg_bytes+1; + signal in[num_bytes]; + in[0]<==255; + for (var i = 0; i < msg_bytes; i++) { + in[i+1] <== msg[i]; + } + + component eq[49][num_bytes]; + component lt[16][num_bytes]; + component and[48][num_bytes]; + component multi_or[16][num_bytes]; + signal states[num_bytes+1][18]; + signal states_tmp[num_bytes+1][18]; + signal from_zero_enabled[num_bytes+1]; + from_zero_enabled[num_bytes] <== 0; + component state_changed[num_bytes]; + + for (var i = 1; i < 18; i++) { + states[0][i] <== 0; + } + + for (var i = 0; i < num_bytes; i++) { + state_changed[i] = MultiOR(17); + states[i][0] <== 1; + eq[0][i] = IsEqual(); + eq[0][i].in[0] <== in[i]; + eq[0][i].in[1] <== 62; + and[0][i] = AND(); + and[0][i].a <== states[i][0]; + and[0][i].b <== eq[0][i].out; + states_tmp[i+1][1] <== 0; + lt[0][i] = LessEqThan(8); + lt[0][i].in[0] <== 1; + lt[0][i].in[1] <== in[i]; + lt[1][i] = LessEqThan(8); + lt[1][i].in[0] <== in[i]; + lt[1][i].in[1] <== 59; + and[1][i] = AND(); + and[1][i].a <== lt[0][i].out; + and[1][i].b <== lt[1][i].out; + lt[2][i] = LessEqThan(8); + lt[2][i].in[0] <== 63; + lt[2][i].in[1] <== in[i]; + lt[3][i] = LessEqThan(8); + lt[3][i].in[0] <== in[i]; + lt[3][i].in[1] <== 127; + and[2][i] = AND(); + and[2][i].a <== lt[2][i].out; + and[2][i].b <== lt[3][i].out; + eq[1][i] = IsEqual(); + eq[1][i].in[0] <== in[i]; + eq[1][i].in[1] <== 61; + and[3][i] = AND(); + and[3][i].a <== states[i][1]; + multi_or[0][i] = MultiOR(3); + multi_or[0][i].in[0] <== and[1][i].out; + multi_or[0][i].in[1] <== and[2][i].out; + multi_or[0][i].in[2] <== eq[1][i].out; + and[3][i].b <== multi_or[0][i].out; + and[4][i] = AND(); + and[4][i].a <== states[i][2]; + and[4][i].b <== multi_or[0][i].out; + lt[4][i] = LessEqThan(8); + lt[4][i].in[0] <== 128; + lt[4][i].in[1] <== in[i]; + lt[5][i] = LessEqThan(8); + lt[5][i].in[0] <== in[i]; + lt[5][i].in[1] <== 191; + and[5][i] = AND(); + and[5][i].a <== lt[4][i].out; + and[5][i].b <== lt[5][i].out; + and[6][i] = AND(); + and[6][i].a <== states[i][3]; + and[6][i].b <== and[5][i].out; + multi_or[1][i] = MultiOR(3); + multi_or[1][i].in[0] <== and[3][i].out; + multi_or[1][i].in[1] <== and[4][i].out; + multi_or[1][i].in[2] <== and[6][i].out; + states[i+1][2] <== multi_or[1][i].out; + lt[6][i] = LessEqThan(8); + lt[6][i].in[0] <== 194; + lt[6][i].in[1] <== in[i]; + lt[7][i] = LessEqThan(8); + lt[7][i].in[0] <== in[i]; + lt[7][i].in[1] <== 223; + and[7][i] = AND(); + and[7][i].a <== lt[6][i].out; + and[7][i].b <== lt[7][i].out; + and[8][i] = AND(); + and[8][i].a <== states[i][1]; + and[8][i].b <== and[7][i].out; + and[9][i] = AND(); + and[9][i].a <== states[i][2]; + and[9][i].b <== and[7][i].out; + lt[8][i] = LessEqThan(8); + lt[8][i].in[0] <== 160; + lt[8][i].in[1] <== in[i]; + lt[9][i] = LessEqThan(8); + lt[9][i].in[0] <== in[i]; + lt[9][i].in[1] <== 191; + and[10][i] = AND(); + and[10][i].a <== lt[8][i].out; + and[10][i].b <== lt[9][i].out; + and[11][i] = AND(); + and[11][i].a <== states[i][4]; + and[11][i].b <== and[10][i].out; + and[12][i] = AND(); + and[12][i].a <== states[i][5]; + and[12][i].b <== and[5][i].out; + lt[10][i] = LessEqThan(8); + lt[10][i].in[0] <== 128; + lt[10][i].in[1] <== in[i]; + lt[11][i] = LessEqThan(8); + lt[11][i].in[0] <== in[i]; + lt[11][i].in[1] <== 159; + and[13][i] = AND(); + and[13][i].a <== lt[10][i].out; + and[13][i].b <== lt[11][i].out; + and[14][i] = AND(); + and[14][i].a <== states[i][6]; + and[14][i].b <== and[13][i].out; + multi_or[2][i] = MultiOR(5); + multi_or[2][i].in[0] <== and[8][i].out; + multi_or[2][i].in[1] <== and[9][i].out; + multi_or[2][i].in[2] <== and[11][i].out; + multi_or[2][i].in[3] <== and[12][i].out; + multi_or[2][i].in[4] <== and[14][i].out; + states[i+1][3] <== multi_or[2][i].out; + eq[2][i] = IsEqual(); + eq[2][i].in[0] <== in[i]; + eq[2][i].in[1] <== 224; + and[15][i] = AND(); + and[15][i].a <== states[i][1]; + and[15][i].b <== eq[2][i].out; + and[16][i] = AND(); + and[16][i].a <== states[i][2]; + and[16][i].b <== eq[2][i].out; + multi_or[3][i] = MultiOR(2); + multi_or[3][i].in[0] <== and[15][i].out; + multi_or[3][i].in[1] <== and[16][i].out; + states[i+1][4] <== multi_or[3][i].out; + eq[3][i] = IsEqual(); + eq[3][i].in[0] <== in[i]; + eq[3][i].in[1] <== 225; + eq[4][i] = IsEqual(); + eq[4][i].in[0] <== in[i]; + eq[4][i].in[1] <== 226; + eq[5][i] = IsEqual(); + eq[5][i].in[0] <== in[i]; + eq[5][i].in[1] <== 227; + eq[6][i] = IsEqual(); + eq[6][i].in[0] <== in[i]; + eq[6][i].in[1] <== 228; + eq[7][i] = IsEqual(); + eq[7][i].in[0] <== in[i]; + eq[7][i].in[1] <== 229; + eq[8][i] = IsEqual(); + eq[8][i].in[0] <== in[i]; + eq[8][i].in[1] <== 230; + eq[9][i] = IsEqual(); + eq[9][i].in[0] <== in[i]; + eq[9][i].in[1] <== 231; + eq[10][i] = IsEqual(); + eq[10][i].in[0] <== in[i]; + eq[10][i].in[1] <== 232; + eq[11][i] = IsEqual(); + eq[11][i].in[0] <== in[i]; + eq[11][i].in[1] <== 233; + eq[12][i] = IsEqual(); + eq[12][i].in[0] <== in[i]; + eq[12][i].in[1] <== 234; + eq[13][i] = IsEqual(); + eq[13][i].in[0] <== in[i]; + eq[13][i].in[1] <== 235; + eq[14][i] = IsEqual(); + eq[14][i].in[0] <== in[i]; + eq[14][i].in[1] <== 236; + eq[15][i] = IsEqual(); + eq[15][i].in[0] <== in[i]; + eq[15][i].in[1] <== 238; + eq[16][i] = IsEqual(); + eq[16][i].in[0] <== in[i]; + eq[16][i].in[1] <== 239; + and[17][i] = AND(); + and[17][i].a <== states[i][1]; + multi_or[4][i] = MultiOR(14); + multi_or[4][i].in[0] <== eq[3][i].out; + multi_or[4][i].in[1] <== eq[4][i].out; + multi_or[4][i].in[2] <== eq[5][i].out; + multi_or[4][i].in[3] <== eq[6][i].out; + multi_or[4][i].in[4] <== eq[7][i].out; + multi_or[4][i].in[5] <== eq[8][i].out; + multi_or[4][i].in[6] <== eq[9][i].out; + multi_or[4][i].in[7] <== eq[10][i].out; + multi_or[4][i].in[8] <== eq[11][i].out; + multi_or[4][i].in[9] <== eq[12][i].out; + multi_or[4][i].in[10] <== eq[13][i].out; + multi_or[4][i].in[11] <== eq[14][i].out; + multi_or[4][i].in[12] <== eq[15][i].out; + multi_or[4][i].in[13] <== eq[16][i].out; + and[17][i].b <== multi_or[4][i].out; + and[18][i] = AND(); + and[18][i].a <== states[i][2]; + and[18][i].b <== multi_or[4][i].out; + lt[12][i] = LessEqThan(8); + lt[12][i].in[0] <== 144; + lt[12][i].in[1] <== in[i]; + lt[13][i] = LessEqThan(8); + lt[13][i].in[0] <== in[i]; + lt[13][i].in[1] <== 191; + and[19][i] = AND(); + and[19][i].a <== lt[12][i].out; + and[19][i].b <== lt[13][i].out; + and[20][i] = AND(); + and[20][i].a <== states[i][7]; + and[20][i].b <== and[19][i].out; + and[21][i] = AND(); + and[21][i].a <== states[i][8]; + and[21][i].b <== and[5][i].out; + eq[17][i] = IsEqual(); + eq[17][i].in[0] <== in[i]; + eq[17][i].in[1] <== 128; + eq[18][i] = IsEqual(); + eq[18][i].in[0] <== in[i]; + eq[18][i].in[1] <== 129; + eq[19][i] = IsEqual(); + eq[19][i].in[0] <== in[i]; + eq[19][i].in[1] <== 130; + eq[20][i] = IsEqual(); + eq[20][i].in[0] <== in[i]; + eq[20][i].in[1] <== 131; + eq[21][i] = IsEqual(); + eq[21][i].in[0] <== in[i]; + eq[21][i].in[1] <== 132; + eq[22][i] = IsEqual(); + eq[22][i].in[0] <== in[i]; + eq[22][i].in[1] <== 133; + eq[23][i] = IsEqual(); + eq[23][i].in[0] <== in[i]; + eq[23][i].in[1] <== 134; + eq[24][i] = IsEqual(); + eq[24][i].in[0] <== in[i]; + eq[24][i].in[1] <== 135; + eq[25][i] = IsEqual(); + eq[25][i].in[0] <== in[i]; + eq[25][i].in[1] <== 136; + eq[26][i] = IsEqual(); + eq[26][i].in[0] <== in[i]; + eq[26][i].in[1] <== 137; + eq[27][i] = IsEqual(); + eq[27][i].in[0] <== in[i]; + eq[27][i].in[1] <== 138; + eq[28][i] = IsEqual(); + eq[28][i].in[0] <== in[i]; + eq[28][i].in[1] <== 139; + eq[29][i] = IsEqual(); + eq[29][i].in[0] <== in[i]; + eq[29][i].in[1] <== 140; + eq[30][i] = IsEqual(); + eq[30][i].in[0] <== in[i]; + eq[30][i].in[1] <== 141; + eq[31][i] = IsEqual(); + eq[31][i].in[0] <== in[i]; + eq[31][i].in[1] <== 142; + eq[32][i] = IsEqual(); + eq[32][i].in[0] <== in[i]; + eq[32][i].in[1] <== 143; + and[22][i] = AND(); + and[22][i].a <== states[i][9]; + multi_or[5][i] = MultiOR(16); + multi_or[5][i].in[0] <== eq[17][i].out; + multi_or[5][i].in[1] <== eq[18][i].out; + multi_or[5][i].in[2] <== eq[19][i].out; + multi_or[5][i].in[3] <== eq[20][i].out; + multi_or[5][i].in[4] <== eq[21][i].out; + multi_or[5][i].in[5] <== eq[22][i].out; + multi_or[5][i].in[6] <== eq[23][i].out; + multi_or[5][i].in[7] <== eq[24][i].out; + multi_or[5][i].in[8] <== eq[25][i].out; + multi_or[5][i].in[9] <== eq[26][i].out; + multi_or[5][i].in[10] <== eq[27][i].out; + multi_or[5][i].in[11] <== eq[28][i].out; + multi_or[5][i].in[12] <== eq[29][i].out; + multi_or[5][i].in[13] <== eq[30][i].out; + multi_or[5][i].in[14] <== eq[31][i].out; + multi_or[5][i].in[15] <== eq[32][i].out; + and[22][i].b <== multi_or[5][i].out; + multi_or[6][i] = MultiOR(5); + multi_or[6][i].in[0] <== and[17][i].out; + multi_or[6][i].in[1] <== and[18][i].out; + multi_or[6][i].in[2] <== and[20][i].out; + multi_or[6][i].in[3] <== and[21][i].out; + multi_or[6][i].in[4] <== and[22][i].out; + states[i+1][5] <== multi_or[6][i].out; + eq[33][i] = IsEqual(); + eq[33][i].in[0] <== in[i]; + eq[33][i].in[1] <== 237; + and[23][i] = AND(); + and[23][i].a <== states[i][1]; + and[23][i].b <== eq[33][i].out; + and[24][i] = AND(); + and[24][i].a <== states[i][2]; + and[24][i].b <== eq[33][i].out; + multi_or[7][i] = MultiOR(2); + multi_or[7][i].in[0] <== and[23][i].out; + multi_or[7][i].in[1] <== and[24][i].out; + states[i+1][6] <== multi_or[7][i].out; + eq[34][i] = IsEqual(); + eq[34][i].in[0] <== in[i]; + eq[34][i].in[1] <== 240; + and[25][i] = AND(); + and[25][i].a <== states[i][1]; + and[25][i].b <== eq[34][i].out; + and[26][i] = AND(); + and[26][i].a <== states[i][2]; + and[26][i].b <== eq[34][i].out; + multi_or[8][i] = MultiOR(2); + multi_or[8][i].in[0] <== and[25][i].out; + multi_or[8][i].in[1] <== and[26][i].out; + states[i+1][7] <== multi_or[8][i].out; + eq[35][i] = IsEqual(); + eq[35][i].in[0] <== in[i]; + eq[35][i].in[1] <== 241; + eq[36][i] = IsEqual(); + eq[36][i].in[0] <== in[i]; + eq[36][i].in[1] <== 242; + eq[37][i] = IsEqual(); + eq[37][i].in[0] <== in[i]; + eq[37][i].in[1] <== 243; + and[27][i] = AND(); + and[27][i].a <== states[i][1]; + multi_or[9][i] = MultiOR(3); + multi_or[9][i].in[0] <== eq[35][i].out; + multi_or[9][i].in[1] <== eq[36][i].out; + multi_or[9][i].in[2] <== eq[37][i].out; + and[27][i].b <== multi_or[9][i].out; + and[28][i] = AND(); + and[28][i].a <== states[i][2]; + and[28][i].b <== multi_or[9][i].out; + multi_or[10][i] = MultiOR(2); + multi_or[10][i].in[0] <== and[27][i].out; + multi_or[10][i].in[1] <== and[28][i].out; + states[i+1][8] <== multi_or[10][i].out; + eq[38][i] = IsEqual(); + eq[38][i].in[0] <== in[i]; + eq[38][i].in[1] <== 244; + and[29][i] = AND(); + and[29][i].a <== states[i][1]; + and[29][i].b <== eq[38][i].out; + and[30][i] = AND(); + and[30][i].a <== states[i][2]; + and[30][i].b <== eq[38][i].out; + multi_or[11][i] = MultiOR(2); + multi_or[11][i].in[0] <== and[29][i].out; + multi_or[11][i].in[1] <== and[30][i].out; + states[i+1][9] <== multi_or[11][i].out; + eq[39][i] = IsEqual(); + eq[39][i].in[0] <== in[i]; + eq[39][i].in[1] <== 60; + and[31][i] = AND(); + and[31][i].a <== states[i][2]; + and[31][i].b <== eq[39][i].out; + lt[14][i] = LessEqThan(8); + lt[14][i].in[0] <== 11; + lt[14][i].in[1] <== in[i]; + lt[15][i] = LessEqThan(8); + lt[15][i].in[0] <== in[i]; + lt[15][i].in[1] <== 127; + and[32][i] = AND(); + and[32][i].a <== lt[14][i].out; + and[32][i].b <== lt[15][i].out; + eq[40][i] = IsEqual(); + eq[40][i].in[0] <== in[i]; + eq[40][i].in[1] <== 1; + eq[41][i] = IsEqual(); + eq[41][i].in[0] <== in[i]; + eq[41][i].in[1] <== 2; + eq[42][i] = IsEqual(); + eq[42][i].in[0] <== in[i]; + eq[42][i].in[1] <== 3; + eq[43][i] = IsEqual(); + eq[43][i].in[0] <== in[i]; + eq[43][i].in[1] <== 4; + eq[44][i] = IsEqual(); + eq[44][i].in[0] <== in[i]; + eq[44][i].in[1] <== 5; + eq[45][i] = IsEqual(); + eq[45][i].in[0] <== in[i]; + eq[45][i].in[1] <== 6; + eq[46][i] = IsEqual(); + eq[46][i].in[0] <== in[i]; + eq[46][i].in[1] <== 7; + eq[47][i] = IsEqual(); + eq[47][i].in[0] <== in[i]; + eq[47][i].in[1] <== 8; + eq[48][i] = IsEqual(); + eq[48][i].in[0] <== in[i]; + eq[48][i].in[1] <== 9; + and[33][i] = AND(); + and[33][i].a <== states[i][10]; + multi_or[12][i] = MultiOR(10); + multi_or[12][i].in[0] <== and[32][i].out; + multi_or[12][i].in[1] <== eq[40][i].out; + multi_or[12][i].in[2] <== eq[41][i].out; + multi_or[12][i].in[3] <== eq[42][i].out; + multi_or[12][i].in[4] <== eq[43][i].out; + multi_or[12][i].in[5] <== eq[44][i].out; + multi_or[12][i].in[6] <== eq[45][i].out; + multi_or[12][i].in[7] <== eq[46][i].out; + multi_or[12][i].in[8] <== eq[47][i].out; + multi_or[12][i].in[9] <== eq[48][i].out; + and[33][i].b <== multi_or[12][i].out; + and[34][i] = AND(); + and[34][i].a <== states[i][11]; + and[34][i].b <== and[5][i].out; + multi_or[13][i] = MultiOR(3); + multi_or[13][i].in[0] <== and[31][i].out; + multi_or[13][i].in[1] <== and[33][i].out; + multi_or[13][i].in[2] <== and[34][i].out; + states[i+1][10] <== multi_or[13][i].out; + and[35][i] = AND(); + and[35][i].a <== states[i][10]; + and[35][i].b <== and[7][i].out; + and[36][i] = AND(); + and[36][i].a <== states[i][12]; + and[36][i].b <== and[10][i].out; + and[37][i] = AND(); + and[37][i].a <== states[i][13]; + and[37][i].b <== and[5][i].out; + and[38][i] = AND(); + and[38][i].a <== states[i][14]; + and[38][i].b <== and[13][i].out; + multi_or[14][i] = MultiOR(4); + multi_or[14][i].in[0] <== and[35][i].out; + multi_or[14][i].in[1] <== and[36][i].out; + multi_or[14][i].in[2] <== and[37][i].out; + multi_or[14][i].in[3] <== and[38][i].out; + states[i+1][11] <== multi_or[14][i].out; + and[39][i] = AND(); + and[39][i].a <== states[i][10]; + and[39][i].b <== eq[2][i].out; + states[i+1][12] <== and[39][i].out; + and[40][i] = AND(); + and[40][i].a <== states[i][10]; + and[40][i].b <== multi_or[4][i].out; + and[41][i] = AND(); + and[41][i].a <== states[i][15]; + and[41][i].b <== and[19][i].out; + and[42][i] = AND(); + and[42][i].a <== states[i][16]; + and[42][i].b <== and[5][i].out; + and[43][i] = AND(); + and[43][i].a <== states[i][17]; + and[43][i].b <== multi_or[5][i].out; + multi_or[15][i] = MultiOR(4); + multi_or[15][i].in[0] <== and[40][i].out; + multi_or[15][i].in[1] <== and[41][i].out; + multi_or[15][i].in[2] <== and[42][i].out; + multi_or[15][i].in[3] <== and[43][i].out; + states[i+1][13] <== multi_or[15][i].out; + and[44][i] = AND(); + and[44][i].a <== states[i][10]; + and[44][i].b <== eq[33][i].out; + states[i+1][14] <== and[44][i].out; + and[45][i] = AND(); + and[45][i].a <== states[i][10]; + and[45][i].b <== eq[34][i].out; + states[i+1][15] <== and[45][i].out; + and[46][i] = AND(); + and[46][i].a <== states[i][10]; + and[46][i].b <== multi_or[9][i].out; + states[i+1][16] <== and[46][i].out; + and[47][i] = AND(); + and[47][i].a <== states[i][10]; + and[47][i].b <== eq[38][i].out; + states[i+1][17] <== and[47][i].out; + from_zero_enabled[i] <== MultiNOR(17)([states_tmp[i+1][1], states[i+1][2], states[i+1][3], states[i+1][4], states[i+1][5], states[i+1][6], states[i+1][7], states[i+1][8], states[i+1][9], states[i+1][10], states[i+1][11], states[i+1][12], states[i+1][13], states[i+1][14], states[i+1][15], states[i+1][16], states[i+1][17]]); + states[i+1][1] <== MultiOR(2)([states_tmp[i+1][1], from_zero_enabled[i] * and[0][i].out]); + state_changed[i].in[0] <== states[i+1][1]; + state_changed[i].in[1] <== states[i+1][2]; + state_changed[i].in[2] <== states[i+1][3]; + state_changed[i].in[3] <== states[i+1][4]; + state_changed[i].in[4] <== states[i+1][5]; + state_changed[i].in[5] <== states[i+1][6]; + state_changed[i].in[6] <== states[i+1][7]; + state_changed[i].in[7] <== states[i+1][8]; + state_changed[i].in[8] <== states[i+1][9]; + state_changed[i].in[9] <== states[i+1][10]; + state_changed[i].in[10] <== states[i+1][11]; + state_changed[i].in[11] <== states[i+1][12]; + state_changed[i].in[12] <== states[i+1][13]; + state_changed[i].in[13] <== states[i+1][14]; + state_changed[i].in[14] <== states[i+1][15]; + state_changed[i].in[15] <== states[i+1][16]; + state_changed[i].in[16] <== states[i+1][17]; + } + + component is_accepted = MultiOR(num_bytes+1); + for (var i = 0; i <= num_bytes; i++) { + is_accepted.in[i] <== states[i][10]; + } + out <== is_accepted.out; + signal is_consecutive[msg_bytes+1][3]; + is_consecutive[msg_bytes][2] <== 0; + for (var i = 0; i < msg_bytes; i++) { + is_consecutive[msg_bytes-1-i][0] <== states[num_bytes-i][10] * (1 - is_consecutive[msg_bytes-i][2]) + is_consecutive[msg_bytes-i][2]; + is_consecutive[msg_bytes-1-i][1] <== state_changed[msg_bytes-i].out * is_consecutive[msg_bytes-1-i][0]; + is_consecutive[msg_bytes-1-i][2] <== ORAnd()([(1 - from_zero_enabled[msg_bytes-i+1]), states[num_bytes-i][10], is_consecutive[msg_bytes-1-i][1]]); + } + // substrings calculated: [{(1, 2), (1, 3), (1, 4), (1, 5), (1, 6), (1, 7), (1, 8), (1, 9), (2, 2), (2, 3), (2, 4), (2, 5), (2, 6), (2, 7), (2, 8), (2, 9), (3, 2), (4, 3), (5, 3), (6, 3), (7, 5), (8, 5), (9, 5)}] + signal prev_states0[23][msg_bytes]; + signal is_substr0[msg_bytes]; + signal is_reveal0[msg_bytes]; + signal output reveal0[msg_bytes]; + for (var i = 0; i < msg_bytes; i++) { + // the 0-th substring transitions: [(1, 2), (1, 3), (1, 4), (1, 5), (1, 6), (1, 7), (1, 8), (1, 9), (2, 2), (2, 3), (2, 4), (2, 5), (2, 6), (2, 7), (2, 8), (2, 9), (3, 2), (4, 3), (5, 3), (6, 3), (7, 5), (8, 5), (9, 5)] + prev_states0[0][i] <== (1 - from_zero_enabled[i+1]) * states[i+1][1]; + prev_states0[1][i] <== (1 - from_zero_enabled[i+1]) * states[i+1][1]; + prev_states0[2][i] <== (1 - from_zero_enabled[i+1]) * states[i+1][1]; + prev_states0[3][i] <== (1 - from_zero_enabled[i+1]) * states[i+1][1]; + prev_states0[4][i] <== (1 - from_zero_enabled[i+1]) * states[i+1][1]; + prev_states0[5][i] <== (1 - from_zero_enabled[i+1]) * states[i+1][1]; + prev_states0[6][i] <== (1 - from_zero_enabled[i+1]) * states[i+1][1]; + prev_states0[7][i] <== (1 - from_zero_enabled[i+1]) * states[i+1][1]; + prev_states0[8][i] <== (1 - from_zero_enabled[i+1]) * states[i+1][2]; + prev_states0[9][i] <== (1 - from_zero_enabled[i+1]) * states[i+1][2]; + prev_states0[10][i] <== (1 - from_zero_enabled[i+1]) * states[i+1][2]; + prev_states0[11][i] <== (1 - from_zero_enabled[i+1]) * states[i+1][2]; + prev_states0[12][i] <== (1 - from_zero_enabled[i+1]) * states[i+1][2]; + prev_states0[13][i] <== (1 - from_zero_enabled[i+1]) * states[i+1][2]; + prev_states0[14][i] <== (1 - from_zero_enabled[i+1]) * states[i+1][2]; + prev_states0[15][i] <== (1 - from_zero_enabled[i+1]) * states[i+1][2]; + prev_states0[16][i] <== (1 - from_zero_enabled[i+1]) * states[i+1][3]; + prev_states0[17][i] <== (1 - from_zero_enabled[i+1]) * states[i+1][4]; + prev_states0[18][i] <== (1 - from_zero_enabled[i+1]) * states[i+1][5]; + prev_states0[19][i] <== (1 - from_zero_enabled[i+1]) * states[i+1][6]; + prev_states0[20][i] <== (1 - from_zero_enabled[i+1]) * states[i+1][7]; + prev_states0[21][i] <== (1 - from_zero_enabled[i+1]) * states[i+1][8]; + prev_states0[22][i] <== (1 - from_zero_enabled[i+1]) * states[i+1][9]; + is_substr0[i] <== MultiOR(23)([prev_states0[0][i] * states[i+2][2], prev_states0[1][i] * states[i+2][3], prev_states0[2][i] * states[i+2][4], prev_states0[3][i] * states[i+2][5], prev_states0[4][i] * states[i+2][6], prev_states0[5][i] * states[i+2][7], prev_states0[6][i] * states[i+2][8], prev_states0[7][i] * states[i+2][9], prev_states0[8][i] * states[i+2][2], prev_states0[9][i] * states[i+2][3], prev_states0[10][i] * states[i+2][4], prev_states0[11][i] * states[i+2][5], prev_states0[12][i] * states[i+2][6], prev_states0[13][i] * states[i+2][7], prev_states0[14][i] * states[i+2][8], prev_states0[15][i] * states[i+2][9], prev_states0[16][i] * states[i+2][2], prev_states0[17][i] * states[i+2][3], prev_states0[18][i] * states[i+2][3], prev_states0[19][i] * states[i+2][3], prev_states0[20][i] * states[i+2][5], prev_states0[21][i] * states[i+2][5], prev_states0[22][i] * states[i+2][5]]); + is_reveal0[i] <== MultiAND(3)([out, is_substr0[i], is_consecutive[i][2]]); + reveal0[i] <== in[i+1] * is_reveal0[i]; + } +} \ No newline at end of file diff --git a/packages/circom/circuits/common/to_addr.json b/packages/circom/circuits/common/to_addr.json deleted file mode 100644 index 9c7a4b1..0000000 --- a/packages/circom/circuits/common/to_addr.json +++ /dev/null @@ -1,20 +0,0 @@ -{ - "parts": [ - { - "is_public": false, - "regex_def": "(\r\n|^)to:" - }, - { - "is_public": false, - "regex_def": "([^\r\n]+<)?" - }, - { - "is_public": true, - "regex_def": "[A-Za-z0-9!#$%&'*+=?\\-\\^_`{|}~./@]+@[a-zA-Z0-9.\\-]+" - }, - { - "is_public": false, - "regex_def": ">?\r\n" - } - ] -} \ No newline at end of file diff --git a/packages/circom/tests/from_addr.test.js b/packages/circom/tests/from_addr.test.js index ac9c50f..bfc8baa 100644 --- a/packages/circom/tests/from_addr.test.js +++ b/packages/circom/tests/from_addr.test.js @@ -28,17 +28,17 @@ describe("From Addr Regex", () => { } { const email_addr_json = readFileSync( - path.join(__dirname, "../circuits/common/reversed_email_addr_with_name.json"), + path.join(__dirname, "../circuits/common/reversed_bracket.json"), "utf8" ); const circom = compiler.genFromDecomposed( email_addr_json, - "ReversedEmailAddrWithNameRegex" + "ReversedBracketRegex" ); writeFileSync( path.join( __dirname, - "../circuits/common/reversed_email_addr_with_name_regex.circom" + "../circuits/common/reversed_bracket_regex.circom" ), circom ); @@ -297,19 +297,15 @@ describe("From Addr Regex", () => { }; const witness = await circuit.calculateWitness(circuitInputs); await circuit.checkConstraints(witness); - console.log((witness[1])); expect(1n).toEqual(witness[1]); const prefixIdxes = apis.extractFromAddrIdxes(fromStr)[0]; expect(" attacker@outlook.com").toEqual(fromStr.slice(prefixIdxes[0], prefixIdxes[1])); for (let idx = 0; idx < 1024; ++idx) { - if (witness[2 + idx] !== 0n) { - console.log('idx:', idx, 'witness:', witness[2 + idx]); + if (idx >= prefixIdxes[0] && idx < prefixIdxes[1]) { + expect(BigInt(paddedStr[idx])).toEqual(witness[2 + idx]); + } else { + expect(0n).toEqual(witness[2 + idx]); } - // if (idx >= prefixIdxes[0] && idx < prefixIdxes[1]) { - // expect(BigInt(paddedStr[idx])).toEqual(witness[2 + idx]); - // } else { - // expect(0n).toEqual(witness[2 + idx]); - // } } }); @@ -322,19 +318,19 @@ describe("From Addr Regex", () => { }; const witness = await circuit.calculateWitness(circuitInputs); await circuit.checkConstraints(witness); - console.log((witness[1])); + // console.log((witness[1])); expect(1n).toEqual(witness[1]); const prefixIdxes = apis.extractFromAddrIdxes(fromStr)[0]; expect("attacker@outlook.com ").toEqual(fromStr.slice(prefixIdxes[0], prefixIdxes[1])); for (let idx = 0; idx < 1024; ++idx) { - if (witness[2 + idx] !== 0n) { - console.log('idx:', idx, 'witness:', witness[2 + idx]); - } - // if (idx >= prefixIdxes[0] && idx < prefixIdxes[1]) { - // expect(BigInt(paddedStr[idx])).toEqual(witness[2 + idx]); - // } else { - // expect(0n).toEqual(witness[2 + idx]); + // if (witness[2 + idx] !== 0n) { + // console.log('idx:', idx, 'witness:', witness[2 + idx]); // } + if (idx >= prefixIdxes[0] && idx < prefixIdxes[1]) { + expect(BigInt(paddedStr[idx])).toEqual(witness[2 + idx]); + } else { + expect(0n).toEqual(witness[2 + idx]); + } } }); diff --git a/packages/circom/tests/to_addr.test.js b/packages/circom/tests/to_addr.test.js index e03ffe2..266814a 100644 --- a/packages/circom/tests/to_addr.test.js +++ b/packages/circom/tests/to_addr.test.js @@ -28,17 +28,17 @@ describe("To Addr Regex", () => { } { const email_addr_json = readFileSync( - path.join(__dirname, "../circuits/common/reversed_email_addr_with_name.json"), + path.join(__dirname, "../circuits/common/reversed_bracket.json"), "utf8" ); const circom = compiler.genFromDecomposed( email_addr_json, - "ReversedEmailAddrWithNameRegex" + "ReversedBracketRegex" ); writeFileSync( path.join( __dirname, - "../circuits/common/reversed_email_addr_with_name_regex.circom" + "../circuits/common/reversed_bracket_regex.circom" ), circom ); @@ -296,19 +296,19 @@ describe("To Addr Regex", () => { }; const witness = await circuit.calculateWitness(circuitInputs); await circuit.checkConstraints(witness); - console.log((witness[1])); + // console.log((witness[1])); expect(1n).toEqual(witness[1]); const prefixIdxes = apis.extractToAddrIdxes(toStr)[0]; expect(" attacker@outlook.com").toEqual(toStr.slice(prefixIdxes[0], prefixIdxes[1])); for (let idx = 0; idx < 1024; ++idx) { - if (witness[2 + idx] !== 0n) { - console.log('idx:', idx, 'witness:', witness[2 + idx]); - } - // if (idx >= prefixIdxes[0] && idx < prefixIdxes[1]) { - // expect(BigInt(paddedStr[idx])).toEqual(witness[2 + idx]); - // } else { - // expect(0n).toEqual(witness[2 + idx]); + // if (witness[2 + idx] !== 0n) { + // console.log('idx:', idx, 'witness:', witness[2 + idx]); // } + if (idx >= prefixIdxes[0] && idx < prefixIdxes[1]) { + expect(BigInt(paddedStr[idx])).toEqual(witness[2 + idx]); + } else { + expect(0n).toEqual(witness[2 + idx]); + } } }); @@ -321,19 +321,19 @@ describe("To Addr Regex", () => { }; const witness = await circuit.calculateWitness(circuitInputs); await circuit.checkConstraints(witness); - console.log((witness[1])); + // console.log((witness[1])); expect(1n).toEqual(witness[1]); const prefixIdxes = apis.extractToAddrIdxes(toStr)[0]; expect("attacker@outlook.com ").toEqual(toStr.slice(prefixIdxes[0], prefixIdxes[1])); for (let idx = 0; idx < 1024; ++idx) { - if (witness[2 + idx] !== 0n) { - console.log('idx:', idx, 'witness:', witness[2 + idx]); - } - // if (idx >= prefixIdxes[0] && idx < prefixIdxes[1]) { - // expect(BigInt(paddedStr[idx])).toEqual(witness[2 + idx]); - // } else { - // expect(0n).toEqual(witness[2 + idx]); + // if (witness[2 + idx] !== 0n) { + // console.log('idx:', idx, 'witness:', witness[2 + idx]); // } + if (idx >= prefixIdxes[0] && idx < prefixIdxes[1]) { + expect(BigInt(paddedStr[idx])).toEqual(witness[2 + idx]); + } else { + expect(0n).toEqual(witness[2 + idx]); + } } });