Saltar al contenido principal

Protocol: Overview

Esta es la especificación normativa del protocolo DIG, definida como siete capas, de abajo hacia arriba. Cada capa nombra su crate/archivo canónico como referencia normativa.

Esta es la referencia autoritativa del protocolo

Esta sección es la fuente de verdad de lo que hace la red. Documenta el protocolo tal como se ejecuta realmente, con citas file:line a la implementación canónica.

La unidad fundamental: el capsule

Un concepto atraviesa todas las capas: el capsule = (store_id, root_hash), canónicamente storeId:rootHash. Un store es una secuencia ordenada de capsules (del más antiguo al más nuevo), uno por commit; su identidad store_id es un launcher id de singleton DataLayer CHIP-0035 en Chia. La identidad, la compilación, el precio, la recuperación, la caché y la procedencia se definen todos por capsule.

La tesis: host ciego, verificación del lado del cliente, raíz anclada en cadena

  • Host ciego. Un host solo tiene texto cifrado opaco identificado por hashes. No tiene ninguna URN ni clave, retransmite la salida propia del capsule textualmente, y no puede distinguir un acierto de un fallo. No hay campo decoy en el wire ni CDN — el contenido se sirve solo a través del dig RPC.
  • Verificación del lado del cliente. Cada byte se comprueba en el dispositivo del lector contra una raíz en cadena con una prueba de inclusión merkle por recurso, y luego se autentica y descifra. La confianza nunca recae en el origen de servicio.
  • Raíz anclada en cadena. La raíz de confianza proviene únicamente del singleton CHIP-0035 en Chia (resuelto vía coinset.org), nunca de la "última" servida.

Las siete capas

#CapaQué defineReferencia canónica
0Identidad y nomenclaturastore, capsule, generation; store_id = launcher iddigstore-core::capsule, ::urn
0URN y direccionamientogramática urn:dig:chia:…; retrieval_key sin raízdigstore-core::urn, lib.rs
1CriptografíaKDF HKDF; sellado AES-256-GCM-SIVdigstore-core::crypto
1Pruebas de inclusión Merklehoja por recurso D5; pliegue NODE_TAGdigstore-core::merkle
1Firmas BLS y DSTsAugScheme de Chia; cinco DSTs de roldigstore-crypto::bls
2Formato del capsulela sección de datos DIGS (BINDING D1)digstore-core::datasection
2El módulo autodefendidoofuscación de tamaño fijo; el guest de serviciodigstore-compiler, digstore-guest
4Anclaje en cadenastore = singleton; capsule = avance de raízchip35_dl_coin, digstore-chain
4Pago y precio del CAT DIGpor capsule, dinámico, referenciado en USDchip35_dl_coin::dig
6El dig RPCla interfaz de máquina (JSON-RPC 2.0)hub retrieval, dig-node
5Transporte y push §21localizador dig://, REST, push v1digstore-remote
7Red de pares de DIG Nodeidentidad de par mTLS, traversal NAT, STUN, introducer, wire de relay, RPC de pardig-gossip, dig-relay, dig-nat, dig-node
6Verificación y procedencialas cuatro puertas de integridad ordenadasdigstore-core::merkle, dig-node
6El modelo de host ciegoceguera del proveedor; resolver; plano de control /v1hub retrieval/resolver/api
Conformidad y paridadla disciplina de paridad entre implementacionesgoldens congelados, diff de OpenRPC

(Las capas 3 y el transporte §21 se entrelazan con la vía de lectura; la tabla las agrupa donde un lector las encuentra. La numeración completa de capas se da en cada página.)

Cómo fluye un capsule a través de las capas

Un publicador fragmenta + cifra (L1) el contenido en un formato de capsule (L2) que se autosirve (L3), lo ancla en cadena (L4) y lo envía sobre el transporte §21 (L5). Cualquier cliente lo lee a través del dig RPC y lo verifica contra la raíz anclada en cadena enteramente del lado del cliente (L6). Cada constante criptográfica tiene una definición compartida entre el productor, el host y el verificador — el invariante de paridad C8.

Terminología

  • chia:// — la dirección de contenido de la red (lo que abre un navegador).
  • dig:// — el localizador de transporte §21 (plano de CLI/pares) y el esquema de página interno del DIG Browser — dos usos distintos, nunca la dirección de contenido.
  • urn:dig: — el espacio de nombres URN del que ambos derivan.
  • store / capsule — la identidad y su generation inmutable.
  • $DIG — el CAT pagado por capsule; DigStore — el formato del store.