X-Git-Url: https://plomlompom.com/repos/berlin_corona.txt?a=blobdiff_plain;f=plomtask%2Fconditions.py;h=539db9c0d50efb44e182137d7096c3d71a38345f;hb=a0244482692edf794960f3c2af9461be2ad15e8a;hp=66961256e28ad2843ae9d72ba9babbbd552b6f60;hpb=8570f4ce4d44b813a1f02b72c5c45a57d2003bae;p=plomtask diff --git a/plomtask/conditions.py b/plomtask/conditions.py index 6696125..539db9c 100644 --- a/plomtask/conditions.py +++ b/plomtask/conditions.py @@ -3,11 +3,12 @@ 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]): - """Non Process-dependency for ProcessSteps and Todos.""" + """Non-Process dependency for ProcessSteps and Todos.""" table_name = 'conditions' to_save = ['is_active'] @@ -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."""