メインコンテンツまでスキップ

証拠の検証

証拠を自分で検証する

プルーフは標準の SP1 圧縮プルーフです。 SP1 SDK を使用して検証します。

use sp1_sdk::{ProverClient, SP1ProofWithPublicValues};

let client = ProverClient::from_env();
let (_, vk) = client.setup(ELF);
let proof = SP1ProofWithPublicValues::load("proof.bin")?;
client.verify(&proof, &vk)?;

検証キーは決定的であり、ゲスト プログラム バイナリから派生します。誰でも再現できます。
ZkEVM SP1 ゲスト プログラムの不変性は、プログラム キーによって証明されます。証明者のソース コードは GitHub で入手できます。誰でもコンパイルしてプログラム キーを比較できます。 SP1 ゲスト プログラムに変更が実行されると、プログラム キーも変更されます。

名前の証明を確認する

名前を解決すると、API は merkle_proof フィールド内に 128 個の兄弟ハッシュで構成されるメンバーシップ証明を返します。これらの兄弟ハッシュを使用して、ドメイン名とターゲット shielded アドレス間のマッピングをローカルで検証できます。

以下に、解決された名前の Sparse Merkle Tree (SMT) 証明を検証する方法を示す Python、PHP、および JavaScript の例を示します。

import hashlib

def get_bit(key_bytes, bit_idx):
"""
Returns the bit value (0 or 1) at a given index (0 to 127)
from MSB to LSB of the 16-byte key.
"""
byte_pos = bit_idx // 8
bit_pos = 7 - (bit_idx % 8)
return (key_bytes[byte_pos] >> bit_pos) & 1

def verify_smt_proof(domain_name, target_address, merkle_proof, expected_root):
# 1. Compute key as SHA-256 of lowercase domain name
key_hash = hashlib.sha256(domain_name.lower().encode('utf-8')).digest()
# Take first 16 bytes (128 bits) for a depth-128 SMT
key = key_hash[:16]

# 2. Compute leaf hash as SHA-256 of target address
current = hashlib.sha256(target_address.encode('utf-8')).digest()

# 3. Hash up the tree using the 128 sibling hashes
# Sibling proof array goes from bottom (closest to leaf, index 0) to top (closest to root, index 127)
for i in range(128):
sibling = bytes.fromhex(merkle_proof[i])

# Level 127 (index 0) corresponds to the bottom-most bit (bit 127)
# Level 0 (index 127) corresponds to the top-most bit (bit 0)
bit_idx = 127 - i
bit = get_bit(key, bit_idx)

if bit == 1:
# Current node is on the right, sibling is on the left
current = hashlib.sha256(sibling + current).digest()
else:
# Current node is on the left, sibling is on the right
current = hashlib.sha256(current + sibling).digest()

return current.hex() == expected_root.lower()