Ecosyste.ms: Awesome
An open API service indexing awesome lists of open source software.
https://github.com/webex/integration-refresh
Used to programatically refresh an Integration's token.
https://github.com/webex/integration-refresh
Last synced: 5 days ago
JSON representation
Used to programatically refresh an Integration's token.
- Host: GitHub
- URL: https://github.com/webex/integration-refresh
- Owner: webex
- License: mit
- Created: 2020-06-22T17:50:40.000Z (over 4 years ago)
- Default Branch: master
- Last Pushed: 2020-06-23T19:12:10.000Z (over 4 years ago)
- Last Synced: 2024-12-17T02:03:04.946Z (17 days ago)
- Language: Python
- Size: 22.5 KB
- Stars: 2
- Watchers: 8
- Forks: 1
- Open Issues: 0
-
Metadata Files:
- Readme: README.md
- License: LICENSE
Awesome Lists containing this project
README
# Getting Started
First, you will need to create an app (create an integration) here:
https://developer.webex.com/my-apps1. For most of the fields, like name, icon and description enter any values.
a. For Redirect URI(s), enter: https://localhost:8000/oauth
(or the url where you intend to deploy this code. The app expects the url to end in ``/oauth``)b. For scopes, select only ``spark:all``
(or the scopes you intend to use for your integration)
If you do not select ``spark:all``, ``spark:people_read`` is required for this demo.c. Scroll to the bottom and click Add Integration.
# Running the Code
Requirements:
1. python 3.7.4 or higher
2. pip install tornado==4.5.2Environment Variables:
Please review the ``sample_environ_vars.sh`` file and **edit the values to include the integration client_id and secret from the Getting Started step.** If you used a different redirect_uri or scopes from the Getting Started step, then you'll need to edit those values here as well, or set them as environment variables via your preferred method. For example, you can run the following in a unix terminal to set the environment variables in that local terminal window:
``>>>username$ source sample_environ_vars.sh``
Running the App from the terminal:
``>>>username$ python app.py --debug``# About the App
Once the app is running...
1. Navigate to https://localhost:8000/oauth in your browser (your redirect_uri, which should end in oauth for this demo).
2. Sign into your integration with a valid Webex Teams account.
a. You will be redirected back to your local app server.
3. Wait. Your app will check for old tokens every ``EVENT_LOOP_SLEEP_SECONDS`` (default 3600 seconds, or 1 hour).
a. If the user's token is older than ``EVENT_LOOP_DAYS`` (default 1 day), app will attempt to refresh it.
b. You can increase the frequency for testing purposes, but please note:
Tokens refreshed more than once every 24 hours will often leave the value, including the expire time, unchanged.
This essentially means that a token can only be truly refreshed at most once daily.# Developer Info
1. In the token_helper.py file is a commented explanation about how to test the refresh right at app start.
2. This demo prints sensitive information like access tokens to the terminal. This is not advised for a real application.
3. This demo stores tokens in app memory, which is not helpful if the application is restarted. For this reason, a database would be recommended instead.