Expand description
The current types used to represent catalog data stored on disk. These objects generally fall into two categories.
The key-value objects are a one-to-one mapping of the protobuf objects used to save catalog
data durably. They can be converted to and from protobuf via the mz_proto::RustType trait.
These objects should not be exposed anywhere outside the crate::durable module.
The other type of objects combine the information from keys and values into a single struct,
but are still a direct representation of the data stored on disk. They can be converted to and
from the key-value objects via the DurableType trait. These objects are used to pass
information to other modules in this crate and other catalog related code.
All non-catalog code should interact with the objects in crate::memory::objects and never
directly interact with the objects in this module.
As an example, DatabaseKey and DatabaseValue are key-value objects, while Database
is the non-key-value counterpart.
Modules§
- serialization
- This module is responsible for serializing catalog objects into Protobuf.
- state_update 🔒
- This module contains various representations of a single catalog update and the logic necessary for converting between representations.
Structs§
- AuditLog 
- AuditLogKey 
- Cluster
- ClusterConfig 
- ClusterIntrospection Source Index Key 
- ClusterIntrospection Source Index Value 
- ClusterKey 
- ClusterReplica 
- ClusterReplica Key 
- ClusterReplica Value 
- ClusterValue 
- ClusterVariant Managed 
- Comment
- CommentKey 
- CommentValue 
- Config
- ConfigKey 
- ConfigValue 
- Database
- DatabaseKey 
- DatabaseValue 
- DefaultPrivilege 
- DefaultPrivileges Key 
- DefaultPrivileges Value 
- FenceToken 
- Token used to fence out other processes.
- GidMappingKey 
- GidMappingValue 
- IdAlloc
- IdAllocKey 
- IdAllocValue 
- IntrospectionSource Index 
- IntrospectionSource Index Catalog Item Id 
- A newtype wrapper for CatalogItemIdthat is only for the “introspection source index” namespace.
- IntrospectionSource Index Global Id 
- A newtype wrapper for GlobalIdthat is only for the “introspection source index” namespace.
- Item
- ItemKey
- ItemValue 
- NetworkPolicy 
- NetworkPolicy Key 
- NetworkPolicy Value 
- ReplicaConfig 
- Role
- RoleAuth 
- RoleAuth Key 
- RoleAuth Value 
- RoleKey
- RoleValue 
- Schema
- SchemaKey 
- SchemaValue 
- ServerConfiguration Key 
- ServerConfiguration Value 
- Setting
- SettingKey 
- SettingValue 
- Snapshot
- A snapshot of the current on-disk state.
- SourceReference 
- SourceReferences 
- SourceReferences Key 
- SourceReferences Value 
- StorageCollection Metadata 
- StorageCollection Metadata Key 
- StorageCollection Metadata Value 
- This value is stored transparently, however, it should only ever be manipulated by the storage controller.
- SystemCatalog Item Id 
- A newtype wrapper for CatalogItemIdthat is only for the “system” namespace.
- SystemConfiguration 
- SystemGlobal Id 
- A newtype wrapper for GlobalIdthat is only for the “system” namespace.
- SystemObject Description 
- SystemObject Mapping 
- Functions can share the same name as any other catalog item type within a given schema. For example, a function can have the same name as a type, e.g. ‘date’. As such, system objects are keyed in the catalog storage by the tuple (schema_name, object_type, object_name), which is guaranteed to be unique.
- SystemObject Unique Identifier 
- SystemPrivileges Key 
- SystemPrivileges Value 
- TxnWalShard Value 
- This value is stored transparently, however, it should only ever be manipulated by the storage controller.
- UnfinalizedShard 
- UnfinalizedShard Key 
- This value is stored transparently, however, it should only ever be manipulated by the storage controller.
Enums§
Traits§
- DurableType 
- A trait for representing Selfas a key-value pair of type(Key, Value)for the purpose of storing this value durably.