o
    e5                     @   s  d dl 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 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mZ d dlmZmZ d dlmZ d dl m!Z! d dl"m#Z# d dl$m%Z%m&Z& d dl'm(Z) d dl*m+Z+ d dl,m-Z- d dl.m/Z/ d dl0m1Z1 d dl2m3Z3 e Z4G dd dZ5G dd de5e3Z6G dd de5e1Z7d1ddZ8defd d!Z9G d"d# d#Z:G d$d% d%e:e3Z;d&Z<G d'd( d(e:e1Z=G d)d* d*e:e3Z>G d+d, d,e:e1Z?G d-d. d.e:e3Z@G d/d0 d0e:e1ZAdS )2    )urlparse
urlunparse)settings)REDIRECT_FIELD_NAMEget_user_model)login)logout)update_session_auth_hash)login_required)AuthenticationFormPasswordChangeFormPasswordResetFormSetPasswordForm)default_token_generator)get_current_site)ImproperlyConfiguredValidationError)HttpResponseRedirect	QueryDict)resolve_url)reverse_lazy)method_decorator)url_has_allowed_host_and_schemeurlsafe_base64_decode)gettext_lazy)never_cache)csrf_protect)sensitive_post_parameters)TemplateView)FormViewc                   @   s:   e Zd ZdZeZe Zdd Zdd Z	dd Z
dd	 ZdS )
RedirectURLMixinNc                 C   s   |   p|  S N)get_redirect_urlget_default_redirect_urlself r&   L/var/www/html/venv/lib/python3.10/site-packages/django/contrib/auth/views.pyget_success_url(   s   z RedirectURLMixin.get_success_urlc                 C   sB   | j j| j| j j| j}t||  | j  d}|r|S dS )z6Return the user-originating redirect URL if it's safe.)urlallowed_hostsrequire_https )requestPOSTgetredirect_field_nameGETr   get_success_url_allowed_hosts	is_secure)r%   redirect_tourl_is_safer&   r&   r'   r"   +   s   z!RedirectURLMixin.get_redirect_urlc                 C   s   | j  h| jS r!   )r-   get_hostsuccess_url_allowed_hostsr$   r&   r&   r'   r2   7   s   z.RedirectURLMixin.get_success_url_allowed_hostsc                 C   s   | j rt| j S td) Return the default redirect URL.z+No URL to redirect to. Provide a next_page.)	next_pager   r   r$   r&   r&   r'   r#   :   s   
z)RedirectURLMixin.get_default_redirect_url)__name__
__module____qualname__r9   r   r0   setr7   r(   r"   r2   r#   r&   r&   r&   r'   r    #   s    r    c                       s~   e Zd ZdZeZdZdZdZdZ	e
e e
ee
e fddZdd Zd	d
 Z fddZdd Z fddZ  ZS )	LoginViewz=
    Display the login form and handle the login action.
    Nzregistration/login.htmlFc                    sN   | j r| jjjr|  }|| jjkrtdt|S t j	|g|R i |S )NzsRedirection loop for authenticated user detected. Check that your LOGIN_REDIRECT_URL doesn't point to a login page.)
redirect_authenticated_userr-   useris_authenticatedr(   path
ValueErrorr   superdispatchr%   r-   argskwargsr4   	__class__r&   r'   rE   L   s   zLoginView.dispatchc                 C   s   | j rt| j S ttjS r8   )r9   r   r   LOGIN_REDIRECT_URLr$   r&   r&   r'   r#   Z   s   

z"LoginView.get_default_redirect_urlc                 C   s   | j p| jS r!   )authentication_form
form_classr$   r&   r&   r'   get_form_classa   s   zLoginView.get_form_classc                       t   }| j|d< |S )Nr-   )rD   get_form_kwargsr-   r%   rH   rI   r&   r'   rQ   d      

zLoginView.get_form_kwargsc                 C   s   t | j|  t|  S )z)Security check complete. Log the user in.)
auth_loginr-   get_userr   r(   r%   formr&   r&   r'   
form_validi   s   zLoginView.form_validc                    sH   t  jdi |}t| j}|| j|  d|d|ji| jpi  |S )Nsite	site_namer&   )	rD   get_context_datar   r-   updater0   r"   nameextra_contextr%   rH   contextcurrent_siterI   r&   r'   r[   n   s   

zLoginView.get_context_data)r:   r;   r<   __doc__r   rN   rM   template_namer?   r^   r   r   r   r   rE   r#   rO   rQ   rX   r[   __classcell__r&   r&   rI   r'   r>   A   s     r>   c                       s`   e Zd ZdZddgZdZdZeeee	 fddZ
 fdd	Zd
d Z fddZ  ZS )
LogoutViewzH
    Log out the user and display the 'You are logged out' message.
    postoptionszregistration/logged_out.htmlNc                    s   t  j|g|R i |S r!   rD   rE   )r%   r-   rG   rH   rI   r&   r'   rE      s   zLogoutView.dispatchc                    s>   t | |  }|| krt|S t j|g|R i |S )zLogout may be done via POST.)auth_logoutr(   get_full_pathr   rD   r/   rF   rI   r&   r'   rf      s
   zLogoutView.postc                 C   s(   | j rt| j S tjrttjS | jjS rK   )r9   r   r   LOGOUT_REDIRECT_URLr-   rB   r$   r&   r&   r'   r#      s
   

z#LogoutView.get_default_redirect_urlc                    sD   t  jdi |}t| j}|||jtdd d| jpi  |S )Nz
Logged out)rY   rZ   titlesubtitler&   )rD   r[   r   r-   r\   r]   _r^   r_   rI   r&   r'   r[      s   
	zLogoutView.get_context_data)r:   r;   r<   rb   http_method_namesrc   r^   r   r   r   rE   rf   r#   r[   rd   r&   r&   rI   r'   re   |   s    		re   Nc                 C   s   t |ptj}tj|d| S )zR
    Log out the user if they are logged in. Then redirect to the login page.
    )r9   )r   r   	LOGIN_URLre   as_view)r-   	login_urlr&   r&   r'   logout_then_login   s   rs   c                 C   sR   t |ptj}tt|}|r#t|d dd}| ||< |jdd|d< tt|S )zM
    Redirect the user to the login page, passing the given 'next' page.
       T)mutable/)safe)	r   r   rp   listr   r   	urlencoder   r   )nextrr   r0   resolved_urllogin_url_partsquerystringr&   r&   r'   redirect_to_login   s   r~   c                       s    e Zd ZdZ fddZ  ZS )PasswordContextMixinNc                    s2   t  jdi |}|| jd d| jpi  |S )N)rl   rm   r&   )rD   r[   r\   rl   r^   r%   rH   r`   rI   r&   r'   r[      s
   z%PasswordContextMixin.get_context_data)r:   r;   r<   r^   r[   rd   r&   r&   rI   r'   r      s    r   c                       s`   e Zd ZdZdZeZdZdZdZ	e
dZdZedZeZee fddZ fd	d
Z  ZS )PasswordResetViewz&registration/password_reset_email.htmlNz'registration/password_reset_subject.txtpassword_reset_donez%registration/password_reset_form.htmlzPassword resetc                       t  j|i |S r!   rh   r%   rG   rH   rI   r&   r'   rE         zPasswordResetView.dispatchc              	      sF   | j  | j| j| j| j| j | j| jd}|jdi | t	 
|S )N)	use_httpstoken_generator
from_emailemail_template_namesubject_template_namer-   html_email_template_nameextra_email_contextr&   )r-   r3   r   r   r   r   r   r   saverD   rX   )r%   rW   optsrI   r&   r'   rX      s   
zPasswordResetView.form_valid)r:   r;   r<   r   r   r   rN   r   r   r   r   success_urlrc   rn   rl   r   r   r   r   rE   rX   rd   r&   r&   rI   r'   r      s    r   _password_reset_tokenc                   @   s   e Zd ZdZedZdS )PasswordResetDoneViewz%registration/password_reset_done.htmlzPassword reset sentN)r:   r;   r<   rc   rn   rl   r&   r&   r&   r'   r      s    r   c                       s   e Zd ZeZdZdZdZedZ	dZ
edZeZee ee fddZd	d
 Z fddZ fddZ fddZ  ZS )PasswordResetConfirmViewFNzset-passwordpassword_reset_completez(registration/password_reset_confirm.htmlzEnter new passwordc                    s   d|vsd|vrt dd| _| |d | _| jd ur\|d }|| jkrA| jjt}| j	
| j|r@d| _t j|i |S n| j	
| j|r\|| jjt< | jj|| j}t|S | |  S )Nuidb64tokenz:The URL path must contain 'uidb64' and 'token' parameters.FT)r   	validlinkrU   r@   reset_url_tokenr-   sessionr/   INTERNAL_RESET_SESSION_TOKENr   check_tokenrD   rE   rB   replacer   render_to_responser[   )r%   rG   rH   r   session_tokenredirect_urlrI   r&   r'   rE     s*   

z!PasswordResetConfirmView.dispatchc                 C   sF   zt | }tjj|d}W |S  ttttjt	fy"   d }Y |S w )N)pk)
r   decode	UserModel_default_managerr/   	TypeErrorrC   OverflowErrorDoesNotExistr   )r%   r   uidr@   r&   r&   r'   rU   (  s   	
z!PasswordResetConfirmView.get_userc                    rP   Nr@   )rD   rQ   r@   rR   rI   r&   r'   rQ   7  rS   z(PasswordResetConfirmView.get_form_kwargsc                    s4   |  }| jjt= | jrt| j|| j t |S r!   )	r   r-   r   r   post_reset_loginrT   post_reset_login_backendrD   rX   )r%   rW   r@   rI   r&   r'   rX   <  s
   
z#PasswordResetConfirmView.form_validc                    s>   t  jdi |}| jrd|d< |S |d tddd |S )NTr   zPassword reset unsuccessfulF)rW   rl   r   r&   )rD   r[   r   r\   rn   r   rI   r&   r'   r[   C  s   	z)PasswordResetConfirmView.get_context_data)r:   r;   r<   r   rN   r   r   r   r   r   rc   rn   rl   r   r   r   r   r   rE   rU   rQ   rX   r[   rd   r&   r&   rI   r'   r      s      r   c                       s(   e Zd ZdZedZ fddZ  ZS )PasswordResetCompleteViewz)registration/password_reset_complete.htmlzPassword reset completec                    s$   t  jdi |}ttj|d< |S )Nrr   r&   )rD   r[   r   r   rp   r   rI   r&   r'   r[   V  s   z*PasswordResetCompleteView.get_context_data)r:   r;   r<   rc   rn   rl   r[   rd   r&   r&   rI   r'   r   R  s    r   c                       sf   e Zd ZeZedZdZedZ	e
e e
ee
e fddZ fddZ fdd	Z  ZS )
PasswordChangeViewpassword_change_donez&registration/password_change_form.htmlzPassword changec                    r   r!   rh   r   rI   r&   r'   rE   b  s   zPasswordChangeView.dispatchc                    s   t   }| jj|d< |S r   )rD   rQ   r-   r@   rR   rI   r&   r'   rQ   h  s   
z"PasswordChangeView.get_form_kwargsc                    s"   |   t| j|j t |S r!   )r   r	   r-   r@   rD   rX   rV   rI   r&   r'   rX   m  s   zPasswordChangeView.form_valid)r:   r;   r<   r   rN   r   r   rc   rn   rl   r   r   r   r
   rE   rQ   rX   rd   r&   r&   rI   r'   r   \  s    r   c                       s0   e Zd ZdZedZee fddZ  Z	S )PasswordChangeDoneViewz&registration/password_change_done.htmlzPassword change successfulc                    r   r!   rh   r   rI   r&   r'   rE   y  r   zPasswordChangeDoneView.dispatch)
r:   r;   r<   rc   rn   rl   r   r
   rE   rd   r&   r&   rI   r'   r   u  s
    r   r!   )Burllib.parser   r   django.confr   django.contrib.authr   r   r   rT   r   ri   r	   django.contrib.auth.decoratorsr
   django.contrib.auth.formsr   r   r   r   django.contrib.auth.tokensr   django.contrib.sites.shortcutsr   django.core.exceptionsr   r   django.httpr   r   django.shortcutsr   django.urlsr   django.utils.decoratorsr   django.utils.httpr   r   django.utils.translationr   rn   django.views.decorators.cacher   django.views.decorators.csrfr   django.views.decorators.debugr   django.views.generic.baser   django.views.generic.editr   r   r    r>   re   rs   r~   r   r   r   r   r   r   r   r   r&   r&   r&   r'   <module>   sH    ;
/V
