Skip to content

Information about local API for SolarEdge Inverters

Notifications You must be signed in to change notification settings

dragoshenron/solaredge-local

 
 

Folders and files

NameName
Last commit message
Last commit date

Latest commit

 

History

4 Commits
 
 
 
 
 
 

Repository files navigation

SolarEdge Local

The goal if this respository is to provide information about using the local API available on some solar edge inverters. This is a WIP based on my observations and may contain inaccuracies. Pull Requests or Issues are encouraged to correct any mistakes or add additonal informatoin.

Relevant Models

The local api appears to be available on the SExxxxH-US models with SetApp. See more information on SetApp. These models have no LED screen, and are provisioned via a phone app when installed.

You can check by finding the IP address of your inverter and visiting it in a browser. If it supports the local API, you'll see the SolarEdge logo and a "Commissioning" menu.

API Endpoints

  • AppConfigs: "web/v1/app_configs"
  • Region: "web/v1/region"
  • Region_Country: "web/v1/region/country"
  • Region_Language: "web/v1/region/language"
  • Pairing: "web/v1/pairing"
  • Pairing_Request: "web/v1/pairing/request"
  • Communication: "web/v1/communication"
  • Communication_Server: "web/v1/communication/server"
  • Communication_Lan: "web/v1/communication/lan"
  • Communication_Rs485_SlaveDetect: "web/v1/communication/rs485//slave_detect"
  • Communication_Rs485_Protocol: "web/v1/communication/rs485//protocol"
  • Communication_Rs485_DeviceId: "web/v1/communication/rs485//deviceid"
  • Communication_Rs485_Modbus: "web/v1/communication/rs485//modbus"
  • Communication_Rs485_Modbus_AddDevice: "web/v1/communication/rs485//modbus/add_device"
  • Communication_Rs485_Modbus_RemoveDevice: "web/v1/communication/rs485//modbus/remove_device"
  • Communication_Wifi: "web/v1/communication/wifi"
  • Communication_Wifi_Wps: "web/v1/communication/wifi/wps"
  • Communication_Wifi_Connect: "web/v1/communication/wifi/connect"
  • Communication_Cellular: "web/v1/communication/cellular"
  • Communication_Zigbee_Defaults: "web/v1/communication/zigbee/defaults"
  • Communication_Zigbee_ModuleConfigs: "web/v1/communication/zigbee/module_configs"
  • Communication_Zigbee_OpMode: "web/v1/communication/zigbee/op_mode"
  • Communication_Gpio_Pri: "web/v1/communication/gpio/pri"
  • Communication_ModbusTcp: "web/v1/communication/modbus_tcp"
  • PowerControl: "web/v1/power_control"
  • PowerControl_GridControl: "web/v1/power_control/grid_control"
  • PowerControl_EnergyManager_LimitControl: "web/v1/power_control/energy_manager/limit_control"
  • PowerControl_EnergyManager_EnergyControl: "web/v1/power_control/energy_manager/energy_control"
  • PowerControl_EnergyManager_StorageControl: "web/v1/power_control/energy_manager/storage_control"
  • PowerControl_ReactivePower: "web/v1/power_control/reactive_power"
  • PowerControl_ActivePower: "web/v1/power_control/active_power"
  • PowerControl_Wakeup: "web/v1/power_control/wakeup"
  • PowerControl_Advanced: "web/v1/power_control/advanced"
  • PowerControl_Reset: "web/v1/power_control/reset"
  • PowerControl_Rrcr: "web/v1/power_control/rrcr"
  • Maintenance: "web/v1/maintenance"
  • Maintenance_DateTime: "web/v1/maintenance/date_and_time"
  • Maintenance_ResetCounters: "web/v1/maintenance/reset_counters"
  • Maintenance_ResetFactory: "web/v1/maintenance/reset_factory"
  • Maintenance_Afci: "web/v1/maintenance/afci"
  • Maintenance_AfciTest: "web/v1/maintenance/afci/test"
  • Maintenance_Inverters_SelfTest: "web/v1/maintenance/inverters//self_test"
  • Maintenance_Standby: "web/v1/maintenance/standby"
  • Maintenance_GridProtectionLogin: "web/v1/maintenance/grid_protection/login"
  • Maintenance_GridProtection: "web/v1/maintenance/grid_protection"
  • Maintenance_UpgradeUsb: "web/v1/maintenance/fw_upgrade/usb"
  • Information: "web/v1/information"
  • Status: "web/v1/status"
  • Status_ServerCommTest: "web/v1/status/server_comm_test"

The Status endpoint appears to the most useful for realtime production data. Optimizer level data is available from the maintenance API endpoint.

Using the API

All endpoints I have explored so far appear to be a GET, and responses use Protocol Buffers. There is no authentication

View Raw Response

You can see the raw data by doing the following (assuming you have the protoocal buffers CLI tool installed)

curl http://<inverter ip>/web/v1/status --output response.bin
protoc --decode_raw < response.bin

Many numbers appear to be 32 bit floating point.

The proto definitions required to fully parse the responses are available in javascript if you choose "view source" in the developer tools of your browser.

View Parsed response

If there is a corresponding .proto file in message_types, you can view the parsed response from the API. Each proto file correspond to the name of an API endpoint. These are very much a WIP and may be incomplete. These can be created by choosing "view source" in the developer tools of your browser, and searching for text like proto.web_status.<apiNameInCamelCase>.toObject

Here is an example for the status API:

curl http://<inverter ip>/web/v1/status --output response.bin
protoc --decode Status message_types/status.proto < response.bin

About

Information about local API for SolarEdge Inverters

Resources

Stars

Watchers

Forks

Releases

No releases published

Packages

No packages published