{
    "timestamp": "2026-05-01 08:43:07",
    "level": "INFO",
    "function": "updateUserInfoByCsvV2",
    "message": "Process started"
}
{
    "timestamp": "2026-05-01 08:43:07",
    "level": "INFO",
    "function": "updateUserInfoByCsvV2",
    "message": "CSV read: 548 valid rows, 11 empty username rows"
}
{
    "timestamp": "2026-05-01 08:43:07",
    "level": "WARNING",
    "function": "updateUserInfoByCsvV2",
    "message": "Not-found exported: update_user_info_v2_not_found_69f4052ad7fa4.csv (1 rows)"
}
{
    "timestamp": "2026-05-01 08:43:07",
    "level": "INFO",
    "function": "updateUserInfoByCsvV2",
    "message": "Total allowed user_moodle_ids: 547"
}
{
    "timestamp": "2026-05-01 08:43:07",
    "level": "INFO",
    "function": "updateUserInfoByCsvV2",
    "message": "Total user_moodle_ids to remove: 25203"
}
{
    "timestamp": "2026-05-01 08:43:35",
    "level": "INFO",
    "function": "updateUserInfoByCsvV2",
    "message": "Course 45: Removed 11980 from users_enrollment_moodle_speakup_45"
}
{
    "timestamp": "2026-05-01 08:44:02",
    "level": "INFO",
    "function": "updateUserInfoByCsvV2",
    "message": "Course 46: Removed 12047 from users_enrollment_moodle_speakup_46"
}
{
    "timestamp": "2026-05-01 08:44:29",
    "level": "INFO",
    "function": "updateUserInfoByCsvV2",
    "message": "Course 47: Removed 8586 from users_enrollment_moodle_speakup_47"
}
{
    "timestamp": "2026-05-01 08:44:56",
    "level": "INFO",
    "function": "updateUserInfoByCsvV2",
    "message": "Course 68: Removed 3353 from users_enrollment_moodle_speakup_68"
}
{
    "timestamp": "2026-05-01 08:44:56",
    "level": "INFO",
    "function": "updateUserInfoByCsvV2",
    "message": "Course 45: Removed 0 from activity_completion_speakup_45"
}
{
    "timestamp": "2026-05-01 08:44:57",
    "level": "INFO",
    "function": "updateUserInfoByCsvV2",
    "message": "Course 46: Removed 0 from activity_completion_speakup_46"
}
{
    "timestamp": "2026-05-01 08:44:57",
    "level": "INFO",
    "function": "updateUserInfoByCsvV2",
    "message": "Course 47: Removed 0 from activity_completion_speakup_47"
}
{
    "timestamp": "2026-05-01 08:44:57",
    "level": "INFO",
    "function": "updateUserInfoByCsvV2",
    "message": "Course 68: Removed 0 from activity_completion_speakup_68"
}
{
    "timestamp": "2026-05-01 08:44:57",
    "level": "INFO",
    "function": "updateUserInfoByCsvV2",
    "message": "Removed 25 from user_quiz_grade"
}
{
    "timestamp": "2026-05-01 08:44:57",
    "level": "INFO",
    "function": "updateUserInfoByCsvV2",
    "message": "Process completed. Counts: {\"users_enrollment\":35966,\"activity_completion\":0,\"user_quiz_grade\":25}"
}
{
    "timestamp": "2026-05-01 09:02:39",
    "level": "INFO",
    "function": "updateUserInfoByCsvV2",
    "message": "Process started"
}
{
    "timestamp": "2026-05-01 09:02:39",
    "level": "INFO",
    "function": "updateUserInfoByCsvV2",
    "message": "CSV read: 548 valid rows, 11 empty username rows"
}
{
    "timestamp": "2026-05-01 09:02:39",
    "level": "WARNING",
    "function": "updateUserInfoByCsvV2",
    "message": "Not-found exported: update_user_info_v2_not_found_69f409becccf7.csv (1 rows)"
}
{
    "timestamp": "2026-05-01 09:02:39",
    "level": "INFO",
    "function": "updateUserInfoByCsvV2",
    "message": "Total allowed user_moodle_ids: 547"
}
{
    "timestamp": "2026-05-01 09:02:39",
    "level": "INFO",
    "function": "updateUserInfoByCsvV2",
    "message": "Total user_moodle_ids to remove: 0"
}
{
    "timestamp": "2026-05-01 09:02:39",
    "level": "INFO",
    "function": "updateUserInfoByCsvV2",
    "message": "Course 45: Removed 0 from users_enrollment_moodle_speakup_45"
}
{
    "timestamp": "2026-05-01 09:02:39",
    "level": "INFO",
    "function": "updateUserInfoByCsvV2",
    "message": "Course 46: Removed 0 from users_enrollment_moodle_speakup_46"
}
{
    "timestamp": "2026-05-01 09:02:39",
    "level": "INFO",
    "function": "updateUserInfoByCsvV2",
    "message": "Course 47: Removed 0 from users_enrollment_moodle_speakup_47"
}
{
    "timestamp": "2026-05-01 09:02:39",
    "level": "INFO",
    "function": "updateUserInfoByCsvV2",
    "message": "Course 68: Removed 0 from users_enrollment_moodle_speakup_68"
}
{
    "timestamp": "2026-05-01 09:02:39",
    "level": "INFO",
    "function": "updateUserInfoByCsvV2",
    "message": "Course 45: Removed 0 from activity_completion_speakup_45"
}
{
    "timestamp": "2026-05-01 09:02:39",
    "level": "INFO",
    "function": "updateUserInfoByCsvV2",
    "message": "Course 46: Removed 0 from activity_completion_speakup_46"
}
{
    "timestamp": "2026-05-01 09:02:39",
    "level": "INFO",
    "function": "updateUserInfoByCsvV2",
    "message": "Course 47: Removed 0 from activity_completion_speakup_47"
}
{
    "timestamp": "2026-05-01 09:02:39",
    "level": "INFO",
    "function": "updateUserInfoByCsvV2",
    "message": "Course 68: Removed 0 from activity_completion_speakup_68"
}
{
    "timestamp": "2026-05-01 09:04:22",
    "level": "INFO",
    "function": "updateUserInfoByCsvV2",
    "message": "Removed 1113924 from user_quiz_grade"
}
{
    "timestamp": "2026-05-01 09:04:22",
    "level": "INFO",
    "function": "updateUserInfoByCsvV2",
    "message": "Process completed. Counts: {\"users_enrollment\":0,\"activity_completion\":0,\"user_quiz_grade\":1113924}"
}
