Sign in
← avoid.net

Verify a decision

Every moderation decision on AVOID.NET is anchored to the Solana blockchain. You don't have to trust us — you can verify cryptographically that we committed to a verdict at a specific moment and have not rewritten it.

How verification works

  1. We commit. When a moderator accepts/rejects a submission, we serialize the decision into deterministic UTF-8 bytes (payload_canonical_string), hash it with SHA-256, encode the digest as base58, and write it to Solana inside an SPL Memo v2 transaction.
  2. We store the bytes. The exact bytes we hashed are stored alongside the decision in our database. Anyone can read them and recompute the hash in any language.
  3. You compare three values. Database hash, your independently-recomputed hash, and the hash inside the on-chain memo. If all three match, the decision is authentic and timestamped.
The on-chain memo format is AVOID.NET|v1|h:<b58-sha256>|d:<id>|t:<iso>

Find a signature on any investigation page's decision log, or run python -m src.verify_decision --signature <sig> for a CLI check.

Sequence
#1
Score
1514 (-1)
Cluster
mainnet-beta
Slot
417643395
Off-chain at
2026-05-05T00:46:05.013Z
Anchored at
Block time

Independent verification

1. Database (off-chain)
5Zi7e31pvEBbiWCYQNyTNQGsbHCoxJBghYC2TU7VNYSX
2. Recomputed (your browser)
computing…
3. On-chain (Solana memo)
fetching…
Canonical bytes hashed (449 chars)
{"actor":"auto:lightweight","decided_at":"2026-05-05T00:46:04.495Z","decision":"accept","investigation_id":"7d9ea471-6a8b-4714-8f3b-088965af1f3c","new_score":14,"page_slug":"axiom-exchange","prev_score":15,"reason":null,"score_delta":-1,"sequence_num":1,"submission_content_hash":"F2BXHp7BnhV1568S3ehkDuzcRCq2UPkj1725ATM6d7q7","submission_id":"8ca23ce8-6175-44e2-bce7-75a4b884e02c","submission_kind":"url","submission_valence":"incriminating","v":1}