- Python 3.7+
You can install the package directly from Github (you may need to run pip
with
sudo
):
pip install arduino-iot-client
The client requires a valid access token, you can use requests-oauthlib
to get
one, to install the library do:
pip install requests-oauthlib
After installing the library you can use this Python code to get a token:
from oauthlib.oauth2 import BackendApplicationClient
from requests_oauthlib import OAuth2Session
oauth_client = BackendApplicationClient(client_id=YOUR_CLIENT_ID)
token_url = "https://api2.arduino.cc/iot/v1/clients/token"
oauth = OAuth2Session(client=oauth_client)
token = oauth.fetch_token(
token_url=token_url,
client_id=YOUR_CLIENT_ID,
client_secret=YOUR_CLIENT_SECRET,
include_client_id=True,
audience="https://api2.arduino.cc/iot"
)
print(token.get("access_token"))
In case of organization access, you can add organization identifier specifying required header:
org_id="<org-id>"
token = oauth.fetch_token(
token_url=token_url,
client_id=YOUR_CLIENT_ID,
client_secret=YOUR_CLIENT_SECRET,
include_client_id=True,
audience="https://api2.arduino.cc/iot",
headers={"X-Organization":org_id}
)
print(token.get("access_token"))
Once you get a token, you can create an instance of the iot-api client:
import iot_api_client as iot
from iot_api_client.rest import ApiException
from iot_api_client.configuration import Configuration
import iot_api_client.apis.tags.devices_v2_api as deviceApi
# configure and instance the API client
client_config = Configuration(host="https://api2.arduino.cc/iot")
client_config.access_token = YOUR_ACCESS_TOKEN
client = iot.ApiClient(client_config)
# as an example, interact with the devices API
devices_api = deviceApi.DevicesV2Api(client)
try:
devices = devices_api.devices_v2_list()
if devices.response.status==200:
for device in devices.body:
print("Device ("+device["id"]+"): "+device["name"])
except ApiException as e:
print("Got an exception: {}".format(e))
In case of organization access, you can specify organization identifier in this way:
client = iot.ApiClient(client_config,header_name="X-Organization",header_value=org_id)
For a working example, see the example folder in this repo.
You can generate Arduino IoT Cloud Client Credentials in API Keys
section in the IoT Cloud: