mirror of https://github.com/jumpserver/jumpserver
				
				
				
			
		
			
				
	
	
		
			91 lines
		
	
	
		
			3.5 KiB
		
	
	
	
		
			Python
		
	
	
			
		
		
	
	
			91 lines
		
	
	
		
			3.5 KiB
		
	
	
	
		
			Python
		
	
	
import uuid
 | 
						|
from functools import partial
 | 
						|
 | 
						|
from django.utils import timezone
 | 
						|
from django.utils.translation import ugettext_lazy as _, ugettext as __
 | 
						|
from rest_framework.authtoken.models import Token
 | 
						|
from django.conf import settings
 | 
						|
from django.utils.crypto import get_random_string
 | 
						|
 | 
						|
from common.db import models
 | 
						|
from common.mixins.models import CommonModelMixin
 | 
						|
from common.utils import get_object_or_none, get_request_ip, get_ip_city
 | 
						|
 | 
						|
 | 
						|
class AccessKey(models.Model):
 | 
						|
    id = models.UUIDField(verbose_name='AccessKeyID', primary_key=True,
 | 
						|
                          default=uuid.uuid4, editable=False)
 | 
						|
    secret = models.UUIDField(verbose_name='AccessKeySecret',
 | 
						|
                              default=uuid.uuid4, editable=False)
 | 
						|
    user = models.ForeignKey(settings.AUTH_USER_MODEL, verbose_name='User',
 | 
						|
                             on_delete=models.CASCADE, related_name='access_keys')
 | 
						|
    is_active = models.BooleanField(default=True, verbose_name=_('Active'))
 | 
						|
    date_created = models.DateTimeField(auto_now_add=True)
 | 
						|
 | 
						|
    def get_id(self):
 | 
						|
        return str(self.id)
 | 
						|
 | 
						|
    def get_secret(self):
 | 
						|
        return str(self.secret)
 | 
						|
 | 
						|
    def get_full_value(self):
 | 
						|
        return '{}:{}'.format(self.id, self.secret)
 | 
						|
 | 
						|
    def __str__(self):
 | 
						|
        return str(self.id)
 | 
						|
 | 
						|
 | 
						|
class PrivateToken(Token):
 | 
						|
    """Inherit from auth token, otherwise migration is boring"""
 | 
						|
 | 
						|
    class Meta:
 | 
						|
        verbose_name = _('Private Token')
 | 
						|
 | 
						|
 | 
						|
class LoginConfirmSetting(CommonModelMixin):
 | 
						|
    user = models.OneToOneField('users.User', on_delete=models.CASCADE, verbose_name=_("User"), related_name="login_confirm_setting")
 | 
						|
    reviewers = models.ManyToManyField('users.User', verbose_name=_("Reviewers"), related_name="review_login_confirm_settings", blank=True)
 | 
						|
    is_active = models.BooleanField(default=True, verbose_name=_("Is active"))
 | 
						|
 | 
						|
    @classmethod
 | 
						|
    def get_user_confirm_setting(cls, user):
 | 
						|
        return get_object_or_none(cls, user=user)
 | 
						|
 | 
						|
    def create_confirm_ticket(self, request=None):
 | 
						|
        from tickets.models import Ticket
 | 
						|
        title = _('Login confirm') + ' {}'.format(self.user)
 | 
						|
        if request:
 | 
						|
            remote_addr = get_request_ip(request)
 | 
						|
            city = get_ip_city(remote_addr)
 | 
						|
            datetime = timezone.now().strftime('%Y-%m-%d %H:%M:%S')
 | 
						|
            body = __("{user_key}: {username}<br>"
 | 
						|
                      "IP: {ip}<br>"
 | 
						|
                      "{city_key}: {city}<br>"
 | 
						|
                      "{date_key}: {date}<br>").format(
 | 
						|
                user_key=__("User"), username=self.user,
 | 
						|
                ip=remote_addr, city_key=_("City"), city=city,
 | 
						|
                date_key=__("Datetime"), date=datetime
 | 
						|
            )
 | 
						|
        else:
 | 
						|
            body = ''
 | 
						|
        reviewer = self.reviewers.all()
 | 
						|
        ticket = Ticket.objects.create(
 | 
						|
            user=self.user, title=title, body=body,
 | 
						|
            type=Ticket.TYPE.LOGIN_CONFIRM,
 | 
						|
        )
 | 
						|
        ticket.assignees.set(reviewer)
 | 
						|
        return ticket
 | 
						|
 | 
						|
    def __str__(self):
 | 
						|
        return '{} confirm'.format(self.user.username)
 | 
						|
 | 
						|
 | 
						|
class SSOToken(models.JMSBaseModel):
 | 
						|
    """
 | 
						|
    类似腾讯企业邮的 [单点登录](https://exmail.qq.com/qy_mng_logic/doc#10036)
 | 
						|
    出于安全考虑,这里的 `token` 使用一次随即过期。但我们保留每一个生成过的 `token`。
 | 
						|
    """
 | 
						|
    authkey = models.UUIDField(primary_key=True, default=uuid.uuid4, verbose_name=_('Token'))
 | 
						|
    expired = models.BooleanField(default=False, verbose_name=_('Expired'))
 | 
						|
    user = models.ForeignKey('users.User', on_delete=models.PROTECT, verbose_name=_('User'), db_constraint=False)
 |