Pharo Netatmo API implementation for Legrand Netatmo products.
Supported products :
You cannot access data directly from the devices : Netatmo not provide that for the moment. The only way to access the data and the devices is via Netatmo servers. You need to be connected to Internet to get datas from your devices.
The access require an OAuth2 authentication to get an access token. This token should be refresh in time with another authentication request. For more details about the security see the link to official Netatmo documentation at the bottom of this page.
OAuth2 authentication is working in this project using Zinc and can be used for desktop or web applications.
When your token is recover, use the api with it during the token validity time.
Metacello new
baseline: 'NetatmoAPI';
repository: 'github://labordep/PharoNetatmoAPI:main';
onConflictUseIncoming;
ignoreImage;
load.
Create an application access with your Netatmo connect account to get your client_id and client_secret datas. See the bottom section to use the OAuth2 authentication in this project.
For more details see the official guidelines.
This section describes how to authenticate and get an access token. This step is not mandatory if you get manually a token, for example directly by a Netamo account website or another providing library. When you get a token you can use the API, see next section to have some examples.
First, instanciate a new NetatmoAPIAuthentificator
with your client_id and client_secret datas. You need to specifiy the scope of your datas, for examples : thermostat temperature, humidity, etc. If your are not sure or if you need all use NetatmoScopeEnum allReadScopes
to get all can be read datas.
authenticator := NetatmoAPIAuthentificator
clientId: 'myClientId'
clientSecret: 'myClientSecret'
scopes: (NetatmoScopeEnum allReadScopes).
Now create a new session to request the authentication.
This method return a ZnOAuth2Session
which provide OAuth2 connexion process.
session := authenticator createOAuth2Session.
If this is the first try to get a token, the session is not live. Call the requestUserAuthentication
method to open your web browser and validate the authentication using the Netatmo online form.
session isLive ifFalse:[
authenticator requestUserAuthentication.
].
At this step your default web browser open the online Netatmo authentication form :
Check and accept if you are agree. A basic result page is display to confirm the good authentication, close this page when it appears :
Getting your token :
token := session liveAccessToken.
Instanciante NetatmoAPI
to have to request datas from the API. Use a token to setup the connection.
| api |
api := NetatmoAPI new.
api token: 'yourAccess|tokenHere'
Use "api" category methods to request datas.
Get all devices, return a list of NetatmoDevice
. The list can change depending session authorization.
| devices |
devices := api getDevices.
Get all device, return a list of NetatmoStation
devices.
| devices |
devices := api getStationDevices.
Get specific device from mac address (id), return a list of NetatmoStation
devices.
| devices |
devices := api getStationDevice:: '01:23:45:67:89:ab'.
Get all device, return a list of NetatmoHealthyHomeCoach
devices.
| devices |
devices := api getHealthyHomeCoachDevices.
Get specific device from mac address (id), return a list of NetatmoHealthyHomeCoach
devices.
| devices |
devices := api getHealthyHomeCoachDevice: '01:23:45:67:89:ab'.
Use the API to get measure from a device, return a list of NetatmoMeasure
measures.
Each NetatmoMeasure
contains data (for example 56
), type (for example 'humidity'
), unit (for example '%'
), data unit (for example Number
) and a DateTime
of the measure.
When requested a measure from the API use types:
to choose data type by passing a list of NetatmoMeasureType
.
Get one type of data from a device.
| measures |
measures := api getMeasures: (device id)
types: NetatmoMeasureType humidity.
Get multiples types of data from a device.
| measures |
measures := api getMeasures: (device id)
types: (OrderedCollection
with: NetatmoMeasureType temperature
with: NetatmoMeasureType humidity).
It is possible to request a date time interval of measure, with a scale for the sample. Example : get temperature each days at the current time in the last week.
| measures |
measures := api getMeasures: (device id)
types: NetatmoMeasureType temperature
scale: 1 day
dateTimeBegin: (DateAndTime now - 7 day)
dateTimeEnd: DateAndTime now.
The package NetatmoAPI-Examples
contains some API uses examples with basics user interfaces using Spec
and Roassal
.
A list of availables devices (with sub devices) :
A list of last 7 days Healthy Home Coach measures :
A Weather Station dashboard :
A Weather Station last 7 days indoor and outdoor humidity :
Etc.
Using Netatmo Connect APIs you will have access to very sensitive information. This is particularly true if your app accesses our Cameras (live stream or videos). Make sure you respect user's privacy and have a strong privacy policy.
Netatmo Connect APIs Terms of Use
This ressources are my reference to implement this API. There are two API product groups : Weather/Security/Energy and HomeCoach/Aircare.
General Netatmo documentation
More specific produtcs API :
Netatmo Aircare API Documentation
This project is a personnal work, I'm not affilied with Legrand.
This project is licensed under the MIT License - see the LICENSE file for details.