openapi-python-generator 2.0.1.dev1757317856__tar.gz → 2.0.1.dev1758361866__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.
- {openapi_python_generator-2.0.1.dev1757317856 → openapi_python_generator-2.0.1.dev1758361866}/PKG-INFO +1 -1
- {openapi_python_generator-2.0.1.dev1757317856 → openapi_python_generator-2.0.1.dev1758361866}/pyproject.toml +1 -1
- {openapi_python_generator-2.0.1.dev1757317856 → openapi_python_generator-2.0.1.dev1758361866}/setup.py +1 -1
- {openapi_python_generator-2.0.1.dev1757317856 → openapi_python_generator-2.0.1.dev1758361866}/src/openapi_python_generator/language_converters/python/service_generator.py +11 -2
- {openapi_python_generator-2.0.1.dev1757317856 → openapi_python_generator-2.0.1.dev1758361866}/LICENSE +0 -0
- {openapi_python_generator-2.0.1.dev1757317856 → openapi_python_generator-2.0.1.dev1758361866}/README.md +0 -0
- {openapi_python_generator-2.0.1.dev1757317856 → openapi_python_generator-2.0.1.dev1758361866}/src/openapi_python_generator/__init__.py +0 -0
- {openapi_python_generator-2.0.1.dev1757317856 → openapi_python_generator-2.0.1.dev1758361866}/src/openapi_python_generator/__main__.py +0 -0
- {openapi_python_generator-2.0.1.dev1757317856 → openapi_python_generator-2.0.1.dev1758361866}/src/openapi_python_generator/common.py +0 -0
- {openapi_python_generator-2.0.1.dev1757317856 → openapi_python_generator-2.0.1.dev1758361866}/src/openapi_python_generator/generate_data.py +0 -0
- {openapi_python_generator-2.0.1.dev1757317856 → openapi_python_generator-2.0.1.dev1758361866}/src/openapi_python_generator/language_converters/__init__.py +0 -0
- {openapi_python_generator-2.0.1.dev1757317856 → openapi_python_generator-2.0.1.dev1758361866}/src/openapi_python_generator/language_converters/python/__init__.py +0 -0
- {openapi_python_generator-2.0.1.dev1757317856 → openapi_python_generator-2.0.1.dev1758361866}/src/openapi_python_generator/language_converters/python/api_config_generator.py +0 -0
- {openapi_python_generator-2.0.1.dev1757317856 → openapi_python_generator-2.0.1.dev1758361866}/src/openapi_python_generator/language_converters/python/common.py +0 -0
- {openapi_python_generator-2.0.1.dev1757317856 → openapi_python_generator-2.0.1.dev1758361866}/src/openapi_python_generator/language_converters/python/generator.py +0 -0
- {openapi_python_generator-2.0.1.dev1757317856 → openapi_python_generator-2.0.1.dev1758361866}/src/openapi_python_generator/language_converters/python/jinja_config.py +0 -0
- {openapi_python_generator-2.0.1.dev1757317856 → openapi_python_generator-2.0.1.dev1758361866}/src/openapi_python_generator/language_converters/python/model_generator.py +0 -0
- {openapi_python_generator-2.0.1.dev1757317856 → openapi_python_generator-2.0.1.dev1758361866}/src/openapi_python_generator/language_converters/python/templates/aiohttp.jinja2 +0 -0
- {openapi_python_generator-2.0.1.dev1757317856 → openapi_python_generator-2.0.1.dev1758361866}/src/openapi_python_generator/language_converters/python/templates/apiconfig.jinja2 +0 -0
- {openapi_python_generator-2.0.1.dev1757317856 → openapi_python_generator-2.0.1.dev1758361866}/src/openapi_python_generator/language_converters/python/templates/apiconfig_pydantic_2.jinja2 +0 -0
- {openapi_python_generator-2.0.1.dev1757317856 → openapi_python_generator-2.0.1.dev1758361866}/src/openapi_python_generator/language_converters/python/templates/enum.jinja2 +0 -0
- {openapi_python_generator-2.0.1.dev1757317856 → openapi_python_generator-2.0.1.dev1758361866}/src/openapi_python_generator/language_converters/python/templates/httpx.jinja2 +0 -0
- {openapi_python_generator-2.0.1.dev1757317856 → openapi_python_generator-2.0.1.dev1758361866}/src/openapi_python_generator/language_converters/python/templates/models.jinja2 +0 -0
- {openapi_python_generator-2.0.1.dev1757317856 → openapi_python_generator-2.0.1.dev1758361866}/src/openapi_python_generator/language_converters/python/templates/models_pydantic_2.jinja2 +0 -0
- {openapi_python_generator-2.0.1.dev1757317856 → openapi_python_generator-2.0.1.dev1758361866}/src/openapi_python_generator/language_converters/python/templates/requests.jinja2 +0 -0
- {openapi_python_generator-2.0.1.dev1757317856 → openapi_python_generator-2.0.1.dev1758361866}/src/openapi_python_generator/language_converters/python/templates/service.jinja2 +0 -0
- {openapi_python_generator-2.0.1.dev1757317856 → openapi_python_generator-2.0.1.dev1758361866}/src/openapi_python_generator/models.py +0 -0
- {openapi_python_generator-2.0.1.dev1757317856 → openapi_python_generator-2.0.1.dev1758361866}/src/openapi_python_generator/parsers/__init__.py +0 -0
- {openapi_python_generator-2.0.1.dev1757317856 → openapi_python_generator-2.0.1.dev1758361866}/src/openapi_python_generator/parsers/openapi_30.py +0 -0
- {openapi_python_generator-2.0.1.dev1757317856 → openapi_python_generator-2.0.1.dev1758361866}/src/openapi_python_generator/parsers/openapi_31.py +0 -0
- {openapi_python_generator-2.0.1.dev1757317856 → openapi_python_generator-2.0.1.dev1758361866}/src/openapi_python_generator/py.typed +0 -0
- {openapi_python_generator-2.0.1.dev1757317856 → openapi_python_generator-2.0.1.dev1758361866}/src/openapi_python_generator/version_detector.py +0 -0
|
@@ -32,7 +32,7 @@ entry_points = \
|
|
|
32
32
|
|
|
33
33
|
setup_kwargs = {
|
|
34
34
|
'name': 'openapi-python-generator',
|
|
35
|
-
'version': '2.0.1.
|
|
35
|
+
'version': '2.0.1.dev1758361866',
|
|
36
36
|
'description': 'Openapi Python Generator',
|
|
37
37
|
'long_description': "# Openapi Python Generator\n\n[][pypi_]\n[][status]\n[][python version]\n[][license]\n\n[][documentation]\n[][tests]\n[][codecov]\n\n[][pre-commit]\n[][black]\n\n[pypi_]: https://pypi.org/project/openapi-python-generator/\n[status]: https://pypi.org/project/openapi-python-generator/\n[python version]: https://pypi.org/project/openapi-python-generator\n[documentation]: https://marcomuellner.github.io/openapi-python-generator/\n[tests]: https://github.com/MarcoMuellner/openapi-python-generator/actions?workflow=Tests\n[codecov]: https://app.codecov.io/gh/MarcoMuellner/openapi-python-generator\n[pre-commit]: https://github.com/pre-commit/pre-commit\n[black]: https://github.com/psf/black\n\n\n\n---\n__Documentation:__ [here][documentation]\n\n---\n\n## Features\n\n- __Ease of use__. Provide input, output and the library, and the generator will do the rest.\n- __Type safety and type hinting.__ __OpenAPI python generator__ makes heavy use of pydantic models to provide type-safe data structures.\n- __Support for multiple rest frameworks.__ __OpenAPI python generator__ currently supports the following:\n - [httpx](https://pypi.org/project/httpx/)\n - [requests](https://pypi.org/project/requests/)\n - [aiohttp](https://pypi.org/project/aiohttp/)\n- __Async and sync code generation support__, depending on the framework. It will automatically create both for frameworks that support both.\n- __Easily extendable using Jinja2 templates__. The code is designed to be easily extendable and should support even more languages and frameworks in the future.\n- __Fully tested__. Every generated code is automatically tested against the OpenAPI spec and we have 100% coverage.\n- __Usage as CLI or as library__.\n\n## Requirements\n\n- Python 3.7+\n\n## Installation\n\nYou can install _Openapi Python Generator_ via [pip] from [PyPI]:\n\n```console\n$ pip install openapi-python-generator\n```\n\n## Usage\n\nPlease see the [Quick start page] for details.\n\n## Roadmap\n\n- Support for all commonly used http libraries in the python ecosystem (~~requests~~, urllib, ...)\n- Support for multiple languages\n- Support for multiple authentication schemes\n- Support custom themes\n\n## Contributing\n\nContributions are very welcome.\nTo learn more, see the [Contributor Guide].\n\n## License\n\nDistributed under the terms of the [MIT license][license],\n_Openapi Python Generator_ is free and open source software.\n\n## Issues\n\nIf you encounter any problems,\nplease [file an issue] along with a detailed description.\n\n## Credits\n\nSpecial thanks to the peeps from [openapi-schema-pydantic](https://github.com/kuimono/openapi-schema-pydantic),\nwhich already did a lot of the legwork by providing a pydantic schema for the OpenAPI 3.0.0+ specification.\n\nThis project was generated from [@cjolowicz]'s [Hypermodern Python Cookiecutter] template.\n\n[@cjolowicz]: https://github.com/cjolowicz\n[pypi]: https://pypi.org/\n[hypermodern python cookiecutter]: https://github.com/cjolowicz/cookiecutter-hypermodern-python\n[file an issue]: https://github.com/MarcoMuellner/openapi-python-generator/issues\n[pip]: https://pip.pypa.io/\n\n<!-- github-only -->\n\n[license]: https://github.com/MarcoMuellner/openapi-python-generator/blob/main/LICENSE\n[contributor guide]: https://github.com/MarcoMuellner/openapi-python-generator/blob/main/CONTRIBUTING.md\n[Quick start page]: https://marcomuellner.github.io/openapi-python-generator/quick_start/\n",
|
|
38
38
|
'author': 'Marco Müllner',
|
|
@@ -428,17 +428,18 @@ def generate_services(
|
|
|
428
428
|
services = []
|
|
429
429
|
service_ops = []
|
|
430
430
|
for path_name, path in paths.items():
|
|
431
|
+
clean_path_name = clean_up_path_name(path_name)
|
|
431
432
|
for http_operation in HTTP_OPERATIONS:
|
|
432
433
|
op = path.__getattribute__(http_operation)
|
|
433
434
|
if op is None:
|
|
434
435
|
continue
|
|
435
436
|
|
|
436
437
|
if library_config.include_sync:
|
|
437
|
-
sync_so = generate_service_operation(op,
|
|
438
|
+
sync_so = generate_service_operation(op, clean_path_name, False)
|
|
438
439
|
service_ops.append(sync_so)
|
|
439
440
|
|
|
440
441
|
if library_config.include_async:
|
|
441
|
-
async_so = generate_service_operation(op,
|
|
442
|
+
async_so = generate_service_operation(op, clean_path_name, True)
|
|
442
443
|
service_ops.append(async_so)
|
|
443
444
|
|
|
444
445
|
# Ensure every operation has a tag; fallback to "default" for untagged operations
|
|
@@ -489,3 +490,11 @@ def generate_services(
|
|
|
489
490
|
)
|
|
490
491
|
|
|
491
492
|
return services
|
|
493
|
+
|
|
494
|
+
|
|
495
|
+
def clean_up_path_name(path_name: str) -> str:
|
|
496
|
+
# Clean up path name: only replace dashes inside curly brackets for f-string compatibility, keep other dashes
|
|
497
|
+
def _replace_bracket_dashes(match):
|
|
498
|
+
return "{" + match.group(1).replace("-", "_") + "}"
|
|
499
|
+
|
|
500
|
+
return re.sub(r"\{([^}/]+)\}", _replace_bracket_dashes, path_name)
|
|
File without changes
|
|
File without changes
|
|
File without changes
|
|
File without changes
|
|
File without changes
|
|
File without changes
|
|
File without changes
|
|
File without changes
|
|
File without changes
|
|
File without changes
|
|
File without changes
|
|
File without changes
|
|
File without changes
|
|
File without changes
|
|
File without changes
|
|
File without changes
|
|
File without changes
|
|
File without changes
|
|
File without changes
|
|
File without changes
|
|
File without changes
|
|
File without changes
|
|
File without changes
|
|
File without changes
|
|
File without changes
|
|
File without changes
|
|
File without changes
|