X-Git-Url: https://plomlompom.com/repos/?a=blobdiff_plain;f=plomtask%2Fconditions.py;h=cba606d1a71dd19a0e410677f0ee8fc528d5bdbf;hb=c4ccb784bb3a83c1c614c9bab7fc007ee17f6615;hp=a45260092fdc6c75a94846eb0893b775eb9316dd;hpb=ee18435127ad396c24dbee2c7efcdbe6810d5a91;p=plomtask diff --git a/plomtask/conditions.py b/plomtask/conditions.py index a452600..cba606d 100644 --- a/plomtask/conditions.py +++ b/plomtask/conditions.py @@ -3,7 +3,8 @@ from __future__ import annotations from typing import Any from sqlite3 import Row from plomtask.db import DatabaseConnection, BaseModel -from plomtask.misc import VersionedAttribute +from plomtask.versioned_attributes import VersionedAttribute +from plomtask.exceptions import HandledException class Condition(BaseModel[int]): @@ -35,6 +36,23 @@ 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 VersionedAttributes. + + Checks for Todos and Processes that depend on Condition, prohibits + deletion if found. + """ + if self.id_ is None: + raise HandledException('cannot remove unsaved item') + 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."""