Uploaded image for project: 'Blesta Core'
  1. Blesta Core
  2. CORE-5356

cPanel: Investigate connectivity issue, possible bug on some configurations

    Details

    • Type: Bug
    • Status: Closed
    • Priority: Major
    • Resolution: Fixed
    • Affects Version/s: 5.11.0
    • Fix Version/s: 5.11.1
    • Component/s: Gateways
    • Labels:
      None

      Description

      We have a customer using a reseller user on WHM/cPanel, but the token appears to be correct and it appears to have proper permissions. However, the logs show the following error:

      eneral.ERROR: curl_exec threw error "HTTP/2 stream 1 was not closed cleanly: PROTOCOL_ERROR (err 1)" for [hostname]:2087/json-api/listaccts? (same for listpkgs if we force the credentials and try to create a Package)

      The error seems to indicate that WHM is requiring HTTP/2 and that curl cannot communicate with HTTP/2

      On line 775, after curl_init() in apis/cpanel_api.php I added the following in an attempt to force HTTP/1.1

      curl_setopt($curl, CURLOPT_HTTP_VERSION, CURL_HTTP_VERSION_1_1); // Force HTTP/1.1

      It no longer produced the curl error, but if I add some debugging right after curl_close($curl) of
      var_dump($result);
      die;

      Saving the module row credentials page outputs:

      string(90) "<html><body><h1>400 Bad request</h1>
      Your browser sent an invalid request.
      </body></html>
      "

      to test via SSH/CLI

      curl -v -H "Authorization: WHM USER:TOKEN" "https://HOSTNAME:2087/json-api/listpkgs"

      Running this via SSH with the correct data does return the packages

        Activity

        admin Paul Phillips created issue -
        admin Paul Phillips made changes -
        Field Original Value New Value
        Rank Ranked higher
        admin Paul Phillips made changes -
        Description We have a customer using a reseller user on WHM/cPanel, but the token appears to be correct and it appears to have proper permissions. However, the logs show the following error:

        eneral.ERROR: curl_exec threw error "HTTP/2 stream 1 was not closed cleanly: PROTOCOL_ERROR (err 1)" for [hostname]:2087/json-api/listaccts? (same for listpkgs if we force the credentials and try to create a Package)

        The error seems to indicate that WHM is requiring HTTP/2 and that curl cannot communicate with HTTP/2

        On line 775, after curl_init() in apis/cpanel_api.php I added the following in an attempt to force HTTP/1.1

                curl_setopt($curl, CURLOPT_HTTP_VERSION, CURL_HTTP_VERSION_1_1); // Force HTTP/1.1

        It no longer produced the curl error, but if I add some debugging right after curl_close($curl) of
        var_dump($result);
        die;

        Saving the module row credentials page outputs:

        string(90) "<html><body><h1>400 Bad request</h1>
        Your browser sent an invalid request.
        </body></html>
        "
        We have a customer using a reseller user on WHM/cPanel, but the token appears to be correct and it appears to have proper permissions. However, the logs show the following error:

        eneral.ERROR: curl_exec threw error "HTTP/2 stream 1 was not closed cleanly: PROTOCOL_ERROR (err 1)" for [hostname]:2087/json-api/listaccts? (same for listpkgs if we force the credentials and try to create a Package)

        The error seems to indicate that WHM is requiring HTTP/2 and that curl cannot communicate with HTTP/2

        On line 775, after curl_init() in apis/cpanel_api.php I added the following in an attempt to force HTTP/1.1

                curl_setopt($curl, CURLOPT_HTTP_VERSION, CURL_HTTP_VERSION_1_1); // Force HTTP/1.1

        It no longer produced the curl error, but if I add some debugging right after curl_close($curl) of
        var_dump($result);
        die;

        Saving the module row credentials page outputs:

        string(90) "<html><body><h1>400 Bad request</h1>
        Your browser sent an invalid request.
        </body></html>
        "

        to test via SSH/CLI

        curl -v -H "Authorization: WHM USER:TOKEN" "https://HOSTNAME:2087/json-api/listpkgs"

        Running this via SSH with the correct data does return the packages

        abdy Abdy Franco made changes -
        Status Open [ 1 ] In Progress [ 3 ]
        abdy Abdy Franco made changes -
        Remaining Estimate 0 minutes [ 0 ]
        Time Spent 1 hour, 58 minutes [ 7080 ]
        Worklog Id 17576 [ 17576 ]
        abdy Abdy Franco made changes -
        Status In Progress [ 3 ] In Review [ 5 ]
        Resolution Fixed [ 1 ]
        jonathan Jonathan Reissmueller made changes -
        Sprint 5.11.1 Sprint 1 [ 213 ]
        jonathan Jonathan Reissmueller made changes -
        Rank Ranked higher
        jonathan Jonathan Reissmueller made changes -
        Rank Ranked higher
        admin Paul Phillips made changes -
        Security Private [ 10000 ]
        jonathan Jonathan Reissmueller made changes -
        Status In Review [ 5 ] Closed [ 6 ]

          People

          • Assignee:
            abdy Abdy Franco
            Reporter:
            admin Paul Phillips
          • Votes:
            0 Vote for this issue
            Watchers:
            1 Start watching this issue

            Dates

            • Created:
              Updated:
              Resolved:
              Fix Release Date:
              10/Mar/25

              Time Tracking

              Estimated:
              Original Estimate - Not Specified
              Not Specified
              Remaining:
              Remaining Estimate - 0 minutes
              0m
              Logged:
              Time Spent - 1 hour, 58 minutes
              1h 58m

                Agile