Module aws_lambda_powertools.event_handler.openapi.swagger_ui.html
Expand source code
def generate_swagger_html(spec: str, js_url: str, css_url: str) -> str:
"""
Generate Swagger UI HTML page
Parameters
----------
spec: str
The OpenAPI spec in the JSON format
js_url: str
The URL to the Swagger UI JavaScript file
css_url: str
The URL to the Swagger UI CSS file
"""
return f"""
<!DOCTYPE html>
<html>
<head>
<meta charset="UTF-8">
<title>Swagger UI</title>
<link rel="stylesheet" type="text/css" href="{css_url}">
</head>
<body>
<div id="swagger-ui">
Loading...
</div>
</body>
<script src="{js_url}"></script>
<script>
var swaggerUIOptions = {{
dom_id: "#swagger-ui",
docExpansion: "list",
deepLinking: true,
filter: true,
spec: JSON.parse(`
{spec}
`.trim()),
presets: [
SwaggerUIBundle.presets.apis,
SwaggerUIBundle.SwaggerUIStandalonePreset
],
plugins: [
SwaggerUIBundle.plugins.DownloadUrl
]
}}
var ui = SwaggerUIBundle(swaggerUIOptions)
</script>
</html>
""".strip()
Functions
def generate_swagger_html(spec: str, js_url: str, css_url: str) ‑> str
-
Generate Swagger UI HTML page
Parameters
spec
:str
- The OpenAPI spec in the JSON format
js_url
:str
- The URL to the Swagger UI JavaScript file
css_url
:str
- The URL to the Swagger UI CSS file
Expand source code
def generate_swagger_html(spec: str, js_url: str, css_url: str) -> str: """ Generate Swagger UI HTML page Parameters ---------- spec: str The OpenAPI spec in the JSON format js_url: str The URL to the Swagger UI JavaScript file css_url: str The URL to the Swagger UI CSS file """ return f""" <!DOCTYPE html> <html> <head> <meta charset="UTF-8"> <title>Swagger UI</title> <link rel="stylesheet" type="text/css" href="{css_url}"> </head> <body> <div id="swagger-ui"> Loading... </div> </body> <script src="{js_url}"></script> <script> var swaggerUIOptions = {{ dom_id: "#swagger-ui", docExpansion: "list", deepLinking: true, filter: true, spec: JSON.parse(` {spec} `.trim()), presets: [ SwaggerUIBundle.presets.apis, SwaggerUIBundle.SwaggerUIStandalonePreset ], plugins: [ SwaggerUIBundle.plugins.DownloadUrl ] }} var ui = SwaggerUIBundle(swaggerUIOptions) </script> </html> """.strip()