-
Notifications
You must be signed in to change notification settings - Fork 3
/
Copy pathdelete_learners.py
120 lines (97 loc) · 4.01 KB
/
delete_learners.py
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
61
62
63
64
65
66
67
68
69
70
71
72
73
74
75
76
77
78
79
80
81
82
83
84
85
86
87
88
89
90
91
92
93
94
95
96
97
98
99
100
101
102
103
104
105
106
107
108
109
110
111
112
113
114
115
116
117
118
119
120
import kolibri # noqa F401
import django
import sys
import csv
import argparse
from colors import *
from django.core.exceptions import ObjectDoesNotExist
django.setup()
from kolibri.core.auth.models import FacilityUser # noqa E402
argParser = argparse.ArgumentParser()
argParser.add_argument(
"--file", "-f", help="File containing user_ids of users to delete"
)
argParser.add_argument(
"--hard",
"-d",
action="store_true",
default=False,
help="Permanently delete users with user_ids in the file provided. The default value is False",
)
def delete_users(input_file, permanently_delete_user=False):
"""Function to delete users supplied in a csv file
The csv file is expected to have a column user_id (uuid of each user to be deleted)
Args:
input_file (string): Path to the file containig the ids of users to delete
Returns:
None
"""
# open the csv file provided and read each line into a dictionary data structure
with open(input_file) as f:
reader = csv.DictReader(f)
# use a list comprehension to store all of the lines an array
to_delete = [r for r in reader]
# initialize a counter variable to track how many users have been deleted
num_deleted = 0
# loop through the objects in the array
for user in to_delete:
# check if a user with the id specified exists
try:
FacilityUser.objects.get(id=user["id"])
# catch the exception when the object does not exist
except ObjectDoesNotExist:
# print out the id that does not exist
print_colored(
"Error: User with id {} does not exist".format(user["id"]),
colors.fg.red,
)
# continue to the next iteration of the loop
continue
# get the full name of the user from the database
user_to_delete = str(FacilityUser.objects.get(id=user["id"]).full_name)
user_obj = FacilityUser.objects.get(id=user["id"])
# if the hard delete flag is supplied, permanently delete the user
if permanently_delete_user:
# delete the user
# note: deleting in this way cascades to other models that reference the user
# i.e memberships, roles, loggers etc
user_obj.delete()
# print out a message containing the name of the user that was permanently deleted
print_colored(
"User {} has been permanently deleted".format(user_to_delete),
colors.fg.orange,
)
# increment the counter by 1
num_deleted += 1
else:
# soft delete
user_obj.set_deleted = True # set deleted to true
user_obj.save()
# print out a message containing the name of the user that was soft deleted
print_colored(
"User {} has been soft deleted".format(user_to_delete),
colors.fg.yellow,
)
# increment the counter by 1
num_deleted += 1
# once the loop completes, print out the number of users that were deleted
if len(to_delete) == num_deleted:
print_colored(
"Done! {} users were deleted".format(num_deleted),
colors.fg.lightgreen,
)
else:
print_colored(
"{} user(s) deleted but {} were supplied. Please check the errors above".format(
num_deleted, len(to_delete)
),
colors.fg.lightcyan,
)
# Main function called when the script is run
if __name__ == "__main__":
args = argParser.parse_args()
if args.file:
open_file = args.file
delete_users(open_file, permanently_delete_user=args.hard)
else:
sys.exit("Please supply a file containing the users to delete")