Diode API Docs
#Enabling the Diode API
This API runs on every Diode app instance, and is disabled by default.
The API is device-wide. To enable the API on your device:
1. Open the Diode app (version 1.10.7 or later)
2. Navigate to any Zone and any Channel, it doesn’t matter which Channel
3. Send the following chat command to the Channel: /sysconfig remote-api enable
.
Messages that start with “/” are chat commands. Chat commands and the automated responses to them don’t send any data to the channel members, only the sender can see them, and they disappear after leaving the page.
4. Next, a token will need generated. To generate a token, send this chat command: /sysconfig remote-api generate-token
5. To view the newly generated token, use this command: /sysconfig remote-api view-token
WARNING: When your API is enabled, anyone with this token can perform API functions on your behalf. Keep it a secret.
6. The API is now enabled device-wide and a token has been obtained. The device is now ready to accept API requests by whoever has the token. Here are some other helpful commands:
- A) Regenerate Token (Note: This will replace the previous token):
/sysconfig remote-api generate-token
- B) Disable API:
/sysconfig remote-api disable
- C) API Status:
/sysconfig remote-api status
- D) API Version:
/sysconfig remote-api version
#Calling the API (HTTP)
A valid request is an HTTP POST request containing the following two headers and a JSON-RPC 2.0 payload.
There are two ways to reach the API endpoint:
- Via the Diode Web2 Gateway (most convenient, use anywhere):
https://<device_address>.diode.link/api/json_rpc
- Direct via Web3 (most secure, requires web3 pipe between caller and device where the API is enabled):
http://<device_address>.diode/api/json_rpc
The “device_address” can be found on the “About” page in Diode Drive, or by sending the /info
chat command to any Channel.
#Headers:
Content-Type: application/json
Authorization: Bearer <bearer_token>
#JSON-RPC 2.0 Payload Format:
{"jsonrpc":"2.0","method":"<method>","params":["<param1>", "<param2>", ..., <paramN>], "id":N}
#Curl Example:
curl -X POST -H "Content-Type: application/json" -H "Authorization: Bearer <bearer_token>" -d '{"jsonrpc":"2.0","method":"<method>","params":["<param1>", "<param2>", ..., <paramN>], "id":N}' https://<device_address>.diode.link/api/json_rpc
You can use the following chat commands to get curl templates for the “send_message” method. Please note that the second command will auto-populate the “zone_id” and “channel_id” for the specific channel the command is sent to; the “device_address” will also be auto-populated./sysconfig remote-api template
/sysconfig remote-api example
#Calling the API (WebSocket)
To use advanced methods such as “subscribe_channel”, the WebSocket API can be used. Once connected, the WebSocket payload must contain a valid JSON-RPC 2.0 method call. Authentication is done via the “authenticate” method when calling the WebSocket API . Once authenticated successfully, any method can be called.
Like the HTTP API, there are two ways to reach the WebSockets API endpoint:
- Via the Diode Web2 Gateway (most convenient, use anywhere):
ws://<device_address>.diode.link/api/json_rpc/ws
- Direct via Web3 (most secure, requires web3 pipe between caller and device where the API is enabled):
ws://<device_address>.diode/api/json_rpc/ws
Here is an example of a python script calling the API via WebSockets.
#API Methods
Some of these methods required “zone_id” and “channel_id” parameters. To obtain these values, navigate to the target Channel in the Diode App and send the /info
chat command to that Channel. The “zone_id” and “channel_id” will be printed out, amongst other helpful information. Passing a bns name (such as a Diode username) as the “channel_id” is also valid.
#“ping”
#Call
{"jsonrpc":"2.0","method":"ping","id":1}
#Success Response
{"jsonrpc":"2.0","result":"The RPC endpoint has been successfully contacted.","id":1}
#“send_message”
#Call
{"jsonrpc":"2.0","method":"send_message","params":["<zone_id>", "<channel_id>", "<message_text>"], "id":1}
#Success Response
{"jsonrpc":"2.0","result":"Message sent","id":1}
#“subscribe_channel” (WebSocket only)
#Call
{"jsonrpc":"2.0","method":"subscribe_channel","params":["<zone_id>", "<channel_id>"], "id":1}
#Success Response
{"jsonrpc":"2.0","result":"Subscribed","id":1}
#Incoming Message(s)
{
"jsonrpc":"2.0",
"result":
{
"messages":
[
{
"attributes": {
"mentions": <peer_address>,
"reply": <unix_timestamp>,
"t": <hex>
},
"creation_time": <unix_timestamp>,
"edited_at": <unix_timestamp>,
"group_id": <channel_id>,
"message": <string>,
"reply_to": <message_object>,
"sender": {
"address": <sender_hex_address>,
"domain": <sender_bns_name>,
"nickname": <sender_nickname>
}
},
...
]
},
"id":1
}
#“subscribe_all_channels_in_zone” (WebSocket only)
#Call
{"jsonrpc":"2.0","method":"subscribe_all_channels_in_zone","params":["<zone_id>"], "id":1}
#Success Response
{"jsonrpc":"2.0","result":"Subscribed","id":1}
#Incoming Message(s)
# Same format as the "subscribe_channel" function.
#“authenticate” (WebSocket only)
#Call
{"jsonrpc":"2.0","method":"authenticate","params":["<bearer_token>"], "id":1}
#Success Response
{"jsonrpc":"2.0","result":"Authentication successful","id":1}