William Cheng 0204bf4ae2 Squashed commit of the following:
commit c5a0d0f7394aa742fa336fff7e7c1d3049761868
Merge: 8c4991ba3ed f8ff8c87609
Author: William Cheng <wing328hk@gmail.com>
Date:   Tue Aug 17 18:28:12 2021 +0800

    Merge branch 'mustache-linting' of https://github.com/NathanBaulch/openapi-generator into NathanBaulch-mustache-linting

commit f8ff8c87609b1ca36fa26fb8474806999638195e
Author: Nathan Baulch <nathan.baulch@gmail.com>
Date:   Thu Aug 5 14:12:47 2021 +1000

    Reorder tags that handle missing values

commit f5d8a33709d6a3f846a9fe4520b78c3d637051d9
Author: Nathan Baulch <nathan.baulch@gmail.com>
Date:   Thu Aug 5 14:08:59 2021 +1000

    Use dot notation where possible

commit 493d14921e2333f3ae19ef6fc89318b7e263a80c
Author: Nathan Baulch <nathan.baulch@gmail.com>
Date:   Thu Aug 5 14:10:49 2021 +1000

    Remove empty tags

commit 32480dc53f48227d55531b94e307d72671373737
Author: Nathan Baulch <nathan.baulch@gmail.com>
Date:   Thu Aug 5 10:41:58 2021 +1000

    Remove redundant sections

commit a8edabd722c34aa094b4aeb11c22664529c3a219
Author: Nathan Baulch <nathan.baulch@gmail.com>
Date:   Wed Aug 4 22:02:22 2021 +1000

    Trim extra EOF new lines

commit e89bd7458e3594bf0d30e580bc9408e45b018a57
Author: Nathan Baulch <nathan.baulch@gmail.com>
Date:   Wed Aug 4 21:59:26 2021 +1000

    Trim trailing whitespace
2021-08-17 18:37:51 +08:00
..
2021-07-10 00:12:23 +08:00
2021-08-17 18:37:51 +08:00
2021-05-18 23:09:59 +08:00
2021-05-18 23:09:59 +08:00
2021-05-18 23:09:59 +08:00
2021-05-18 23:09:59 +08:00
2021-05-18 23:09:59 +08:00
2021-08-17 18:37:51 +08:00

OpenAPI Petstore

  • API version: 1.0.0

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

Licence

Apache-2.0

for more information visit Apache-2.0

Requirements

Building the API client library requires:

  1. Java 1.7+
  2. Maven/Gradle

Installation

To install the API client library to your local Maven repository, simply execute:

mvn clean install

To deploy it to a remote Maven repository instead, configure the settings of the repository and execute:

mvn clean deploy

Refer to the OSSRH Guide for more information.

Generate manually

At first generate the JAR by executing:

mvn clean package

Use the Jar file to generate the Qt Client:

java -jar target/openapi-generator-cli.jar generate -i <yourOpenApiFile> -g cpp-qt-client -o <outputDir>

Getting Started

Please follow the installation instruction and execute the following Java code:

example.h:


#include <iostream>
#include "../client/PFXPetApi.h"

using namespace test_namespace;

class Example : public QObject {
    Q_OBJECT
    PFXPet create();
public slots:
   void exampleFunction1();
};

example.cpp:


#include "../client/PFXPetApi.h"
#include "example.h"
#include <QTimer>
#include <QEventLoop>

PFXPet Example::create(){
    PFXPet obj;
 return obj;
}

void Example::exampleFunction1(){
     PFXPetApi apiInstance;
     
      //OAuth Authentication supported right now

      QEventLoop loop;
      connect(&apiInstance, &PFXPetApi::addPetSignal, [&]() {
          loop.quit();
      });
      connect(&apiInstance, &PFXPetApi::addPetSignalE, [&](QNetworkReply::NetworkError, QString error_str) {
          qDebug() << "Error happened while issuing request : " << error_str;
          loop.quit();
      });

      PFXPet body = create(); // PFXPet | Pet object that needs to be added to the store
      apiInstance.addPet(body);
      QTimer::singleShot(5000, &loop, &QEventLoop::quit);
      loop.exec();
  }

Documentation for API Endpoints

All URIs are relative to http://petstore.swagger.io/v2

Class Method HTTP request Description
PFXPetApi addPet POST /pet Add a new pet to the store
PFXPetApi deletePet DELETE /pet/{petId} Deletes a pet
PFXPetApi findPetsByStatus GET /pet/findByStatus Finds Pets by status
PFXPetApi findPetsByTags GET /pet/findByTags Finds Pets by tags
PFXPetApi getPetById GET /pet/{petId} Find pet by ID
PFXPetApi updatePet PUT /pet Update an existing pet
PFXPetApi updatePetWithForm POST /pet/{petId} Updates a pet in the store with form data
PFXPetApi uploadFile POST /pet/{petId}/uploadImage uploads an image
PFXStoreApi deleteOrder DELETE /store/order/{orderId} Delete purchase order by ID
PFXStoreApi getInventory GET /store/inventory Returns pet inventories by status
PFXStoreApi getOrderById GET /store/order/{orderId} Find purchase order by ID
PFXStoreApi placeOrder POST /store/order Place an order for a pet
PFXUserApi createUser POST /user Create user
PFXUserApi createUsersWithArrayInput POST /user/createWithArray Creates list of users with given input array
PFXUserApi createUsersWithListInput POST /user/createWithList Creates list of users with given input array
PFXUserApi deleteUser DELETE /user/{username} Delete user
PFXUserApi getUserByName GET /user/{username} Get user by user name
PFXUserApi loginUser GET /user/login Logs user into the system
PFXUserApi logoutUser GET /user/logout Logs out current logged in user session
PFXUserApi updateUser PUT /user/{username} Updated user

Documentation for Models

Documentation for Servers

Parameterized Servers are supported. Define a server in the API for each endpoint with arbitrary numbers of variables:

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:

    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 Paramter "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:

    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. 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.

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:

api_key

  • Type: API key
  • API key parameter name: api_key
  • Location: HTTP header

petstore_auth

Author