document

package
v0.0.1 Latest Latest
Warning

This package is not in the latest version of its module.

Go to latest
Published: Jun 20, 2026 License: Apache-2.0 Imports: 2 Imported by: 0

Documentation

Overview

Package document is the CRDT document plane for KindDocument entities (collaborative documents: page-builder documents, annotations).

THIS PASS DEFINES THE SEAM ONLY. The port below and the crdt_updates / crdt_snapshots migrations exist from phase 1 so the contract is stable; sync transport and materialization are deferred (see DESIGN.md).

Intended semantics (normative for the future implementation):

  • Updates are appended to the crdt_updates table (append-only, per-doc monotonic sequence). The merge engine comes from grove's crdt / crdt-js packages — referenced, never reimplemented here.
  • Bidirectional sync rides the subscription hub's connection layer WITHOUT conflation and WITHOUT update coalescing (Hub.PublishRaw is the seam) — CRDT updates must arrive complete and in order.
  • After a per-document quiet window, materialization snapshots the merged state into the entity's relational row and emits ONE ordinary domain event (<entity>.updated, version++) through the outbox, so projections, search and audit see CRDT documents as normal entities.
  • Materialization runs post-merge validation: CRDTs converge but do not guarantee business validity; violations flag the document for resolution instead of silently materializing.
  • Awareness/presence (cursors, who's online) is ephemeral Redis pub/sub, never persisted.

Index

Constants

This section is empty.

Variables

This section is empty.

Functions

This section is empty.

Types

type Materialized

type Materialized struct {
	DocID    string
	Snapshot json.RawMessage
	// Version is the aggregate version assigned by the LAST materialization
	// event; it advances only when the quiet-window snapshot lands.
	Version int64
}

Materialized is a point-in-time snapshot of a document's merged state.

type Store

type Store interface {
	// ApplyUpdate appends one encoded CRDT update to the document's log.
	ApplyUpdate(ctx context.Context, docID string, update []byte) error

	// Sync returns the updates the caller is missing, given its encoded
	// state vector (the CRDT engine's diff protocol).
	Sync(ctx context.Context, docID string, stateVector []byte) ([]byte, error)

	// Snapshot returns the current merged state of the document.
	Snapshot(ctx context.Context, docID string) (Materialized, error)

	// Compact folds the update log into a snapshot row and trims the log
	// (SnapshotEvery from the entity's CRDTSpec governs cadence).
	Compact(ctx context.Context, docID string) error
}

Store is the document-plane port. The production implementation (phase 7) lives in adapters/postgres backed by crdt_updates + crdt_snapshots; fabriqtest provides a fake that returns ErrStoreNotConfigured-style errors until then.

Jump to

Keyboard shortcuts

? : This menu
/ : Search site
f or F : Jump to
y or Y : Canonical URL