nips/107.md

73 lines
2.8 KiB
Markdown
Raw Normal View History

2023-10-10 21:27:08 +00:00
NIP-107
======
Nostr Internet of Things
-----------------------------------
`draft` `optional` `author:benarc` `author:blackcoffeebtc`
2023-10-19 09:55:59 +00:00
## Rationale
2023-10-10 21:27:08 +00:00
2023-10-19 10:00:51 +00:00
The terms/conditions of IoT software/hardware is horrible. A user should be able to message a light or heating and ask it to turn on/off. Nostr gives the simple, permissionless development environment IoT needs.
2023-10-10 21:27:08 +00:00
All communication happens over [NIP04](https://github.com/nostr-protocol/nips/blob/master/04.md).
## 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
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
## `User` OR `device` registering/updating a `user` OR `device`
2023-10-19 09:53:55 +00:00
A `device` or a `user` can publish these event kinds:
2023-10-10 21:27:08 +00:00
| Kind | | Description | NIP |
|---------|------------------|---------------------------------------------------------------------------------------------------------------|-----------------------------------------|
2023-10-19 10:07:54 +00:00
| `4 ` | `direct_message` | Communicate between two `devices` or between a `device` and a `user`.<br/>The messages must be a JSON following the structure defined In this NIP. | [NIP04](https://github.com/nostr-protocol/nips/blob/master/04.md) |
2023-10-10 21:27:08 +00:00
### Event: Register a `device`
**Event Content**:
```json
{
"id": <String, UUID generated by the user.Sequential IDs (`0`, `1`, `2`...) are discouraged>,
2023-10-19 09:54:07 +00:00
"device_id": <String, UUID of the device>,
2023-10-10 21:27:08 +00:00
"name": <String, device name>,
"description": <String (optional), device description>,
"categories":[ <String (optional), device category, such as 'boiler'>],
"users":[ [<String (optional), user public-key>]],
}
```
Note:
- `users`:
- A list that can restrict access to public-keys, `device`(s) also has keys and can be a `user`.
### 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>]]`