docs/architecture/storage-control-data-plane.md
This document defines migration boundaries for the storage hot path and adjacent control-plane responsibilities.
Storage API contracts must not absorb implementation details from ECStore or the reader pipeline.
Out of scope for the contract layer:
No-drift behavior:
ClusterControlPlane starts as a read-only facade inside crates/ecstore/src/cluster.
Do not create a standalone cluster crate until internal dependencies are stable.
Initial scope:
Risk controls:
Scanner, heal, lifecycle, replication, config reload, metrics, and auto-tuning controllers should move behind explicit controller boundaries after lifecycle contracts are stable.
The first controller work should be read-only status and shutdown ordering, not behavior changes.