Skip to main content
Version: 0.14

EMData

The EMData component stores data from an energy meter. It uses EMData as RPC namespace and provides the methods:

EMData components are identified with emdata:<id> in objects containing multiple component payloads.

Methods:

EMdata.GetStatus

Properties:

PropertyTypeDescription

id

number

Id of the EMData component instance Required

Find more about the status response properties in status section

EMdata.GetRecords

Properties:

PropertyTypeDescription

id

number

Id of the EMData component instance Required

ts

number

UNIX timestamp of the first interval. Used for selecting next data chunk when response is too large to fit in one call. Default is 0. Optional

EMdata.GetData

Properties:

PropertyTypeDescription

id

number

Id of the EMData component instance Required

ts

number

UNIX timestamp of the first record. Any record with data having timestamp between ts and end_ts will be retrieved. Required

end_ts

number

UNIX timestamp of the last record to get (if available). If response is too big, it will be chunked. Default is to get all available records without limit. Optional

add_keys

boolean

If false will not print the keys array in the response. Default is true. Optional

info

Type of data structure returned is:

namespace EMData {

interface DataKey {
ts: number;
period: string;
values: number[][];
}

export interface GetDataResult {
keys?: string[];
data: DataKey[];
}
}

Usually EMData.data will be an array containing a single object. There will be situations when the records will be interrupted (power loss) and then the array will contain more than one item.

EMdata.DeleteAllData

Properties:

PropertyTypeDescription

id

number

Id of the EMData component instance Required

  • Deletes all the data stored on the device, nullifies the perpetual counters.

Status

The status of the EMData component contains information about the perpetual counters and possible errors.

Properties:

PropertyTypeDescription

id

number

Id of the EMData component instance

a_total_act_energy

number

Total active energy on phase A, Wh

a_total_act_ret_energy

number

Total active returned energy on phase A, Wh

b_total_act_energy

number

Total active energy on phase B, Wh

b_total_act_ret_energy

number

Total active returned energy on phase B, Wh

c_total_act_energy

number

Total active energy on phase C, Wh

c_total_act_ret_energy

number

Total active returned energy on phase C, Wh

total_act

number

Total active energy on all phases, Wh

total_act_ret

number

Total active returned energy on all phases, Wh

errors

array of type string

Error condition occurred. May contain database_error, (shown if the error is present).

Notifications

Data

This notification is triggered whenever data is saved to device flash. Format of the data is the same as EMData.GetData response. See the example below.

  • method: "NotifyEvent"
  • params:
    • ts: number, UNIX timestamp
    • event: "data"
    • component: id of the EMData component
    • data: array of objects:
      • ts: UNIX timestamp
      • period: Period of aggregated data
      • values: array of type number, data values corresponding to keys array of GetData method

StatusChange

A StatusChange event of EMData is emitted when perpetual total active energy counters are saved to flash.

Modbus registers

AddressTypeDescription
31160uint32Timestamp of the last update
31162floatTotal active energy accumulated for all phases - perpetual count, Wh
31164floatTotal active returned energy accumulated for all phases - perpetual count, Wh
311664 registers reserved
31170floatPhase A total active energy, Wh
31172floatPhase A fundamental active energy, Wh
31174floatPhase A total active returned energy, Wh
31176floatPhase A fundamental active returned energy, Wh
31178floatPhase A lagging reactive energy, VARh
31180floatPhase A leading reactive energy, VARh
31182floatPhase A total active energy - perpetual count, Wh
31184floatPhase A total active returned energy - perpetual count, Wh
311864 registers reserved
31190floatPhase B total active energy, Wh
31192floatPhase B fundamental active energy, Wh
31194floatPhase B total active returned energy, Wh
31196floatPhase B fundamental active returned energy, Wh
31198floatPhase B lagging reactive energy, VARh
31200floatPhase B leading reactive energy, VARh
31202floatPhase B total active energy - perpetual count, Wh
31204floatPhase B total active returned energy - perpetual count, Wh
312064 registers reserved
31210floatPhase C total active energy, Wh
31212floatPhase C fundamental active energy, Wh
31214floatPhase C total active returned energy, Wh
31216floatPhase C fundamental active returned energy, Wh
31218floatPhase C lagging reactive energy, VARh
31220floatPhase C leading reactive energy, VARh
31222floatPhase C total active energy - perpetual count, Wh
31224floatPhase C total active returned energy - perpetual count, Wh
312264 registers reserved

If there is a second EMData component on the device, its corresponding registers addresses are calculated by adding 70 to the address in the table above.

CSV file download

Alternatively to the RPC method GetData, the same data can be downloaded in CSV file by calling HTTP url:

http://<device ip>/emdata/<id>/data.csv

Optional HTTP parameters ts, end_ts and add_keys may be used the same way as in EMData.GetData. See the example below.

Examples

EMData.GetStatus example

http://192.168.33.1/rpc/EMData.GetStatus?id=0

Response

{
"id": 0,
"a_total_act_energy": 0,
"a_total_act_ret_energy": 0,
"b_total_act_energy": 0,
"b_total_act_ret_energy": 0,
"c_total_act_energy": 0,
"c_total_act_ret_energy": 0,
"total_act": 0,
"total_act_ret": 0
}

EMData.GetRecords example

http://192.168.33.1/rpc/EMData.GetRecords?id=0&ts=0

Response

{
"data_blocks": [
{
"ts": 1657739460,
"period": 60,
"records": 1
},
{
"ts": 180,
"period": 60,
"records": 1
},
{
"ts": 1657739580,
"period": 60,
"records": 2
}
]
}

EMData.GetData example

http://192.168.33.1/rpc/EMData.GetData?id=0&ts=1656356400&minutes=5

Response

{
"keys": [
"a_total_act_energy",
"a_fund_act_energy",
"a_total_act_ret_energy",
"a_fund_act_ret_energy",
"a_lag_react_energy",
"a_lead_react_energy",
"a_max_act_power",
"a_min_act_power",
"a_max_aprt_power",
"a_min_aprt_power",
"a_max_voltage",
"a_min_voltage",
"a_avg_voltage",
"a_max_current",
"a_min_current",
"a_avg_current",
"b_total_act_energy",
"b_fund_act_energy",
"b_total_act_ret_energy",
"b_fund_act_ret_energy",
"b_lag_react_energy",
"b_lead_react_energy",
"b_max_act_power",
"b_min_act_power",
"b_max_aprt_power",
"b_min_aprt_power",
"b_max_voltage",
"b_min_voltage",
"b_avg_voltage",
"b_max_current",
"b_min_current",
"b_avg_current",
"c_total_act_energy",
"c_fund_act_energy",
"c_total_act_ret_energy",
"c_fund_act_ret_energy",
"c_lag_react_energy",
"c_lead_react_energy",
"c_max_act_power",
"c_min_act_power",
"c_max_aprt_power",
"c_min_aprt_power",
"c_max_voltage",
"c_min_voltage",
"c_avg_voltage",
"c_max_current",
"c_min_current",
"c_avg_current",
"n_max_current",
"n_min_current",
"n_avg_current"
],
"data": [
{
"ts": 0,
"period": 60,
"values": [
[
0,
0,
0,
0,
0,
0,
0,
0,
0,
0,
0,
0,
0,
0,
0,
0,
0,
0,
0,
0,
0,
0,
0,
0,
0,
0,
0,
0,
0,
0,
0,
0,
0,
0,
0,
0,
0,
0,
0,
0,
0,
0,
0,
0,
0,
0,
0,
0,
0,
0,
0
],
[
0,
0,
0,
0,
0,
0,
0,
0,
0,
0,
0,
0,
0,
0,
0,
0,
0,
0,
0,
0,
0,
0,
0,
0,
0,
0,
0,
0,
0,
0,
0,
0,
0,
0,
0,
0,
0,
0,
0,
0,
0,
0,
0,
0,
0,
0,
0,
0,
0,
0,
0
]
]
}
],
"next_record_ts": 1656356520
}
info

Data units are: Wh, VAh, VARh, W, V, A; For n_isum_mismatch: 0/1

EMData.DeleteAllData example

http://192.168.33.1/rpc/EMData.DeleteAllData?id=0

Response

null

Notifications example

  • When data is saved to the database in device flash memory:

Example:

Notify that new data is saved.
{
"src": "shellypro3em-f008d1d8b8b8",
"dst": "user_1",
"method": "NotifyEvent",
"params": {
"ts": 1631266595.43,
"events": [
{
"component":"emdata:0",
"id":0,
"event":"data",
"ts":1631266595.43,
"data":[
{
"ts":0,
"period":60,
"values":[
[0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0]
]
}
],
}
]
}
}

CSV file download example

Example 1:

Using curl GET to download CSV data with header row.
curl -OJ http://192.168.33.1/emdata/0/data.csv?add_keys=true

Example 2:

Using curl POST to download CSV data from 2022-01-01 00:00:00 to 2023-01-01 00:00:00 UTC.
curl -OJ -X POST -d "add_keys=true&ts=1640995200&end_ts=1672531200" http://192.168.33.1/emdata/0/data.csv