Wie verifiziere ich Vermögenswerte im OKX-Merkle-Baum? (Merkle-Baum V2)
Gilt für den Prüfungszeitraum nach März 2023
Was ist ein Merkle Tree?
Ein Merkle Tree (oder Hash Tree) ist eine Datenstruktur, die normalerweise ein binärer Baum ist. Er verwendet vordefinierte Funktionen, um den Hash-Wert eines Knotens von unten nach oben bis zum obersten Wurzelknoten des Baums zu berechnen.
Knoteninformation
In jedem Baumknoten sind folgende Informationen gespeichert:
- Hash-Wert des Knotens
- Während der Prüfung als Momentaufnahme erfasster Kryptowährungsbetrag eines Benutzers/einer Benutzerin (z. B. BTC, ETC oder USDT)### Hash-Regel
Hash-Wert,{"BTC":"BTC amount","ETH":"ETH amount","USDT":"USDT amount"}
be324cf06aee0616b4ec20c3,{"BTC":"1.023","ETH":"0","USDT":"20.2343322"} - Blattknoten (ausgenommen Paddingknoten)OKX weist jedem Benutzer und jeder Benutzerin eine einzigartige __Nonce__ (Zufallszahl) zu, die auf der Prüfungsseite des Benutzers/der Benutzerin angezeigt wird; __Saldo__ ist ein JSON-String, der sich aus den Vermögenswerten eines Benutzers/einer Benutzerin und den während der Prüfung als Momentaufnahme erfassten Beträgen zusammensetzt, zum Beispiel: {"BTC":"1.023","ETH":"0","USDT":"20.2343322"} (HINWEIS: Es ist eine Genauigkeit von acht Nachkommastellen einzuhalten; die darauffolgenden Nullen sind wegzulassen) ### Elternknoten
Hash=SHA256(Nonce+Saldos) __h1__=Hash des linken Unterknotens des aktuellen Knotens, __h2__=Hash des rechten untergeordneten Knotens des aktuellen Knotens, __audit_id__=ID des aktuellen Audits, __height__=die Höhe des Knotens h1 (oder h2) Definition der Höhe: Höhe des untersten Blattknotens=1, Höhe eines Elternknotens=Höhe seines untergeordneten Knotens + 1, Wurzelknoten hat die maximale HöheHash eines Elternknotens = SHA256(h1+h2+(h1 BTC Betrag+h2 BTC Betrag)+(h1 ETH Betrag+h2 ETH Betrag)+(h1 USDT Betrag+h2 USDT Betrag)+Höhe)
Regel für Splittingknoten
Um die Privatsphäre der Kundinnen und Kunden zu schützen, teilt OKX das Vermögen der Benutzerinnen und Benutzer nach dem Zufallsprinzip in zwei Knoten auf, wobei der Zufallswert zwischen 0 und 1 liegt. Zum Beispiel, wenn die Vermögenswerte einer Benutzerin oder eines Benutzers wie folgt sind: {"BTC": "10.2", "ETH": "4", "USDT": "5"} und die Zufallszahl 0,6 ist, wird das Vermögen der Benutzerin oder des Benutzers in 60% und 40% aufgeteilt.
Bei der anschließenden Generierung des Merkle-Baums werden die aufgespaltenen Blattknoten zufällig verwürfelt, um sie auf verschiedene Positionen im Baum zu verteilen.
Regel für Paddingknoten
Für den Aufbau eines vollständigen Merkle Tree (eines vollständigen Binärbaums) sind 2^n Blattknoten erforderlich. Es kann jedoch vorkommen, dass die vorhandenen Daten nicht ausreichen, um diese Voraussetzung zu erfüllen, oder dass Daten in ungerader Anzahl auftreten. In diesen Fällen, d. h. wenn der Knoten k keinen Geschwisterknoten besitzt, wird automatisch ein Geschwisterknoten k' als Paddingknoten erzeugt (der engl. Begriff „padding“ bedeutet wörtlich „auffüllen“), sodass hash(k')=hash(k) gilt; die Vermögenswertbeträge werden dabei für alle Währungen auf 0 gesetzt.
z. B.
Hash | balances |
---|---|
h1 | {"BTC": 1, "ETH": 1,"USDT": 1} |
h2 | {"BTC": 1, "ETH": 2,"USDT": 3} |
h3 | {"BTC": 1, "ETH": 2,"USDT": 4} |
Hash eines Elternknotens = SHA256(h1+h2+(h1 BTC Betrag+h2 BTC Betrag)+(h1 ETH Betrag+h2 ETH Betrag)+(h1 USDT Betrag+h2 USDT Betrag)+Höhe) |
Wie überprüfe ich, ob meine Vermögenswerte in der OKX-Merkle-Struktur enthalten sind?
Verifizierungstheorie
Gemäß der Definition des OKX-Merkle-Baums können Sie den Hash-Wert eines Elternknotens berechnen, indem Sie sich von unten nach oben vorarbeiten und dabei die Hash-Werte seiner linken und rechten untergeordneten Knoten verwenden. Schließlich erhalten Sie den Hash-Wert des Wurzelknotens. Sie können dann diesen berechneten Hash-Wert des Wurzelknotens mit dem des Wurzelknotens des Merkle-Baumpfades vergleichen. Wenn sie übereinstimmen, ist die Verifizierung erfolgreich, andernfalls schlägt sie fehl.
Beispiel: Sehen Sie sich Bild 1 und den Text unten an. Auf Basis des eigenen Knotens des Benutzers/der Benutzerin h3 und mithilfe seines Geschwisterknotens h4 lässt sich ihr Elternknoten h6 berechnen, und mithilfe von h6' der Geschwisterknoten h5, mit dem sich wiederum der Hash-Wert des Elternknotens h7 errechnen lässt. Dieser kann daraufhin mit dem h7'-Hash-Wert des Merkle Tree-Pfad-Wurzelknotens verglichen werden, um zu ermitteln, ob diese identisch sind, womit der Verifizierungsprozess abgeschlossen wäre.
Text der Merkle-Tree-Pfad-Daten:
h7,3,{"BTC":"3","ETH":"5","USDT":"8"} h6,2,{"BTC":"1","ETH":"2","USDT":"4"} h5,2,{"BTC":"2","ETH":"3","USDT":"4"} h4,1,{"BTC":"0","ETH":"0","USDT":"0"} h3,1,{"BTC":"1","ETH":"2","USDT":"4"} h2,1,{"BTC":"1","ETH":"2","USDT":"3"} h1,1,{"BTC":"1","ETH":"1","USDT":"1"} |
Verifizierungsschritte
Melden Sie sich bei Ihrem OKX-Konto an, gehen Sie zu Vermögenswerte > Audits, um die letzten Audits zu sehen, wählen Sie Details um Ihre Audit-Daten zu sehen.
Wählen Sie Vermögenswerte und Details anzeigen für ein besseres Verständnis der DatenprüfungSie können Ihre Vermögenswerte auch manuell im Merkle Tree verifizieren, indem Sie Daten kopieren auswählen
Wählen Sie Daten kopieren für die manuelle Verifizierung*Öffnen Sie einen Texteditor (z. B. Notebook), fügen Sie den JSON-String ein und speichern Sie ihn als JSON-Datei.
Vorgangsschritte
Mac: Öffnen Sie das Terminal und geben Sie den Befehl touch merkle_proof_file.json ein, woraufhin eine JSON-Datei erzeugt wird. Die Datei wird standardmäßig auf dem Desktop des Systems gespeichert. Sie können Finder öffnen und nach merkle_proof_file.json suchen, um diese Datei zu finden. Öffnen Sie diese JSON-Datei, fügen Sie die kopierten Daten ein und speichern Sie sie.
Windows: Öffnen Sie einen Texteditor (z. B. den Windows-Editor) per Doppelklick, fügen Sie die Daten ein und speichern Sie sie als JSON-Datei.
In unserem Fall nennen wir die Datei „merkle_proof_file.json“. Der JSON-Text der Merkle-Tree-Pfad-Daten ist nachfolgend aufgeführt:
{
"hash": "7e5a588806ff1de23f81e3a092860de43367fb4ea5503a53d95a5bc36d77e0c2",
"nodes": [
{ "balances": { "BTC": "0.49997703", "ETH": "0", "USDT": "16.62437479" },
"hash": "4087972e6b4bd3897c19f76b94b27db8eaf19f0d27d1b73e18297c18c850c3c1"
},
{ "balances": { "BTC": "0.40002297", "ETH": "0", "USDT": "12.18752303" },
"hash": "da14bd34c8d933781b8ec20a7e16109d0d650306b049da52c755437c4f7ec5e5" }
],
"nonce": "b6f6ea7584742839791ab923f4f1980d7ca3ff7c5d3f3fd9cc2a18c598503553",
"totalBalances": { "BTC": "0.9", "ETH": "0", "USDT": "28.81189782" }
}
Laden Sie die "Full Merkle Tree" Dateien unter im Verbindlichkeitsbericht herunter und entpacken Sie die heruntergeladene Datei, um eine "Full Merkle Tree file" zu erhalten.
Wählen Sie Download, um den Bericht zu erhaltenLaden Sie das Open-Source-Verifizierungstool von OKX (MerkleValidator) herunter
Speichern Sie das Open-Source-Verifizierungstool von OKX (MerkleValidator) und die beiden Datendateien (merkle_proof_file.json, full-liabilities-merkle-tree.txt) im selben Ordner. In unserem Fall speichern wir das Tool und die Datendatei im Ordner Downloads unter der Bezeichnung proof-of-reserves, wie unten dargestellt:
7. Führen Sie den Befehl aus und lokalisieren Sie das Verzeichnis des heruntergeladenen Ordners. In unserem Fall geben Sie den Befehl : cd ~/Downloads/proof-of-reserve einGeben Sie den nachfolgenden Befehl ein und drücken Sie die Eingabetaste, um die Verifizierung zu starten:
Mac
./MerkleValidator --merkle_file full-liabilities-merkle-tree.txt --user_info_file merkle_proof_file.json
Windows
MerkleValidator.exe --merkle_file full-liabilities-merkle-tree.txt --user_info_file merkle_proof_file.json
Hinweis: - Wenn Sie einen Mac benutzen und die Fehlermeldung „cannot open the tools because the developer cannot be verified“ („Die Tools können nicht geöffnet werden, da der Entwickler nicht verifiziert werden kann“) erhalten, dann navigieren Sie bitte zu Systemeinstellungen > Sicherheit & Datenschutz > Allgemein > Klicken Sie auf das Schloss, um Änderungen vorzunehmen > __Apps-Download von App Store und identifizierte Entwicklern erlaubenÜberprüfen Sie das Ergebnis
War die Verifizierung erfolgreich, dann wird das Ergebnis Validierung des Merkle-Tree-Pfads erfolgreich angezeigt, wie nachfolgend dargestellt:
Wenn die Verifizierung fehlschlägt, wird das Ergebnis Validierung des Merkle-Tree-Pfads fehlgeschlagen wie folgt angezeigt:Sie können auch unter Rückgriff auf den Code des Open-Source-Verifizierungstools von OKX (MerkleValidator) und auf die [Definition des Merkle Tree von OKX] (#was-ist-ein-merkle-tree) selbst ein Programm schreiben, um zu verifizieren, ob Ihre im Merkle Tree enthaltenen Vermögenswerte mit jenen der Momentaufnahme im Rahmen der Prüfung identisch sind. Verwenden Sie hierfür die in Schritt 2 referenzierten Merkle-Tree-Pfad-Daten.