# C++ Qt API client # OpenAPI Petstore - API version: 1.0.0 - Generator version: 7.20.0-SNAPSHOT This is a sample server Petstore server. For this sample, you can use the api key `special-key` to test the authorization filters. *Automatically generated by the [OpenAPI Generator](https://openapi-generator.tech)* ## Requirements Building the API client library requires: 1. CMake 3.2+ 2. Qt 3. C++ Compiler ## Getting Started example.h: ```c++ #include #include "../client/PFXFakeApi.h" using namespace test_namespace; class Example : public QObject { Q_OBJECT QString create(); PFXEnumStatus create(); public Q_SLOTS: void exampleFunction1(); }; ``` example.cpp: ```c++ #include "../client/PFXFakeApi.h" #include "example.h" #include #include QString Example::create(){ QString obj; PFXEnumStatus Example::create(){ PFXEnumStatus obj; return obj; } void Example::exampleFunction1(){ PFXFakeApi apiInstance; QEventLoop loop; connect(&apiInstance, &PFXFakeApi::getEnumInlineOrRefSignal, [&]() { loop.quit(); }); connect(&apiInstance, &PFXFakeApi::getEnumInlineOrRefSignalE, [&](QNetworkReply::NetworkError, QString error_str) { qDebug() << "Error happened while issuing request : " << error_str; loop.quit(); }); QString enum_inline = create(); // QString | Enum status inline QEventLoop loop; connect(&apiInstance, &PFXFakeApi::getEnumInlineOrRefSignal, [&]() { loop.quit(); }); connect(&apiInstance, &PFXFakeApi::getEnumInlineOrRefSignalE, [&](QNetworkReply::NetworkError, QString error_str) { qDebug() << "Error happened while issuing request : " << error_str; loop.quit(); }); PFXEnumStatus enum_ref = create(); // PFXEnumStatus | Enum status apiInstance.getEnumInlineOrRef(enum_inlineenum_ref); QTimer::singleShot(5000, &loop, &QEventLoop::quit); loop.exec(); } ``` ## Documentation for Servers Parameterized Servers are supported. Define a server in the API for each endpoint with arbitrary numbers of variables: ```yaml servers: - url: http://{server}:{port}/{basePath} description: Description of the Server variables: server: enum: - 'petstore' - 'qa-petstore' - 'dev-petstore' default: 'petstore' port: enum: - '3000' - '1000' default: '3000' basePath: default: v1 ``` To change the default variable, use this function in each Api: ```c++ int setDefaultServerValue(int serverIndex,const QString &operation, const QString &variable,const QString &val); ``` The parameter "serverIndex" will choose a server from the server list for each endpoint. There is always at least one server with index 0. The Parameter "operation" should be the desired endpoint operationid. Variable is the name of the variable you wish to change and the value is the new default Value. The function will return -1 when the variable does not exists, -2 if value is not defined in the variable enum and -3 if the operation is not found. If your endpoint has multiple server objects in the servers array, you can set the server that will be used with this function: ```c++ void setServerIndex(const QString &operation, int serverIndex); ``` Parameter "operation" should be your operationid. "serverIndex" is the index you want to set as your default server. The function will check if there is a server with your index. Alternatively, to set the server index globally for all operations: ```c++ void setServerIndex(int serverIndex); ``` This will apply the specified server index to all operations in the API. Here is an example of multiple servers in the servers array. The first server will have index 0 and the second will have index 1. ```yaml servers: - url: http://{server}:8080/ description: Description of the Server variables: server: enum: - 'petstore' - 'qa-petstore' - 'dev-petstore' default: 'petstore' - url: https://localhost:8080/v1 ``` ## Documentation for Authorization Authentication schemes defined for the API: ### petstore_auth - **Type**: OAuth - **Flow**: implicit - **Authorization URL**: http://petstore.swagger.io/api/oauth/dialog - **Scopes**: - write:pets: modify pets in your account - read:pets: read your pets ### api_key - **Type**: API key - **API key parameter name**: api_key - **Location**: HTTP header ## Author ## License Apache-2.0 for more information visit [Apache-2.0](https://www.apache.org/licenses/LICENSE-2.0.html)