Bases: SQLiteRepository[VP]
SQLite implementation of VP repository.
Provides CRUD operations for VP entities with additional specialized query methods for utterance management by session and segment.
Source code in audex/lib/repos/vp.py
| def __init__(self, sqlite: SQLite) -> None:
super().__init__(sqlite)
|
Functions
create async
Create a new utterance in the database.
Parameters:
| Name | Type | Description | Default |
data | VP | The utterance entity to create. | required |
Returns:
| Type | Description |
str | The ID of the created utterance. |
Source code in audex/lib/repos/vp.py
| async def create(self, data: VP, /) -> str:
"""Create a new utterance in the database.
Args:
data: The utterance entity to create.
Returns:
The ID of the created utterance.
"""
async with self.sqlite.session() as session:
utterance_table = VPTable.from_entity(data)
session.add(utterance_table)
await session.commit()
await session.refresh(utterance_table)
return utterance_table.id
|
read async
read(id: str) -> VP | None
Read an utterance by ID.
Parameters:
| Name | Type | Description | Default |
id | str | The ID (id) of the utterance to retrieve. | required |
Returns:
| Type | Description |
VP | None | The utterance entity if found, None otherwise. |
Source code in audex/lib/repos/vp.py
| async def read(self, id: str, /) -> VP | None:
"""Read an utterance by ID.
Args:
id: The ID (id) of the utterance to retrieve.
Returns:
The utterance entity if found, None otherwise.
"""
async with self.sqlite.session() as session:
stmt = sqlm.select(VPTable).where(VPTable.id == id)
result = await session.execute(stmt)
utterance_obj = result.scalar_one_or_none()
if utterance_obj is None:
return None
return utterance_obj.to_entity()
|
first async
first(filter: Filter) -> VP | None
Retrieve the first utterance matching the filter.
Parameters:
| Name | Type | Description | Default |
filter | Filter | Filter to apply when searching for the utterance. | required |
Returns:
| Type | Description |
VP | None | The first utterance entity matching the filter, or None if no match. |
Source code in audex/lib/repos/vp.py
| async def first(self, filter: Filter) -> VP | None:
"""Retrieve the first utterance matching the filter.
Args:
filter: Filter to apply when searching for the utterance.
Returns:
The first utterance entity matching the filter, or None if no match.
"""
spec = self.build_query_spec(filter)
async with self.sqlite.session() as session:
stmt = sqlm.select(VPTable)
for clause in spec.where:
stmt = stmt.where(clause)
for order in spec.order_by:
stmt = stmt.order_by(order)
stmt = stmt.limit(1)
result = await session.execute(stmt)
utterance_obj = result.scalar_one_or_none()
if utterance_obj is None:
return None
return utterance_obj.to_entity()
|
list async
list(arg: list[str] | Optional[Filter] = None, *, page_index: int = 0, page_size: int = 100) -> list[VP]
List utterances by IDs or with optional filtering and pagination.
Parameters:
| Name | Type | Description | Default |
arg | list[str] | Optional[Filter] | Either a list of IDs to retrieve, or an optional filter. | None |
page_index | int | Zero-based page index for pagination. | 0 |
page_size | int | Number of items per page. | 100 |
Returns:
| Type | Description |
list[VP] | List of utterance entities matching the criteria. |
Source code in audex/lib/repos/vp.py
| async def list(
self,
arg: builtins.list[str] | t.Optional[Filter] = None, # noqa
*,
page_index: int = 0,
page_size: int = 100,
) -> builtins.list[VP]:
"""List utterances by IDs or with optional filtering and
pagination.
Args:
arg: Either a list of IDs to retrieve, or an optional filter.
page_index: Zero-based page index for pagination.
page_size: Number of items per page.
Returns:
List of utterance entities matching the criteria.
"""
async with self.sqlite.session() as session:
if isinstance(arg, list):
if not arg:
return []
stmt = sqlm.select(VPTable).where(sqlm.col(VPTable.id).in_(arg))
result = await session.execute(stmt)
utterance_objs = result.scalars().all()
return [obj.to_entity() for obj in utterance_objs]
spec = self.build_query_spec(arg)
stmt = sqlm.select(VPTable)
for clause in spec.where:
stmt = stmt.where(clause)
for order in spec.order_by:
stmt = stmt.order_by(order)
stmt = stmt.offset(page_index * page_size).limit(page_size)
result = await session.execute(stmt)
utterance_objs = result.scalars().all()
return [obj.to_entity() for obj in utterance_objs]
|
update async
Update an existing utterance.
Parameters:
| Name | Type | Description | Default |
data | VP | The utterance entity with updated values. | required |
Returns:
| Type | Description |
str | The ID of the updated utterance. |
Raises:
| Type | Description |
ValueError | If the utterance with the given ID does not exist. |
Source code in audex/lib/repos/vp.py
| async def update(self, data: VP, /) -> str:
"""Update an existing utterance.
Args:
data: The utterance entity with updated values.
Returns:
The ID of the updated utterance.
Raises:
ValueError: If the utterance with the given ID does not exist.
"""
async with self.sqlite.session() as session:
stmt = sqlm.select(VPTable).where(VPTable.id == data.id)
result = await session.execute(stmt)
utterance_obj = result.scalar_one_or_none()
if utterance_obj is None:
raise ValueError(f"VP with id {data.id} not found")
utterance_obj.update(data)
session.add(utterance_obj)
await session.commit()
await session.refresh(utterance_obj)
return utterance_obj.id
|
update_many async
update_many(datas: list[VP]) -> list[str]
Update multiple utterances in the database.
Parameters:
| Name | Type | Description | Default |
datas | list[VP] | List of utterance entities with updated values. | required |
Returns:
| Type | Description |
list[str] | List of IDs of the updated utterances. |
Raises:
| Type | Description |
ValueError | If any utterance with the given ID does not exist. |
Source code in audex/lib/repos/vp.py
| async def update_many(self, datas: builtins.list[VP]) -> builtins.list[str]:
"""Update multiple utterances in the database.
Args:
datas: List of utterance entities with updated values.
Returns:
List of IDs of the updated utterances.
Raises:
ValueError: If any utterance with the given ID does not exist.
"""
if not datas:
return []
updated_ids: builtins.list[str] = []
async with self.sqlite.session() as session:
ids = [data.id for data in datas]
stmt = sqlm.select(VPTable).where(sqlm.col(VPTable.id).in_(ids))
result = await session.execute(stmt)
table_objs = {obj.id: obj for obj in result.scalars().all()}
missing_ids = set(ids) - set(table_objs.keys())
if missing_ids:
raise ValueError(f"VPs with IDs {missing_ids} not found")
for data in datas:
utterance_obj = table_objs[data.id]
utterance_obj.update(data)
session.add(utterance_obj)
updated_ids.append(utterance_obj.id)
await session.commit()
return updated_ids
|
delete async
Delete an utterance by ID.
Parameters:
| Name | Type | Description | Default |
id | str | The ID (id) of the utterance to delete. | required |
Returns:
| Type | Description |
bool | True if the utterance was deleted, False if not found. |
Source code in audex/lib/repos/vp.py
| async def delete(self, id: str, /) -> bool:
"""Delete an utterance by ID.
Args:
id: The ID (id) of the utterance to delete.
Returns:
True if the utterance was deleted, False if not found.
"""
async with self.sqlite.session() as session:
stmt = sqlm.select(VPTable).where(VPTable.id == id)
result = await session.execute(stmt)
utterance_obj = result.scalar_one_or_none()
if utterance_obj is None:
return False
await session.delete(utterance_obj)
await session.commit()
return True
|
delete_many async
delete_many(arg: list[str] | Optional[Filter] = None) -> list[str]
Delete multiple utterances by IDs or matching a filter.
Parameters:
| Name | Type | Description | Default |
arg | list[str] | Optional[Filter] | Either a list of IDs to delete, or an optional filter. | None |
Returns:
| Type | Description |
list[str] | If deleting by IDs, returns list of deleted IDs. |
list[str] | If deleting by filter, returns count of deleted records. |
Source code in audex/lib/repos/vp.py
| async def delete_many(
self,
arg: builtins.list[str] | t.Optional[Filter] = None, # noqa
) -> builtins.list[str]:
"""Delete multiple utterances by IDs or matching a filter.
Args:
arg: Either a list of IDs to delete, or an optional filter.
Returns:
If deleting by IDs, returns list of deleted IDs.
If deleting by filter, returns count of deleted records.
"""
async with self.sqlite.session() as session:
if isinstance(arg, list):
if not arg:
return []
stmt = sqlm.select(VPTable).where(sqlm.col(VPTable.id).in_(arg))
result = await session.execute(stmt)
utterance_objs = result.scalars().all()
if not utterance_objs:
return []
utterance_ids = [obj.id for obj in utterance_objs]
for obj in utterance_objs:
await session.delete(obj)
await session.commit()
return utterance_ids
spec = self.build_query_spec(arg)
stmt = sqlm.select(VPTable.id) # type: ignore
for clause in spec.where:
stmt = stmt.where(clause)
result = await session.execute(stmt)
utterance_ids = [row[0] for row in result.all()]
if not utterance_ids:
return []
delete_stmt = sa.delete(VPTable).where(sqlm.col(VPTable.id).in_(utterance_ids))
await session.execute(delete_stmt)
await session.commit()
return utterance_ids
|
count async
count(filter: Optional[Filter] = None) -> int
Count utterances matching the filter.
Parameters:
| Name | Type | Description | Default |
filter | Optional[Filter] | Optional filter to apply. If None, counts all utterances. | None |
Returns:
| Type | Description |
int | Number of utterances matching the filter. |
Source code in audex/lib/repos/vp.py
| async def count(self, filter: t.Optional[Filter] = None) -> int: # noqa
"""Count utterances matching the filter.
Args:
filter: Optional filter to apply. If None, counts all utterances.
Returns:
Number of utterances matching the filter.
"""
spec = self.build_query_spec(filter)
async with self.sqlite.session() as session:
stmt = sqlm.select(sa.func.count()).select_from(VPTable)
for clause in spec.where:
stmt = stmt.where(clause)
result = await session.execute(stmt)
return result.scalar_one()
|