Skip to main content

API Consistency

SpiceDB's v1 API provides the ability to specify the desired consistency level on a per-request basis. This allows for the API consumers dynamically trade-off less fresh data for more performance when possible.

Consistency is provided via the Consistency message on supported API calls.

Defaults

APIDefault Consistency
WriteRelationshipsfully_consistent
DeleteRelationshipsfully_consistent
ReadSchemafully_consistent
WriteSchemafully_consistent
All other APIsminimize_latency

Levels

minimize_latency

minimize_latency will attempt to minimize the latency of the API call, using whatever caches are available.

WARNING: If used exclusively, this can lead to a window of time where the New Enemy Problem can occur.

Consistency {
    minimize_latency: true
}

at_least_as_fresh

at_least_as_fresh will ensure that all data used for computing the response is at least as fresh as the point-in-time specified in the ZedToken.

If newer information is available, it will be used.

Consistency {
    at_least_as_fresh: ZedToken { token: "..." }
}

at_exact_snapshot

at_exact_snapshot will ensure that all data used for computing the response is that found at the exact point-in-time specified in the ZedToken.

If the snapshot is not available, an error will be raised.

Consistency {
    at_exact_snapshot: ZedToken { token: "..." }
}

fully_consistent

fully_consistent will ensure that all data used is fully consistent with the latest data available within the SpiceDB datastore.

Note that the snapshot used will be loaded at the beginning of the API call, and that new data written after the API starts executing will be ignored.

WARNING: Use of fully_consistent means little caching will be available, which means performance will suffer. Only use if a ZedToken is not available or absolutely latest information is required.

Consistency {
    fully_consistent: true
}