star-openapi-scalar 1.40.9__tar.gz

This diff represents the content of publicly available package versions that have been released to one of the supported registries. The information contained in this diff is provided for informational purposes only and reflects changes between package versions as they appear in their respective public registries.
@@ -0,0 +1,141 @@
1
+ ### Python template
2
+ # Byte-compiled / optimized / DLL files
3
+ __pycache__/
4
+ *.py[cod]
5
+ *$py.class
6
+
7
+ # C extensions
8
+ *.so
9
+
10
+ # Distribution / packaging
11
+ .Python
12
+ build/
13
+ develop-eggs/
14
+ dist/
15
+ downloads/
16
+ eggs/
17
+ .eggs/
18
+ lib/
19
+ lib64/
20
+ parts/
21
+ sdist/
22
+ var/
23
+ wheels/
24
+ share/python-wheels/
25
+ *.egg-info/
26
+ .installed.cfg
27
+ *.egg
28
+ MANIFEST
29
+
30
+ # PyInstaller
31
+ # Usually these files are written by a python script from a template
32
+ # before PyInstaller builds the exe, so as to inject date/other infos into it.
33
+ *.manifest
34
+ *.spec
35
+
36
+ # Installer logs
37
+ pip-log.txt
38
+ pip-delete-this-directory.txt
39
+
40
+ # Unit test / coverage reports
41
+ htmlcov/
42
+ .tox/
43
+ .nox/
44
+ .coverage
45
+ .coverage.*
46
+ .cache
47
+ nosetests.xml
48
+ coverage.xml
49
+ *.cover
50
+ *.py,cover
51
+ .hypothesis/
52
+ .pytest_cache/
53
+ cover/
54
+
55
+ # Translations
56
+ *.mo
57
+ *.pot
58
+
59
+ # Django stuff:
60
+ *.log
61
+ local_settings.py
62
+ db.sqlite3
63
+ db.sqlite3-journal
64
+
65
+ # Flask stuff:
66
+ instance/
67
+ .webassets-cache
68
+
69
+ # Scrapy stuff:
70
+ .scrapy
71
+
72
+ # Sphinx documentation
73
+ docs/_build/
74
+
75
+ # PyBuilder
76
+ .pybuilder/
77
+ target/
78
+
79
+ # Jupyter Notebook
80
+ .ipynb_checkpoints
81
+
82
+ # IPython
83
+ profile_default/
84
+ ipython_config.py
85
+
86
+ # pyenv
87
+ # For a library or package, you might want to ignore these files since the code is
88
+ # intended to run in multiple environments; otherwise, check them in:
89
+ # .python-version
90
+
91
+ # pipenv
92
+ # According to pypa/pipenv#598, it is recommended to include Pipfile.lock in version control.
93
+ # However, in case of collaboration, if having platform-specific dependencies or dependencies
94
+ # having no cross-platform support, pipenv may install dependencies that don't work, or not
95
+ # install all needed dependencies.
96
+ #Pipfile.lock
97
+
98
+ # PEP 582; used by e.g. github.com/David-OConnor/pyflow
99
+ __pypackages__/
100
+
101
+ # Celery stuff
102
+ celerybeat-schedule
103
+ celerybeat.pid
104
+
105
+ # SageMath parsed files
106
+ *.sage.py
107
+
108
+ # Environments
109
+ .env
110
+ .venv
111
+ env/
112
+ venv/
113
+ ENV/
114
+ env.bak/
115
+ venv.bak/
116
+
117
+ # Spyder project settings
118
+ .spyderproject
119
+ .spyproject
120
+
121
+ # Rope project settings
122
+ .ropeproject
123
+
124
+ # mkdocs documentation
125
+ /site
126
+
127
+ # mypy
128
+ .mypy_cache/
129
+ .dmypy.json
130
+ dmypy.json
131
+
132
+ # Pyre type checker
133
+ .pyre/
134
+
135
+ # pytype static type analyzer
136
+ .pytype/
137
+
138
+ # Cython debug symbols
139
+ cython_debug/
140
+
141
+ .idea
@@ -0,0 +1,22 @@
1
+ Metadata-Version: 2.4
2
+ Name: star-openapi-scalar
3
+ Version: 1.40.9
4
+ Summary: Provide Scalar UI for star-openapi.
5
+ Project-URL: Homepage, https://github.com/luolingchun/star-openapi-plugins/tree/master/star-openapi-scalar
6
+ Project-URL: Documentation, https://luolingchun.github.io/star-openapi/latest/Usage/UI_Templates/
7
+ Maintainer-email: llc <luolingchun@outlook.com>
8
+ License: MIT
9
+ Classifier: Development Status :: 5 - Production/Stable
10
+ Classifier: Environment :: Web Environment
11
+ Classifier: Framework :: Flask
12
+ Classifier: Intended Audience :: Developers
13
+ Classifier: License :: OSI Approved :: MIT License
14
+ Classifier: Operating System :: OS Independent
15
+ Classifier: Programming Language :: Python
16
+ Classifier: Programming Language :: Python :: 3
17
+ Classifier: Programming Language :: Python :: 3 :: Only
18
+ Requires-Python: >=3.8
19
+ Requires-Dist: star-openapi
20
+ Description-Content-Type: text/markdown
21
+
22
+ Provide Scalar UI for [star-openapi](https://github.com/luolingchun/star-openapi).
@@ -0,0 +1,45 @@
1
+ [project]
2
+ name = "star-openapi-scalar"
3
+ description = "Provide Scalar UI for star-openapi."
4
+ readme = { text = "Provide Scalar UI for [star-openapi](https://github.com/luolingchun/star-openapi).", content-type = "text/markdown" }
5
+ license = { text = "MIT" }
6
+ maintainers = [{ name = "llc", email = "luolingchun@outlook.com" }]
7
+ classifiers = [
8
+ # "Development Status :: 1 - Planning",
9
+ # "Development Status :: 2 - Pre-Alpha",
10
+ # "Development Status :: 3 - Alpha",
11
+ # "Development Status :: 4 - Beta",
12
+ "Development Status :: 5 - Production/Stable",
13
+ # "Development Status :: 6 - Mature",
14
+ # "Development Status :: 7 - Inactive",
15
+ "Environment :: Web Environment",
16
+ "Framework :: Flask",
17
+ "Intended Audience :: Developers",
18
+ "License :: OSI Approved :: MIT License",
19
+ "Operating System :: OS Independent",
20
+ "Programming Language :: Python",
21
+ "Programming Language :: Python :: 3",
22
+ "Programming Language :: Python :: 3 :: Only"
23
+ ]
24
+ requires-python = ">=3.8"
25
+ dependencies = ["star-openapi"]
26
+ dynamic = ["version"]
27
+
28
+ [project.urls]
29
+ Homepage = "https://github.com/luolingchun/star-openapi-plugins/tree/master/star-openapi-scalar"
30
+ Documentation = "https://luolingchun.github.io/star-openapi/latest/Usage/UI_Templates/"
31
+
32
+ [project.entry-points."star_openapi.plugins"]
33
+ register = "star_openapi_scalar.plugins.RegisterPlugin"
34
+
35
+ [build-system]
36
+ requires = ["hatchling"]
37
+ build-backend = "hatchling.build"
38
+
39
+ [tool.hatch.version]
40
+ path = "star_openapi_scalar/__version__.py"
41
+
42
+ [tool.hatch.build.targets.sdist]
43
+ include = [
44
+ "/star_openapi_scalar"
45
+ ]
@@ -0,0 +1,3 @@
1
+ # -*- coding: utf-8 -*-
2
+
3
+ __version__ = "1.40.9"
@@ -0,0 +1,41 @@
1
+ import os.path
2
+
3
+ from jinja2 import Template
4
+ from star_openapi.plugins import BasePlugin
5
+ from starlette.responses import HTMLResponse
6
+ from starlette.routing import Route, Mount
7
+ from starlette.staticfiles import StaticFiles
8
+
9
+ from .templates import scalar_html_string
10
+
11
+
12
+ class RegisterPlugin(BasePlugin):
13
+ def __init__(self):
14
+ self.name = "scalar"
15
+ self.display_name = "Scalar"
16
+ self.doc_url = "/openapi.json"
17
+
18
+ def scalar_endpoint(self, request):
19
+ template = Template(request.app.config.get("SCALAR_HTML_STRING") or scalar_html_string)
20
+ return HTMLResponse(
21
+ content=template.render(
22
+ {
23
+ "doc_url": self.doc_url,
24
+ "scalar_config": request.app.config.get("SCALAR_CONFIG")
25
+ }
26
+ )
27
+ )
28
+
29
+ def register(self, doc_url: str) -> list[Route]:
30
+ self.doc_url = doc_url
31
+ static_folder = os.path.join(os.path.dirname(__file__), "templates", "scalar")
32
+
33
+ routes = [
34
+ Route(
35
+ f"/{self.name}",
36
+ endpoint=self.scalar_endpoint
37
+ ),
38
+ Mount("/scalar", app=StaticFiles(directory=static_folder), name="static"),
39
+ ]
40
+
41
+ return routes
@@ -0,0 +1,26 @@
1
+ scalar_html_string = """
2
+ <!doctype html>
3
+ <html>
4
+ <head>
5
+ <title>Scalar API</title>
6
+ <meta charset="utf-8" />
7
+ <meta
8
+ name="viewport"
9
+ content="width=device-width, initial-scale=1" />
10
+ <link rel="shortcut icon" href="scalar/images/scalar.svg">
11
+ </head>
12
+ <body>
13
+ <script
14
+ id="api-reference"
15
+ data-url="{{ doc_url }}">
16
+ </script>
17
+ <script>
18
+ const scalar_config = JSON.parse(`{{ scalar_config|default('{}')|tojson }}`);
19
+ var configuration = {...scalar_config};
20
+ var apiReference = document.getElementById('api-reference');
21
+ apiReference.dataset.configuration = JSON.stringify(configuration);
22
+ </script>
23
+ <script src="scalar/js/scalar.standalone.js"></script>
24
+ </body>
25
+ </html>
26
+ """
@@ -0,0 +1,4 @@
1
+ <svg xmlns="http://www.w3.org/2000/svg" viewBox="0 0 593 593">
2
+ <path fill="black" fill-rule="evenodd"
3
+ d="M347 0c6 0 12 5 12 12v134l94-95c5-5 13-5 17 0l72 72c4 4 5 12 0 16v1l-95 94h134c7 0 12 5 12 12v101c0 7-5 12-12 12H447l95 94c4 5 5 13 0 17l-72 72c-4 4-12 5-16 0h-1l-94-95v134c0 7-5 12-12 12H246c-7 0-12-5-12-12v-70c0-22 9-43 24-59l130-130c14-14 14-37 0-51L259 142a84 84 0 0 1-25-59V12c0-7 5-12 12-12h101ZM138 52h1l219 219c14 14 14 37 0 51L139 542c-4 5-12 5-17 0l-71-70c-4-5-5-12 0-17l95-96H12c-7 0-12-5-12-12V246c0-7 5-12 12-12h134l-95-94c-4-5-4-12 0-17l71-71c4-5 12-5 16 0Z" />
4
+ </svg>