Ë
    D¨6i\  ã            
       ó^   — d dl mZ d dlmZ d dlmZ dZ	 	 d	dddddddddœd„Z ed„ «      Zy)
é    )Úg)Ú
LocalProxy)ÚOAuth2ConsumerBlueprintz)Michael Abrahamsen <support@conveyor.dev>N)ÚscopeÚredirect_urlÚredirect_toÚ	login_urlÚauthorized_urlÚsession_classÚstorageÚrule_kwargsc                óÐ   ‡— t        dt        | ||r|j                  dd«      ndddd|||||||	¬«      Šd	‰j                  d
<   d‰j                  d<   ‰j                  ˆfd„«       }
‰S )a†  
    Make a blueprint for authenticating with Digital Ocean using OAuth 2.
    This requires a client ID and client secret from Digital Ocean.
    You should either pass them to this constructor, or make sure that your
    Flask application config defines them, using the variables
    :envvar:`DIGITALOCEAN_OAUTH_CLIENT_ID` and
    :envvar:`DIGITALOCEAN_OAUTH_CLIENT_SECRET`.

    Args:
        client_id (str): Client ID for your application on Digital Ocean
        client_secret (str): Client secret for your Digital Ocean application
        scope (str, optional): comma-separated list of scopes for the OAuth
            token.
        redirect_url (str): the URL to redirect to after the authentication
            dance is complete
        redirect_to (str): if ``redirect_url`` is not defined, the name of the
            view to redirect to after the authentication dance is complete.
            The actual URL will be determined by :func:`flask.url_for`
        login_url (str, optional): the URL path for the ``login`` view.
            Defaults to ``/digitalocean``
        authorized_url (str, optional): the URL path for the ``authorized`` view.
            Defaults to ``/digitalocean/authorized``.
        session_class (class, optional): The class to use for creating a
            Requests session. Defaults to
            :class:`~flask_dance.consumer.requests.OAuth2Session`.
        storage: A token storage class, or an instance of a token storage
                class, to use for this blueprint. Defaults to
                :class:`~flask_dance.consumer.storage.session.SessionStorage`.
        rule_kwargs (dict, optional): Additional arguments that should be passed when adding
            the login and authorized routes. Defaults to ``None``.

    :rtype: :class:`~flask_dance.consumer.OAuth2ConsumerBlueprint`
    :returns: A :doc:`blueprint <flask:blueprints>` to attach to your Flask app.
    Údigitaloceanú,ú Nz'https://cloud.digitalocean.com/v1/oauthz1https://cloud.digitalocean.com/v1/oauth/authorizez-https://cloud.digitalocean.com/v1/oauth/token)Ú	client_idÚclient_secretr   Úbase_urlÚauthorization_urlÚ	token_urlr   r   r	   r
   r   r   r   ÚDIGITALOCEAN_OAUTH_CLIENT_IDr   Ú DIGITALOCEAN_OAUTH_CLIENT_SECRETr   c                  ó0   •— ‰ j                   t        _        y ©N)Úsessionr   Úflask_dance_digitalocean)Údigitalocean_bps   €úc/home/azureuser/techstart-app/venv/lib/python3.12/site-packages/flask_dance/contrib/digitalocean.pyÚset_applocal_sessionz9make_digitalocean_blueprint.<locals>.set_applocal_sessionL   s   ø€ à%4×%<Ñ%<ŒÕ"ó    )r   Ú__name__ÚreplaceÚfrom_configÚbefore_app_request)r   r   r   r   r   r	   r
   r   r   r   r   r   s              @r   Úmake_digitalocean_blueprintr%   	   s   ø€ ô^ .ØÜØØ#Ù).ˆem‰m˜C Ô%°DØ:ØMØAØ!ØØØ%Ø#ØØô€Oð" 0N€O×Ñ Ñ,Ø3U€O×Ñ Ñ0à×'Ñ'ó=ó (ð=ð Ðr    c                  ó"   — t         j                  S r   )r   r   © r    r   ú<lambda>r(   S   s   € ¤!×"<Ñ"<€ r    )NN)	Úflaskr   Úwerkzeug.localr   Úflask_dance.consumerr   Ú__maintainer__r%   r   r'   r    r   ú<module>r-      sO   ðÝ Ý %å 8à<€ð ØðGð ØØØØØØØôGñT Ñ<Ó=r    