nips/107.md

88 lines
4.1 KiB
Markdown
Raw Normal View History

2023-10-10 21:27:08 +00:00
NIP-107
======
Nostr Internet of Things
-----------------------------------
2023-10-24 12:43:50 +00:00
`draft` `optional` `author:benarc` `author:blackcoffeebtc` `author:motorina0`
2023-10-10 21:27:08 +00:00
2023-10-19 09:55:59 +00:00
## Rationale
2023-10-10 21:27:08 +00:00
2023-10-24 12:33:47 +00:00
The terms/conditions of IoT software/hardware is horrible. A user should be able to message a light or heating system and ask it to turn on/off. Nostr gives the simple, permissionless development environment IoT needs.
2023-10-10 21:27:08 +00:00
## Terms
2023-10-19 10:00:51 +00:00
- `user` - user operating IoT devices with NOSTR key-pair and a client made specifically for IoT
2023-10-10 21:27:08 +00:00
- `device` - device to operate over Nostr with NOSTR key-pair, using a microcontroller client like <a href="https://github.com/lnbits/arduino-nostr">nostr-arduino</a>
## Nostr IoT Clients
### User
Where the `user` registers 'device'(s) and its keys, then updates the `device`(s).
### Device
2023-10-19 10:27:29 +00:00
The `device` uses a client like <a href="https://github.com/lnbits/arduino-nostr">nostr-arduino</a> to receive commands from the `user` or another `device`.
2023-10-19 09:53:43 +00:00
The `device` can also push data such as sensor readings and updates.
2023-10-10 21:27:08 +00:00
2023-10-19 10:27:29 +00:00
## Events
2023-10-10 21:27:08 +00:00
2023-10-24 12:33:47 +00:00
A `device` can publish any of the events described in [NIP-91 Event Kinds](https://github.com/nostr-protocol/nips/blob/iot/91.md#event-kinds).
A `user` can publish these event kinds:
| Kind | | Description | NIP |
|--------|----------|-------------------------------|-----------------------------------------------------------------------------------------|
| `8000` | `intent` | Trigger an action on a device | [NIP-91 Event Kinds](https://github.com/nostr-protocol/nips/blob/iot/91.md#event-kinds) |
2023-10-24 12:43:50 +00:00
The content of events can be transmitted in clear text (for public data) or as [NIP-59 Gift Wrap](https://github.com/staab/nips/blob/NIP-59/59.md).
2023-10-10 21:27:08 +00:00
2023-10-24 12:54:21 +00:00
## Intent Events
2023-10-24 12:47:17 +00:00
Intent Events represent different actions that can be performed on a device. These actions can be triggered by a `user` or by another `device`. The content of the event is a `JSON` which `MUST` have a `type` field indicating the what the JSON represents. Possible types:
2023-10-10 21:27:08 +00:00
2023-10-19 10:27:29 +00:00
| Message Type | Sent By | Description |
|--------------|----------------|------------------|
| 0 | User | Configure Device |
2023-10-24 12:54:21 +00:00
### Configure Device
2023-10-24 12:47:17 +00:00
This message is sent by a `user` to a `device`. The `device` saves the config locally and then uses it.
2023-10-10 21:27:08 +00:00
**Event Content**:
```json
{
2023-10-24 06:29:59 +00:00
"type": 0,
"name": <String (optional), set a name for the device>,
2023-10-10 21:27:08 +00:00
"description": <String (optional), device description>,
"categories":[ <String (optional), device category, such as 'boiler'>],
2023-10-24 13:28:19 +00:00
"admin_pubkeys": [ [<String (optional), admin user public-key>]],
"publish_to_pubkeys":[ [<String (optional), user public-key>]],
2023-10-24 13:21:46 +00:00
"intents_from_pubkeys":[ [<String (optional), user public-key>]],
2023-10-24 13:28:19 +00:00
"publish_on_change": <Boolean (optional, default `true`), publish event each time a sensor value changes>,
"publish_interval": <Integer (optional), publish the sensor value at regular intervals (regardless the value changes or not). The value is in `millisecods`.>
2023-10-10 21:27:08 +00:00
}
```
2023-10-24 12:54:21 +00:00
| Field | Description |
|---|---|
2023-10-24 13:21:46 +00:00
| `admin_pubkeys` | List of public keys that are allowed to configure this device.<br>A fresh/blank device will not have this value, so the first received `"type: 0"` should set it.<br/> The `admin_pubkeys` implicitly have the `actions_from_pubkeys` permissions. |
2023-10-24 13:28:19 +00:00
| `publish_to_pubkeys` | List of public keys to which events are published. |
2023-10-24 13:21:46 +00:00
| `actions_from_pubkeys` | List of public keys that are allowed to trigger an action on this device.<br/> The `admin_pubkeys` implicitly have the `actions_from_pubkeys` permissions. |
2023-10-10 21:27:08 +00:00
### Event: Update a `device`
**Event Content**:
```json
{
2023-10-19 09:54:38 +00:00
"id": <String, UUID generated by the user. Sequential IDs (`0`, `1`, `2`...) are discouraged>,
2023-10-10 21:27:08 +00:00
"device_id": <String, UUID of the stall to which this device belong to>,
"settings":[ [<String (optional), user public-key>]]
}
```
Note:
- `settings`:
2023-10-19 10:00:51 +00:00
- Standard `settings` include:
2023-10-10 21:27:08 +00:00
- eg: `[["on", <bool>], ["range", <int, 0-1000>], ["timer_on", <int unix timestamp>], ["timer_off", <int unix timestamp>]]`