kiwi-oss dec8a430df
[Microprofile] Add option to use tags a client keys and server generator (#16673)
* [Java/Microprofile] Add support for Jackson serialization & async interfaces using Mutiny in Java Microprofile library

* Regenerate samples & docs

* Add server generator

* Update client to set configKey by classname

* Remove debug remains and comments

* Adapt method override to upstream changes

* Regenerate samples

* Revert "Regenerate samples"

This reverts commit b5bcbdea90c71a2819a3ea6339c3878f249f97b4.

* Move additional 2xx response to dedicated OpenAPI document

Some other generators than those for Micronaut don't seem to be able to
handle this case, so we don't add it to the general pet store document.

* Make filename consistent with other files in the folder

* Regenerate Microprofile client and server samples

* Generate samples

* Update documentation

* Generate samples

* Remove left-over `*.orig` files from Git merges

* Regenerate samples

* Regenerated samples

* changed generator name to "java-microprofile"

* added the new folder to .github/workflows/samples-java-server-jdk8.yaml so that CI will test it moving forward

* Renamed JavaMicroprofileServerCodegen.java

* regenerated samples

* only enable configKeyFromClassName if configKey is not set

* Updated documentation

* Change samples to use junit 4

* Fix junit 4 test classes

* run ensure up-to-date script

* fix kotlin test errors

---------

Co-authored-by: pravussum <pravussum@users.noreply.github.com>
Co-authored-by: frank <frank.buechel@kiwigrid.com>
Co-authored-by: Oscar <oscar.obrien@kiwigrid.com>
Co-authored-by: oscarobr <133783370+oscarobr@users.noreply.github.com>
2024-05-07 16:24:23 +08:00
..
2024-04-17 19:05:37 +08:00
2018-11-17 01:32:18 +08:00
2024-04-17 19:05:37 +08:00

C API client for openapi_petstore

Overview

This API client was generated by the OpenAPI Generator project. By using the OpenAPI spec from a remote server, you can easily generate an API client.

  • API version: 1.0.0
  • Package version:
  • Generator version: 7.6.0-SNAPSHOT
  • Build package: org.openapitools.codegen.languages.CLibcurlClientCodegen

Installation

You'll need the curl 7.58.0 package in order to build the API. To have code formatted nicely, you also need to have uncrustify version 0.67 or later.

Prerequisites

Install the curl 7.58.0 package with the following command on Linux.

sudo apt remove curl
wget http://curl.haxx.se/download/curl-7.58.0.tar.gz
tar -xvf curl-7.58.0.tar.gz
cd curl-7.58.0/
./configure
make
sudo make install

Install the uncrustify 0.67 package with the following command on Linux.

git clone https://github.com/uncrustify/uncrustify.git
cd uncrustify
mkdir build
cd build
cmake ..
make
sudo make install

Compile the sample:

This will compile the generated code and create a library in the build folder which has to be linked to the codes where API will be used.

mkdir build
cd build
// To install library to specific location, use following commands
cmake -DCMAKE_INSTALL_PREFIX=/pathtolocation ..
// for normal install use following command
cmake ..
make
sudo make install

How to use compiled library

Considering the test/source code which uses the API is written in main.c(respective api include is written and all objects necessary are defined and created)

To compile main.c(considering the file is present in build folder) use following command -L - location of the library(not required if cmake with normal installation is performed) -l library name

gcc main.c -L. -lopenapi_petstore -o main

Once compiled, you can run it with ./main

Note: You don't need to specify includes for models and include folder separately as they are path linked. You just have to import the api.h file in your code, the include linking will work.

Documentation for API Endpoints

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

Category Method HTTP request Description
PetAPI PetAPI_addPet POST /pet Add a new pet to the store
PetAPI PetAPI_deletePet DELETE /pet/{petId} Deletes a pet
PetAPI PetAPI_findPetsByStatus GET /pet/findByStatus Finds Pets by status
PetAPI PetAPI_findPetsByTags GET /pet/findByTags Finds Pets by tags
PetAPI PetAPI_getPetById GET /pet/{petId} Find pet by ID
PetAPI PetAPI_updatePet PUT /pet Update an existing pet
PetAPI PetAPI_updatePetWithForm POST /pet/{petId} Updates a pet in the store with form data
PetAPI PetAPI_uploadFile POST /pet/{petId}/uploadImage uploads an image
StoreAPI StoreAPI_deleteOrder DELETE /store/order/{orderId} Delete purchase order by ID
StoreAPI StoreAPI_getInventory GET /store/inventory Returns pet inventories by status
StoreAPI StoreAPI_getOrderById GET /store/order/{orderId} Find purchase order by ID
StoreAPI StoreAPI_placeOrder POST /store/order Place an order for a pet
UserAPI UserAPI_createUser POST /user Create user
UserAPI UserAPI_createUsersWithArrayInput POST /user/createWithArray Creates list of users with given input array
UserAPI UserAPI_createUsersWithListInput POST /user/createWithList Creates list of users with given input array
UserAPI UserAPI_deleteUser DELETE /user/{username} Delete user
UserAPI UserAPI_getUserByName GET /user/{username} Get user by user name
UserAPI UserAPI_loginUser GET /user/login Logs user into the system
UserAPI UserAPI_logoutUser GET /user/logout Logs out current logged in user session
UserAPI UserAPI_testIntAndBool GET /user/testIntAndBool test integer and boolean query parameters in API
UserAPI UserAPI_updateUser PUT /user/{username} Updated user

Documentation for Models

Documentation for Authorization

Authentication schemes defined for the API:

petstore_auth

api_key

  • Type: API key

  • API key parameter name: api_key

  • Location: HTTP header

Author