Onboard API SDK
Project description
Onboard Portal Python SDK
This package provides Python bindings to Onboard Data's building data API. For more details, you can navigate to the API & Docs Page to read the Getting Started Documentation section in the portal. You'll have access to this page once you've signed up for our sandbox or you've been given access to your organization's account.
API Access
You'll need an API key or existing account in order to use this client. If you don't have one and would like to start prototyping against an example building please request a key here.
Once you have a key, data access is explicitly granted by attaching one or more 'scopes' to the key. Our endpoints are grouped by scope on the swagger documentation viewer.
Client usage example
First, you'll need to install the client (requires Python >= 3.7
)
$ pip install onboard.client
Now you can use the client to fetch timeseries data for sensors by building or based on type. This example requires an API key with the scopes general
and buildings:read
.
from onboard.client import OnboardClient
client = OnboardClient(api_key='ob-p-your-key-here')
client.whoami() # verify access & connectivity
client.get_all_point_types() # retrieve available types of sensors
# retrieve the past 6 hours of data for sensors measuring CO2 ppm
from datetime import datetime, timezone, timedelta
from onboard.client.models import PointSelector, TimeseriesQuery, PointData
from typing import List
query = PointSelector()
query.point_types = ['Zone Carbon Dioxide']
query.buildings = ['Office Building'] # one of the example buildings available in the sandbox
selection = client.select_points(query)
end = datetime.utcnow().replace(tzinfo=timezone.utc)
start = end - timedelta(hours=6)
timeseries_query = TimeseriesQuery(point_ids=selection['points'], start=start, end=end) # Or `TimeseriesQuery(selector=query, ...)`
sensor_metadata = client.get_points_by_ids(selection['points'])
sensor_data: List[PointData] = list(client.stream_point_timeseries(timeseries_query))
License
Copyright 2018-2021 Onboard Data Inc
Licensed under the Apache License, Version 2.0 (the "License"); you may not use this file except in compliance with the License. You may obtain a copy of the License at
http://www.apache.org/licenses/LICENSE-2.0
Unless required by applicable law or agreed to in writing, software distributed under the License is distributed on an "AS IS" BASIS, WITHOUT WARRANTIES OR CONDITIONS OF ANY KIND, either express or implied. See the License for the specific language governing permissions and limitations under the License.
Project details
Release history Release notifications | RSS feed
Download files
Download the file for your platform. If you're not sure which to choose, learn more about installing packages.
Source Distribution
Built Distribution
Hashes for onboard.client-1.8.1-py3-none-any.whl
Algorithm | Hash digest | |
---|---|---|
SHA256 | d18c15da11fac879121cfc58d1835d9e2cbeeb7d87a2a14c51cb0186514bf634 |
|
MD5 | 7a44a4d123481b1b30a772e3fcd710fe |
|
BLAKE2b-256 | 350fdf85225e65e6c204222c4b3939094978dc61803e4cd824171f799c6d2a7a |