1
Fork 0
mirror of https://github.com/thegeneralist01/twitter-openapi synced 2026-01-10 15:20:26 +01:00
twitter-openapi/tools/build_config.py
ふぁ 59e1e2b8e2
update tags
Signed-off-by: ふぁ <yuki@yuki0311.com>
2023-08-07 00:41:20 +09:00

77 lines
2.5 KiB
Python

from hooks import *
class Config:
OUTPUT_DIR = "dist/{0}"
INPUT_DIR = "src/openapi"
def hooks_generator(self, queryParameterJson=True):
# https://stackoverflow.com/questions/34820064/defining-an-api-with-swagger-get-call-that-uses-json-in-parameters/45223964
if queryParameterJson:
getParamHook = AddParametersOnContent(
split=-1,
contentType="application/json",
ignoreKeys=["queryId"],
)
postParamHook = AddParametersOnParameters(
split=-1,
schemaType=None,
)
else:
getParamHook = AddParametersOnParameters(
split=-1,
schemaType="string",
ignoreKeys=["queryId"],
)
postParamHook = AddParametersOnBody(
split=-1,
schemaType=None,
contentType="application/json",
)
return {
"openapi": [AddSecuritySchemesOnSecuritySchemes()],
"schemas": [],
"other": [],
"request": {
key: [
SetResponsesHeader(suffix=None),
AddPathQueryIdOnParameters(split=-1),
getParamHook,
]
for key in ["default", "user", "users", "user-list", "tweet"]
}
| {
key: [
SetResponsesHeader(suffix=None),
AddPathQueryIdOnParameters(split=-1),
postParamHook,
]
for key in ["post"]
}
| {
key: [
SetResponsesHeader(suffix="legacy"),
AddParametersOnParameters(split=2, schemaType=None),
]
for key in ["v1.1-get", "v2.0-get"]
}
| {
key: [
SetResponsesHeader(suffix="legacy"),
AddParametersOnBody(
split=2,
schemaType=None,
contentType="application/x-www-form-urlencoded",
),
]
for key in ["v1.1-post", "v2.0-post"]
}
| {"other": []},
}
def main(self):
return {
"docs": self.hooks_generator(),
"compatible": self.hooks_generator(queryParameterJson=False),
}