|  |  |  | @ -5,28 +5,26 @@ from django.db.models import Q | 
		
	
		
			
				|  |  |  |  | 
 | 
		
	
		
			
				|  |  |  |  | @shared_task | 
		
	
		
			
				|  |  |  |  | def set_offline(): | 
		
	
		
			
				|  |  |  |  |     print('Hello') | 
		
	
		
			
				|  |  |  |  |     all_staff_profiles = StaffProfile.objects.all() | 
		
	
		
			
				|  |  |  |  | 
 | 
		
	
		
			
				|  |  |  |  |     staff_without_working_points = all_staff_profiles.exclude( | 
		
	
		
			
				|  |  |  |  |         Q(task__point__status='Working On') | 
		
	
		
			
				|  |  |  |  |     ) | 
		
	
		
			
				|  |  |  |  | 
 | 
		
	
		
			
				|  |  |  |  |     users_without_working_points = [staff_profile.user for staff_profile in staff_without_working_points] | 
		
	
		
			
				|  |  |  |  |     print(users_without_working_points) | 
		
	
		
			
				|  |  |  |  |     for staff_profile in all_staff_profiles: | 
		
	
		
			
				|  |  |  |  |         last_working_point_activity = PointActivity.objects.filter( | 
		
	
		
			
				|  |  |  |  |             point__status='Working On', | 
		
	
		
			
				|  |  |  |  |             point__task__assigned_to=staff_profile.user, | 
		
	
		
			
				|  |  |  |  |         ).order_by('-end_time').first() | 
		
	
		
			
				|  |  |  |  | 
 | 
		
	
		
			
				|  |  |  |  |     # Create a new connection record for each user with status set to 'Offline' | 
		
	
		
			
				|  |  |  |  |     for user in users_without_working_points: | 
		
	
		
			
				|  |  |  |  |         if last_working_point_activity and last_working_point_activity.end_time <= datetime.now() - timedelta(minutes=10): | 
		
	
		
			
				|  |  |  |  |             user = staff_profile.user | 
		
	
		
			
				|  |  |  |  |             last_connection = Connection.objects.filter(user=user).order_by('-date').first() | 
		
	
		
			
				|  |  |  |  |         if last_connection.status != 'Offline': | 
		
	
		
			
				|  |  |  |  |             if last_connection is None or last_connection.status != 'Offline': | 
		
	
		
			
				|  |  |  |  |                 Connection.objects.create( | 
		
	
		
			
				|  |  |  |  |                     status='Offline', | 
		
	
		
			
				|  |  |  |  |                 date=timezone.now(), | 
		
	
		
			
				|  |  |  |  |                     date=datetime.now(), | 
		
	
		
			
				|  |  |  |  |                     user=user | 
		
	
		
			
				|  |  |  |  |                 ) | 
		
	
		
			
				|  |  |  |  |             new_status = Status.objects.create( | 
		
	
		
			
				|  |  |  |  |                 Status.objects.create( | 
		
	
		
			
				|  |  |  |  |                     text='I am now offline!', | 
		
	
		
			
				|  |  |  |  |                     date=datetime.now().date(),  # Getting the current date | 
		
	
		
			
				|  |  |  |  |                     date=datetime.now().date(), | 
		
	
		
			
				|  |  |  |  |                     time=datetime.now().strftime('%I:%M %p'), | 
		
	
		
			
				|  |  |  |  |                     staff=user.staffprofile | 
		
	
		
			
				|  |  |  |  |                 ) |