
     h                         d Z ddlZddlZddlmZ ddlmZ ddlmZm	Z	m
Z
 ddlmZ ddlmZmZ ddlmZ dd	lmZ  G d
 dej                  Z G d dej                  ZdS )zg
This module allows importing AbstractBaseUser even when django.contrib.auth is
not in INSTALLED_APPS.
    N)settings)password_validation)check_passwordis_password_usablemake_password)models)get_random_stringsalted_hmac)RemovedInDjango51Warning)gettext_lazyc                   6    e Zd Zed             Z	 	 ddZd ZdS )BaseUserManagerc                     |pd}	 |                                                     dd          \  }}|dz   |                                z   }n# t          $ r Y nw xY w|S )zS
        Normalize the email address by lowercasing the domain part of it.
         @   )striprsplitlower
ValueError)clsemail
email_namedomain_parts       \/var/www/surfInsights/venv3-11/lib/python3.11/site-packages/django/contrib/auth/base_user.pynormalize_emailzBaseUserManager.normalize_email   s|    
 	;&+kkmm&:&:3&B&B#J ${'8'8':'::EE  	 	 	D	 s   +A 
AA
   7abcdefghjkmnpqrstuvwxyzABCDEFGHJKLMNPQRSTUVWXYZ23456789c                 Z    t          j        dt          d           t          ||          S )z
        Generate a random password with the given length and given
        allowed_chars. The default value of allowed_chars does not have "I" or
        "O" or letters and digits that look similar -- just to avoid confusion.
        z5BaseUserManager.make_random_password() is deprecated.   )category
stacklevel)warningswarnr   r	   )selflengthallowed_charss      r   make_random_passwordz$BaseUserManager.make_random_password$   s8     	C-	
 	
 	
 	

 !777    c                 4     | j         di | j        j        |iS )N )getmodelUSERNAME_FIELD)r%   usernames     r   get_by_natural_keyz"BaseUserManager.get_by_natural_key5   s$    tx@@4:4h?@@@r)   N)r   r   )__name__
__module____qualname__classmethodr   r(   r0   r+   r)   r   r   r      s]          [ O8 8 8 8"A A A A Ar)   r   c                   N    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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dS )AbstractBaseUser.MetaTN)r1   r2   r3   abstractr+   r)   r   Metar=   E   s        r)   r?   c                 *    |                                  S Nget_usernamer%   s    r   __str__zAbstractBaseUser.__str__H   s      """r)   c                      t                      j        |i | | j        #t          j        | j        |            d | _        d S d S rA   )supersave	_passwordr   password_changed)r%   argskwargs	__class__s      r   rH   zAbstractBaseUser.saveK   sN    d%f%%%>%0FFF!DNNN &%r)   c                 ,    t          | | j                  S )z"Return the username for this User.)getattrr.   rD   s    r   rC   zAbstractBaseUser.get_usernameQ   s    tT0111r)   c                 |    t          | | j        |                     |                                                      d S rA   )setattrr.   normalize_usernamerC   rD   s    r   cleanzAbstractBaseUser.cleanU   s7    d)4+B+B4CTCTCVCV+W+WXXXXXr)   c                 ,    |                                  fS rA   rB   rD   s    r   natural_keyzAbstractBaseUser.natural_keyX   s    !!##%%r)   c                     dS )zj
        Always return False. This is a way of comparing User objects to
        anonymous users.
        Fr+   rD   s    r   is_anonymouszAbstractBaseUser.is_anonymous[   s	     ur)   c                     dS )zt
        Always return True. This is a way to tell if the user has been
        authenticated in templates.
        Tr+   rD   s    r   is_authenticatedz!AbstractBaseUser.is_authenticatedc   s	     tr)   c                 <    t          |          | _        || _        d S rA   )r   r7   rI   )r%   raw_passwords     r   set_passwordzAbstractBaseUser.set_passwordk   s    %l3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                 n                         |            d _                            dg           d S )Nr7   )update_fields)r\   rI   rH   )r[   r%   s    r   setterz/AbstractBaseUser.check_password.<locals>.setteru   s:    l+++!DNIIZLI11111r)   )r   r7   )r%   r[   r`   s   `  r   r   zAbstractBaseUser.check_passwordo   s2    	2 	2 	2 	2 	2 lDM6BBBr)   c                 .    t          d           | _        d S rA   )r   r7   rD   s    r   set_unusable_passwordz&AbstractBaseUser.set_unusable_password}   s    %d++r)   c                 *    t          | j                  S )zX
        Return False if set_unusable_password() has been called for this user.
        )r   r7   rD   s    r   has_usable_passwordz$AbstractBaseUser.has_usable_password   s     "$-000r)   c                 *    |                                  S )z7
        Return an HMAC of the password field.
        )_get_session_auth_hashrD   s    r   get_session_auth_hashz&AbstractBaseUser.get_session_auth_hash   s     **,,,r)   c              #   X   K   t           j        D ]}|                     |          V  d S )N)secret)r   SECRET_KEY_FALLBACKSrf   )r%   fallback_secrets     r   get_session_auth_fallback_hashz/AbstractBaseUser.get_session_auth_fallback_hash   sF      '< 	F 	FO--_-EEEEEE	F 	Fr)   c                 Z    d}t          || j        |d                                          S )NzAdjango.contrib.auth.models.AbstractBaseUser.get_session_auth_hashsha256)ri   	algorithm)r
   r7   	hexdigest)r%   ri   key_salts      r   rf   z'AbstractBaseUser._get_session_auth_hash   s7    VM	
 
 

 )++	r)   c                 4    	 | j         S # t          $ r Y dS w xY w)Nr   )EMAIL_FIELDAttributeError)r   s    r   get_email_field_namez%AbstractBaseUser.get_email_field_name   s1    	?" 	 	 	77	s   	 
c                 Z    t          |t                    rt          j        d|          n|S )NNFKC)
isinstancestrunicodedata	normalize)r   r/   s     r   rR   z#AbstractBaseUser.normalize_username   s0     (C((K!&(333	
r)   rA   ) r1   r2   r3   r   	CharField_r7   DateTimeField
last_login	is_activeREQUIRED_FIELDSrI   r?   rE   rH   rC   rS   rU   propertyrW   rY   r\   r   rb   rd   rg   rl   rf   r4   ru   rR   __classcell__)rM   s   @r   r6   r6   9   s       v*#>>>H%%aaooTMMMJIO I       # # #" " " " "2 2 2Y Y Y& & &   X   X& & &C C C, , ,1 1 1- - -F F F      [ 
 
 [
 
 
 
 
r)   r6   )__doc__rz   r#   django.confr   django.contrib.authr   django.contrib.auth.hashersr   r   r   	django.dbr   django.utils.cryptor	   r
   django.utils.deprecationr   django.utils.translationr   r}   Managerr   Modelr6   r+   r)   r   <module>r      sA                     3 3 3 3 3 3         
       > > > > > > > > = = = = = = 6 6 6 6 6 6!A !A !A !A !Afn !A !A !AHn
 n
 n
 n
 n
v| n
 n
 n
 n
 n
r)   