Skip to content
/ rct Public
forked from mlnoga/rct

A library for communication with solar power inverters of the RCT power brand, not endorsed by or affiliated with the eponymous company.

License

Notifications You must be signed in to change notification settings

Maschga/rct

 
 

Repository files navigation

rct

A library for communication with solar power inverters of the RCT power brand. Tested with the RCT PS 6.0 solar power inverter, battery and grid power sensor.

RCT power is a registered trademark of RCT Power GmbH. This library is not provided by, endorsed by, supported by or affiliated with the company in any way.

It is provided without any warranties, entirely for use at your own risk under a LGPL 2.1 license.

Usage

Install via go get github.com/mlnoga/rct.

Use like this:

package main

import (
	"fmt"
	"rct"
	"time"
)

func main() {
	conn, err := rct.NewConnection("my-RCT-hostname-or-IP-address", time.Second*2)
	if err != nil {
		fmt.Println(err)
		return
	}
	defer conn.Close()

	// read
	a, err := conn.QueryFloat32(rct.SolarGenAPowerW)
	if err != nil {
		fmt.Println(err)
		return
	}

	fmt.Printf("%s is %.0fV\n", string(rct.SolarGenAPowerW), a)

	// write
	if err := conn.SetSocMin(0.07); err != nil {
		fmt.Println(err)
		return
	}
}

Architecture

  • datagram.go defines basic constants like commands, on-device identifiers and datagram packets; as well as conversions of datagram payloads to golang types
  • crc.go defines the cyclic redundancy check algorithm to ensure data integrity used by the RCT
  • build.go defines a datagram builder for assembling datagrams to send
  • parse.go defines a datagram parser which parses incoming bytes into datagrams
  • connection.go ties builders and parsers into a bidirectional connection with the device, and defines convenience methods to synchronously query identifiers
  • write.go defines methods to validate and write data

About

A library for communication with solar power inverters of the RCT power brand, not endorsed by or affiliated with the eponymous company.

Resources

License

Stars

Watchers

Forks

Packages

No packages published

Languages

  • Go 99.6%
  • Makefile 0.4%