Skip to content
New issue

Have a question about this project? Sign up for a free GitHub account to open an issue and contact its maintainers and the community.

By clicking “Sign up for GitHub”, you agree to our terms of service and privacy statement. We’ll occasionally send you account related emails.

Already on GitHub? Sign in to your account

CURL support via scripting. #160

Open
wants to merge 8 commits into
base: master
Choose a base branch
from

Conversation

ohlidalp
Copy link
Member

@ohlidalp ohlidalp commented Dec 23, 2024

Added a CURL request function to scripting API. Please see updated 'example-script.as' for all details.

To test, spin up a server with the example script and say "CURL test" in chat - this sends a GET request to https://www.rigsofrods.org.

Known issue: the option RORSERVER_WITH_CURL doesn't come up in cmake-gui for some reason. @AnotherFoxGuy can you troubleshoot it please?

Status: builds, not tested yet.

The new HTTP(S) request API:
```
    /**
    * Launches a background task, use `curlStatus` callback to monitor progress and receive result.
    * @param displayname The "correlation ID" - the label passed to the callback to identify the transfer.
    * @remark Callback signature: `curlStatus(curlStatusType, int n1, int n2, string displayname, string message)`
    * - for CURL_STATUS_PROGRESS, n1 = bytes downloaded, n2 = total bytes,
    * - otherwise, n1 = CURL return code, n2 = HTTP result code.
    */
    void fetchUrlAsStringAsync(std::string url, std::string displayname);
```

The new status reporting callback:
```
enum CurlStatusType
{
    CURL_STATUS_INVALID,
    CURL_STATUS_PROGRESS,
    CURL_STATUS_SUCCESS,
    CURL_STATUS_FAILURE,
};

    /**
     * Params `n1` and `n2` depend on status type :
     * - for CURL_STATUS_PROGRESS, n1 = bytes downloaded, n2 = total bytes,
     * - otherwise, n1 = CURL return code, n2 = HTTP result code.
     */
    void curlStatus(CurlStatusType type, int n1, int n2, std::string displayname, std::string message);
```
See updated 'example-script.as'
cmake_dependent_option(RORSERVER_WITH_ANGELSCRIPT "Adds scripting support" ON "TARGET Angelscript::angelscript" OFF)
cmake_dependent_option(RORSERVER_WITH_CURL "Adds CURL request support (needs AngelScript)" ON "TARGET CURL:libcurl" OFF)
Copy link
Member

@AnotherFoxGuy AnotherFoxGuy Jan 8, 2025

Choose a reason for hiding this comment

The reason will be displayed to describe this comment to others. Learn more.

This is the cause of CURL not being found

Suggested change
cmake_dependent_option(RORSERVER_WITH_CURL "Adds CURL request support (needs AngelScript)" ON "TARGET CURL:libcurl" OFF)
cmake_dependent_option(RORSERVER_WITH_CURL "Adds CURL request support (needs AngelScript)" ON "TARGET CURL::libcurl" OFF)

Sign up for free to join this conversation on GitHub. Already have an account? Sign in to comment
Labels
None yet
Projects
None yet
Development

Successfully merging this pull request may close these issues.

2 participants