{
  "dataType": "CVE_RECORD",
  "dataVersion": "5.1",
  "cveMetadata": {
    "cveId": "CVE-2025-29756",
    "assignerOrgId": "00000000-0000-4000-9000-000000000000",
    "requesterUserId": "00000000-0000-4000-9000-000000000000",
    "serial": 1,
    "state": "PUBLISHED"
  },
  "containers": {
    "cna": {
      "providerMetadata": {
        "orgId": "00000000-0000-4000-9000-000000000000"
      },
      "title": "MQTT implementation in Sungrow iSolarCloud allowed users to subscribe to all data of all connected inverters",
      "datePublic": "2025-06-08T22:00:00.000Z",
      "problemTypes": [
        {
          "descriptions": [
            {
              "lang": "en",
              "cweId": "CWE-862",
              "description": "CWE-862 Missing Authorization",
              "type": "CWE"
            }
          ]
        }
      ],
      "impacts": [
        {
          "capecId": "CAPEC-1",
          "descriptions": [
            {
              "lang": "en",
              "value": "CAPEC-1 Accessing Functionality Not Properly Constrained by ACLs"
            }
          ]
        }
      ],
      "affected": [
        {
          "vendor": "SunGrow",
          "product": "iSolarCloud",
          "versions": [
            {
              "status": "affected",
              "version": "0",
              "lessThan": "7 June 2025",
              "versionType": "custom"
            }
          ],
          "defaultStatus": "unaffected"
        }
      ],
      "descriptions": [
        {
          "lang": "en",
          "value": "SunGrow's back end users system  iSolarCloud https://isolarcloud.com  uses an MQTT service to transport data from the user's connected devices to the user's web browser. \nThe MQTT server however did not have sufficient restrictions in place to limit the topics that a user could subscribe to. \nWhile the data that is transmitted through the MQTT server is encrypted and the credentials for the MQTT server are obtained though an API call, the credentials could be used to subscribe to any topic and the encryption key can be used to decrypt all messages received.\nAn attack with an account on iSolarCloud.com could extract MQTT credentials and the decryption key from the browser and then use an external program to subscribe to the topic '#' and thus recieve all messages from all connected devices.",
          "supportingMedia": [
            {
              "type": "text/html",
              "base64": false,
              "value": "SunGrow's back end users system <a target=\"_blank\" rel=\"nofollow\" href=\"https://isolarcloud.com\">iSolarCloud</a>&nbsp;uses an MQTT service to transport data from the user's connected devices to the user's web browser.&nbsp;<br>The MQTT server however did not have sufficient restrictions in place to limit the topics that a user could subscribe to.&nbsp;<br>While the data that is transmitted through the MQTT server is encrypted and the credentials for the MQTT server are obtained though an API call, the credentials could be used to subscribe to any topic and the encryption key can be used to decrypt all messages received.<br>An attack with an account on iSolarCloud.com could extract&nbsp;MQTT credentials and the decryption key from the browser and then use an external program to subscribe to the topic '#' and thus recieve all messages from all connected devices."
            }
          ]
        }
      ],
      "tags": [
        "exclusively-hosted-service"
      ],
      "references": [
        {
          "url": "https://csirt.divd.nl/CVE-2025-29756",
          "tags": [
            "third-party-advisory",
            "technical-description"
          ]
        },
        {
          "url": "https://csirt.divd.nl/DIVD-2025-00009",
          "tags": [
            "third-party-advisory"
          ]
        },
        {
          "url": "https://isolarcloud.com",
          "tags": [
            "product"
          ]
        }
      ],
      "metrics": [
        {
          "format": "CVSS",
          "scenarios": [
            {
              "lang": "en",
              "value": "GENERAL"
            }
          ],
          "cvssV4_0": {
            "version": "4.0",
            "attackVector": "NETWORK",
            "attackComplexity": "LOW",
            "attackRequirements": "NONE",
            "privilegesRequired": "LOW",
            "userInteraction": "NONE",
            "vulnConfidentialityImpact": "HIGH",
            "subConfidentialityImpact": "HIGH",
            "vulnIntegrityImpact": "NONE",
            "subIntegrityImpact": "NONE",
            "vulnAvailabilityImpact": "NONE",
            "subAvailabilityImpact": "NONE",
            "Safety": "NOT_DEFINED",
            "Automatable": "YES",
            "Recovery": "NOT_DEFINED",
            "valueDensity": "NOT_DEFINED",
            "vulnerabilityResponseEffort": "NOT_DEFINED",
            "providerUrgency": "NOT_DEFINED",
            "baseSeverity": "HIGH",
            "baseScore": 8.3,
            "vectorString": "CVSS:4.0/AV:N/AC:L/AT:N/PR:L/UI:N/VC:H/VI:N/VA:N/SC:H/SI:N/SA:N/AU:Y"
          }
        }
      ],
      "solutions": [
        {
          "lang": "en",
          "value": "iSolarCloud has been patched by SunGrow and the vulnerability is no longer exploitable.",
          "supportingMedia": [
            {
              "type": "text/html",
              "base64": false,
              "value": "iSolarCloud has been patched by SunGrow and the vulnerability is no longer exploitable."
            }
          ]
        }
      ],
      "credits": [
        {
          "lang": "en",
          "value": "Harm van den Brink (DIVD)",
          "type": "finder"
        },
        {
          "lang": "en",
          "value": "Frank Breedijk (DIVD)",
          "type": "analyst"
        },
        {
          "lang": "en",
          "value": "ENCS (https://encs.eu/)",
          "type": "finder"
        }
      ],
      "source": {
        "advisory": "DIVD-2025-00009",
        "discovery": "EXTERNAL"
      },
      "x_generator": {
        "engine": "Vulnogram 0.2.0"
      }
    }
  }
}