Skip to main content

The Sensor Object Library

Project description

All rights reserved.

Redistribution and use in source and binary forms, with or without
modification, are permitted provided that the following conditions are met:

* Redistributions of source code must retain the above copyright notice, this
list of conditions and the following disclaimer.

* Redistributions in binary form must reproduce the above copyright notice,
this list of conditions and the following disclaimer in the documentation
and/or other materials provided with the distribution.

* Neither the name of sol nor the names of its
contributors may be used to endorse or promote products derived from
this software without specific prior written permission.

THIS SOFTWARE IS PROVIDED BY THE COPYRIGHT HOLDERS AND CONTRIBUTORS "AS IS"
AND ANY EXPRESS OR IMPLIED WARRANTIES, INCLUDING, BUT NOT LIMITED TO, THE
IMPLIED WARRANTIES OF MERCHANTABILITY AND FITNESS FOR A PARTICULAR PURPOSE ARE
DISCLAIMED. IN NO EVENT SHALL THE COPYRIGHT HOLDER OR CONTRIBUTORS BE LIABLE
FOR ANY DIRECT, INDIRECT, INCIDENTAL, SPECIAL, EXEMPLARY, OR CONSEQUENTIAL
DAMAGES (INCLUDING, BUT NOT LIMITED TO, PROCUREMENT OF SUBSTITUTE GOODS OR
SERVICES; LOSS OF USE, DATA, OR PROFITS; OR BUSINESS INTERRUPTION) HOWEVER
CAUSED AND ON ANY THEORY OF LIABILITY, WHETHER IN CONTRACT, STRICT LIABILITY,
OR TORT (INCLUDING NEGLIGENCE OR OTHERWISE) ARISING IN ANY WAY OUT OF THE USE
OF THIS SOFTWARE, EVEN IF ADVISED OF THE POSSIBILITY OF SUCH DAMAGE.

Description: | Master branch | Develop branch |
| -------------- | ------------- |
| [![Build Status](https://travis-ci.org/realms-team/sol.svg?branch=master)](https://travis-ci.org/realms-team/sol) | [![Build Status](https://travis-ci.org/realms-team/sol.svg?branch=develop)](https://travis-ci.org/realms-team/sol) |
| [![Code Health](https://landscape.io/github/realms-team/sol/master/landscape.svg?style=flat)](https://landscape.io/github/realms-team/sol/master) | [![Code Health](https://landscape.io/github/realms-team/sol/develop/landscape.svg?style=flat)](https://landscape.io/github/realms-team/sol/develop) |

This repo contains a set of libraries to manipulate sensor Objects.

An sensor Object contains the following _conceptual_ fields:
* `M`: MAC address of the device creating the Object
* `T`: timestamp of when the Object was created
* `t`: type of Object, a number
* `L`: the length of the value
* `V`: Object value, a opaque string of bytes

We refer to this format as the MTtlv format. It is a generalization of the well-known "Type-Length-Value" (TLV) format.

# Installation
Download source:
`git clone https://github.com/realms-team/sol.git`

# Code documentation
http://realms-sol.readthedocs.io

# Registry

## Objects' "types" registry

See [registry](registry.md).

# Representations

The SOL Objects are manipulated in groups.
Each group of Objects can be represented in [binary](#binary-representation), [JSON](#json-representation) or [HTTP](#http-representation) format.

## Binary representation

This representation is used for:
* sending data in packets
* writing data to a file

Each group of Objects consists of the following fields:

```
| SOL header | Objects list |
```

Some rules:
* all multi-byte value are encoded "big endian" (a.k.a "network order")
* when saving Objects in a binary file, each Object MUST be framed using HDLC.

#### SOL Header

```
0 1 2 3 4 5 6 7
+-+-+-+-+-+-+-+-+
| V |T|M|S|Y| L |
+-+-+-+-+-+-+-+-+
```
* `V`: Version of the Object:
* Only value `b00` is defined in this document. Other values for the 2 first bits are reserved and may be defined in later revisions of this document.
* `T`: Type of MTtlv Object:
* `0`: single-MTtlv Object
* `1`: multi-MTtlv Object (MTNtlv) this implies the 1st byte next to timestamp is N: number of Objects
* `M`: MAC address encoding:
* `0`: no MAC address present
* `1`: 8-byte MAC address present
* `S`: timestamp encoding
* `0`: timestamp is a 4-byte Linux epoch in UTC (1-second granularity)
* `1`: timestamp is elided, and recovered from the timestamp field present in the SmartMesh IP header
* `Y`: type encoding
* `0`: 1-byte type field
* `1`: 2-byte type field
* `L`: length encoding
* `b00`: use well-known value. No length field present
* `b01`: 1-byte length field present
* `b10`: 2-byte length field present
* `b11`: elided. The length is recovered from the length of the packet or HDLC frame.

#### Object List

According to the header flags, the Object list structure can vary.

* If the T flag is `0` then the message will have the following structure:
```|| SOL Header || MT | tlv |```
* If the T flag is `1` then the message will have the following structure:
```|| SOL Header || MT | N | tlv | tlv | ... ```

#### Example transmission use cases

**Example 1**. transmitting a single 2-byte temperature sensor reading, taken in the past:

* `[1B]` SOL Header
* `V`=`00` (version 0)
* `T`=`0` (Type of MTtlv Object)
* `M`=`0` (no MAC address)
* `S`=`0` (epoch)
* `Y`=`0` (1-byte type)
* `L`=`b00` (well-known value, no length field)
* `[--]` MAC: _elided_
* `[4B]` Timestamp: `0x........`
* `[1B]` type=`b..` (temperature)
* `[--]` length: _elided_
* `[2B]` value: `0x....`

Total 8 bytes.

**Example 2**. transmitting a single 2-byte temperature sensor reading, taken just now:

* `[1B]` SOL Header
* `V`=`00` (version 0)
* `T`=`0` (Type of MTtlv Object)
* `M`=`0` (no MAC address)
* `S`=`1` (elided)
* `Y`=`0` (1-byte type)
* `L`=`b00` (well-known value, no length field)
* `[3B]` sensor reading 1
* `[--]` MAC: _elided_
* `[--]` Timestamp: _elided_
* `[1B]` type=`b..` (temperature)
* `[--]` length: _elided_
* `[2B]` value: `0x....`

Total: 4 bytes.


**Example 3**. Transmitting 3 sensor readings from 3 different sensors with well-known length, taken at the same time in the past:

* `[1B]` SOL Header
* `V`=`00` (version 0)
* `T`=`1` (Type of MTtlv Object)
* `M`=`0` (no MAC address)
* `S`=`0` (epoch)
* `Y`=`0` (1-byte type)
* `L`=`b00` (well-known value, no length field)
* `[--]` MAC: _elided_
* `[4B]` Timestamp: `0x........`
* `[1B]` Number of Objects = 3
* `[3B]` sensor reading 1
* `[--]` MAC: _elided_
* `[--]` Timestamp: _elided_
* `[1B]` type=`b..` (temperature)
* `[--]` length: _elided_
* `[2B]` value: `0x....`
* `[3B]` sensor reading 2
* `[--]` MAC: _elided_
* `[--]` Timestamp: _elided_
* `[1B]` type=`b..` (RH)
* `[--]` length: _elided_
* `[2B]` value: `0x....`
* `[3B]` sensor reading 3
* `[--]` MAC: _elided_
* `[--]` Timestamp: _elided_
* `[1B]` type=`b..` (solar)
* `[--]` length: _elided_
* `[2B]` value: `0x....`

Total: 15 bytes.


### Rules for saving to a binary file

The assumption is that a binary file is stored on some hard/flash drive with orders of magnitude more space than a packet. The driving design choice are hence made to allow:
* simple parsing
* recoverable file in case parts of it get corrupted.

The following rules hence apply when saving to a binary file:
* sensor Object chaining is NOT allowed (except on Neomote SD card level)
* each sensor Object MUST be framed using HDLC framing ([RFC1662](https://tools.ietf.org/html/rfc1662))
* the length field MUST be elided, and the `L` bit in the start header set to `b11`


## JSON representation

A [JSON](http://json.org/) representation is used:
* when the Objects are stored in a database
* when manipulating Objects

We use clean indentation for easier readability in these examples. An efficient implementation SHOULD represent the entire JSON string on a single line.

The following is the general format of a JSON representation of sensor Objects:

```
{
"mac": "00-17-0d-00-00-12-34-56",
"timestamp": 12345678890,
"type": 39,
"value": {
'temperature': 0x0a33,
},
}
```

* "mac"
* represented exactly like in the example above, lowercase hex bytes (exactly 2 characters per byte), separated by `-`.
* "timestamp"
* an integer representing the epoch
* "type"
* an integer, per the registry above
* "value"
* a dictionary of values


## HTTP representation

This representation is used for minimal communication overhead (when data transists).

```
{
"v": 0,
"o": [
ew0KICAgIm1hYyI6ICAg,
ICAgICIwMC0xNy0wZC0w,
...
1NiIsDQogICAidGltZXw,
]
}
```

* `v`: the version of the representation. Only version `0` is defined in this specification. Other values SHOULD NOT be used. Future revisions of this document MIGHT define further versions.
* `o`: an array of representations. Each representation is a string representing the binary representation of one or more sensor Objects.
* the string MUST be a [Base64](https://en.wikipedia.org/wiki/Base64) encoding of the binary representation of exactly one sensor Objects.


Keywords: wireless,sensor,network
Platform: UNKNOWN
Description-Content-Type: text/markdown

Project details


Download files

Download the file for your platform. If you're not sure which to choose, learn more about installing packages.

Source Distribution

sensorobjectlibrary-1.8.0.0.tar.gz (21.0 kB view details)

Uploaded Source

Built Distribution

sensorobjectlibrary-1.8.0.0-py2.py3-none-any.whl (20.9 kB view details)

Uploaded Python 2 Python 3

File details

Details for the file sensorobjectlibrary-1.8.0.0.tar.gz.

File metadata

  • Download URL: sensorobjectlibrary-1.8.0.0.tar.gz
  • Upload date:
  • Size: 21.0 kB
  • Tags: Source
  • Uploaded using Trusted Publishing? No
  • Uploaded via: twine/1.13.0 pkginfo/1.5.0.1 requests/2.21.0 setuptools/40.8.0 requests-toolbelt/0.9.1 tqdm/4.31.1 CPython/3.5.3

File hashes

Hashes for sensorobjectlibrary-1.8.0.0.tar.gz
Algorithm Hash digest
SHA256 c55332fa819e5def4b9abc0bff52eb53aa71a4d520fcfdc027f455be9efeb9fa
MD5 a150079394a5394ec37a1e16334b9436
BLAKE2b-256 d69dd069607a3ba75eb367665e8254674e0a724c52bd791aee21305c7aaca5d5

See more details on using hashes here.

File details

Details for the file sensorobjectlibrary-1.8.0.0-py2.py3-none-any.whl.

File metadata

  • Download URL: sensorobjectlibrary-1.8.0.0-py2.py3-none-any.whl
  • Upload date:
  • Size: 20.9 kB
  • Tags: Python 2, Python 3
  • Uploaded using Trusted Publishing? No
  • Uploaded via: twine/1.13.0 pkginfo/1.5.0.1 requests/2.21.0 setuptools/40.8.0 requests-toolbelt/0.9.1 tqdm/4.31.1 CPython/3.5.3

File hashes

Hashes for sensorobjectlibrary-1.8.0.0-py2.py3-none-any.whl
Algorithm Hash digest
SHA256 14a09990f41c26c89a5fbccb0b5be045494df0230c30cf4db85271397fe4b4bc
MD5 8d51172f5925d0ee3a1d7413812b2805
BLAKE2b-256 6c9e1f9b8eb01217f521aed7aef27e12bdd936653dd82573d1f517f865a092c7

See more details on using hashes here.

Supported by

AWS AWS Cloud computing and Security Sponsor Datadog Datadog Monitoring Fastly Fastly CDN Google Google Download Analytics Microsoft Microsoft PSF Sponsor Pingdom Pingdom Monitoring Sentry Sentry Error logging StatusPage StatusPage Status page