You can not select more than 25 topics
Topics must start with a letter or number, can include dashes ('-') and can be up to 35 characters long.
193 lines
5.8 KiB
193 lines
5.8 KiB
---
|
|
title: Custom API
|
|
description: Custom Widget Configuration from the API
|
|
---
|
|
|
|
This widget can show information from custom self-hosted or third party API.
|
|
|
|
Fields need to be defined in the `mappings` section YAML object to correlate with the value in the APIs JSON object. Final field definition needs to be the key with the desired value information.
|
|
|
|
```yaml
|
|
widget:
|
|
type: customapi
|
|
url: http://custom.api.host.or.ip:port/path/to/exact/api/endpoint
|
|
refreshInterval: 10000 # optional - in milliseconds, defaults to 10s
|
|
username: username # auth - optional
|
|
password: password # auth - optional
|
|
method: GET # optional, e.g. POST
|
|
headers: # optional, must be object, see below
|
|
requestBody: # optional, can be string or object, see below
|
|
display: # optional, default to block, see below
|
|
mappings:
|
|
- field: key # needs to be YAML string or object
|
|
label: Field 1
|
|
format: text # optional - defaults to text
|
|
- field: # needs to be YAML string or object
|
|
path:
|
|
to: key2
|
|
format: number # optional - defaults to text
|
|
label: Field 2
|
|
- field: # needs to be YAML string or object
|
|
path:
|
|
to:
|
|
another: key3
|
|
label: Field 3
|
|
format: percent # optional - defaults to text
|
|
- field: key # needs to be YAML string or object
|
|
label: Field 4
|
|
format: date # optional - defaults to text
|
|
locale: nl # optional
|
|
dateStyle: long # optional - defaults to "long". Allowed values: `["full", "long", "medium", "short"]`.
|
|
timeStyle: medium # optional - Allowed values: `["full", "long", "medium", "short"]`.
|
|
- field: key # needs to be YAML string or object
|
|
label: Field 5
|
|
format: relativeDate # optional - defaults to text
|
|
locale: nl # optional
|
|
style: short # optional - defaults to "long". Allowed values: `["long", "short", "narrow"]`.
|
|
numeric: auto # optional - defaults to "always". Allowed values `["always", "auto"]`.
|
|
- field: key
|
|
label: Field 6
|
|
format: text
|
|
additionalField: # optional
|
|
field:
|
|
hourly:
|
|
time: other key
|
|
color: theme # optional - defaults to "". Allowed values: `["theme", "adaptive", "black", "white"]`.
|
|
format: date # optional
|
|
- field: key
|
|
label: Number of things in array
|
|
format: size
|
|
# This (no field) will take the root of the API response, e.g. when APIs return an array:
|
|
- label: Number of items
|
|
format: size
|
|
```
|
|
|
|
Supported formats for the values are `text`, `number`, `float`, `percent`, `duration`, `bytes`, `bitrate`, `size`, `date` and `relativeDate`.
|
|
|
|
The `dateStyle` and `timeStyle` options of the `date` format are passed directly to [Intl.DateTimeFormat](https://developer.mozilla.org/en-US/docs/Web/JavaScript/Reference/Global_Objects/Intl/DateTimeFormat/DateTimeFormat) and the `style` and `numeric` options of `relativeDate` are passed to [Intl.RelativeTimeFormat](https://developer.mozilla.org/en-US/docs/Web/JavaScript/Reference/Global_Objects/Intl/RelativeTimeFormat/RelativeTimeFormat).
|
|
|
|
The `duration` format expects the duration to be specified in seconds. The `scale` transformation tool can be used if a conversion is required.
|
|
|
|
The `size` format will return the length of the array or string, or the number of keys in an object. This is then formatted as `number`.
|
|
|
|
## Example
|
|
|
|
For the following JSON object from the API:
|
|
|
|
```json
|
|
{
|
|
"id": 1,
|
|
"name": "Rick Sanchez",
|
|
"status": "Alive",
|
|
"species": "Human",
|
|
"gender": "Male",
|
|
"origin": {
|
|
"name": "Earth (C-137)"
|
|
},
|
|
"locations": [
|
|
{
|
|
"name": "Earth (C-137)"
|
|
},
|
|
{
|
|
"name": "Citadel of Ricks"
|
|
}
|
|
]
|
|
}
|
|
```
|
|
|
|
Define the `mappings` section as an array, for example:
|
|
|
|
```yaml
|
|
mappings:
|
|
- field: name # Rick Sanchez
|
|
label: Name
|
|
- field: status # Alive
|
|
label: Status
|
|
- field:
|
|
origin: name # Earth (C-137)
|
|
label: Origin
|
|
- field:
|
|
locations:
|
|
1: name # Citadel of Ricks
|
|
label: Location
|
|
```
|
|
|
|
## Data Transformation
|
|
|
|
You can manipulate data with the following tools `remap`, `scale`, `prefix` and `suffix`, for example:
|
|
|
|
```yaml
|
|
- field: key4
|
|
label: Field 4
|
|
format: text
|
|
remap:
|
|
- value: 0
|
|
to: None
|
|
- value: 1
|
|
to: Connected
|
|
- any: true # will map all other values
|
|
to: Unknown
|
|
- field: key5
|
|
label: Power
|
|
format: float
|
|
scale: 0.001 # can be number or string e.g. 1/16
|
|
suffix: "kW"
|
|
- field: key6
|
|
label: Price
|
|
format: float
|
|
prefix: "$"
|
|
```
|
|
|
|
## List View
|
|
|
|
You can change the default block view to a list view by setting the `display` option to `list`.
|
|
|
|
The list view can optionally display an additional field next to the primary field.
|
|
|
|
`additionalField`: Similar to `field`, but only used in list view. Displays additional information for the mapping object on the right.
|
|
|
|
`field`: Defined the same way as other custom api widget fields.
|
|
|
|
`color`: Allowed options: `"theme", "adaptive", "black", "white"`. The option `adaptive` will apply a color using the value of the `additionalField`, green for positive numbers, red for negative numbers.
|
|
|
|
```yaml
|
|
- field: key
|
|
label: Field
|
|
format: text
|
|
remap:
|
|
- value: 0
|
|
to: None
|
|
- value: 1
|
|
to: Connected
|
|
- any: true # will map all other values
|
|
to: Unknown
|
|
additionalField:
|
|
field:
|
|
hourly:
|
|
time: key
|
|
color: theme
|
|
format: date
|
|
```
|
|
|
|
## Custom Headers
|
|
|
|
Pass custom headers using the `headers` option, for example:
|
|
|
|
```yaml
|
|
headers:
|
|
X-API-Token: token
|
|
```
|
|
|
|
## Custom Request Body
|
|
|
|
Pass custom request body using the `requestBody` option in either a string or object format. Objects will automatically be converted to a JSON string.
|
|
|
|
```yaml
|
|
requestBody:
|
|
foo: bar
|
|
# or
|
|
requestBody: "{\"foo\":\"bar\"}"
|
|
```
|
|
|
|
Both formats result in `{"foo":"bar"}` being sent as the request body. Don't forget to set your `Content-Type` headers!
|