Metadata-Version: 2.1
Name: dash-okta-oauth2
Version: 0.0.2
Summary: Dash Okta OAuth2
Home-page: https://github.com/nicohein/dash-okta-oauth2
Author: Nico Hein
Author-email: nico.hein@me.com
License: MIT
Platform: UNKNOWN
Classifier: License :: OSI Approved :: MIT License
Classifier: Operating System :: OS Independent
Classifier: Programming Language :: Python :: 3
Requires-Python: >=3.7
Description-Content-Type: text/markdown
Requires-Dist: dash (>=1.9.1)
Requires-Dist: dash-core-components (>=1.8.1)
Requires-Dist: dash-html-components (>=1.0.2)
Requires-Dist: Flask (>=1.1.1)
Requires-Dist: Flask-Dance (>=3.0.0)
Requires-Dist: blinker (>=1.4)

# Dash Okta OAuth2

Dash Okta Auth is a simple library using Okta OAuth2 to authenticate and
view a [Dash](https://dash.plot.ly/) app.

This Library uses [Flask Dance](https://github.com/singingwolfboy/flask-dance)
and a modified version of Plotly's own [dash auth](https://github.com/plotly/dash-auth)
for authentication.

This Library is heavily inspired by [dash-google-oauth](https://github.com/lchapo/dash-google-auth) 
created by Lucas Chapin and forked from [dash-okta-auth](https://github.com/fspijkerman/dash-okta-auth) 
created by Frank Spijkerman.

I decided to deploy to pip after I received no response to this 
[issue](https://github.com/fspijkerman/dash-okta-auth/issues/2).

## Basic Use

Authentication can be added to your Dash application using the `OktaOAuth`
class, i.e.

```python
from dash import Dash
from flask import Flask
from dash_okta_oauth2 import OktaOAuth

server = Flask(__name__)
server.config.update({
  'OKTA_OAUTH_CLIENT_ID': ...,
  'OKTA_OAUTH_CLIENT_SECRET': ...,
  'OKTA_BASE_URL': ...
})

app = Dash(__name__, server=server, url_base_pathname='/')


additional_scopes = [...]
auth = OktaOAuth(app, additional_scopes)

# your Dash app here :)
...
```

## Example
Steps to try this out yourself:

1. Install the `dash-okta-auth` library using `pip`:

    ```bash
    $ pip install dash-okta-oauth2
    ```

2. Follow the [Flask Dance Guide](https://flask-dance.readthedocs.io/en/latest/quickstart.html)
   to create an app on the okta admin console

3. Make a copy of [app.py](https://github.com/nicohein/dash-okta-oauth2/blob/master/app.pyy)
   and set the variables (or set the corresponding environment variables):
    ```python
    server.config["OKTA_OAUTH_CLIENT_ID"] = ...
    server.config["OKTA_OAUTH_CLIENT_SECRET"] = ...
    ```
   with values from the Okta OAuth 2 application you should have set up earlier.
   If you've set these up properly, you can find them at
   `Applications > yourapp > General`
   under the section **Client Credentials**.

4. Run `python app.py` and open [localhost](http://localhost:8050/) in a
   browser window to try it out! If the app loads automatically without
   prompting a Okta login, that means you're already authenticated -- try
   using an inokta window in this case if you want to see the login
   experience for a new user.

