node-red-contrib-rainbird 1.0.15

Node-RED nodes for controlling RainBird LNK2 sprinkler controller via local connection. This wraps the RainBird SIP protocol using AES encryption. It uses a slightly modified version of node-rainbird originally developed by @bbreukelen.

npm install node-red-contrib-rainbird

This set of nodes enables communication with the Rainbird LNK2 sprinkler controller via a local LNK2 connection. To use these nodes, you need both the Rainbird controller and the LNK2 add-on properly plugged in and configured.

Prerequisites

To connect, you need the LNK2 IP address and PIN:

  • LNK2 PIN: This is the code you set up in the Rainbird mobile app when configuring the LNK2.
  • LNK2 IP: This is the local IP address assigned by your router.

This package wraps the functionality of node-rainbird and exposes Rainbird LNK2 functions to Node-RED.

Available Nodes:

rainbird-info

Fetches basic information about the Rainbird sprinkler controller via the local LNK2 connection. The payload returned contains the following:

{
  "serialNumber": "xxxxxxxxxx",
  "modelID": "xxxxx",
  "protocolRevisionMajor": "xx",
  "protocolRevisionMinor": "xx",
  "hour": 13,
  "minute": 21,
  "second": 19,
  "day": 25,
  "month": 5,
  "year": 2025,
  "pageNumber": "00",
  "stationsAvail": 10
}

rainbird-state

Retrieves the current IrrigationState from the Rainbird sprinkler controller. The payload will contain:

{
  "irrigationState": "_state_"
}

The irrigationState indicates whether the Rainbird controller is running a program. This does not provide information on active zones.

rainbird-active

Fetches information on active zones (sprinklers) from the Rainbird sprinkler controller. The returned payload will include:

{
  "pageNumber": "00",
  "activeStations": "00000000",
  "activeZones": [0, 0, 0, 0]
}

rainbird-config

Configuration node for managing the controller's setup.

rainbird-startZone

Manually activates a specific zone for a set duration (in minutes). If another zone is already active, it will be deactivated.

  • msg.zone: Specifies which zone to activate.
  • msg.time: Defines how long the zone should run (in minutes).

rainbird-stopZone

Stops all sprinkler zones, halting irrigation.

rainbird-delayStart

Delays the start of an irrigation program by a specified number of days. The delay duration is provided in msg.payload.

rainbird-startProgram

Manually starts a program by specifying the program number in msg.payload (e.g., Program "A" = 1, Program "B" = 2). This feature is not supported on ESP-RZXe but works on ESP-me3 and may work on other models.

rainbird-getDelay

Retrieves information on whether a program's start has been delayed. The payload will return:

{
  "delaySetting": number_of_days
}

Example Flow

An example flow is provided in the examples folder of the repository. This flow demonstrates how to integrate and use the available Rainbird nodes within a Node-RED environment.

Credits

This package uses a modified version of node-rainbird originally developed by @bbreukelen. All protocol decoding and encryption logic is based on that excellent work.


Maciej Szulc, 2025

Node Info

Version: 1.0.15
Updated 4 days ago
License: GPL-3.0-or-later
Rating: not yet rated

Categories

Actions

Rate:

Downloads

115 in the last week

Nodes

  • rainbird-info
  • rainbird-state
  • rainbird-active
  • rainbird-server
  • rainbird-startZone
  • rainbird-stopZone
  • rainbird-delayStart
  • rainbird-startProgram
  • rainbird-getDelay

Keywords

  • node-red
  • rainbird
  • sprinkler
  • irrigation
  • lnk2
  • smart-home

Maintainers