Skip to content

An IoBroker Adapter for Sainlogic based weather stations

License

Notifications You must be signed in to change notification settings

phifogg/ioBroker.sainlogic

Folders and files

NameName
Last commit message
Last commit date

Latest commit

 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 

Repository files navigation

Logo

ioBroker.sainlogic

NPM version Downloads Number of Installations (latest) Number of Installations (stable) Dependency Status Known Vulnerabilities

NPM

sainlogic adapter for ioBroker

Read data from a sainlogic based weather station

Supported devices

Basically any device working with the sainlogic hardware, the firmware usually reports as 'EasyWeather Vx.x.x)'.

Known working devices:

  1. ELV WS980Wifi
  2. Eurochron EFWS2900 (Listener mode only)
  3. Froggit WH400SE
  4. Froggit DP1500 (Ecowitt protocol only)
  5. Sainlogic WS3500 (Listener mode only)
  6. WH51 Moisture sensor
  7. Ecowitt GW1000
  8. Froggit WH3000SE (Listener mode only)

Usage

The adapter supports two modes to show data of your weather station.

In Listener mode the adapter does support additional sensor if delivered from your weather station. Currently supported are temperature and humidity. If you have another additional sensor please raise a github issue and post your data string as this helps me to extend the functionality.

Listener mode:

With latest firmware releases the weather station supports sending data to a custom server. The adapter will act as such a server. The setup needs two steps:

Configure Weather station

Use the 'WS View'app on your mobile device to configure the weatherstation. Configure the following settings for customized server settings:

  • Server: IP/Hostname of your IOBroker server
  • Path: anything, just remember it for the adapter configuration Note: on some stations it has been proven success to add a question mark at the end of the path. Some others work without it. Best is to try both.
  • Port: any number between 1024 and 65000 (default is 45000), needs to be unique and free on your IOBroker system
  • Station ID: not used Note: some station still require any value to be set
  • Station Key: not used Note: some station still require any value to be set
  • Protocol Type: WeatherUnderground
  • Upload Interval: anyting supported by your weather station

Configure the Listener

In the instance configuration choose the tab 'Listener' and set the following:

  • Active: true
  • IP: choose the IP of your IOBroker which the weatherstation will be able to connect to (default is 0.0.0.0 to allow all IPs), this is mainly relevant if you have multiple networks, otherwise the default will do
  • Port: Enter the same port as in the WS View app
  • Path: Enter the same path as in the WS View app
  • Forward URL: If you want to forward the received data to another consumer you can specify an additional adress. E.g. you may receive data in WU format and still want to forward this to WeatherUnderground.

Note: The forwarding URL needs to end with a trailing question mark (?). Example: https://weatherstation.wunderground.com/weatherstation/updateweatherstation.php?

Save. The listener will start and wait on incoming connections. Based on your interval you should see in the log a message ' Listener received update: ...' with the data.

Scheduler mode:

If your weather station supports pulling for data you can configure the scheduler to do so. The protocol used is based on WS980 documentation.

Configure the scheduler

In the instance configuration choose the tab 'Scheduler' and set the following:

  • Active: true
  • IP: choose the IP of your weather station, you should make sure that the IP is fixed and does not change
  • Port: Enter the port to connect to (default is 45000)
  • Interval: Enter an interval in seconds (I would recommend at minimum 10 seconds to not overload the system or network)

Save.

The schheduler will start and connect to the weather station after the first interval time. You should see message in the log like 'Scheduler pulling for new data'. If you set the log mode to debug you will also see the data strings received.

Station specific infos

Froggit DP1500

It seems this station does not send any data when WeatherUnderground is selected as protocol. It works correctly with Ecowitt.

Eurochron EFWS290

Station does not answer to scheduler commands, so only listener mode is supported.

Sainlogic WS3500

Station does not answer to scheduler commands, so only listener mode is supported.

Changelog

Latest version

0.11.6 Adapater checker related updates

0.11.5 ECOWITT forwarding fixed

0.11.4 Fix yearlyrain max value and mapping for CO2 sensors

0.10.5 Bugfix for state initialization, removed log messages for forwarding

0.10.4 Bugfix for lightning count, new battery states for additional sensors

0.10.3 Bugfixes

0.10.2 Bugfixes

0.10.0 Added new sensors for Lightning, Piezo elements, DP250 and minor fixes

0.8.2 Updated UVRaw to maxvalue 4000

0.8.1 Bugfix for timestamp and listener

0.8.0 Added time stamps for daily min and max values

0.7.3 Dependency updates and Travis testing updates

0.7.2 Dependency updates for security vulnerabilities

0.7.1 Fix Soilbatt mapping

0.7.0 Support for Soil Moisture devices like attached to DP1500

0.6.6 Adressed github issue #53 - warning on non existing object

0.6.5 Removed unneeded events

0.6.4 For WH2650: Adding model name and weather station communication frequency datapoint

0.6.3 Fixed outdoor humidity

0.6.2 Added additional sensor support

For detailed change log or previous versions check io-package.json

Credits

Credits go to: lemuba, StrathCole, Glasfaser, Latzi: for relentless testing of my bugs :) Lisa for her code to translate wind degrees in a heading

License

MIT License

Copyright (c) 2025 Fogg [email protected]

Permission is hereby granted, free of charge, to any person obtaining a copy of this software and associated documentation files (the "Software"), to deal in the Software without restriction, including without limitation the rights to use, copy, modify, merge, publish, distribute, sublicense, and/or sell copies of the Software, and to permit persons to whom the Software is furnished to do so, subject to the following conditions:

The above copyright notice and this permission notice shall be included in all copies or substantial portions of the Software.

THE SOFTWARE IS PROVIDED "AS IS", WITHOUT WARRANTY OF ANY KIND, EXPRESS OR IMPLIED, INCLUDING BUT NOT LIMITED TO THE WARRANTIES OF MERCHANTABILITY, FITNESS FOR A PARTICULAR PURPOSE AND NONINFRINGEMENT. IN NO EVENT SHALL THE AUTHORS OR COPYRIGHT HOLDERS BE LIABLE FOR ANY CLAIM, DAMAGES OR OTHER LIABILITY, WHETHER IN AN ACTION OF CONTRACT, TORT OR OTHERWISE, ARISING FROM, OUT OF OR IN CONNECTION WITH THE SOFTWARE OR THE USE OR OTHER DEALINGS IN THE SOFTWARE.