[2026-05-28 00:00:01] [cron_daily_schedule_fcm] Notification Results:
[2026-05-28 00:00:01] [cron_daily_schedule_fcm] -------------------------
[2026-05-28 00:00:01] [cron_mark_yesterday_absent] start
[2026-05-28 00:00:01] [cron_daily_schedule_fcm] All schedules reset: sent = 0
[2026-05-28 00:00:01] [cron_daily_schedule_fcm] Active status updated based on leave dates
[2026-05-28 00:00:01] [cron_deactivate_schedules_for_inactive_users] start
[2026-05-28 00:00:01] [cron_mark_yesterday_absent] {"success":true,"date":"2026-05-27","marked_absent":3,"users_absent":[{"user_id":4,"name":"vital"},{"user_id":13,"name":"test"},{"user_id":22,"name":"Mangamma"}]}
[2026-05-28 00:00:01] [cron_mark_yesterday_absent] end
[2026-05-28 00:00:01] [cron_deactivate_schedules_for_inactive_users] {"success":true,"message":"No inactive users","inactive_user_ids":[],"schedules_updated":0}
[2026-05-28 00:00:01] [cron_deactivate_schedules_for_inactive_users] end
[2026-05-28 00:00:02] [cron_daily_schedule_fcm] User Tamil → Schedule 271 (active=1) sent to 1 device(s)
[2026-05-28 00:00:02] [cron_daily_schedule_fcm] User Naveen → Schedule 272 (active=1) sent to 1 device(s)
[2026-05-28 00:00:02] [cron_daily_schedule_fcm] User Sathish → Schedule 273 (active=1) sent to 1 device(s)
[2026-05-28 00:00:02] [cron_daily_schedule_fcm] User Madesh → Schedule 274 (active=1) sent to 1 device(s)
[2026-05-28 00:00:02] [cron_daily_schedule_fcm] User Tamil → Schedule 276 (active=1) sent to 1 device(s)
[2026-05-28 00:00:03] [cron_daily_schedule_fcm] User Naveen → Schedule 277 (active=1) sent to 1 device(s)
[2026-05-28 00:00:03] [notification_received] Schedule 274 acknowledged by user_id=15 (event=received)
[2026-05-28 00:00:03] [cron_daily_schedule_fcm] User Sathish → Schedule 278 (active=1) sent to 1 device(s)
[2026-05-28 00:00:03] [cron_daily_schedule_fcm] User Madesh → Schedule 279 (active=1) sent to 1 device(s)
[2026-05-28 00:00:03] [cron_daily_schedule_fcm] User pooarasan → Schedule 281 (active=1) sent to 1 device(s)
[2026-05-28 00:00:03] [notification_received] Schedule 279 acknowledged by user_id=15 (event=received)
[2026-05-28 00:00:03] [cron_daily_schedule_fcm] User pooarasan → Schedule 282 (active=1) sent to 1 device(s)
[2026-05-28 00:00:03] [cron_daily_schedule_fcm] User pooarasan → Schedule 283 (active=1) sent to 1 device(s)
[2026-05-28 00:00:03] [cron_daily_schedule_fcm] -------------------------
[2026-05-28 00:00:03] [cron_daily_schedule_fcm] Total Sent: 11
[2026-05-28 00:00:03] [cron_daily_schedule_fcm] Total Skipped: 0
[2026-05-28 00:00:03] [cron_daily_schedule_fcm] Execution Time: 2.3 sec
[2026-05-28 00:00:03] [cron_daily_schedule_fcm] -------------------------
[2026-05-28 00:00:03] [cron_daily_schedule_fcm] Done.
[2026-05-28 00:00:06] [notification_received] Schedule 283 acknowledged by user_id=6 (event=received)
[2026-05-28 00:00:06] [notification_received] Schedule 281 acknowledged by user_id=6 (event=received)
[2026-05-28 00:00:06] [notification_received] Schedule 282 acknowledged by user_id=6 (event=received)
[2026-05-28 01:00:01] [cron_deactivate_schedules_for_inactive_users] start
[2026-05-28 01:00:01] [cron_deactivate_schedules_for_inactive_users] {"success":true,"message":"No inactive users","inactive_user_ids":[],"schedules_updated":0}
[2026-05-28 01:00:01] [cron_deactivate_schedules_for_inactive_users] end
[2026-05-28 02:00:01] [cron_deactivate_schedules_for_inactive_users] start
[2026-05-28 02:00:01] [cron_deactivate_schedules_for_inactive_users] {"success":true,"message":"No inactive users","inactive_user_ids":[],"schedules_updated":0}
[2026-05-28 02:00:01] [cron_deactivate_schedules_for_inactive_users] end
[2026-05-28 03:00:01] [cron_deactivate_schedules_for_inactive_users] start
[2026-05-28 03:00:01] [cron_deactivate_schedules_for_inactive_users] {"success":true,"message":"No inactive users","inactive_user_ids":[],"schedules_updated":0}
[2026-05-28 03:00:01] [cron_deactivate_schedules_for_inactive_users] end
[2026-05-28 03:50:03] [fcm_token] FCM token saved/updated: user_id=6 device_type=android
[2026-05-28 03:55:01] [notification_received] Schedule 282 acknowledged by user_id=6 (event=tapped)
[2026-05-28 03:55:59] [notification_received] Schedule 282 acknowledged by user_id=6 (event=tapped)
[2026-05-28 03:57:04] [fcm_token] FCM token saved/updated: user_id=5 device_type=android
[2026-05-28 03:57:24] [attendance_code_created] date=2026-05-28 type=first_half
[2026-05-28 03:58:04] [attendance_code_created] date=2026-05-28 type=second_half
[2026-05-28 03:58:11] [attendance_login] user_id=6 date=2026-05-28 first_half
[2026-05-28 04:00:01] [notification_received] Schedule 283 acknowledged by user_id=6 (event=tapped)
[2026-05-28 04:00:01] [cron_deactivate_schedules_for_inactive_users] start
[2026-05-28 04:00:01] [cron_deactivate_schedules_for_inactive_users] {"success":true,"message":"No inactive users","inactive_user_ids":[],"schedules_updated":0}
[2026-05-28 04:00:01] [cron_deactivate_schedules_for_inactive_users] end
[2026-05-28 04:15:02] [fcm_token] FCM token saved/updated: user_id=7 device_type=android
[2026-05-28 04:15:11] [attendance_login] user_id=7 date=2026-05-28 first_half
[2026-05-28 04:33:23] [attendance_login] user_id=21 date=2026-05-28 first_half
[2026-05-28 04:33:41] [fcm_token] FCM token saved/updated: user_id=21 device_type=android
[2026-05-28 04:37:31] [notification_received] Schedule 272 acknowledged by user_id=18 (event=received)
[2026-05-28 04:41:12] [notification_received] Schedule 278 acknowledged by user_id=17 (event=received)
[2026-05-28 04:41:12] [notification_received] Schedule 273 acknowledged by user_id=17 (event=received)
[2026-05-28 04:41:49] [fcm_token] FCM token saved/updated: user_id=17 device_type=android
[2026-05-28 04:42:05] [fcm_token] FCM token saved/updated: user_id=18 device_type=android
[2026-05-28 04:42:08] [attendance_login] user_id=18 date=2026-05-28 first_half
[2026-05-28 04:42:31] [attendance_login] user_id=17 date=2026-05-28 first_half
[2026-05-28 04:46:00] [fcm_token] FCM token saved/updated: user_id=20 device_type=android
[2026-05-28 04:46:07] [attendance_login] user_id=20 date=2026-05-28 first_half
[2026-05-28 05:00:01] [cron_deactivate_schedules_for_inactive_users] start
[2026-05-28 05:00:01] [cron_deactivate_schedules_for_inactive_users] {"success":true,"message":"No inactive users","inactive_user_ids":[],"schedules_updated":0}
[2026-05-28 05:00:01] [cron_deactivate_schedules_for_inactive_users] end
[2026-05-28 06:00:01] [cron_deactivate_schedules_for_inactive_users] start
[2026-05-28 06:00:01] [cron_deactivate_schedules_for_inactive_users] {"success":true,"message":"No inactive users","inactive_user_ids":[],"schedules_updated":0}
[2026-05-28 06:00:01] [cron_deactivate_schedules_for_inactive_users] end
[2026-05-28 06:00:11] [notification_received] Schedule 279 acknowledged by user_id=15 (event=tapped)
[2026-05-28 06:00:22] [fcm_token] FCM token saved/updated: user_id=15 device_type=android
[2026-05-28 06:00:31] [attendance_login] user_id=15 date=2026-05-28 first_half
[2026-05-28 06:01:20] [fcm_token] FCM token saved/updated: user_id=15 device_type=android
[2026-05-28 07:00:01] [cron_deactivate_schedules_for_inactive_users] start
[2026-05-28 07:00:01] [cron_deactivate_schedules_for_inactive_users] {"success":true,"message":"No inactive users","inactive_user_ids":[],"schedules_updated":0}
[2026-05-28 07:00:01] [cron_deactivate_schedules_for_inactive_users] end
[2026-05-28 07:23:50] [fcm_token] FCM token saved/updated: user_id=15 device_type=android
[2026-05-28 07:23:54] [fcm_token] FCM token saved/updated: user_id=20 device_type=android
[2026-05-28 07:23:55] [attendance_logout] user_id=15 date=2026-05-28 first_half
[2026-05-28 07:23:59] [attendance_logout] user_id=20 date=2026-05-28 first_half
[2026-05-28 07:24:19] [fcm_token] FCM token saved/updated: user_id=6 device_type=android
[2026-05-28 07:24:24] [attendance_logout] user_id=6 date=2026-05-28 first_half
[2026-05-28 07:24:31] [attendance_login] user_id=6 date=2026-05-28 second_half
[2026-05-28 07:24:35] [fcm_token] FCM token saved/updated: user_id=21 device_type=android
[2026-05-28 07:24:35] [attendance_login] user_id=20 date=2026-05-28 second_half
[2026-05-28 07:24:39] [attendance_logout] user_id=21 date=2026-05-28 first_half
[2026-05-28 07:24:42] [attendance_login] user_id=15 date=2026-05-28 second_half
[2026-05-28 07:25:01] [fcm_token] FCM token saved/updated: user_id=7 device_type=android
[2026-05-28 07:25:04] [attendance_logout] user_id=7 date=2026-05-28 first_half
[2026-05-28 07:25:11] [attendance_login] user_id=21 date=2026-05-28 second_half
[2026-05-28 07:26:14] [fcm_token] FCM token saved/updated: user_id=7 device_type=android
[2026-05-28 07:26:29] [attendance_login] user_id=7 date=2026-05-28 second_half
[2026-05-28 07:44:20] [fcm_token] FCM token saved/updated: user_id=21 device_type=android
[2026-05-28 07:44:31] [attendance_logout] user_id=21 date=2026-05-28 second_half
[2026-05-28 07:58:37] [attendance_logout] user_id=18 date=2026-05-28 first_half
[2026-05-28 07:58:41] [attendance_login] user_id=18 date=2026-05-28 second_half
[2026-05-28 08:00:01] [cron_deactivate_schedules_for_inactive_users] start
[2026-05-28 08:00:01] [cron_deactivate_schedules_for_inactive_users] {"success":true,"message":"No inactive users","inactive_user_ids":[],"schedules_updated":0}
[2026-05-28 08:00:01] [cron_deactivate_schedules_for_inactive_users] end
[2026-05-28 08:00:10] [attendance_logout] user_id=18 date=2026-05-28 second_half
[2026-05-28 08:31:34] [fcm_token] FCM token saved/updated: user_id=17 device_type=android
[2026-05-28 08:32:52] [attendance_logout] user_id=17 date=2026-05-28 first_half
[2026-05-28 08:32:56] [attendance_login] user_id=17 date=2026-05-28 second_half
[2026-05-28 08:33:33] [fcm_token] FCM token saved/updated: user_id=23 device_type=android
[2026-05-28 08:38:31] [fcm_token] FCM token saved/updated: user_id=15 device_type=android
[2026-05-28 08:38:35] [attendance_logout] user_id=15 date=2026-05-28 second_half
[2026-05-28 08:49:37] [fcm_token] FCM token saved/updated: user_id=7 device_type=android
[2026-05-28 08:49:54] [attendance_logout] user_id=7 date=2026-05-28 second_half
[2026-05-28 08:49:54] [fcm_token] FCM token saved/updated: user_id=20 device_type=android
[2026-05-28 08:49:58] [attendance_logout] user_id=20 date=2026-05-28 second_half
[2026-05-28 08:50:04] [fcm_token] FCM token saved/updated: user_id=6 device_type=android
[2026-05-28 08:50:08] [attendance_logout] user_id=6 date=2026-05-28 second_half
[2026-05-28 08:50:18] [fcm_token] FCM token saved/updated: user_id=17 device_type=android
[2026-05-28 08:50:29] [attendance_logout] user_id=17 date=2026-05-28 second_half
[2026-05-28 09:00:01] [cron_deactivate_schedules_for_inactive_users] start
[2026-05-28 09:00:01] [cron_deactivate_schedules_for_inactive_users] {"success":true,"message":"No inactive users","inactive_user_ids":[],"schedules_updated":0}
[2026-05-28 09:00:01] [cron_deactivate_schedules_for_inactive_users] end
[2026-05-28 10:00:01] [cron_deactivate_schedules_for_inactive_users] start
[2026-05-28 10:00:01] [cron_deactivate_schedules_for_inactive_users] {"success":true,"message":"No inactive users","inactive_user_ids":[],"schedules_updated":0}
[2026-05-28 10:00:01] [cron_deactivate_schedules_for_inactive_users] end
[2026-05-28 11:00:01] [cron_deactivate_schedules_for_inactive_users] start
[2026-05-28 11:00:01] [cron_deactivate_schedules_for_inactive_users] {"success":true,"message":"No inactive users","inactive_user_ids":[],"schedules_updated":0}
[2026-05-28 11:00:01] [cron_deactivate_schedules_for_inactive_users] end
[2026-05-28 12:00:01] [cron_deactivate_schedules_for_inactive_users] start
[2026-05-28 12:00:01] [cron_deactivate_schedules_for_inactive_users] {"success":true,"message":"No inactive users","inactive_user_ids":[],"schedules_updated":0}
[2026-05-28 12:00:01] [cron_deactivate_schedules_for_inactive_users] end
[2026-05-28 12:00:01] [cron_daily_schedule_fcm] Notification Results:
[2026-05-28 12:00:01] [cron_daily_schedule_fcm] -------------------------
[2026-05-28 12:00:01] [cron_daily_schedule_fcm] All schedules reset: sent = 0
[2026-05-28 12:00:01] [cron_daily_schedule_fcm] Active status updated based on leave dates
[2026-05-28 12:00:02] [cron_daily_schedule_fcm] User Tamil → Schedule 271 (active=1) sent to 1 device(s)
[2026-05-28 12:00:02] [cron_daily_schedule_fcm] User Naveen → Schedule 272 (active=1) sent to 1 device(s)
[2026-05-28 12:00:02] [cron_daily_schedule_fcm] User Sathish → Schedule 273 (active=1) sent to 1 device(s)
[2026-05-28 12:00:02] [cron_daily_schedule_fcm] User Madesh → Schedule 274 (active=1) sent to 1 device(s)
[2026-05-28 12:00:02] [cron_daily_schedule_fcm] User Tamil → Schedule 276 (active=1) sent to 1 device(s)
[2026-05-28 12:00:02] [cron_daily_schedule_fcm] User Naveen → Schedule 277 (active=1) sent to 1 device(s)
[2026-05-28 12:00:02] [notification_received] Schedule 274 acknowledged by user_id=15 (event=received)
[2026-05-28 12:00:03] [cron_daily_schedule_fcm] User Sathish → Schedule 278 (active=1) sent to 1 device(s)
[2026-05-28 12:00:03] [cron_daily_schedule_fcm] User Madesh → Schedule 279 (active=1) sent to 1 device(s)
[2026-05-28 12:00:03] [cron_daily_schedule_fcm] User pooarasan → Schedule 281 (active=1) sent to 1 device(s)
[2026-05-28 12:00:03] [notification_received] Schedule 279 acknowledged by user_id=15 (event=received)
[2026-05-28 12:00:03] [cron_daily_schedule_fcm] User pooarasan → Schedule 282 (active=1) sent to 1 device(s)
[2026-05-28 12:00:03] [cron_daily_schedule_fcm] User pooarasan → Schedule 283 (active=1) sent to 1 device(s)
[2026-05-28 12:00:03] [cron_daily_schedule_fcm] -------------------------
[2026-05-28 12:00:03] [cron_daily_schedule_fcm] Total Sent: 11
[2026-05-28 12:00:03] [cron_daily_schedule_fcm] Total Skipped: 0
[2026-05-28 12:00:03] [cron_daily_schedule_fcm] Execution Time: 2.25 sec
[2026-05-28 12:00:03] [cron_daily_schedule_fcm] -------------------------
[2026-05-28 12:00:03] [cron_daily_schedule_fcm] Done.
[2026-05-28 12:00:04] [notification_received] Schedule 281 acknowledged by user_id=6 (event=received)
[2026-05-28 12:00:04] [notification_received] Schedule 282 acknowledged by user_id=6 (event=received)
[2026-05-28 12:00:06] [notification_received] Schedule 283 acknowledged by user_id=6 (event=received)
[2026-05-28 12:10:13] [notification_received] Schedule 271 acknowledged by user_id=20 (event=received)
[2026-05-28 12:10:13] [notification_received] Schedule 276 acknowledged by user_id=20 (event=received)
[2026-05-28 12:26:06] [notification_received] Schedule 272 acknowledged by user_id=18 (event=received)
[2026-05-28 12:26:06] [notification_received] Schedule 277 acknowledged by user_id=18 (event=received)
[2026-05-28 13:00:01] [cron_deactivate_schedules_for_inactive_users] start
[2026-05-28 13:00:01] [cron_deactivate_schedules_for_inactive_users] {"success":true,"message":"No inactive users","inactive_user_ids":[],"schedules_updated":0}
[2026-05-28 13:00:01] [cron_deactivate_schedules_for_inactive_users] end
[2026-05-28 14:00:01] [cron_deactivate_schedules_for_inactive_users] start
[2026-05-28 14:00:01] [cron_deactivate_schedules_for_inactive_users] {"success":true,"message":"No inactive users","inactive_user_ids":[],"schedules_updated":0}
[2026-05-28 14:00:01] [cron_deactivate_schedules_for_inactive_users] end
[2026-05-28 14:31:45] [notification_received] Schedule 273 acknowledged by user_id=17 (event=received)
[2026-05-28 14:32:11] [notification_received] Schedule 278 acknowledged by user_id=17 (event=received)
[2026-05-28 14:32:20] [notification_received] Schedule 278 acknowledged by user_id=17 (event=received)
[2026-05-28 15:00:01] [cron_deactivate_schedules_for_inactive_users] start
[2026-05-28 15:00:01] [cron_deactivate_schedules_for_inactive_users] {"success":true,"message":"No inactive users","inactive_user_ids":[],"schedules_updated":0}
[2026-05-28 15:00:01] [cron_deactivate_schedules_for_inactive_users] end
[2026-05-28 16:00:01] [cron_deactivate_schedules_for_inactive_users] start
[2026-05-28 16:00:01] [cron_deactivate_schedules_for_inactive_users] {"success":true,"message":"No inactive users","inactive_user_ids":[],"schedules_updated":0}
[2026-05-28 16:00:01] [cron_deactivate_schedules_for_inactive_users] end
[2026-05-28 17:00:01] [cron_deactivate_schedules_for_inactive_users] start
[2026-05-28 17:00:01] [cron_deactivate_schedules_for_inactive_users] {"success":true,"message":"No inactive users","inactive_user_ids":[],"schedules_updated":0}
[2026-05-28 17:00:01] [cron_deactivate_schedules_for_inactive_users] end
[2026-05-28 18:00:01] [cron_deactivate_schedules_for_inactive_users] start
[2026-05-28 18:00:01] [cron_deactivate_schedules_for_inactive_users] {"success":true,"message":"No inactive users","inactive_user_ids":[],"schedules_updated":0}
[2026-05-28 18:00:01] [cron_deactivate_schedules_for_inactive_users] end
[2026-05-28 19:00:01] [cron_deactivate_schedules_for_inactive_users] start
[2026-05-28 19:00:01] [cron_deactivate_schedules_for_inactive_users] {"success":true,"message":"No inactive users","inactive_user_ids":[],"schedules_updated":0}
[2026-05-28 19:00:01] [cron_deactivate_schedules_for_inactive_users] end
[2026-05-28 20:00:01] [cron_deactivate_schedules_for_inactive_users] start
[2026-05-28 20:00:01] [cron_deactivate_schedules_for_inactive_users] {"success":true,"message":"No inactive users","inactive_user_ids":[],"schedules_updated":0}
[2026-05-28 20:00:01] [cron_deactivate_schedules_for_inactive_users] end
[2026-05-28 21:00:01] [cron_deactivate_schedules_for_inactive_users] start
[2026-05-28 21:00:01] [cron_deactivate_schedules_for_inactive_users] {"success":true,"message":"No inactive users","inactive_user_ids":[],"schedules_updated":0}
[2026-05-28 21:00:01] [cron_deactivate_schedules_for_inactive_users] end
[2026-05-28 22:00:01] [cron_deactivate_schedules_for_inactive_users] start
[2026-05-28 22:00:01] [cron_deactivate_schedules_for_inactive_users] {"success":true,"message":"No inactive users","inactive_user_ids":[],"schedules_updated":0}
[2026-05-28 22:00:01] [cron_deactivate_schedules_for_inactive_users] end
[2026-05-28 23:00:01] [cron_deactivate_schedules_for_inactive_users] start
[2026-05-28 23:00:01] [cron_deactivate_schedules_for_inactive_users] {"success":true,"message":"No inactive users","inactive_user_ids":[],"schedules_updated":0}
[2026-05-28 23:00:01] [cron_deactivate_schedules_for_inactive_users] end
