X-Git-Url: https://plomlompom.com/repos/?a=blobdiff_plain;ds=sidebyside;f=plomtask%2Fconditions.py;h=45aa62b9b27a026c75549aea3350640c419d8a5e;hb=f19823e9e77ae0017022dbfe63f66d2b065ba33a;hp=a45260092fdc6c75a94846eb0893b775eb9316dd;hpb=ee18435127ad396c24dbee2c7efcdbe6810d5a91;p=plomtask diff --git a/plomtask/conditions.py b/plomtask/conditions.py index a452600..45aa62b 100644 --- a/plomtask/conditions.py +++ b/plomtask/conditions.py @@ -4,6 +4,7 @@ from typing import Any from sqlite3 import Row from plomtask.db import DatabaseConnection, BaseModel from plomtask.misc import VersionedAttribute +from plomtask.exceptions import HandledException class Condition(BaseModel[int]): @@ -35,6 +36,18 @@ class Condition(BaseModel[int]): self.title.save(db_conn) self.description.save(db_conn) + def remove(self, db_conn: DatabaseConnection) -> None: + """Remove from DB, with dependencies.""" + assert isinstance(self.id_, int) + for item in ('process', 'todo'): + for attr in ('conditions', 'enables', 'disables'): + table_name = f'{item}_{attr}' + for _ in db_conn.row_where(table_name, 'condition', self.id_): + raise HandledException('cannot remove Condition in use') + db_conn.delete_where('condition_titles', 'parent', self.id_) + db_conn.delete_where('condition_descriptions', 'parent', self.id_) + super().remove(db_conn) + class ConditionsRelations: """Methods for handling relations to Conditions, for Todo and Process."""