This sample code involves using a simple Flask webapp providing a front-end interface using the requests-oauthlib Python3 library to access the Airthings for Business API using the Authorization Grant OAuth2 flow.
Please note that this is a basic example created only to show how to access information from the Airthings API. Do not use this code in production without first implementing standard security within your web application.
This example is built to work with the Airthings for Business API.
To setup the example Flask webapp simply run the following from the command line:
git clone https://github.com/Airthings/python-flask-ext-api-example
cd python-flask-ext-api-example
pip install -r requirements.txt
The webapp can then be run by using:
python app.py
Please refer to the Getting Started guide for a more generalized overview of accessing the the Airthings API.
Before starting ensure you have your credentials:
- Airthings Client Id
- Airthings Client Secret
- Redirect URI All three can be found at https://accounts.airthings.com/clients when registering an API Client.
The AirthingsAccount
class within the AirthingsAccount.py
file can be used to begin the OAuth2 flow. The class can be initialised with by being supplied with the API credentials. Three steps must be followed to gain an access token:
Initialize the AirthingsAccount with your API credentials.
myAccount = AirthingsAccount(
client_id=AIRTHINGS_CLIENT_ID,
client_secret=AIRTHINGS_CLIENT_SECRET,
redirect_uri=APP_REDIRECT_URI
)
The getAuthorization
function returns an authorization URL that will provide a link provided by Airthings that will let you log into your account via username and password. Upon logging in you will then be redirected to the redirect URI that you provided.
myAccount.getAuthorization()
Ideally, the redirect URI will contain a code
that can be used to fetch access tokens. The getAccessToken
function can be provided with the redirected page URL you were sent to from the previous step to allow you to get your access token.
myAccount.getAccessToken(request.url)
Currently only GET
requests are supported, which are listed in the API documentation. The routes defined in the app.py
file detail how these requests can be made, while the index.html
can display basic JSON results.
There are a number of ways to supply API credentials to the AirthingsAccount
class. It is critical to never include client secrets within your web app directly. This can lead to a number of security risks that may compromise your account information.