openhab-addons/bundles/org.openhab.binding.solaredge
Wouter Born 8672ed0208
Start license headers with `/*` instead of `/**` (#18061)
Prevents JavaDoc tooling issues because these tools check comments starting with `/**`.

Signed-off-by: Wouter Born <github@maindrain.net>
2025-01-07 22:33:03 +01:00
..
src/main Start license headers with `/*` instead of `/**` (#18061) 2025-01-07 22:33:03 +01:00
NOTICE added migrated 2.x add-ons 2020-09-21 03:37:19 +02:00
README.md Multiple line break fixes in documentation (#17628) 2024-10-28 21:09:24 +01:00
pom.xml Prepare for OH 5.0.0 (#17906) 2024-12-15 20:30:05 +01:00

README.md

SolarEdge Binding

The SolarEdge binding is used to get live data from from SolarEdge inverters via the central web api. This binding should in general be compatible with all inverter models that upload data to the solaredge portal. Only read access is supported.

Supported Things

This binding provides only one thing type: "generic" which is the inverter itself. As the name suggests it is generic which means it applies to all available inverters. Create one inverter thing per physical inverter installation available in your home(s). Additional stuff like batteries is automatically supported. Inverters which have a meter attached allow more detailed measuring. Either a SolarEdge modbus meter or a S0 meter (export or consumption meter) can be used. While on the one hand the S0 meter is the cheaper solution the solaredge meter on the other hand can be used as combined import+export meter and therefore allows even more detailed measurements. For more details please see here:

Discovery

Auto-Discovery is not supported, as access requires authentication.

Thing Configuration

The following configuration parameters are available for this thing:

  • tokenOrApiKey (required) Either the official API Key for using the public API or when using the inofficial private API: a token which can be retrieved from browser's cookie store when logged into the SolarEdge website. It is called "SPRING_SECURITY_REMEMBER_ME_COOKIE". When using this token, see also usePrivateApi and meterInstalled. E.g. for Firefox, use the built-in Storage Inspector to retrieve the token.

  • solarId (required)
    Id of your inverter at SolarEdge (can be found in the URL after successful login: https://monitoring.solaredge.com/solaredge-web/p/site/ <solarId> /#/dashboard)

  • usePrivateApi (optional)
    can be set to true to use the private API. Private API has no limit regarding query frequency but is less stable. Private API will only gather live data if a meter is available. The official public API has a limit of 300 queries per day but should be much more reliable/stable. Set this to true when using token retrieved from browser in tokenOrApiKey. See also meterInstalled. (default = false)

  • meterInstalled (optional)
    can be set to true for setups that contain a meter which is connected to the inverter. A meter allows more detailed data retrieval. This must be set to true when using token retrieved from browser in tokenOrApiKey. This can be set either to true or false when using the API key. (default = false)

  • liveDataPollingInterval (optional)
    interval (minutes) in which live data values are retrieved from Solaredge. Setting less than 10 minutes is only allowed when using private API. (default = 10)

  • aggregateDataPollingInterval (optional)
    interval (minutes) in which aggregate data values are retrieved from Solaredge. Setting less than 60 is only allowed when using private API. (default = 60)

Channels

Available channels depend on the specific setup e.g. if a meter and/or a battery is present. All numeric channels use the UoM feature. This means you can easily change the desired unit e.g. MWh instead of kWh just in your item definition. Following channels are currently available:

Channel Type ID Item Type Description Remark
live#production Number:Power Current PV production general available
live#pv_status String Current PV status requires meter attached and 'meterInstalled' set
live#consumption Number:Power Current power consumption requires meter attached and 'meterInstalled' set
live#load_status String Current load status requires meter attached and 'meterInstalled' set
live#battery_charge Number:Power Current charge flow requires battery
live#battery_discharge Number:Power Current discharge flow requires battery
live#battery_charge_discharge Number:Power Current charge/discharge flow (+/-) requires battery
live#battery_level Number:Dimensionless Current charge level requires battery
live#battery_status String Current battery status requires battery
live#battery_critical String true or false requires battery
live#import Number:Power Current import from grid requires meter attached and 'meterInstalled' set
live#export Number:Power Current export to grid requires meter attached and 'meterInstalled' set
live#grid_status String Current grid status requires meter attached and 'meterInstalled' set
aggregate_day#production Number:Energy Day Aggregate PV production general available
aggregate_day#consumption Number:Energy Day Aggregate power consumption requires meter attached and 'meterInstalled' set
aggregate_day#selfConsumptionForConsumption Number:Energy Day Aggregate self consumption (incl battery) requires meter attached and 'meterInstalled' set
aggregate_day#selfConsumptionCoverage Number:Dimensionless Day Coverage of consumption by self production requires meter attached and 'meterInstalled' set
aggregate_day#batterySelfConsumption Number:Energy Day Aggregate self consumption from battery requires battery and private API activated
aggregate_day#import Number:Energy Day Aggregate import from grid requires meter attached and 'meterInstalled' set
aggregate_day#export Number:Energy Day Aggregate export to grid requires meter attached and 'meterInstalled' set
aggregate_week#production Number:Energy Week Aggregate PV production requires meter attached and 'meterInstalled' set
aggregate_week#consumption Number:Energy Week Aggregate power consumption requires meter attached and 'meterInstalled' set
aggregate_week#selfConsumptionForConsumption Number:Energy Week Aggregate self consumption (incl battery) requires meter attached and 'meterInstalled' set
aggregate_week#selfConsumptionCoverage Number:Dimensionless Week Coverage of consumption by self production requires meter attached and 'meterInstalled' set
aggregate_week#batterySelfConsumption Number:Energy Week Aggregate self consumption from battery requires battery and private API activated
aggregate_week#import Number:Energy Week Aggregate import from grid requires meter attached and 'meterInstalled' set
aggregate_week#export Number:Energy Week Aggregate export to grid requires meter attached and 'meterInstalled' set
aggregate_month#production Number:Energy Month Aggregate PV production general available
aggregate_month#consumption Number:Energy Month Aggregate power consumption requires meter attached and 'meterInstalled' set
aggregate_month#selfConsumptionForConsumption Number:Energy Month Aggregate self consumption (incl battery) requires meter attached and 'meterInstalled' set
aggregate_month#selfConsumptionCoverage Number:Dimensionless Month Coverage of consumption by self production requires meter attached and 'meterInstalled' set
aggregate_month#batterySelfConsumption Number:Energy Month Aggregate self consumption from battery requires battery and private API activated
aggregate_month#import Number:Energy Month Aggregate import from grid requires meter attached and 'meterInstalled' set
aggregate_month#export Number:Energy Month Aggregate export to grid requires meter attached and 'meterInstalled' set
aggregate_year#production Number:Energy Year Aggregate PV production general available
aggregate_year#consumption Number:Energy Year Aggregate power consumption requires meter attached and 'meterInstalled' set
aggregate_year#selfConsumptionForConsumption Number:Energy Year Aggregate self consumption (incl battery) requires meter attached and 'meterInstalled' set
aggregate_year#selfConsumptionCoverage Number:Dimensionless Year Coverage of consumption by self production requires meter attached and 'meterInstalled' set
aggregate_year#batterySelfConsumption Number:Energy Year Aggregate self consumption from battery requires battery and private API activated
aggregate_year#import Number:Energy Year Aggregate import from grid requires meter attached and 'meterInstalled' set
aggregate_year#export Number:Energy Year Aggregate export to grid requires meter attached and 'meterInstalled' set

Full Example

Thing

  • minimum configuration
solaredge:generic:se2200 [ tokenOrApiKey="...", solarId="..."]
  • with pollingIntervals
solaredge:generic:se2200[ tokenOrApiKey="...", solarId="...", liveDataPollingInterval=..., aggregateDataPollingInterval=... ]
  • maximum version
solaredge:generic:se2200     [ tokenOrApiKey="secret", solarId="4711", meterInstalled=true, usePrivateApi=true, liveDataPollingInterval=15, aggregateDataPollingInterval=60 ]
  • multiple inverters
solaredge:generic:home1 [ tokenOrApiKey="...", solarId="..."]
solaredge:generic:home2  [ tokenOrApiKey="...", solarId="..."]

Items

Number:Power            SE2200_Live_Production   "PV Produktion [%.2f %unit%]"    {channel="solaredge:generic:se2200:live#production"}
Number:Dimensionless    SE2200_Live_Level        "Batterieladung"                 {channel="solaredge:generic:se2200:live#battery_level"}
Number:Energy           SE2200_Day_Production    "PV Produktion [%.2f kWh]"       {channel="solaredge:generic:se2200:aggregate_day#production"}