zkMe zkVault
This section explains the zkMe data recovery procedure enabled by the zkMe Data Vault required to fulfill KYC data storage and retention requirements in major regulatory jurisdictions.
Last updated
This section explains the zkMe data recovery procedure enabled by the zkMe Data Vault required to fulfill KYC data storage and retention requirements in major regulatory jurisdictions.
Last updated
The use of decentralized storage combined with threshold ensures that only authorized parties can access these documents under strict predetermined conditions and strict collaboration between all involved stakeholders. At no point in time is a single stakeholder able to unlock the private data of the Holder. In threshold encryption, a group of n participants collaboratively generate a public key, while the decryption key is shared among them. The Holder stays anonymous until proven guilty.
The public key can be used to encrypt messages directly, but decryption requires the participation of a minimum number of t participants among the n participants to obtain the correct plaintext. A crypto system that requires at least t participants to decrypt is called a (t/n) threshold crypto system.
The public key can be used to encrypt messages directly, but decryption requires the participation of a minimum number of t participants among the n participants to obtain the correct plaintext. A crypto system that requires at least t participants to decrypt is called a (t/n) threshold crypto system.
The zkMe protocol implements a (2/2) threshold cryptosystem (to be expanded to 3/3 in future iterations, see below).
Notation
Elliptic curve base point
Global private key(no one knows it)(type: scalar)
Order of the base point
Global public key(type: ecpoint)
Field of operations for elliptic curves
party-i 's private key (key share of )(type: scalar)
+
Addition operation in numerical terms
Point addition operation on elliptic curves
*
Multiplication operation in numerical terms
party-i 's commitment(type: scalar)
Point addition operation on elliptic curves
Random number(type: scalar)
Point doubling operation on elliptic curves
message
keccak256
ciphertext
ciphertext of m under AES with symmetric key
𝑘𝑝𝑜𝑖𝑛𝑡
Point can derive the symmetric key
sym_key
sym_key k
The threshold encryption public key negotiation goes through the following steps.
generate_key_share(m, n) at party-i
𝑥𝑖 ⟵𝑅 [𝑚,𝑛], ℎ𝑖=𝑥𝑖⊗𝑃
rand(p) at party-i
𝑟 ⟵𝑅 [1,𝑝]
generate_commitment(m, n) at party-i
𝑐=𝐻(𝑚 ||𝑛)
verify_commitment(c, m, n) at party-i
𝑐′=𝐻(𝑚 ||𝑛), check 𝑐== 𝑐′
compute_global_pubkey(m,n) at party-i
ℎ=𝑚⊕𝑛
The following process is standard hybrid encryption using EC-ElGamal, assuming that the encryption party has already obtained the global encryption key ℎ through the following steps:
generate_key_point(p) at party-i
compute_sym_key( 𝑘𝑝𝑜𝑖𝑛𝑡) at party-i
The ciphertext (ciphertext, 𝐶1,𝐶2 ) is made public.
In case regulators initiate bad actor proceedings, the threshold cryptography protecting the raw data of the user can be recovered using the following steps:
elgamal_decrypt(D1, D2, C2) at party-i
Party-i calls the AES algorithm to decrypt the symmetric ciphertext 𝑒𝑛𝑐 using the symmetric key sym_key to obtain the message m
As shown in the figure below, the (3/3) threshold cryptosystem will be implemented in the next phase. zkMe is currently communicating with different jurisdictions to improve the entire procedure.
Preliminary Investigation: Law enforcement conducts a preliminary investigation to gather evidence and establish reasonable suspicion or probable cause related to the user's activities.
Legal Process: Law enforcement obtains the necessary legal authorization, such as a warrant or court order, to access the user's identity document.
Contact Verifier Governance: Law enforcement reaches out to the web3 protocol governance with the user's digital asset wallet address and provides the legal authorization obtained in step 2.
Verify Legal Request: The web3 protocol governance verifies the legitimacy of the legal request and confirms the scope of the information required.
Stakeholder Collaboration: Each stakeholder (issuer, verifier, regulator) verifies the legal request independently. If they determine that the request is valid, they agree to participate in the decryption process.
Threshold Decryption: The stakeholders collaboratively decrypt the user's Identity document using their respective decryption key shares. This process ensures that no single stakeholder can access the private data of the user without the required collaboration.
Provide Decrypted Document: Once the user's Identity document has been decrypted, the web3 Protocol Governance provides the decrypted document to law enforcement within the scope of the legal authorization.
The Know Your Customer (KYC) process is an essential part of financial institutions' efforts to combat money laundering, terrorist financing, and other illicit activities. Regulatory authorities around the world have established guidelines for KYC data storage and retention to ensure the availability of information for investigations and to maintain the integrity of the financial system. Below are the requirements in some major jurisdictions:
Financial Crimes Enforcement Network. (n.d.). Bank Secrecy Act regulations. Retrieved from https://www.fincen.gov/resources/statutes-regulations/bsa-regulations
U.S. Department of the Treasury. (n.d.). USA PATRIOT Act. Retrieved from https://home.treasury.gov/policy-issues/office-of-terrorism-and-financial-intelligence/usa-patriot-act
European Parliament and Council of the European Union. (2018). Directive (EU) 2018/843. Retrieved from https://eur-lex.europa.eu/legal-content/EN/TXT/?uri=CELEX%3A32018L0843
HM Government. (2017). The Money Laundering, Terrorist Financing and Transfer of Funds (Information on the Payer) Regulations 2017. Retrieved from https://www.legislation.gov.uk/uksi/2017/692/contents/made
National People's Congress. (2006). Anti-Money Laundering Law of the People's Republic of China. Retrieved from http://www.npc.gov.cn/englishnpc/Law/2009-02/20/content_1471587.htm
People's Bank of China. (n.d.). People's Bank of China regulations. Retrieved from http://www.pbc.gov.cn/en/3688016/index.html
Hong Kong Government. (2012). Anti-Money Laundering and Counter-Terrorist Financing Ordinance. Retrieved from https://www.elegislation.gov.hk/hk/cap615
Hong Kong Monetary Authority. (n.d.). Guidelines on Anti-Money Laundering and Counter-Financing of Terrorism. Retrieved from https://www.hkma.gov.hk/eng/regulatory-resources/anti-money-laundering-and-counter-financing-of-terrorism/guidelines/
Monetary Authority of Singapore. (n.d.). Anti-Money Laundering and Countering the Financing of Terrorism. Retrieved from https://www.mas.gov.sg/regulation/anti-money-laundering
Here, two-party EC-ElGamal scheme: Two-party computation of ciphertexts, the global decryption key is given by: , in additive key share form. The global encryption key is given by ℎ = 𝑥 ∗ 𝑃:
Generate the keypair for party-1 regarding ℎ and make a commitment for . Generate keypair for party-2 regarding ℎ and make a commitment for .
Party-1 sends to party-2.
Party-2 sends and the preimage () of to party-1.
Party-1 verifies and then sends the preimage () of to party-2.
Party-2 verifies .
Party-1 and party-2 each compute , confirm that the results are the same, and jointly announce the global encryption key as .
The encrypting party calls generate_sym_key(p) to generate a random 𝑘𝑝𝑜𝑖𝑛𝑡, and then calls compute_sym_key() to compute the symmetric key pair sym_key.
𝑘 ⟵𝑅 [1,𝑝], =𝑘⊗𝑃
𝑠𝑦𝑚_𝑘𝑒𝑦=𝐻(𝑝𝑜𝑖𝑛𝑡2𝑏𝑦𝑡𝑒𝑠())
The encrypting party calls the AES algorithm to encrypt the message m using the symmetric key sym_key to obtain the symmetric ciphertext 𝑒𝑛𝑐, and then uses EC-ElGamal to encrypt by calling elgamal_encrypt() to obtain ( 𝐶1,𝐶2 ).
elgamal_encrypt( ) at encrypt-party
𝑟 ⟵𝑅 [1,𝑝], 𝐶1=𝑟⊗𝑃, 𝐶2=⊕ (𝑟⊗ℎ)
Each party-i calculates the partial decryption with respect to .
compute_partial_decryption(, ) at party-i
𝐷𝑖 =𝑥𝑖⊗
Party-i sends to party-3-i.
Party-i locally calls elgamal_decrypt(D1, D2, C2) to obtain , and then calls compute_sym_key() to compute the symmetric key pair sym_key.
𝐷= 𝐷1⊕𝐷2, = 𝐶2 ⊕ (−𝐷)