Skip to content
New issue

Have a question about this project? Sign up for a free GitHub account to open an issue and contact its maintainers and the community.

By clicking “Sign up for GitHub”, you agree to our terms of service and privacy statement. We’ll occasionally send you account related emails.

Already on GitHub? Sign in to your account

Extend normalized payload #800

Merged
merged 36 commits into from
Sep 17, 2024
Merged
Show file tree
Hide file tree
Changes from 30 commits
Commits
Show all changes
36 commits
Select commit Hold shift + click to select a range
1f79afa
GN & tbms100
LDannijs Jun 20, 2024
47e5ac1
add status
LDannijs Jun 20, 2024
087aa23
add em300-th
LDannijs Jun 25, 2024
8a34b01
Merge branch 'TheThingsNetwork:master' into normalized-pl
LDannijs Jun 25, 2024
ed44952
add lht65
LDannijs Jun 25, 2024
fa99c5e
add lsn50-v2
LDannijs Jun 25, 2024
1cadec3
add ws301
LDannijs Jun 25, 2024
864120a
add ers
LDannijs Jun 26, 2024
b6dfc58
add tbdw100
LDannijs Jun 26, 2024
88a173e
Merge branch 'TheThingsNetwork:master' into normalized-pl
LDannijs Jul 1, 2024
8a6aa64
change battVolt & add elsys, dragino
LDannijs Jul 1, 2024
32cea85
add vicki
LDannijs Jul 2, 2024
ca3be23
add lw001-bgpro beginning
LDannijs Jul 2, 2024
293c775
add to lw001-bgpro
LDannijs Jul 2, 2024
9f7d89d
add laird
LDannijs Jul 3, 2024
0417b50
add strips
LDannijs Jul 4, 2024
ff8275b
add tektelic
LDannijs Jul 4, 2024
e91b303
add lwl03a & change status
LDannijs Jul 4, 2024
5108db3
align all devices same format
LDannijs Jul 5, 2024
00bd1a8
update decodeUplink
LDannijs Jul 5, 2024
524b29c
rename doorStatus & add ers-co2
LDannijs Jul 8, 2024
a15feaa
update lwl03a
LDannijs Jul 8, 2024
2cc330b
add feedback
LDannijs Jul 10, 2024
adb031d
change motion to object
LDannijs Jul 11, 2024
8fa550b
Merge branch 'master' into normalized-pl
LDannijs Jul 11, 2024
634e72b
motion fixes
LDannijs Jul 17, 2024
6d1a4e4
Merge branch 'master' into normalized-pl
LDannijs Jul 18, 2024
f82cdcd
Merge branch 'master' into normalized-pl
LDannijs Aug 12, 2024
bfe92e3
air location
LDannijs Aug 19, 2024
17be71c
change to contactState
LDannijs Aug 22, 2024
8080bfb
Close to closed
LDannijs Aug 23, 2024
543bc1a
add ternary operator
LDannijs Aug 26, 2024
1fb6a05
Update door state once more
LDannijs Aug 30, 2024
af5ac51
revert air to object
LDannijs Sep 2, 2024
9d34711
Merge branch 'TheThingsNetwork:master' into normalized-pl
LDannijs Sep 10, 2024
f1283a0
Merge branch 'master' into normalized-pl
johanstokking Sep 10, 2024
File filter

Filter by extension

Filter by extension

Conversations
Failed to load comments.
Loading
Jump to
Jump to file
Failed to load files.
Loading
Diff view
Diff view
112 changes: 87 additions & 25 deletions lib/payload.json
Original file line number Diff line number Diff line change
Expand Up @@ -56,6 +56,11 @@
"format": "date-time",
"description": "Date and time of the measurement (RFC3339)"
},
"battery": {
"type": "number",
"description": "Voltage (V)",
"minimum": 0
},
"soil": {
"type": "object",
"properties": {
Expand Down Expand Up @@ -97,32 +102,40 @@
"additionalProperties": false
},
"air": {
"type": "object",
"properties": {
"temperature": {
"description": "Air temperature (°C)",
"$ref": "#/definitions/temperature"
},
"relativeHumidity": {
"description": "Relative humidity (%)",
"$ref": "#/definitions/percentage"
},
"pressure": {
"type": "number",
"description": "Atmospheric pressure (hPa)",
"minimum": 900,
"maximum": 1100
"type": "array",
johanstokking marked this conversation as resolved.
Show resolved Hide resolved
"items": {
"type": "object",
"properties": {
"location": {
"type": "string",
"enum": ["indoor", "outdoor"],
"description": "Specifies whether the measurement was taken indoors or outdoors."
},
"temperature": {
"description": "Air temperature (°C)",
"$ref": "#/definitions/temperature"
},
"relativeHumidity": {
"description": "Relative humidity (%)",
"$ref": "#/definitions/percentage"
},
"pressure": {
"type": "number",
"description": "Atmospheric pressure (hPa)",
"minimum": 900,
"maximum": 1100
},
"co2": {
"description": "Concentration of CO2 in the air (ppm)",
"$ref": "#/definitions/concentration"
},
"lightIntensity": {
"description": "Light intensity (lux)",
"$ref": "#/definitions/illuminance"
}
},
"co2": {
"description": "Concentration of CO2 in the air (ppm)",
"$ref": "#/definitions/concentration"
},
"lightIntensity": {
"description": "Light intensity (lux)",
"$ref": "#/definitions/illuminance"
}
},
"additionalProperties": false
"additionalProperties": false
}
},
"wind": {
"type": "object",
Expand All @@ -137,6 +150,55 @@
}
},
"additionalProperties": false
},
"water": {
"type": "object",
"properties": {
"leak": {
"type": "boolean",
"description": "Leak detected"
}
},
"additionalProperties": false
},
"action": {
"type": "object",
"properties": {
"motion": {
"type": "object",
"properties": {
"detected": {
"type": "boolean",
"description": "Motion detected"
},
"count": {
"type": "number",
"description": "Number of motion events (count)"
}
},
"additionalProperties": false
},
"contactState": {
"type": "string",
"description": "State of a contact sensor",
"enum": ["OPEN", "CLOSE"]
LDannijs marked this conversation as resolved.
Show resolved Hide resolved
}
},
"additionalProperties": false
},
"position": {
"type": "object",
"properties": {
"latitude": {
"type": "number",
"description": "Horizontal distance from equator (°)"
},
"longitude": {
"type": "number",
"description": "Vertical distance from prime meridian (°)"
}
},
"additionalProperties": false
}
},
"additionalProperties": false
Expand Down
8 changes: 8 additions & 0 deletions vendor/browan/tbdw100-codec.yaml
Original file line number Diff line number Diff line change
Expand Up @@ -12,6 +12,14 @@ uplinkDecoder:
status: 0
temperatureBoard: 21
time: 0
normalizedOutput:
data:
- action:
motion:
detected: false
air:
- temperature: 21
battery: 3.6
- description: Unknown FPort
input:
fPort: 42
Expand Down
18 changes: 18 additions & 0 deletions vendor/browan/tbdw100.js
Original file line number Diff line number Diff line change
Expand Up @@ -24,3 +24,21 @@ function decodeUplink(input) {
};
}
}

function normalizeUplink(input) {
return {
data: {
action: {
motion: {
detected: input.data.status > 0,
}
},
air: [
{
temperature: input.data.temperatureBoard,
},
],
battery: input.data.battery,
}
};
}
8 changes: 8 additions & 0 deletions vendor/browan/tbms100-codec.yaml
Original file line number Diff line number Diff line change
Expand Up @@ -12,6 +12,14 @@ uplinkDecoder:
status: 1
temperatureBoard: 20
time: 4
normalizedOutput:
data:
- action:
motion:
detected: true
air:
- temperature: 20
battery: 3.6
- description: Unknown FPort
input:
fPort: 42
Expand Down
18 changes: 18 additions & 0 deletions vendor/browan/tbms100.js
Original file line number Diff line number Diff line change
Expand Up @@ -24,3 +24,21 @@ function decodeUplink(input) {
};
}
}

function normalizeUplink(input) {
return {
data: {
action: {
motion: {
detected: input.data.status > 0,
}
},
air: [
{
temperature: input.data.temperatureBoard,
},
],
battery: input.data.battery,
},
};
}
1 change: 1 addition & 0 deletions vendor/dragino/index.yaml
Original file line number Diff line number Diff line change
Expand Up @@ -35,3 +35,4 @@ endDevices:
- sw3l
- lht52
- trackerd
- lwl03a
15 changes: 15 additions & 0 deletions vendor/dragino/lht52-codec.yaml
Original file line number Diff line number Diff line change
Expand Up @@ -8,6 +8,21 @@ uplinkDecoder:
output:
data: { 'Bat_mV': 1, 'Firmware_Version': '8801', 'Freq_Band': 0, 'Sensor_Model': 11, 'Sub_Band': 37 }

- description: Temperature & Humidity
input:
fPort: 2
bytes: [0x08, 0xCD, 0x02, 0x20, 0x7F, 0xFF, 0x01, 0x61, 0xCD, 0x4E, 0xDD]
output:
data: { 'Ext': 1, 'Hum_SHT': 54.4, 'Systimestamp': 1640845021, 'TempC_DS': 327.67, 'TempC_SHT': 22.53 }
normalizedOutput:
data:
- air:
- location: 'indoor'
temperature: 22.53
relativeHumidity: 54.4
- location: 'outdoor'
temperature: 327.67

- description: Unknown FPort
input:
fPort: 42
Expand Down
26 changes: 25 additions & 1 deletion vendor/dragino/lht52.js
Original file line number Diff line number Diff line change
Expand Up @@ -67,4 +67,28 @@ function decodeUplink(input) {
errors: ["unknown FPort"]
}
}
}
}

function normalizeUplink(input) {
var data = {
air: [
{
location: "indoor",
temperature: input.data.TempC_SHT,
relativeHumidity: input.data.Hum_SHT,
},
{
location: "outdoor",
temperature: input.data.TempC_DS
}
]
};

if (input.data.battVolt) {
data.battery = input.data.battVolt;
}

return { data: data };
}


9 changes: 9 additions & 0 deletions vendor/dragino/lht65-codec.yaml
Original file line number Diff line number Diff line change
Expand Up @@ -7,6 +7,15 @@ uplinkDecoder:
bytes: [0xCB, 0xF6, 0x0B, 0x0D, 0x03, 0x76, 0x01, 0x0A, 0xDD, 0x7F, 0xFF]
output:
data: { 'BatV': 3.062, 'Bat_status': 3, 'Ext_sensor': 'Temperature Sensor', 'Hum_SHT': 88.6, 'TempC_DS': 27.81, 'TempC_SHT': 28.29 }
normalizedOutput:
data:
- air:
- location: 'indoor'
temperature: 28.29
relativeHumidity: 88.6
- location: 'outdoor'
temperature: 27.81
battery: 3.062

- description: Unknown FPort
input:
Expand Down
19 changes: 19 additions & 0 deletions vendor/dragino/lht65.js
Original file line number Diff line number Diff line change
Expand Up @@ -99,4 +99,23 @@ default:

}

}

function normalizeUplink(input) {
return {
data: {
air: [
{
location: "indoor",
temperature: input.data.TempC_SHT,
relativeHumidity: input.data.Hum_SHT,
},
{
location: "outdoor",
temperature: input.data.TempC_DS
}
],
battery: input.data.BatV,
}
};
}
10 changes: 9 additions & 1 deletion vendor/dragino/lse01-codec.yaml
Original file line number Diff line number Diff line change
Expand Up @@ -7,7 +7,15 @@ uplinkDecoder:
bytes: [0xCE, 0x29, 0x00, 0xF1, 0x07, 0xA5, 0x09, 0x9B, 0x6E, 0x28, 0x90]
output:
data: { 'Bat': 3.625, 'TempC_DS18B20': '24.1', 'conduct_SOIL': 28200, 'temp_SOIL': '24.59', 'water_SOIL': '19.57' }

normalizedOutput:
data:
- air:
- temperature: 24.1
soil:
temperature: 24.59
moisture: 19.57
ec: 28.2
battery: 3.625
- description: Unknown FPort
input:
fPort: 42
Expand Down
20 changes: 19 additions & 1 deletion vendor/dragino/lse01.js
Original file line number Diff line number Diff line change
Expand Up @@ -32,4 +32,22 @@ switch (input.fPort) {
errors: ["unknown FPort"]
}
}
}
}

function normalizeUplink(input) {
return {
data: {
air: [
{
temperature: Number(input.data.TempC_DS18B20),
}
],
soil: {
temperature: Number(input.data.temp_SOIL),
moisture: Number(input.data.water_SOIL),
ec: input.data.conduct_SOIL / 1000,
},
battery: input.data.Bat,
}
};
}
8 changes: 8 additions & 0 deletions vendor/dragino/lsn50-v2-codec.yaml
Original file line number Diff line number Diff line change
Expand Up @@ -7,6 +7,14 @@ uplinkDecoder:
bytes: [0x0B, 0x54, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0xFC, 0x02, 0x05]
output:
data: { 'ADC_CH0V': 0, 'BatV': 2.9, 'Digital_IStatus': 'L', 'Door_status': 'OPEN', 'EXTI_Trigger': 'FALSE', 'Hum_SHT': 51.7, 'TempC1': 0, 'TempC_SHT': 25.2, 'Work_mode': 'IIC' }
normalizedOutput:
data:
- air:
- temperature: 25.2
relativeHumidity: 51.7
action:
contactState: 'OPEN'
battery: 2.9

- description: Unknown FPort
input:
Expand Down
19 changes: 18 additions & 1 deletion vendor/dragino/lsn50-v2.js
Original file line number Diff line number Diff line change
Expand Up @@ -196,4 +196,21 @@ default:
errors: ["unknown FPort"]
}
}
}
}

function normalizeUplink(input) {
return {
data: {
air: [
{
temperature: input.data.TempC_SHT,
relativeHumidity: input.data.Hum_SHT,
},
],
action: {
johanstokking marked this conversation as resolved.
Show resolved Hide resolved
contactState: input.data.Door_status
},
battery: input.data.BatV,
}
};
}
Loading
Loading