Docs on github pages in separate branch
The docs will now be hosted in a separate gh-pages branch and will update on every push to the main branch.
44
.github/workflows/docs-gh-pages.yml
vendored
Normal file
@ -0,0 +1,44 @@
|
|||||||
|
name: Generate and Deploy Swagger Docs on Github Pages
|
||||||
|
|
||||||
|
on:
|
||||||
|
push:
|
||||||
|
branches:
|
||||||
|
- main
|
||||||
|
|
||||||
|
jobs:
|
||||||
|
docs:
|
||||||
|
runs-on: ubuntu-latest
|
||||||
|
steps:
|
||||||
|
- uses: actions/checkout@v2
|
||||||
|
- name: Get latest swagger version
|
||||||
|
id: swagger-ui
|
||||||
|
run: |
|
||||||
|
echo ::set-output name=release_tag::$(curl -sL https://api.github.com/repos/swagger-api/swagger-ui/releases/latest | jq -r ".tag_name")
|
||||||
|
- name: Generate Docs
|
||||||
|
env:
|
||||||
|
RELEASE_TAG: ${{ steps.swagger-ui.outputs.release_tag }}
|
||||||
|
SWAGGER_YAML: "tdlight-api-openapi.yaml"
|
||||||
|
TITLE: "tdlight Telegram bot API docs"
|
||||||
|
run: |
|
||||||
|
mkdir docs
|
||||||
|
cp -r icons/ docs/icons/
|
||||||
|
cp tdlight-api-openapi.yaml docs/tdlight-api-openapi.yaml
|
||||||
|
cd docs
|
||||||
|
# Download the release
|
||||||
|
curl -sL -o $RELEASE_TAG https://api.github.com/repos/swagger-api/swagger-ui/tarball/$RELEASE_TAG
|
||||||
|
# Extract the dist directory
|
||||||
|
tar -xzf $RELEASE_TAG --strip-components=1 $(tar -tzf $RELEASE_TAG | head -1 | cut -f1 -d"/")/dist
|
||||||
|
rm $RELEASE_TAG
|
||||||
|
# Move index.html
|
||||||
|
mv dist/index.html .
|
||||||
|
# Fix references in index.html
|
||||||
|
sed -i "s|https://petstore.swagger.io/v2/swagger.json|$SWAGGER_YAML|g" index.html
|
||||||
|
sed -i "s|href=\"./|href=\"dist/|g" index.html
|
||||||
|
sed -i "s|src=\"./|src=\"dist/|g" index.html
|
||||||
|
sed -i "s|dist/favicon|icons/favicon|g" index.html
|
||||||
|
sed -i "s|<title>.*</title>|<title>$TITLE</title>|g" index.html
|
||||||
|
- name: Deploy
|
||||||
|
uses: peaceiris/actions-gh-pages@v3
|
||||||
|
with:
|
||||||
|
github_token: ${{ secrets.GITHUB_TOKEN }}
|
||||||
|
publish_dir: ./docs
|
56
.github/workflows/update-swagger.yml
vendored
@ -1,56 +0,0 @@
|
|||||||
name: Update Swagger UI
|
|
||||||
on:
|
|
||||||
schedule:
|
|
||||||
- cron: '0 10 * * *'
|
|
||||||
repository_dispatch:
|
|
||||||
types: [update-swagger-ui]
|
|
||||||
jobs:
|
|
||||||
updateSwagger:
|
|
||||||
runs-on: ubuntu-latest
|
|
||||||
steps:
|
|
||||||
- uses: actions/checkout@v2
|
|
||||||
- name: Get Latest Swagger UI Release
|
|
||||||
id: swagger-ui
|
|
||||||
run: |
|
|
||||||
echo ::set-output name=release_tag::$(curl -sL https://api.github.com/repos/swagger-api/swagger-ui/releases/latest | jq -r ".tag_name")
|
|
||||||
echo ::set-output name=current_tag::$(<docs/swagger-ui.version)
|
|
||||||
- name: Update Swagger UI
|
|
||||||
if: steps.swagger-ui.outputs.current_tag != steps.swagger-ui.outputs.release_tag
|
|
||||||
env:
|
|
||||||
RELEASE_TAG: ${{ steps.swagger-ui.outputs.release_tag }}
|
|
||||||
SWAGGER_YAML: "tdlight-api-openapi.yaml"
|
|
||||||
TITLE: "tdlight Telegram bot API docs"
|
|
||||||
run: |
|
|
||||||
# move to the docs directory
|
|
||||||
cd docs
|
|
||||||
# Delete the dist directory and index.html
|
|
||||||
rm -fr dist index.html
|
|
||||||
# Download the release
|
|
||||||
curl -sL -o $RELEASE_TAG https://api.github.com/repos/swagger-api/swagger-ui/tarball/$RELEASE_TAG
|
|
||||||
# Extract the dist directory
|
|
||||||
tar -xzf $RELEASE_TAG --strip-components=1 $(tar -tzf $RELEASE_TAG | head -1 | cut -f1 -d"/")/dist
|
|
||||||
rm $RELEASE_TAG
|
|
||||||
# Move index.html to the root
|
|
||||||
mv dist/index.html .
|
|
||||||
# Fix references in index.html
|
|
||||||
sed -i "s|https://petstore.swagger.io/v2/swagger.json|$SWAGGER_YAML|g" index.html
|
|
||||||
sed -i "s|href=\"./|href=\"dist/|g" index.html
|
|
||||||
sed -i "s|src=\"./|src=\"dist/|g" index.html
|
|
||||||
sed -i "s|dist/favicon|icons/favicon|g" index.html
|
|
||||||
sed -i "s|<title>.*</title>|<title>$TITLE</title>|g" index.html
|
|
||||||
# Update current release
|
|
||||||
echo ${{ steps.swagger-ui.outputs.release_tag }} > swagger-ui.version
|
|
||||||
- name: Create Pull Request
|
|
||||||
uses: peter-evans/create-pull-request@v3
|
|
||||||
with:
|
|
||||||
commit-message: Update swagger-ui to ${{ steps.swagger-ui.outputs.release_tag }}
|
|
||||||
title: Update SwaggerUI to ${{ steps.swagger-ui.outputs.release_tag }}
|
|
||||||
body: |
|
|
||||||
Updates [swagger-ui][1] to ${{ steps.swagger-ui.outputs.release_tag }}
|
|
||||||
|
|
||||||
Auto-generated by [create-pull-request][2]
|
|
||||||
|
|
||||||
[1]: https://github.com/swagger-api/swagger-ui
|
|
||||||
[2]: https://github.com/peter-evans/create-pull-request
|
|
||||||
labels: dependencies, automated pr
|
|
||||||
branch: swagger-ui-updates
|
|
104
docs/README.md
@ -1,104 +0,0 @@
|
|||||||
# Welcome to the documentation of tdlight Telegram Bot API
|
|
||||||
You can always see the up-to-date Swagger documentation here: [https://tdlight-team.github.io/tdlight-telegram-bot-api/](https://tdlight-team.github.io/tdlight-telegram-bot-api/)
|
|
||||||
|
|
||||||
## Table of Contents
|
|
||||||
- [Added Command Line Parameters](#added-command-line-parameters)
|
|
||||||
- [Modified features](#modified-features)
|
|
||||||
- [User Mode](#user-mode)
|
|
||||||
- [User Authorization Process](#user-authorization)
|
|
||||||
- [Add your changes to the documentation](#documentation)
|
|
||||||
|
|
||||||
## Additional changes
|
|
||||||
<a name="added-command-line-parameters"></a>
|
|
||||||
### Added Command Line Parameters
|
|
||||||
#### Flag `--relative`
|
|
||||||
If enabled, allow only relative paths for files in local mode.
|
|
||||||
|
|
||||||
#### Flag `--insecure`
|
|
||||||
Allow http connection in non-local mode
|
|
||||||
|
|
||||||
#### Flag `--max-batch-operations=<number>`
|
|
||||||
maximum number of batch operations (default 10000)
|
|
||||||
|
|
||||||
#### Executable parameter `--stats-hide-sensible-data`
|
|
||||||
Makes the stats page (if enabled) hide the bot token and the webhook url to no leak user secrets, when served publicly.
|
|
||||||
This repository is a template for using the [Swagger UI](https://github.com/swagger-api/swagger-ui) to dynamically generate beautiful documentation for your API and host it for free with GitHub Pages.
|
|
||||||
|
|
||||||
<a name="modified-features"></a>
|
|
||||||
### Modified features
|
|
||||||
|
|
||||||
#### Method `getChat`
|
|
||||||
The command `getChat` will also try to resolve the username online, if it can't be found locally
|
|
||||||
|
|
||||||
In addition, the member list now shows the full bot list (previously only the bot that executed the query was shown)
|
|
||||||
|
|
||||||
The bot will now receive Updates for all received media, even if a destruction timer is set.
|
|
||||||
|
|
||||||
<a name="user-mode"></a>
|
|
||||||
### User Mode
|
|
||||||
|
|
||||||
You can allow user accounts to access the bot api with the command-line option `--allow-users` or set the env variable
|
|
||||||
`TELEGRAM_ALLOW_USERS` to `1` when using docker. User Mode is disabled by default, so only bots can access the api.
|
|
||||||
|
|
||||||
You can now log into the bot api with user accounts to create userbots running on your account.
|
|
||||||
|
|
||||||
Note: Never send your 2fa password over a plain http connection. Make sure https is enabled or use this api locally.
|
|
||||||
|
|
||||||
<a name="user-authorization"></a>
|
|
||||||
#### User Authorization Process
|
|
||||||
Read the detailed Swagger documentation for more information about these methods.
|
|
||||||
|
|
||||||
1. Send a request to `{api_url}/userlogin`
|
|
||||||
|
|
||||||
Returns your `user_token` as `string`. You can use this just like a normal bot token on the `/user` endpoint
|
|
||||||
|
|
||||||
2. Send the received code to `{api_url}/user{user_token}/authCode`
|
|
||||||
|
|
||||||
3. Optional: Send your 2fa password to `{api_url}/user{user_token}/authPassword`
|
|
||||||
|
|
||||||
4. Optional: Register the user by calling `{api_url}/user{user_token}/registerUser`.
|
|
||||||
|
|
||||||
User registration is disabled by default. You can enable it with the `--allow-users-registration` command line
|
|
||||||
option or the env variable `TELEGRAM_ALLOW_USERS_REGISTRATION` set to `1` when using docker.
|
|
||||||
|
|
||||||
You are now logged in and can use all methods like in the bot api, just replace the
|
|
||||||
`/bot{bot_token}/` in your urls with `/user{token}/`.
|
|
||||||
|
|
||||||
You only need to authenticate once, the account will stay logged in. You can use the `logOut` method to log out
|
|
||||||
or simply close the session in your account settings.
|
|
||||||
|
|
||||||
Some methods are (obviously) not available as a user. This includes:
|
|
||||||
- `answerCallbackQuery`
|
|
||||||
- `setMyCommands`
|
|
||||||
- `editMessageReplyMarkup`
|
|
||||||
- `uploadStickerFile`
|
|
||||||
- `createNewStickerSet`
|
|
||||||
- `addStickerToSet`
|
|
||||||
- `setStickerPositionInSet`
|
|
||||||
- `deleteStickerFromSet`
|
|
||||||
- `setStickerSetThumb`
|
|
||||||
- `sendInvoice`
|
|
||||||
- `answerShippingQuery`
|
|
||||||
- `answerPreCheckoutQuery`
|
|
||||||
- `setPassportDataErrors`
|
|
||||||
- `sendGame`
|
|
||||||
- `setGameScore`
|
|
||||||
- `getGameHighscores`
|
|
||||||
|
|
||||||
It is also not possible to attach a `reply_markup` to any message.
|
|
||||||
|
|
||||||
Your api wrapper may behave different in some cases, for examples command message-entities
|
|
||||||
are not created in chats that don't contain anybots, so your Command Handler may not detect it.
|
|
||||||
|
|
||||||
It is possible to have multiple user-tokens to multiple client instances on the same bot api server.
|
|
||||||
|
|
||||||
<a name="documentation"></a>
|
|
||||||
## Add your changes to the documentation
|
|
||||||
|
|
||||||
You can simply add your changes to the Swagger documentation by editing the `tdlight-api-openapi.yaml` file.
|
|
||||||
We suggest that you use a Swagger editor like [https://editor.swagger.io/](https://editor.swagger.io/) for that.
|
|
||||||
|
|
||||||
You can find more information about openAPI here: [https://swagger.io/specification/](https://swagger.io/specification/)
|
|
||||||
|
|
||||||
Setting a custom endpoint to use the `Try it out` feature requires to set CORS headers. We suggest that you configure the
|
|
||||||
header `Access-Control-Allow-Origin: *` on your proxy.
|
|
BIN
docs/dist/favicon-16x16.png
vendored
Before Width: | Height: | Size: 665 B |
BIN
docs/dist/favicon-32x32.png
vendored
Before Width: | Height: | Size: 628 B |
74
docs/dist/oauth2-redirect.html
vendored
@ -1,74 +0,0 @@
|
|||||||
<!doctype html>
|
|
||||||
<html lang="en-US">
|
|
||||||
<head>
|
|
||||||
<title>Swagger UI: OAuth2 Redirect</title>
|
|
||||||
</head>
|
|
||||||
<body>
|
|
||||||
</body>
|
|
||||||
</html>
|
|
||||||
<script>
|
|
||||||
'use strict';
|
|
||||||
function run () {
|
|
||||||
var oauth2 = window.opener.swaggerUIRedirectOauth2;
|
|
||||||
var sentState = oauth2.state;
|
|
||||||
var redirectUrl = oauth2.redirectUrl;
|
|
||||||
var isValid, qp, arr;
|
|
||||||
|
|
||||||
if (/code|token|error/.test(window.location.hash)) {
|
|
||||||
qp = window.location.hash.substring(1);
|
|
||||||
} else {
|
|
||||||
qp = location.search.substring(1);
|
|
||||||
}
|
|
||||||
|
|
||||||
arr = qp.split("&")
|
|
||||||
arr.forEach(function (v,i,_arr) { _arr[i] = '"' + v.replace('=', '":"') + '"';})
|
|
||||||
qp = qp ? JSON.parse('{' + arr.join() + '}',
|
|
||||||
function (key, value) {
|
|
||||||
return key === "" ? value : decodeURIComponent(value)
|
|
||||||
}
|
|
||||||
) : {}
|
|
||||||
|
|
||||||
isValid = qp.state === sentState
|
|
||||||
|
|
||||||
if ((
|
|
||||||
oauth2.auth.schema.get("flow") === "accessCode"||
|
|
||||||
oauth2.auth.schema.get("flow") === "authorizationCode"
|
|
||||||
) && !oauth2.auth.code) {
|
|
||||||
if (!isValid) {
|
|
||||||
oauth2.errCb({
|
|
||||||
authId: oauth2.auth.name,
|
|
||||||
source: "auth",
|
|
||||||
level: "warning",
|
|
||||||
message: "Authorization may be unsafe, passed state was changed in server Passed state wasn't returned from auth server"
|
|
||||||
});
|
|
||||||
}
|
|
||||||
|
|
||||||
if (qp.code) {
|
|
||||||
delete oauth2.state;
|
|
||||||
oauth2.auth.code = qp.code;
|
|
||||||
oauth2.callback({auth: oauth2.auth, redirectUrl: redirectUrl});
|
|
||||||
} else {
|
|
||||||
let oauthErrorMsg
|
|
||||||
if (qp.error) {
|
|
||||||
oauthErrorMsg = "["+qp.error+"]: " +
|
|
||||||
(qp.error_description ? qp.error_description+ ". " : "no accessCode received from the server. ") +
|
|
||||||
(qp.error_uri ? "More info: "+qp.error_uri : "");
|
|
||||||
}
|
|
||||||
|
|
||||||
oauth2.errCb({
|
|
||||||
authId: oauth2.auth.name,
|
|
||||||
source: "auth",
|
|
||||||
level: "error",
|
|
||||||
message: oauthErrorMsg || "[Authorization failed]: no accessCode received from the server"
|
|
||||||
});
|
|
||||||
}
|
|
||||||
} else {
|
|
||||||
oauth2.callback({auth: oauth2.auth, token: qp, isValid: isValid, redirectUrl: redirectUrl});
|
|
||||||
}
|
|
||||||
window.close();
|
|
||||||
}
|
|
||||||
|
|
||||||
window.addEventListener('DOMContentLoaded', function () {
|
|
||||||
run();
|
|
||||||
});
|
|
||||||
</script>
|
|
3
docs/dist/swagger-ui-bundle.js
vendored
1
docs/dist/swagger-ui-bundle.js.map
vendored
3
docs/dist/swagger-ui-es-bundle-core.js
vendored
1
docs/dist/swagger-ui-es-bundle-core.js.map
vendored
3
docs/dist/swagger-ui-es-bundle.js
vendored
1
docs/dist/swagger-ui-es-bundle.js.map
vendored
3
docs/dist/swagger-ui-standalone-preset.js
vendored
4
docs/dist/swagger-ui.css
vendored
1
docs/dist/swagger-ui.css.map
vendored
3
docs/dist/swagger-ui.js
vendored
1
docs/dist/swagger-ui.js.map
vendored
@ -1,61 +0,0 @@
|
|||||||
<!-- HTML for static distribution bundle build -->
|
|
||||||
<!DOCTYPE html>
|
|
||||||
<html lang="en">
|
|
||||||
<head>
|
|
||||||
<meta charset="UTF-8">
|
|
||||||
<title>tdlight Telegram bot API docs</title>
|
|
||||||
<link rel="stylesheet" type="text/css" href="dist/swagger-ui.css" >
|
|
||||||
<link rel="icon" type="image/png" href="icons/favicon-196x196.png" sizes="196x196" />
|
|
||||||
<link rel="icon" type="image/png" href="icons/favicon-32x32.png" sizes="32x32" />
|
|
||||||
<link rel="icon" type="image/png" href="icons/favicon-16x16.png" sizes="16x16" />
|
|
||||||
<style>
|
|
||||||
html
|
|
||||||
{
|
|
||||||
box-sizing: border-box;
|
|
||||||
overflow: -moz-scrollbars-vertical;
|
|
||||||
overflow-y: scroll;
|
|
||||||
}
|
|
||||||
|
|
||||||
*,
|
|
||||||
*:before,
|
|
||||||
*:after
|
|
||||||
{
|
|
||||||
box-sizing: inherit;
|
|
||||||
}
|
|
||||||
|
|
||||||
body
|
|
||||||
{
|
|
||||||
margin:0;
|
|
||||||
background: #fafafa;
|
|
||||||
}
|
|
||||||
</style>
|
|
||||||
</head>
|
|
||||||
|
|
||||||
<body>
|
|
||||||
<div id="swagger-ui"></div>
|
|
||||||
|
|
||||||
<script src="dist/swagger-ui-bundle.js" charset="UTF-8"> </script>
|
|
||||||
<script src="dist/swagger-ui-standalone-preset.js" charset="UTF-8"> </script>
|
|
||||||
<script>
|
|
||||||
window.onload = function() {
|
|
||||||
// Begin Swagger UI call region
|
|
||||||
const ui = SwaggerUIBundle({
|
|
||||||
url: "tdlight-api-openapi.yaml",
|
|
||||||
dom_id: '#swagger-ui',
|
|
||||||
deepLinking: true,
|
|
||||||
presets: [
|
|
||||||
SwaggerUIBundle.presets.apis,
|
|
||||||
SwaggerUIStandalonePreset
|
|
||||||
],
|
|
||||||
plugins: [
|
|
||||||
SwaggerUIBundle.plugins.DownloadUrl
|
|
||||||
],
|
|
||||||
layout: "StandaloneLayout"
|
|
||||||
})
|
|
||||||
// End Swagger UI call region
|
|
||||||
|
|
||||||
window.ui = ui
|
|
||||||
}
|
|
||||||
</script>
|
|
||||||
</body>
|
|
||||||
</html>
|
|
@ -1 +0,0 @@
|
|||||||
v3.38.0
|
|
@ -1,718 +0,0 @@
|
|||||||
---
|
|
||||||
swagger: "2.0"
|
|
||||||
info:
|
|
||||||
description: "This is a sample server Petstore server. You can find out more about\
|
|
||||||
\ Swagger at [http://swagger.io](http://swagger.io) or on [irc.freenode.net, #swagger](http://swagger.io/irc/).\
|
|
||||||
\ For this sample, you can use the api key `special-key` to test the authorization\
|
|
||||||
\ filters."
|
|
||||||
version: "1.0.5"
|
|
||||||
title: "Swagger Petstore"
|
|
||||||
termsOfService: "http://swagger.io/terms/"
|
|
||||||
contact:
|
|
||||||
email: "apiteam@swagger.io"
|
|
||||||
license:
|
|
||||||
name: "Apache 2.0"
|
|
||||||
url: "http://www.apache.org/licenses/LICENSE-2.0.html"
|
|
||||||
host: "petstore.swagger.io"
|
|
||||||
basePath: "/v2"
|
|
||||||
tags:
|
|
||||||
- name: "pet"
|
|
||||||
description: "Everything about your Pets"
|
|
||||||
externalDocs:
|
|
||||||
description: "Find out more"
|
|
||||||
url: "http://swagger.io"
|
|
||||||
- name: "store"
|
|
||||||
description: "Access to Petstore orders"
|
|
||||||
- name: "user"
|
|
||||||
description: "Operations about user"
|
|
||||||
externalDocs:
|
|
||||||
description: "Find out more about our store"
|
|
||||||
url: "http://swagger.io"
|
|
||||||
schemes:
|
|
||||||
- "https"
|
|
||||||
- "http"
|
|
||||||
paths:
|
|
||||||
/pet/{petId}/uploadImage:
|
|
||||||
post:
|
|
||||||
tags:
|
|
||||||
- "pet"
|
|
||||||
summary: "uploads an image"
|
|
||||||
description: ""
|
|
||||||
operationId: "uploadFile"
|
|
||||||
consumes:
|
|
||||||
- "multipart/form-data"
|
|
||||||
produces:
|
|
||||||
- "application/json"
|
|
||||||
parameters:
|
|
||||||
- name: "petId"
|
|
||||||
in: "path"
|
|
||||||
description: "ID of pet to update"
|
|
||||||
required: true
|
|
||||||
type: "integer"
|
|
||||||
format: "int64"
|
|
||||||
- name: "additionalMetadata"
|
|
||||||
in: "formData"
|
|
||||||
description: "Additional data to pass to server"
|
|
||||||
required: false
|
|
||||||
type: "string"
|
|
||||||
- name: "file"
|
|
||||||
in: "formData"
|
|
||||||
description: "file to upload"
|
|
||||||
required: false
|
|
||||||
type: "file"
|
|
||||||
responses:
|
|
||||||
200:
|
|
||||||
description: "successful operation"
|
|
||||||
schema:
|
|
||||||
$ref: "#/definitions/ApiResponse"
|
|
||||||
security:
|
|
||||||
- petstore_auth:
|
|
||||||
- "write:pets"
|
|
||||||
- "read:pets"
|
|
||||||
/pet:
|
|
||||||
post:
|
|
||||||
tags:
|
|
||||||
- "pet"
|
|
||||||
summary: "Add a new pet to the store"
|
|
||||||
description: ""
|
|
||||||
operationId: "addPet"
|
|
||||||
consumes:
|
|
||||||
- "application/json"
|
|
||||||
- "application/xml"
|
|
||||||
produces:
|
|
||||||
- "application/json"
|
|
||||||
- "application/xml"
|
|
||||||
parameters:
|
|
||||||
- in: "body"
|
|
||||||
name: "body"
|
|
||||||
description: "Pet object that needs to be added to the store"
|
|
||||||
required: true
|
|
||||||
schema:
|
|
||||||
$ref: "#/definitions/Pet"
|
|
||||||
responses:
|
|
||||||
405:
|
|
||||||
description: "Invalid input"
|
|
||||||
security:
|
|
||||||
- petstore_auth:
|
|
||||||
- "write:pets"
|
|
||||||
- "read:pets"
|
|
||||||
put:
|
|
||||||
tags:
|
|
||||||
- "pet"
|
|
||||||
summary: "Update an existing pet"
|
|
||||||
description: ""
|
|
||||||
operationId: "updatePet"
|
|
||||||
consumes:
|
|
||||||
- "application/json"
|
|
||||||
- "application/xml"
|
|
||||||
produces:
|
|
||||||
- "application/json"
|
|
||||||
- "application/xml"
|
|
||||||
parameters:
|
|
||||||
- in: "body"
|
|
||||||
name: "body"
|
|
||||||
description: "Pet object that needs to be added to the store"
|
|
||||||
required: true
|
|
||||||
schema:
|
|
||||||
$ref: "#/definitions/Pet"
|
|
||||||
responses:
|
|
||||||
400:
|
|
||||||
description: "Invalid ID supplied"
|
|
||||||
404:
|
|
||||||
description: "Pet not found"
|
|
||||||
405:
|
|
||||||
description: "Validation exception"
|
|
||||||
security:
|
|
||||||
- petstore_auth:
|
|
||||||
- "write:pets"
|
|
||||||
- "read:pets"
|
|
||||||
/pet/findByStatus:
|
|
||||||
get:
|
|
||||||
tags:
|
|
||||||
- "pet"
|
|
||||||
summary: "Finds Pets by status"
|
|
||||||
description: "Multiple status values can be provided with comma separated strings"
|
|
||||||
operationId: "findPetsByStatus"
|
|
||||||
produces:
|
|
||||||
- "application/json"
|
|
||||||
- "application/xml"
|
|
||||||
parameters:
|
|
||||||
- name: "status"
|
|
||||||
in: "query"
|
|
||||||
description: "Status values that need to be considered for filter"
|
|
||||||
required: true
|
|
||||||
type: "array"
|
|
||||||
items:
|
|
||||||
type: "string"
|
|
||||||
enum:
|
|
||||||
- "available"
|
|
||||||
- "pending"
|
|
||||||
- "sold"
|
|
||||||
default: "available"
|
|
||||||
collectionFormat: "multi"
|
|
||||||
responses:
|
|
||||||
200:
|
|
||||||
description: "successful operation"
|
|
||||||
schema:
|
|
||||||
type: "array"
|
|
||||||
items:
|
|
||||||
$ref: "#/definitions/Pet"
|
|
||||||
400:
|
|
||||||
description: "Invalid status value"
|
|
||||||
security:
|
|
||||||
- petstore_auth:
|
|
||||||
- "write:pets"
|
|
||||||
- "read:pets"
|
|
||||||
/pet/findByTags:
|
|
||||||
get:
|
|
||||||
tags:
|
|
||||||
- "pet"
|
|
||||||
summary: "Finds Pets by tags"
|
|
||||||
description: "Multiple tags can be provided with comma separated strings. Use\
|
|
||||||
\ tag1, tag2, tag3 for testing."
|
|
||||||
operationId: "findPetsByTags"
|
|
||||||
produces:
|
|
||||||
- "application/json"
|
|
||||||
- "application/xml"
|
|
||||||
parameters:
|
|
||||||
- name: "tags"
|
|
||||||
in: "query"
|
|
||||||
description: "Tags to filter by"
|
|
||||||
required: true
|
|
||||||
type: "array"
|
|
||||||
items:
|
|
||||||
type: "string"
|
|
||||||
collectionFormat: "multi"
|
|
||||||
responses:
|
|
||||||
200:
|
|
||||||
description: "successful operation"
|
|
||||||
schema:
|
|
||||||
type: "array"
|
|
||||||
items:
|
|
||||||
$ref: "#/definitions/Pet"
|
|
||||||
400:
|
|
||||||
description: "Invalid tag value"
|
|
||||||
security:
|
|
||||||
- petstore_auth:
|
|
||||||
- "write:pets"
|
|
||||||
- "read:pets"
|
|
||||||
deprecated: true
|
|
||||||
/pet/{petId}:
|
|
||||||
get:
|
|
||||||
tags:
|
|
||||||
- "pet"
|
|
||||||
summary: "Find pet by ID"
|
|
||||||
description: "Returns a single pet"
|
|
||||||
operationId: "getPetById"
|
|
||||||
produces:
|
|
||||||
- "application/json"
|
|
||||||
- "application/xml"
|
|
||||||
parameters:
|
|
||||||
- name: "petId"
|
|
||||||
in: "path"
|
|
||||||
description: "ID of pet to return"
|
|
||||||
required: true
|
|
||||||
type: "integer"
|
|
||||||
format: "int64"
|
|
||||||
responses:
|
|
||||||
200:
|
|
||||||
description: "successful operation"
|
|
||||||
schema:
|
|
||||||
$ref: "#/definitions/Pet"
|
|
||||||
400:
|
|
||||||
description: "Invalid ID supplied"
|
|
||||||
404:
|
|
||||||
description: "Pet not found"
|
|
||||||
security:
|
|
||||||
- api_key: []
|
|
||||||
post:
|
|
||||||
tags:
|
|
||||||
- "pet"
|
|
||||||
summary: "Updates a pet in the store with form data"
|
|
||||||
description: ""
|
|
||||||
operationId: "updatePetWithForm"
|
|
||||||
consumes:
|
|
||||||
- "application/x-www-form-urlencoded"
|
|
||||||
produces:
|
|
||||||
- "application/json"
|
|
||||||
- "application/xml"
|
|
||||||
parameters:
|
|
||||||
- name: "petId"
|
|
||||||
in: "path"
|
|
||||||
description: "ID of pet that needs to be updated"
|
|
||||||
required: true
|
|
||||||
type: "integer"
|
|
||||||
format: "int64"
|
|
||||||
- name: "name"
|
|
||||||
in: "formData"
|
|
||||||
description: "Updated name of the pet"
|
|
||||||
required: false
|
|
||||||
type: "string"
|
|
||||||
- name: "status"
|
|
||||||
in: "formData"
|
|
||||||
description: "Updated status of the pet"
|
|
||||||
required: false
|
|
||||||
type: "string"
|
|
||||||
responses:
|
|
||||||
405:
|
|
||||||
description: "Invalid input"
|
|
||||||
security:
|
|
||||||
- petstore_auth:
|
|
||||||
- "write:pets"
|
|
||||||
- "read:pets"
|
|
||||||
delete:
|
|
||||||
tags:
|
|
||||||
- "pet"
|
|
||||||
summary: "Deletes a pet"
|
|
||||||
description: ""
|
|
||||||
operationId: "deletePet"
|
|
||||||
produces:
|
|
||||||
- "application/json"
|
|
||||||
- "application/xml"
|
|
||||||
parameters:
|
|
||||||
- name: "api_key"
|
|
||||||
in: "header"
|
|
||||||
required: false
|
|
||||||
type: "string"
|
|
||||||
- name: "petId"
|
|
||||||
in: "path"
|
|
||||||
description: "Pet id to delete"
|
|
||||||
required: true
|
|
||||||
type: "integer"
|
|
||||||
format: "int64"
|
|
||||||
responses:
|
|
||||||
400:
|
|
||||||
description: "Invalid ID supplied"
|
|
||||||
404:
|
|
||||||
description: "Pet not found"
|
|
||||||
security:
|
|
||||||
- petstore_auth:
|
|
||||||
- "write:pets"
|
|
||||||
- "read:pets"
|
|
||||||
/store/order:
|
|
||||||
post:
|
|
||||||
tags:
|
|
||||||
- "store"
|
|
||||||
summary: "Place an order for a pet"
|
|
||||||
description: ""
|
|
||||||
operationId: "placeOrder"
|
|
||||||
consumes:
|
|
||||||
- "application/json"
|
|
||||||
produces:
|
|
||||||
- "application/json"
|
|
||||||
- "application/xml"
|
|
||||||
parameters:
|
|
||||||
- in: "body"
|
|
||||||
name: "body"
|
|
||||||
description: "order placed for purchasing the pet"
|
|
||||||
required: true
|
|
||||||
schema:
|
|
||||||
$ref: "#/definitions/Order"
|
|
||||||
responses:
|
|
||||||
200:
|
|
||||||
description: "successful operation"
|
|
||||||
schema:
|
|
||||||
$ref: "#/definitions/Order"
|
|
||||||
400:
|
|
||||||
description: "Invalid Order"
|
|
||||||
/store/order/{orderId}:
|
|
||||||
get:
|
|
||||||
tags:
|
|
||||||
- "store"
|
|
||||||
summary: "Find purchase order by ID"
|
|
||||||
description: "For valid response try integer IDs with value >= 1 and <= 10.\
|
|
||||||
\ Other values will generated exceptions"
|
|
||||||
operationId: "getOrderById"
|
|
||||||
produces:
|
|
||||||
- "application/json"
|
|
||||||
- "application/xml"
|
|
||||||
parameters:
|
|
||||||
- name: "orderId"
|
|
||||||
in: "path"
|
|
||||||
description: "ID of pet that needs to be fetched"
|
|
||||||
required: true
|
|
||||||
type: "integer"
|
|
||||||
maximum: 10
|
|
||||||
minimum: 1
|
|
||||||
format: "int64"
|
|
||||||
responses:
|
|
||||||
200:
|
|
||||||
description: "successful operation"
|
|
||||||
schema:
|
|
||||||
$ref: "#/definitions/Order"
|
|
||||||
400:
|
|
||||||
description: "Invalid ID supplied"
|
|
||||||
404:
|
|
||||||
description: "Order not found"
|
|
||||||
delete:
|
|
||||||
tags:
|
|
||||||
- "store"
|
|
||||||
summary: "Delete purchase order by ID"
|
|
||||||
description: "For valid response try integer IDs with positive integer value.\
|
|
||||||
\ Negative or non-integer values will generate API errors"
|
|
||||||
operationId: "deleteOrder"
|
|
||||||
produces:
|
|
||||||
- "application/json"
|
|
||||||
- "application/xml"
|
|
||||||
parameters:
|
|
||||||
- name: "orderId"
|
|
||||||
in: "path"
|
|
||||||
description: "ID of the order that needs to be deleted"
|
|
||||||
required: true
|
|
||||||
type: "integer"
|
|
||||||
minimum: 1
|
|
||||||
format: "int64"
|
|
||||||
responses:
|
|
||||||
400:
|
|
||||||
description: "Invalid ID supplied"
|
|
||||||
404:
|
|
||||||
description: "Order not found"
|
|
||||||
/store/inventory:
|
|
||||||
get:
|
|
||||||
tags:
|
|
||||||
- "store"
|
|
||||||
summary: "Returns pet inventories by status"
|
|
||||||
description: "Returns a map of status codes to quantities"
|
|
||||||
operationId: "getInventory"
|
|
||||||
produces:
|
|
||||||
- "application/json"
|
|
||||||
parameters: []
|
|
||||||
responses:
|
|
||||||
200:
|
|
||||||
description: "successful operation"
|
|
||||||
schema:
|
|
||||||
type: "object"
|
|
||||||
additionalProperties:
|
|
||||||
type: "integer"
|
|
||||||
format: "int32"
|
|
||||||
security:
|
|
||||||
- api_key: []
|
|
||||||
/user/createWithArray:
|
|
||||||
post:
|
|
||||||
tags:
|
|
||||||
- "user"
|
|
||||||
summary: "Creates list of users with given input array"
|
|
||||||
description: ""
|
|
||||||
operationId: "createUsersWithArrayInput"
|
|
||||||
consumes:
|
|
||||||
- "application/json"
|
|
||||||
produces:
|
|
||||||
- "application/json"
|
|
||||||
- "application/xml"
|
|
||||||
parameters:
|
|
||||||
- in: "body"
|
|
||||||
name: "body"
|
|
||||||
description: "List of user object"
|
|
||||||
required: true
|
|
||||||
schema:
|
|
||||||
type: "array"
|
|
||||||
items:
|
|
||||||
$ref: "#/definitions/User"
|
|
||||||
responses:
|
|
||||||
default:
|
|
||||||
description: "successful operation"
|
|
||||||
/user/createWithList:
|
|
||||||
post:
|
|
||||||
tags:
|
|
||||||
- "user"
|
|
||||||
summary: "Creates list of users with given input array"
|
|
||||||
description: ""
|
|
||||||
operationId: "createUsersWithListInput"
|
|
||||||
consumes:
|
|
||||||
- "application/json"
|
|
||||||
produces:
|
|
||||||
- "application/json"
|
|
||||||
- "application/xml"
|
|
||||||
parameters:
|
|
||||||
- in: "body"
|
|
||||||
name: "body"
|
|
||||||
description: "List of user object"
|
|
||||||
required: true
|
|
||||||
schema:
|
|
||||||
type: "array"
|
|
||||||
items:
|
|
||||||
$ref: "#/definitions/User"
|
|
||||||
responses:
|
|
||||||
default:
|
|
||||||
description: "successful operation"
|
|
||||||
/user/{username}:
|
|
||||||
get:
|
|
||||||
tags:
|
|
||||||
- "user"
|
|
||||||
summary: "Get user by user name"
|
|
||||||
description: ""
|
|
||||||
operationId: "getUserByName"
|
|
||||||
produces:
|
|
||||||
- "application/json"
|
|
||||||
- "application/xml"
|
|
||||||
parameters:
|
|
||||||
- name: "username"
|
|
||||||
in: "path"
|
|
||||||
description: "The name that needs to be fetched. Use user1 for testing. "
|
|
||||||
required: true
|
|
||||||
type: "string"
|
|
||||||
responses:
|
|
||||||
200:
|
|
||||||
description: "successful operation"
|
|
||||||
schema:
|
|
||||||
$ref: "#/definitions/User"
|
|
||||||
400:
|
|
||||||
description: "Invalid username supplied"
|
|
||||||
404:
|
|
||||||
description: "User not found"
|
|
||||||
put:
|
|
||||||
tags:
|
|
||||||
- "user"
|
|
||||||
summary: "Updated user"
|
|
||||||
description: "This can only be done by the logged in user."
|
|
||||||
operationId: "updateUser"
|
|
||||||
consumes:
|
|
||||||
- "application/json"
|
|
||||||
produces:
|
|
||||||
- "application/json"
|
|
||||||
- "application/xml"
|
|
||||||
parameters:
|
|
||||||
- name: "username"
|
|
||||||
in: "path"
|
|
||||||
description: "name that need to be updated"
|
|
||||||
required: true
|
|
||||||
type: "string"
|
|
||||||
- in: "body"
|
|
||||||
name: "body"
|
|
||||||
description: "Updated user object"
|
|
||||||
required: true
|
|
||||||
schema:
|
|
||||||
$ref: "#/definitions/User"
|
|
||||||
responses:
|
|
||||||
400:
|
|
||||||
description: "Invalid user supplied"
|
|
||||||
404:
|
|
||||||
description: "User not found"
|
|
||||||
delete:
|
|
||||||
tags:
|
|
||||||
- "user"
|
|
||||||
summary: "Delete user"
|
|
||||||
description: "This can only be done by the logged in user."
|
|
||||||
operationId: "deleteUser"
|
|
||||||
produces:
|
|
||||||
- "application/json"
|
|
||||||
- "application/xml"
|
|
||||||
parameters:
|
|
||||||
- name: "username"
|
|
||||||
in: "path"
|
|
||||||
description: "The name that needs to be deleted"
|
|
||||||
required: true
|
|
||||||
type: "string"
|
|
||||||
responses:
|
|
||||||
400:
|
|
||||||
description: "Invalid username supplied"
|
|
||||||
404:
|
|
||||||
description: "User not found"
|
|
||||||
/user/login:
|
|
||||||
get:
|
|
||||||
tags:
|
|
||||||
- "user"
|
|
||||||
summary: "Logs user into the system"
|
|
||||||
description: ""
|
|
||||||
operationId: "loginUser"
|
|
||||||
produces:
|
|
||||||
- "application/json"
|
|
||||||
- "application/xml"
|
|
||||||
parameters:
|
|
||||||
- name: "username"
|
|
||||||
in: "query"
|
|
||||||
description: "The user name for login"
|
|
||||||
required: true
|
|
||||||
type: "string"
|
|
||||||
- name: "password"
|
|
||||||
in: "query"
|
|
||||||
description: "The password for login in clear text"
|
|
||||||
required: true
|
|
||||||
type: "string"
|
|
||||||
responses:
|
|
||||||
200:
|
|
||||||
description: "successful operation"
|
|
||||||
headers:
|
|
||||||
X-Expires-After:
|
|
||||||
type: "string"
|
|
||||||
format: "date-time"
|
|
||||||
description: "date in UTC when token expires"
|
|
||||||
X-Rate-Limit:
|
|
||||||
type: "integer"
|
|
||||||
format: "int32"
|
|
||||||
description: "calls per hour allowed by the user"
|
|
||||||
schema:
|
|
||||||
type: "string"
|
|
||||||
400:
|
|
||||||
description: "Invalid username/password supplied"
|
|
||||||
/user/logout:
|
|
||||||
get:
|
|
||||||
tags:
|
|
||||||
- "user"
|
|
||||||
summary: "Logs out current logged in user session"
|
|
||||||
description: ""
|
|
||||||
operationId: "logoutUser"
|
|
||||||
produces:
|
|
||||||
- "application/json"
|
|
||||||
- "application/xml"
|
|
||||||
parameters: []
|
|
||||||
responses:
|
|
||||||
default:
|
|
||||||
description: "successful operation"
|
|
||||||
/user:
|
|
||||||
post:
|
|
||||||
tags:
|
|
||||||
- "user"
|
|
||||||
summary: "Create user"
|
|
||||||
description: "This can only be done by the logged in user."
|
|
||||||
operationId: "createUser"
|
|
||||||
consumes:
|
|
||||||
- "application/json"
|
|
||||||
produces:
|
|
||||||
- "application/json"
|
|
||||||
- "application/xml"
|
|
||||||
parameters:
|
|
||||||
- in: "body"
|
|
||||||
name: "body"
|
|
||||||
description: "Created user object"
|
|
||||||
required: true
|
|
||||||
schema:
|
|
||||||
$ref: "#/definitions/User"
|
|
||||||
responses:
|
|
||||||
default:
|
|
||||||
description: "successful operation"
|
|
||||||
securityDefinitions:
|
|
||||||
api_key:
|
|
||||||
type: "apiKey"
|
|
||||||
name: "api_key"
|
|
||||||
in: "header"
|
|
||||||
petstore_auth:
|
|
||||||
type: "oauth2"
|
|
||||||
authorizationUrl: "https://petstore.swagger.io/oauth/authorize"
|
|
||||||
flow: "implicit"
|
|
||||||
scopes:
|
|
||||||
read:pets: "read your pets"
|
|
||||||
write:pets: "modify pets in your account"
|
|
||||||
definitions:
|
|
||||||
ApiResponse:
|
|
||||||
type: "object"
|
|
||||||
properties:
|
|
||||||
code:
|
|
||||||
type: "integer"
|
|
||||||
format: "int32"
|
|
||||||
type:
|
|
||||||
type: "string"
|
|
||||||
message:
|
|
||||||
type: "string"
|
|
||||||
Category:
|
|
||||||
type: "object"
|
|
||||||
properties:
|
|
||||||
id:
|
|
||||||
type: "integer"
|
|
||||||
format: "int64"
|
|
||||||
name:
|
|
||||||
type: "string"
|
|
||||||
xml:
|
|
||||||
name: "Category"
|
|
||||||
Pet:
|
|
||||||
type: "object"
|
|
||||||
required:
|
|
||||||
- "name"
|
|
||||||
- "photoUrls"
|
|
||||||
properties:
|
|
||||||
id:
|
|
||||||
type: "integer"
|
|
||||||
format: "int64"
|
|
||||||
category:
|
|
||||||
$ref: "#/definitions/Category"
|
|
||||||
name:
|
|
||||||
type: "string"
|
|
||||||
example: "doggie"
|
|
||||||
photoUrls:
|
|
||||||
type: "array"
|
|
||||||
xml:
|
|
||||||
wrapped: true
|
|
||||||
items:
|
|
||||||
type: "string"
|
|
||||||
xml:
|
|
||||||
name: "photoUrl"
|
|
||||||
tags:
|
|
||||||
type: "array"
|
|
||||||
xml:
|
|
||||||
wrapped: true
|
|
||||||
items:
|
|
||||||
xml:
|
|
||||||
name: "tag"
|
|
||||||
$ref: "#/definitions/Tag"
|
|
||||||
status:
|
|
||||||
type: "string"
|
|
||||||
description: "pet status in the store"
|
|
||||||
enum:
|
|
||||||
- "available"
|
|
||||||
- "pending"
|
|
||||||
- "sold"
|
|
||||||
xml:
|
|
||||||
name: "Pet"
|
|
||||||
Tag:
|
|
||||||
type: "object"
|
|
||||||
properties:
|
|
||||||
id:
|
|
||||||
type: "integer"
|
|
||||||
format: "int64"
|
|
||||||
name:
|
|
||||||
type: "string"
|
|
||||||
xml:
|
|
||||||
name: "Tag"
|
|
||||||
Order:
|
|
||||||
type: "object"
|
|
||||||
properties:
|
|
||||||
id:
|
|
||||||
type: "integer"
|
|
||||||
format: "int64"
|
|
||||||
petId:
|
|
||||||
type: "integer"
|
|
||||||
format: "int64"
|
|
||||||
quantity:
|
|
||||||
type: "integer"
|
|
||||||
format: "int32"
|
|
||||||
shipDate:
|
|
||||||
type: "string"
|
|
||||||
format: "date-time"
|
|
||||||
status:
|
|
||||||
type: "string"
|
|
||||||
description: "Order Status"
|
|
||||||
enum:
|
|
||||||
- "placed"
|
|
||||||
- "approved"
|
|
||||||
- "delivered"
|
|
||||||
complete:
|
|
||||||
type: "boolean"
|
|
||||||
xml:
|
|
||||||
name: "Order"
|
|
||||||
User:
|
|
||||||
type: "object"
|
|
||||||
properties:
|
|
||||||
id:
|
|
||||||
type: "integer"
|
|
||||||
format: "int64"
|
|
||||||
username:
|
|
||||||
type: "string"
|
|
||||||
firstName:
|
|
||||||
type: "string"
|
|
||||||
lastName:
|
|
||||||
type: "string"
|
|
||||||
email:
|
|
||||||
type: "string"
|
|
||||||
password:
|
|
||||||
type: "string"
|
|
||||||
phone:
|
|
||||||
type: "string"
|
|
||||||
userStatus:
|
|
||||||
type: "integer"
|
|
||||||
format: "int32"
|
|
||||||
description: "User Status"
|
|
||||||
xml:
|
|
||||||
name: "User"
|
|
||||||
externalDocs:
|
|
||||||
description: "Find out more about Swagger"
|
|
||||||
url: "http://swagger.io"
|
|
Before Width: | Height: | Size: 657 B After Width: | Height: | Size: 657 B |
Before Width: | Height: | Size: 25 KiB After Width: | Height: | Size: 25 KiB |
Before Width: | Height: | Size: 1.5 KiB After Width: | Height: | Size: 1.5 KiB |