How to Verify an AI Execution Record Without Trusting the Provider NexArt introduces Certified Execution Records (CERs) for AI systems, enabling independent verification of execution records without trusting the provider. The CER uses canonical JSON, integrity anchoring, and signed trust material to allow third parties to detect tampering and validate authenticity. A developer walkthrough demonstrates verifying a CER using only its bytes, public node metadata, and standard cryptographic primitives. A developer-focused walkthrough of verifying a Certified Execution Record using only its bytes, public node metadata, and standard cryptographic primitives. A client challenges an AI decision six weeks later. They do not want a dashboard screenshot. They do not want a model card. They want something much harder: show me exactly what happened, and prove it. Most systems fail this test. Logs can be edited. Pipelines evolve. Re-running a model rarely reproduces the original result. You end up explaining what should have happened instead of proving what did. This is where execution evidence starts to matter. In NexArt, that evidence takes the form of a Certified Execution Record, or CER. A CER is not just a log entry with a checksum. It is a structured execution artifact with a deterministic identity, integrity anchoring, and signed trust material that can be checked later. The core flow is simple: artifact, hash, trust surface, independent verification. This article walks through what it actually means to verify a CER without trusting the original provider, using the current public NexArt model. The core problem Most AI accountability systems are still closed loops. The application produces the decision. The application writes the logs. The provider stores the logs. The provider explains the logs later. That may be enough for debugging. It is much weaker when someone outside the system wants proof. If a customer, auditor, partner, or regulator asks what happened in one specific execution, the real question is no longer "do you have logs?" It becomes: Can the record be checked later? Can tampering be detected? Can the trust material be validated separately? Does verification depend on trusting the same provider that produced the execution? That is the gap verifiable execution is meant to close. What real proof requires To turn an execution into something stronger than an internal claim, you need three things. Canonical form. The record must have one deterministic representation for hashing and signing. Integrity. If the record changes later, that change must be detectable. Authenticity. You need a way to prove who attested to the record. Without canonical form, hashing becomes unstable. Without integrity, later modification cannot be detected. Without authenticity, the record may still only be self-asserted. What a CER looks like A current AI execution CER uses the cer.ai.execution.v1 bundle type, with top-level fields such as bundleType, version, createdAt, snapshot, optional context and contextSummary, and certificateHash. { "bundleType": "cer.ai.execution.v1", "version": "0.1", "createdAt": "2026-05-15T14:30:00Z", "snapshot": { "executionId": "exec 123", "provider": "openai", "model": "gpt-4o-mini", "input": { "messages": { "role": "user", "content": "Summarize this contract." } }, "output": { "text": "This contract..." }, "parameters": { "temperature": 0.2 } }, "certificateHash": "sha256:7b1f9a2c..." } The most important field is certificateHash. But the key detail is this: the certificate hash is not computed over the entire bundle blindly. The current spec computes the hash from a strict projection over bundleType, version, createdAt, snapshot, and context / contextSummary when present. Fields like certificateHash, meta, and any declaration or verification material are outside the hash projection. That matters because it tells you exactly what the integrity anchor covers. Step 1: Canonicalize the correct payload You cannot hash raw JSON as-is. Two logically identical objects can serialize to different byte sequences if key order changes. The protocol uses RFC 8785 JCS canonicalization for hashing and signing. Alternative serialization is not acceptable for protocol-correct verification. js function cerHashProjection bundle { const projection = { bundleType: bundle.bundleType, version: bundle.version, createdAt: bundle.createdAt, snapshot: bundle.snapshot }; if bundle.context == undefined projection.context = bundle.context; if bundle.contextSummary == undefined projection.contextSummary = bundle.contextSummary; return projection; } Then canonicalize that projection using an RFC 8785 implementation. If you are using NexArt's own package surface, prefer helpers like toCanonicalJson in @nexart/ai-execution rather than ad hoc normalization. Step 2: Recompute the certificate hash python import crypto from "node:crypto"; function sha256Hex data { return "sha256:" + crypto.createHash "sha256" .update data .digest "hex" ; } const canonicalJson = toCanonicalJson cerHashProjection bundle ; const recomputed = sha256Hex canonicalJson ; if recomputed == bundle.certificateHash { throw new Error "Integrity check failed" ; } If the recomputed hash matches, the integrity anchor passes. If it does not match, one of two things is true: the bundle content changed, or the hash is not the correct one for that artifact. Either way, verification fails. Step 3: Fetch the public trust material NexArt's public node metadata is exposed at the well-known node endpoint: curl -s https://node.nexart.io/.well-known/nexart-node.json keys.json This is where public node identity and key material are published for verification flows. If you want to fetch a public CER from the node trust surface, the documented public lookup flow is: curl -s "https://node.nexart.io/v1/cer/public?certificateHash=