OpaqueTableStorageManager¶
- class lsst.daf.butler.registry.interfaces.OpaqueTableStorageManager(*, registry_schema_version: VersionTuple | None = None)¶
- Bases: - VersionedExtension- An interface that manages the opaque tables in a - Registry.- OpaqueTableStorageManagerprimarily serves as a container and factory for- OpaqueTableStorageinstances, which each provide access to the records for a different (logical) opaque table.- Notes - Opaque tables are primarily used by - Datastoreinstances to manage their internal data in the same database that hold the- Registry, but are not limited to this.- While an opaque table in a multi-layer - Registrymay in fact be the union of multiple tables in different layers, we expect this to be rare, as- Registrylayers will typically correspond to different leaf- Datastoreinstances (each with their own opaque table) in a- ChainedDatastore.- Methods Summary - checkCompatibility(registry_schema_version, ...)- Check that schema version defined in registry is compatible with current implementation. - checkNewSchemaVersion(schema_version)- Verify that requested schema version can be created by an extension. - Return schema version(s) supported by this extension class. - Return full name of the extension. - get(name)- Return an object that provides access to the records associated with an opaque logical table. - initialize(db, context[, ...])- Construct an instance of the manager. - Return schema version for newly created registry. - register(name, spec)- Ensure that this layer can hold records for the given opaque logical table, creating new tables as necessary. - Methods Documentation - classmethod checkCompatibility(registry_schema_version: VersionTuple, update: bool) None¶
- Check that schema version defined in registry is compatible with current implementation. - Parameters:
- registry_schema_versionVersionTuple
- Schema version that exists in registry or defined in a configuration for a registry to be created. 
- updatebool
- If True then read-write access is expected. 
 
- registry_schema_version
- Raises:
- IncompatibleVersionError
- Raised if schema version is not supported by implementation. 
 
 - Notes - Default implementation uses - VersionTuple.checkCompatibilityon the versions returned from- currentVersionsmethod. Subclasses that support different compatibility model will overwrite this method.
 - classmethod checkNewSchemaVersion(schema_version: VersionTuple) None¶
- Verify that requested schema version can be created by an extension. - Parameters:
- schema_versionVersionTuple
- Schema version that this extension is asked to create. 
 
- schema_version
 - Notes - This method may be used only occasionally when a specific schema version is given in a regisitry config file. This can be used with an extension that supports multiple schem versions to make it create new schema with a non-default version number. Default implementation compares requested version with one of the version returned from - currentVersions.
 - abstract classmethod currentVersions() list[lsst.daf.butler.registry.interfaces._versioning.VersionTuple]¶
- Return schema version(s) supported by this extension class. - Returns:
- versionlist[VersionTuple]
- Schema versions for this extension. Empty list is returned if an extension does not require its version to be saved or checked. 
 
- version
 
 - classmethod extensionName() str¶
- Return full name of the extension. - This name should match the name defined in registry configuration. It is also stored in registry attributes. Default implementation returns full class name. - Returns:
- namestr
- Full extension name. 
 
- name
 
 - abstract get(name: str) OpaqueTableStorage | None¶
- Return an object that provides access to the records associated with an opaque logical table. - Parameters:
- namestr
- Name of the logical table. 
 
- name
- Returns:
- recordsOpaqueTableStorageorNone
- The object representing the records for the given table in this layer, or - Noneif there are no records for that table in this layer.
 
- records
 - Notes - Opaque tables must be registered with the layer (see - register) by the same client before they can safely be retrieved with- get. Unlike most other manager classes, the set of opaque tables cannot be obtained from an existing data repository.
 - abstract classmethod initialize(db: Database, context: StaticTablesContext, registry_schema_version: VersionTuple | None = None) OpaqueTableStorageManager¶
- Construct an instance of the manager. - Parameters:
- dbDatabase
- Interface to the underlying database engine and namespace. 
- contextStaticTablesContext
- Context object obtained from - Database.declareStaticTables; used to declare any tables that should always be present in a layer implemented with this manager.
- registry_schema_versionVersionTupleorNone
- Schema version of this extension as defined in registry. 
 
- db
- Returns:
- managerOpaqueTableStorageManager
- An instance of a concrete - OpaqueTableStorageManagersubclass.
 
- manager
 
 - newSchemaVersion() VersionTuple | None¶
- Return schema version for newly created registry. - Returns:
- versionVersionTupleorNone
- Schema version created by this extension. - Noneis returned if an extension does not require its version to be saved or checked.
 
- version
 - Notes - Default implementation only forks for extensions that support single schema version and it returns version obtained from - currentVersions. If- currentVersionsreturns multiple version then default implementation will raise an exception and the method has to be reimplemented by a subclass.
 - abstract register(name: str, spec: TableSpec) OpaqueTableStorage¶
- Ensure that this layer can hold records for the given opaque logical table, creating new tables as necessary. - Parameters:
- namestr
- Name of the logical table. 
- specTableSpec
- Schema specification for the table to be created. 
 
- name
- Returns:
- recordsOpaqueTableStorage
- The object representing the records for the given element in this layer. 
 
- records
 - Notes - This operation may not be invoked within a transaction context block.