-
Notifications
You must be signed in to change notification settings - Fork 52
Expand file tree
/
Copy pathrestore_events.py
More file actions
60 lines (47 loc) · 1.46 KB
/
restore_events.py
File metadata and controls
60 lines (47 loc) · 1.46 KB
1
2
3
4
5
6
7
8
9
10
11
12
13
14
15
16
17
18
19
20
21
22
23
24
25
26
27
28
29
30
31
32
33
34
35
36
37
38
39
40
41
42
43
44
45
46
47
48
49
50
51
52
53
54
55
56
57
58
59
60
from datetime import datetime, timedelta
from typing import List
from app.database.models import Event, UserEvent
from app.dependencies import Session
def delete_events_after_optionals_num_days(days: int, session: Session):
"""
Delete events permanently after 30 days
Args:
days: number of days to delete from
session: db session
Returns:
None
"""
date_to_delete = datetime.now() - timedelta(days=days)
user_events_ids_to_be_deleted = (
session.query(UserEvent)
.join(Event)
.filter(Event.deleted_date < date_to_delete)
.all()
)
for id_to_be_deleted in user_events_ids_to_be_deleted:
(
session.query(UserEvent)
.filter(UserEvent.id == id_to_be_deleted.id)
.delete()
)
session.query(Event).filter(Event.deleted_date < date_to_delete).delete()
session.commit()
def get_events_ids_to_restored(events_data: List) -> List[str]:
"""
Get the event ids that need to be restored
Args:
events_data: List df events
Returns:
Events id
"""
ids = []
check_name = "check"
check_on_value = "on"
is_checkbox_is_on = False
for element, element_value in events_data:
if is_checkbox_is_on:
ids.append(element_value)
is_checkbox_is_on = False
if element == check_name and element_value == check_on_value:
is_checkbox_is_on = True
return ids