mirror of
https://github.com/arendst/Tasmota.git
synced 2025-07-22 18:26:30 +00:00
Create SE01-L.be (#23607)
LoRaWAN decoder for Dragino SE01-LB/LS -- LoRaWAN Soil Moisture & EC Sensor
This commit is contained in:
parent
ece26ccfaf
commit
c5aced3dd0
145
tasmota/berry/lorawan/decoders/vendors/dragino/SE01-L.be
vendored
Normal file
145
tasmota/berry/lorawan/decoders/vendors/dragino/SE01-L.be
vendored
Normal file
@ -0,0 +1,145 @@
|
||||
# LoRaWAN Decoder file for Dragino SE01-LB/LS Soil Sensor
|
||||
# URL: https://www.dragino.com/products/agriculture-weather-station/item/277-se01-lb.html
|
||||
# File Name: SE01-L.be
|
||||
#
|
||||
# References
|
||||
# User Manual: https://wiki.dragino.com/xwiki/bin/view/Main/User%20Manual%20for%20LoRaWAN%20End%20Nodes/SE01-LB_LoRaWAN_Soil%20Moisture%26EC_Sensor_User_Manual/
|
||||
# TTN Device Repository:https://github.com/TheThingsNetwork/lorawan-devices/blob/master/vendor/dragino/lse01-121.js
|
||||
|
||||
import string
|
||||
|
||||
global.se01LNodes = {}
|
||||
|
||||
class LwDecoSE01L
|
||||
static def decodeUplink(Node, RSSI, FPort, Bytes)
|
||||
var data = {"Device":"Dragino SE01-LB/LS"}
|
||||
data.insert("Node", Node)
|
||||
|
||||
var valid_values = false
|
||||
var last_seen = 1451602800
|
||||
var battery_last_seen = 1451602800
|
||||
var battery = 1000
|
||||
var rssi = RSSI
|
||||
|
||||
var temp = 1000
|
||||
var conductivity=0
|
||||
var moisture=0
|
||||
var dielectric=0
|
||||
var mod
|
||||
var i_flag # 0: Normal uplink packet, 1: Interrupt Uplink Packet.
|
||||
var s_flag # 0: No sensor was identified, 1: The sensor has been identified
|
||||
|
||||
if global.se01LNodes.find(Node)
|
||||
last_seen = global.se01LNodes.item(Node)[1]
|
||||
battery_last_seen = global.se01LNodes.item(Node)[2]
|
||||
battery = global.se01LNodes.item(Node)[3]
|
||||
rssi = global.se01LNodes.item(Node)[4]
|
||||
|
||||
temp = global.se01LNodes.item(Node)[5]
|
||||
conductivity = global.se01LNodes.item(Node)[6]
|
||||
moisture = global.se01LNodes.item(Node)[7]
|
||||
dielectric = global.se01LNodes.item(Node)[8]
|
||||
end
|
||||
|
||||
## SENSOR DATA ##
|
||||
#e.g. 0f5a 0ccc 0000 079d 0000 10
|
||||
# Battery ExtTemp Moisture Temp EC Mode,Flags
|
||||
if 2 == FPort && ( Bytes.size() == 11 || Bytes.size() == 15)
|
||||
last_seen = tasmota.rtc('local')
|
||||
|
||||
battery_last_seen = tasmota.rtc('local')
|
||||
battery=((Bytes[0]<<8 | Bytes[1]) & 0x3FFF)/1000.0 ##Battery,units:V
|
||||
s_flag = (Bytes[10] >> 4) & 0x01
|
||||
i_flag = Bytes[10] & 0x0f
|
||||
mod=(Bytes[10]>>7)&0x01
|
||||
|
||||
if 0==mod #Default mode
|
||||
moisture=((Bytes[4]<<8 | Bytes[5])/100.0) ##moisture,units:%
|
||||
conductivity=Bytes[8]<<8 | Bytes[9]
|
||||
var value=Bytes[6]<<8 | Bytes[7]
|
||||
if((value & 0x8000)>>15 == 0)
|
||||
temp=(value/100.0)
|
||||
else
|
||||
temp=((value-0xFFFF)/100.0)
|
||||
end
|
||||
data.insert("Mode", "Default")
|
||||
data.insert("Temp", temp)
|
||||
|
||||
else #Raw Data mode
|
||||
conductivity=Bytes[4]<<8 | Bytes[5]
|
||||
moisture = Bytes[6]<<8 | Bytes[7]
|
||||
dielectric = ((Bytes[8]<<8 | Bytes[9])/10.0)
|
||||
data.insert("Mode", "Raw")
|
||||
data.insert("DielectricConstant", dielectric)
|
||||
end
|
||||
|
||||
data.insert("BattV",battery)
|
||||
data.insert("Moisture", moisture)
|
||||
data.insert("Conductivity", conductivity)
|
||||
data.insert("i_flag", i_flag)
|
||||
data.insert("s_flag", s_flag)
|
||||
|
||||
valid_values = true
|
||||
|
||||
## STATUS DATA ##
|
||||
elif 5 == FPort && Bytes.size() == 7
|
||||
data.insert("Sensor_Model",Bytes[0])
|
||||
data.insert("Firmware_Version", f'v{Bytes[1]:%u}.{Bytes[2]>>4:%u}.{Bytes[2]&0xF:%u}')
|
||||
data.insert("Freq_Band",LwRegions[Bytes[3]-1])
|
||||
data.insert("Sub_Band",Bytes[4])
|
||||
data.insert("BattV",((Bytes[5] << 8) | Bytes[6]) / 1000.0)
|
||||
battery_last_seen = tasmota.rtc('local')
|
||||
battery = ((Bytes[5] << 8) | Bytes[6]) / 1000.0
|
||||
valid_values = true
|
||||
else
|
||||
# Ignore other Fports
|
||||
end #Fport
|
||||
|
||||
if valid_values
|
||||
if global.se01LNodes.find(Node)
|
||||
global.se01LNodes.remove(Node)
|
||||
end
|
||||
# sensor[0] [1] [2] [3] [4] [5] [6] [7] [8] [9]
|
||||
global.se01LNodes.insert(Node, [Node, last_seen, battery_last_seen, battery, RSSI, temp, conductivity, moisture, dielectric, mod])
|
||||
end
|
||||
|
||||
return data
|
||||
end #decodeUplink()
|
||||
|
||||
static def add_web_sensor()
|
||||
var msg = ""
|
||||
for sensor: global.se01LNodes
|
||||
var name = string.format("SE01-L-%i", sensor[0])
|
||||
var name_tooltip = "Dragino SE01-L"
|
||||
var last_seen = sensor[1]
|
||||
var battery_last_seen = sensor[2]
|
||||
var battery = sensor[3]
|
||||
var rssi = sensor[4]
|
||||
msg += lwdecode.header(name, name_tooltip, battery, battery_last_seen, rssi, last_seen)
|
||||
|
||||
# Sensors
|
||||
var temp = sensor[5]
|
||||
var conductivity = sensor[6]
|
||||
var moisture = sensor[7]
|
||||
var dielectric = sensor[8]
|
||||
var mod = sensor[9]
|
||||
|
||||
msg += "<tr class='htr'><td colspan='4'>┆" # |
|
||||
if mod
|
||||
msg += string.format(" κ %.1f", dielectric ) # Kappa - dielectric
|
||||
msg += string.format(" 💧️ %u", moisture) # Raindrop - moisture
|
||||
msg += string.format(" σ %u", conductivity) # Sigma - conductivity
|
||||
msg += " (raw)"
|
||||
else
|
||||
msg += string.format(" ☀️ %.1f°C", temp) # Sunshine/Color - Temperature
|
||||
msg += string.format(" 💧️ %.1f%%", moisture) # Raindrop/Color - moisture
|
||||
msg += string.format(" σ %uuS/cm", conductivity) # Sigma - conductivity
|
||||
end
|
||||
|
||||
msg += "{e}" # = </td></tr>
|
||||
end
|
||||
return msg
|
||||
end #add_web_sensor()
|
||||
end #class
|
||||
|
||||
LwDeco = LwDecoSE01L
|
Loading…
x
Reference in New Issue
Block a user