mirror of
				https://github.com/zulip/zulip.git
				synced 2025-10-31 03:53:50 +00:00 
			
		
		
		
	Change `from django.utils.timezone import now` to `from django.utils import timezone`. This is both because now() is ambiguous (could be datetime.datetime.now), and more importantly to make it easier to write a lint rule against datetime.datetime.now().
		
			
				
	
	
		
			68 lines
		
	
	
		
			3.0 KiB
		
	
	
	
		
			Python
		
	
	
	
	
	
			
		
		
	
	
			68 lines
		
	
	
		
			3.0 KiB
		
	
	
	
		
			Python
		
	
	
	
	
	
| from __future__ import absolute_import
 | |
| 
 | |
| from typing import Optional
 | |
| 
 | |
| from django.conf import settings
 | |
| from django.http import HttpRequest, HttpResponse
 | |
| from django.utils import timezone
 | |
| from django.utils.translation import ugettext as _
 | |
| 
 | |
| from zerver.lib.request import has_request_variables, REQ
 | |
| from zerver.lib.response import json_success, json_error
 | |
| from zerver.lib.validator import check_string, check_list, check_bool
 | |
| from zerver.models import PushDeviceToken, UserProfile
 | |
| 
 | |
| def add_push_device_token(request, user_profile, token_str, kind, ios_app_id=None):
 | |
|     # type: (HttpRequest, UserProfile, str, int, Optional[str]) -> HttpResponse
 | |
|     if token_str == '' or len(token_str) > 4096:
 | |
|         return json_error(_('Empty or invalid length token'))
 | |
| 
 | |
|     # If another user was previously logged in on the same device and didn't
 | |
|     # properly log out, the token will still be registered to the wrong account
 | |
|     PushDeviceToken.objects.filter(token=token_str).exclude(user=user_profile).delete()
 | |
| 
 | |
|     # Overwrite with the latest value
 | |
|     token, created = PushDeviceToken.objects.get_or_create(user=user_profile,
 | |
|                                                            token=token_str,
 | |
|                                                            defaults=dict(
 | |
|                                                                kind=kind,
 | |
|                                                                ios_app_id=ios_app_id))
 | |
|     if not created:
 | |
|         token.last_updated = timezone.now()
 | |
|         token.save(update_fields=['last_updated'])
 | |
| 
 | |
|     return json_success()
 | |
| 
 | |
| @has_request_variables
 | |
| def add_apns_device_token(request, user_profile, token=REQ(), appid=REQ(default=settings.ZULIP_IOS_APP_ID)):
 | |
|     # type: (HttpRequest, UserProfile, str, str) -> HttpResponse
 | |
|     return add_push_device_token(request, user_profile, token, PushDeviceToken.APNS, ios_app_id=appid)
 | |
| 
 | |
| @has_request_variables
 | |
| def add_android_reg_id(request, user_profile, token_str=REQ("token")):
 | |
|     # type: (HttpRequest, UserProfile, str) -> HttpResponse
 | |
|     return add_push_device_token(request, user_profile, token_str, PushDeviceToken.GCM)
 | |
| 
 | |
| def remove_push_device_token(request, user_profile, token_str, kind):
 | |
|     # type: (HttpRequest, UserProfile, str, int) -> HttpResponse
 | |
|     if token_str == '' or len(token_str) > 4096:
 | |
|         return json_error(_('Empty or invalid length token'))
 | |
| 
 | |
|     try:
 | |
|         token = PushDeviceToken.objects.get(token=token_str, kind=kind)
 | |
|         token.delete()
 | |
|     except PushDeviceToken.DoesNotExist:
 | |
|         return json_error(_("Token does not exist"))
 | |
| 
 | |
|     return json_success()
 | |
| 
 | |
| @has_request_variables
 | |
| def remove_apns_device_token(request, user_profile, token=REQ()):
 | |
|     # type: (HttpRequest, UserProfile, str) -> HttpResponse
 | |
|     return remove_push_device_token(request, user_profile, token, PushDeviceToken.APNS)
 | |
| 
 | |
| @has_request_variables
 | |
| def remove_android_reg_id(request, user_profile, token=REQ()):
 | |
|     # type: (HttpRequest, UserProfile, str) -> HttpResponse
 | |
|     return remove_push_device_token(request, user_profile, token, PushDeviceToken.GCM)
 |