
    k"g7                         d Z ddlZddlmZ ddlmZ ddlmZmZm	Z	m
Z
 ddlmZ ddlmZ ddlmZ  G d	 d
ej$                        Z G d dej(                        Zy)zg
This module allows importing AbstractBaseUser even when django.contrib.auth is
not in INSTALLED_APPS.
    N)settings)password_validation)acheck_passwordcheck_passwordis_password_usablemake_password)models)salted_hmac)gettext_lazyc                   "    e Zd Zed        Zd Zy)BaseUserManagerc                     |xs d}	 |j                         j                  dd      \  }}|dz   |j                         z   }|S # t        $ r Y |S w xY w)zS
        Normalize the email address by lowercasing the domain part of it.
         @   )striprsplitlower
ValueError)clsemail
email_namedomain_parts       V/var/www/html/djangosite/lib/python3.12/site-packages/django/contrib/auth/base_user.pynormalize_emailzBaseUserManager.normalize_email   si    
 	;&+kkm&:&:3&B#J ${'8'8'::E	  	 		s   #A 	AAc                 R     | j                   di | j                  j                  |iS )N )getmodelUSERNAME_FIELD)selfusernames     r   get_by_natural_keyz"BaseUserManager.get_by_natural_key$   s%    txx@4::44h?@@    N)__name__
__module____qualname__classmethodr   r#   r   r$   r   r   r      s     Ar$   r   c                   2    e Zd Z ej                   ed      d      Z ej                   ed      dd      ZdZ	g Z
dZ G d d	      Zd
 Z fdZd Zd Zd Zed        Zed        Zd Zd Zd Zd Zd Zd Zd ZddZed        Zed        Z xZ S )AbstractBaseUserpassword   )
max_lengthz
last loginT)blanknullNc                       e Zd ZdZy)AbstractBaseUser.MetaTN)r%   r&   r'   abstractr   r$   r   Metar1   4   s    r$   r3   c                 "    | j                         S Nget_usernamer!   s    r   __str__zAbstractBaseUser.__str__7   s      ""r$   c                     t        |   |i | | j                  (t        j                  | j                  |        d | _        y y r5   )supersave	_passwordr   password_changed)r!   argskwargs	__class__s      r   r<   zAbstractBaseUser.save=   s>    d%f%>>%00F!DN &r$   c                 .    t        | | j                        S )z"Return the username for this User.)getattrr    r8   s    r   r7   zAbstractBaseUser.get_usernameC   s    tT0011r$   c                 l    t        | | j                  | j                  | j                                      y r5   )setattrr    normalize_usernamer7   r8   s    r   cleanzAbstractBaseUser.cleanG   s(    d))4+B+B4CTCTCV+WXr$   c                 $    | j                         fS r5   r6   r8   s    r   natural_keyzAbstractBaseUser.natural_keyJ   s    !!#%%r$   c                      y)zj
        Always return False. This is a way of comparing User objects to
        anonymous users.
        Fr   r8   s    r   is_anonymouszAbstractBaseUser.is_anonymousM   s     r$   c                      y)zt
        Always return True. This is a way to tell if the user has been
        authenticated in templates.
        Tr   r8   s    r   is_authenticatedz!AbstractBaseUser.is_authenticatedU   s     r$   c                 2    t        |      | _        || _        y r5   )r   r+   r=   )r!   raw_passwords     r   set_passwordzAbstractBaseUser.set_password]   s    %l3%r$   c                 <      fd}t        | j                  |      S )z~
        Return a boolean of whether the raw_password was correct. Handles
        hashing formats behind the scenes.
        c                 \    j                  |        d _        j                  dg       y Nr+   )update_fields)rP   r=   r<   rO   r!   s    r   setterz/AbstractBaseUser.check_password.<locals>.setterg   s(    l+!DNIIZLI1r$   )r   r+   r!   rO   rV   s   `  r   r   zAbstractBaseUser.check_passworda   s    	2 lDMM6BBr$   c                 X    K    fd}t        | j                  |       d{   S 7 w)zSee check_password().c                 x   K   j                  |        d _        j                  dg       d {    y 7 wrS   )rP   r=   asaverU   s    r   rV   z0AbstractBaseUser.acheck_password.<locals>.setterr   s2     l+!DN**J<*888s   /:8:N)r   r+   rW   s   `  r   r   z AbstractBaseUser.acheck_passwordo   s'     	9 %\4==&IIIIs    *(*c                 $    t        d       | _        y r5   )r   r+   r8   s    r   set_unusable_passwordz&AbstractBaseUser.set_unusable_passwordz   s    %d+r$   c                 ,    t        | j                        S )zX
        Return False if set_unusable_password() has been called for this user.
        )r   r+   r8   s    r   has_usable_passwordz$AbstractBaseUser.has_usable_password~   s     "$--00r$   c                 "    | j                         S )z7
        Return an HMAC of the password field.
        )_get_session_auth_hashr8   s    r   get_session_auth_hashz&AbstractBaseUser.get_session_auth_hash   s     **,,r$   c              #   ^   K   t         j                  D ]  }| j                  |        y w)N)secret)r   SECRET_KEY_FALLBACKSr`   )r!   fallback_secrets     r   get_session_auth_fallback_hashz/AbstractBaseUser.get_session_auth_fallback_hash   s1     '<< 	FO--_-EE	Fs   +-c                 T    d}t        || j                  |d      j                         S )NzAdjango.contrib.auth.models.AbstractBaseUser.get_session_auth_hashsha256)rc   	algorithm)r
   r+   	hexdigest)r!   rc   key_salts      r   r`   z'AbstractBaseUser._get_session_auth_hash   s-    VMM	

 )+	r$   c                 :    	 | j                   S # t        $ r Y yw xY w)Nr   )EMAIL_FIELDAttributeError)r   s    r   get_email_field_namez%AbstractBaseUser.get_email_field_name   s#    	??" 		s    	c                 R    t        |t              rt        j                  d|      S |S )NNFKC)
isinstancestrunicodedata	normalize)r   r"   s     r   rF   z#AbstractBaseUser.normalize_username   s/     (C( !!&(3	
 	
r$   r5   )!r%   r&   r'   r	   	CharField_r+   DateTimeField
last_login	is_activeREQUIRED_FIELDSr=   r3   r9   r<   r7   rG   rI   propertyrK   rM   rP   r   r   r\   r^   ra   rf   r`   r(   ro   rF   __classcell__)rA   s   @r   r*   r*   (   s    v*#>H%%%aoTMJIO I #"2Y&    &C	J,1-F   
 
r$   r*   )__doc__rt   django.confr   django.contrib.authr   django.contrib.auth.hashersr   r   r   r   	django.dbr	   django.utils.cryptor
   django.utils.translationr   rw   Managerr   Modelr*   r   r$   r   <module>r      sN   
    3   + 6Afnn A&|
v|| |
r$   