pub trait Catalog: Send + Sync {
// Required methods
fn name(&self) -> &str;
fn list_namespaces<'life0, 'life1, 'async_trait>(
&'life0 self,
parent: Option<&'life1 [String]>,
) -> Pin<Box<dyn Future<Output = CatalogResult<Vec<Vec<String>>>> + Send + 'async_trait>>
where Self: 'async_trait,
'life0: 'async_trait,
'life1: 'async_trait;
fn create_namespace<'life0, 'life1, 'async_trait>(
&'life0 self,
namespace: &'life1 [String],
properties: NamespaceProperties,
) -> Pin<Box<dyn Future<Output = CatalogResult<()>> + Send + 'async_trait>>
where Self: 'async_trait,
'life0: 'async_trait,
'life1: 'async_trait;
fn drop_namespace<'life0, 'life1, 'async_trait>(
&'life0 self,
namespace: &'life1 [String],
) -> Pin<Box<dyn Future<Output = CatalogResult<()>> + Send + 'async_trait>>
where Self: 'async_trait,
'life0: 'async_trait,
'life1: 'async_trait;
fn namespace_properties<'life0, 'life1, 'async_trait>(
&'life0 self,
namespace: &'life1 [String],
) -> Pin<Box<dyn Future<Output = CatalogResult<NamespaceProperties>> + Send + 'async_trait>>
where Self: 'async_trait,
'life0: 'async_trait,
'life1: 'async_trait;
fn list_tables<'life0, 'life1, 'async_trait>(
&'life0 self,
namespace: &'life1 [String],
) -> Pin<Box<dyn Future<Output = CatalogResult<Vec<TableIdentifier>>> + Send + 'async_trait>>
where Self: 'async_trait,
'life0: 'async_trait,
'life1: 'async_trait;
fn create_table<'life0, 'life1, 'async_trait>(
&'life0 self,
identifier: &'life1 TableIdentifier,
metadata: TableMetadata,
) -> Pin<Box<dyn Future<Output = CatalogResult<TableMetadata>> + Send + 'async_trait>>
where Self: 'async_trait,
'life0: 'async_trait,
'life1: 'async_trait;
fn load_table<'life0, 'life1, 'async_trait>(
&'life0 self,
identifier: &'life1 TableIdentifier,
) -> Pin<Box<dyn Future<Output = CatalogResult<TableMetadata>> + Send + 'async_trait>>
where Self: 'async_trait,
'life0: 'async_trait,
'life1: 'async_trait;
fn drop_table<'life0, 'life1, 'async_trait>(
&'life0 self,
identifier: &'life1 TableIdentifier,
purge: bool,
) -> Pin<Box<dyn Future<Output = CatalogResult<()>> + Send + 'async_trait>>
where Self: 'async_trait,
'life0: 'async_trait,
'life1: 'async_trait;
fn rename_table<'life0, 'life1, 'life2, 'async_trait>(
&'life0 self,
from: &'life1 TableIdentifier,
to: &'life2 TableIdentifier,
) -> Pin<Box<dyn Future<Output = CatalogResult<()>> + Send + 'async_trait>>
where Self: 'async_trait,
'life0: 'async_trait,
'life1: 'async_trait,
'life2: 'async_trait;
fn table_exists<'life0, 'life1, 'async_trait>(
&'life0 self,
identifier: &'life1 TableIdentifier,
) -> Pin<Box<dyn Future<Output = CatalogResult<bool>> + Send + 'async_trait>>
where Self: 'async_trait,
'life0: 'async_trait,
'life1: 'async_trait;
fn commit_table<'life0, 'life1, 'async_trait>(
&'life0 self,
identifier: &'life1 TableIdentifier,
base_version: i64,
metadata: TableMetadata,
) -> Pin<Box<dyn Future<Output = CatalogResult<TableMetadata>> + Send + 'async_trait>>
where Self: 'async_trait,
'life0: 'async_trait,
'life1: 'async_trait;
}Expand description
The main catalog trait for managing tables.
Required Methods§
Sourcefn list_namespaces<'life0, 'life1, 'async_trait>(
&'life0 self,
parent: Option<&'life1 [String]>,
) -> Pin<Box<dyn Future<Output = CatalogResult<Vec<Vec<String>>>> + Send + 'async_trait>>where
Self: 'async_trait,
'life0: 'async_trait,
'life1: 'async_trait,
fn list_namespaces<'life0, 'life1, 'async_trait>(
&'life0 self,
parent: Option<&'life1 [String]>,
) -> Pin<Box<dyn Future<Output = CatalogResult<Vec<Vec<String>>>> + Send + 'async_trait>>where
Self: 'async_trait,
'life0: 'async_trait,
'life1: 'async_trait,
Lists all namespaces, optionally under a parent namespace.
Sourcefn create_namespace<'life0, 'life1, 'async_trait>(
&'life0 self,
namespace: &'life1 [String],
properties: NamespaceProperties,
) -> Pin<Box<dyn Future<Output = CatalogResult<()>> + Send + 'async_trait>>where
Self: 'async_trait,
'life0: 'async_trait,
'life1: 'async_trait,
fn create_namespace<'life0, 'life1, 'async_trait>(
&'life0 self,
namespace: &'life1 [String],
properties: NamespaceProperties,
) -> Pin<Box<dyn Future<Output = CatalogResult<()>> + Send + 'async_trait>>where
Self: 'async_trait,
'life0: 'async_trait,
'life1: 'async_trait,
Creates a new namespace.
Sourcefn drop_namespace<'life0, 'life1, 'async_trait>(
&'life0 self,
namespace: &'life1 [String],
) -> Pin<Box<dyn Future<Output = CatalogResult<()>> + Send + 'async_trait>>where
Self: 'async_trait,
'life0: 'async_trait,
'life1: 'async_trait,
fn drop_namespace<'life0, 'life1, 'async_trait>(
&'life0 self,
namespace: &'life1 [String],
) -> Pin<Box<dyn Future<Output = CatalogResult<()>> + Send + 'async_trait>>where
Self: 'async_trait,
'life0: 'async_trait,
'life1: 'async_trait,
Drops a namespace (must be empty).
Sourcefn namespace_properties<'life0, 'life1, 'async_trait>(
&'life0 self,
namespace: &'life1 [String],
) -> Pin<Box<dyn Future<Output = CatalogResult<NamespaceProperties>> + Send + 'async_trait>>where
Self: 'async_trait,
'life0: 'async_trait,
'life1: 'async_trait,
fn namespace_properties<'life0, 'life1, 'async_trait>(
&'life0 self,
namespace: &'life1 [String],
) -> Pin<Box<dyn Future<Output = CatalogResult<NamespaceProperties>> + Send + 'async_trait>>where
Self: 'async_trait,
'life0: 'async_trait,
'life1: 'async_trait,
Gets namespace properties.
Sourcefn list_tables<'life0, 'life1, 'async_trait>(
&'life0 self,
namespace: &'life1 [String],
) -> Pin<Box<dyn Future<Output = CatalogResult<Vec<TableIdentifier>>> + Send + 'async_trait>>where
Self: 'async_trait,
'life0: 'async_trait,
'life1: 'async_trait,
fn list_tables<'life0, 'life1, 'async_trait>(
&'life0 self,
namespace: &'life1 [String],
) -> Pin<Box<dyn Future<Output = CatalogResult<Vec<TableIdentifier>>> + Send + 'async_trait>>where
Self: 'async_trait,
'life0: 'async_trait,
'life1: 'async_trait,
Lists all tables in a namespace.
Sourcefn create_table<'life0, 'life1, 'async_trait>(
&'life0 self,
identifier: &'life1 TableIdentifier,
metadata: TableMetadata,
) -> Pin<Box<dyn Future<Output = CatalogResult<TableMetadata>> + Send + 'async_trait>>where
Self: 'async_trait,
'life0: 'async_trait,
'life1: 'async_trait,
fn create_table<'life0, 'life1, 'async_trait>(
&'life0 self,
identifier: &'life1 TableIdentifier,
metadata: TableMetadata,
) -> Pin<Box<dyn Future<Output = CatalogResult<TableMetadata>> + Send + 'async_trait>>where
Self: 'async_trait,
'life0: 'async_trait,
'life1: 'async_trait,
Creates a new table.
Sourcefn load_table<'life0, 'life1, 'async_trait>(
&'life0 self,
identifier: &'life1 TableIdentifier,
) -> Pin<Box<dyn Future<Output = CatalogResult<TableMetadata>> + Send + 'async_trait>>where
Self: 'async_trait,
'life0: 'async_trait,
'life1: 'async_trait,
fn load_table<'life0, 'life1, 'async_trait>(
&'life0 self,
identifier: &'life1 TableIdentifier,
) -> Pin<Box<dyn Future<Output = CatalogResult<TableMetadata>> + Send + 'async_trait>>where
Self: 'async_trait,
'life0: 'async_trait,
'life1: 'async_trait,
Loads a table’s metadata.
Sourcefn drop_table<'life0, 'life1, 'async_trait>(
&'life0 self,
identifier: &'life1 TableIdentifier,
purge: bool,
) -> Pin<Box<dyn Future<Output = CatalogResult<()>> + Send + 'async_trait>>where
Self: 'async_trait,
'life0: 'async_trait,
'life1: 'async_trait,
fn drop_table<'life0, 'life1, 'async_trait>(
&'life0 self,
identifier: &'life1 TableIdentifier,
purge: bool,
) -> Pin<Box<dyn Future<Output = CatalogResult<()>> + Send + 'async_trait>>where
Self: 'async_trait,
'life0: 'async_trait,
'life1: 'async_trait,
Drops a table.
Sourcefn rename_table<'life0, 'life1, 'life2, 'async_trait>(
&'life0 self,
from: &'life1 TableIdentifier,
to: &'life2 TableIdentifier,
) -> Pin<Box<dyn Future<Output = CatalogResult<()>> + Send + 'async_trait>>where
Self: 'async_trait,
'life0: 'async_trait,
'life1: 'async_trait,
'life2: 'async_trait,
fn rename_table<'life0, 'life1, 'life2, 'async_trait>(
&'life0 self,
from: &'life1 TableIdentifier,
to: &'life2 TableIdentifier,
) -> Pin<Box<dyn Future<Output = CatalogResult<()>> + Send + 'async_trait>>where
Self: 'async_trait,
'life0: 'async_trait,
'life1: 'async_trait,
'life2: 'async_trait,
Renames a table.
Sourcefn table_exists<'life0, 'life1, 'async_trait>(
&'life0 self,
identifier: &'life1 TableIdentifier,
) -> Pin<Box<dyn Future<Output = CatalogResult<bool>> + Send + 'async_trait>>where
Self: 'async_trait,
'life0: 'async_trait,
'life1: 'async_trait,
fn table_exists<'life0, 'life1, 'async_trait>(
&'life0 self,
identifier: &'life1 TableIdentifier,
) -> Pin<Box<dyn Future<Output = CatalogResult<bool>> + Send + 'async_trait>>where
Self: 'async_trait,
'life0: 'async_trait,
'life1: 'async_trait,
Checks if a table exists.