Ecosyste.ms: Awesome
An open API service indexing awesome lists of open source software.
https://github.com/jdkandersson/openalchemy
Define SQLAlchemy models using the OpenAPI specification.
https://github.com/jdkandersson/openalchemy
openapi openapi-specification openapi3 python python3 sqlalchemy sqlalchemy-models sqlalchemy-python
Last synced: 13 days ago
JSON representation
Define SQLAlchemy models using the OpenAPI specification.
- Host: GitHub
- URL: https://github.com/jdkandersson/openalchemy
- Owner: jdkandersson
- License: apache-2.0
- Created: 2019-08-10T05:09:36.000Z (over 5 years ago)
- Default Branch: master
- Last Pushed: 2023-03-01T00:59:37.000Z (over 1 year ago)
- Last Synced: 2024-05-01T15:13:44.839Z (7 months ago)
- Topics: openapi, openapi-specification, openapi3, python, python3, sqlalchemy, sqlalchemy-models, sqlalchemy-python
- Language: Python
- Homepage: https://openapi-sqlalchemy.readthedocs.io/en/latest/
- Size: 3.38 MB
- Stars: 48
- Watchers: 2
- Forks: 12
- Open Issues: 29
-
Metadata Files:
- Readme: README.md
- Changelog: CHANGELOG.md
- Contributing: .github/CONTRIBUTING.md
- Funding: .github/FUNDING.yml
- License: LICENSE
- Codeowners: .github/CODEOWNERS
Awesome Lists containing this project
README
# OpenAlchemy
![Code Quality Status](https://github.com/jdkandersson/OpenAlchemy/workflows/Code%20quality%20checks/badge.svg)
![Azure DevOps coverage](https://img.shields.io/azure-devops/coverage/anderssonpublic/anderssonpublic/1)
[![Documentation Status](https://readthedocs.org/projects/openapi-sqlalchemy/badge/?version=latest)](https://openapi-sqlalchemy.readthedocs.io/en/latest/?badge=latest)
![Code Climate maintainability](https://img.shields.io/codeclimate/maintainability/jdkandersson/OpenAlchemy)
![Code Climate technical debt](https://img.shields.io/codeclimate/tech-debt/jdkandersson/OpenAlchemy)
![LGTM Grade](https://img.shields.io/lgtm/grade/python/github/jdkandersson/OpenAlchemy)Translates an OpenAPI schema to SQLAlchemy models.
Supports OpenAPI 3.0 and 3.1.
## Installation
```bash
python -m pip install OpenAlchemy
# To be able to load YAML file
python -m pip install OpenAlchemy[yaml]
```## Example
For example, given the following OpenAPI specification:
```yaml
# ./examples/simple/example-spec.yml
openapi: "3.0.0"info:
title: Test Schema
description: API to illustrate OpenAlchemy MVP.
version: "0.1"paths:
/employee:
get:
summary: Used to retrieve all employees.
responses:
200:
description: Return all employees from the database.
content:
application/json:
schema:
type: array
items:
"$ref": "#/components/schemas/Employee"components:
schemas:
Employee:
description: Person that works for a company.
type: object
x-tablename: employee
properties:
id:
type: integer
description: Unique identifier for the employee.
example: 0
x-primary-key: true
x-autoincrement: true
name:
type: string
description: The name of the employee.
example: David Andersson
x-index: true
division:
type: string
description: The part of the company the employee works in.
example: Engineering
x-index: true
salary:
type: number
description: The amount of money the employee is paid.
example: 1000000.00
required:
- id
- name
- division
```The SQLALchemy models file then becomes:
```python
# models.py
from open_alchemy import init_yamlinit_yaml("./examples/simple/example-spec.yml")
```The _Base_ and _Employee_ objects can be accessed:
```python
from open_alchemy.models import Base
from open_alchemy.models import Employee
```With the _models_filename_ parameter a file is auto generated with type hints
for the SQLAlchemy models at the specified location, for example:
[type hinted models example](examples/simple/models_auto.py). This adds support
for IDE auto complete, for example for the model initialization:![autocomplete init](examples/simple/models_autocomplete_init.png)
and for properties and methods available on an instance:
![autocomplete instance](examples/simple/models_autocomplete_instance.png)
An extensive set of examples with a range of features is here:
[examples for main features](examples)
An example API has been defined using connexion and Flask here:
[example connexion app](examples/app)
## Documentation
[Read the Docs](https://openapi-sqlalchemy.readthedocs.io/en/latest/)
## Buy me a coffee
[![Buy Me A Coffee](https://cdn.buymeacoffee.com/buttons/v2/default-yellow.png)](https://www.buymeacoffee.com/jdkandersson)
## Features
- initializing from JSON,
- initializing from YAML,
- build a package with the models for distribution, packaged as sdist or wheel,
- automatically generate a models file,
- `integer` (32 and 64 bit),
- `number` (float only),
- `boolean`,
- `string`,
- `password`,
- `byte`,
- `binary`,
- `date`,
- `date-time`,
- generic JSON data,
- `$ref` references for columns and models,
- remote `$ref` to other files on the same file system
(_not supported on Windows_),
- remote `$ref` to other files at a URL,
- primary keys,
- auto incrementing,
- indexes,
- composite indexes,
- unique constraints,
- composite unique constraints,
- column nullability,
- foreign keys,
- default values for columns (both application and database side),
- many to one relationships,
- one to one relationships,
- one to many relationships,
- many to many relationships,
- many to many relationships with custom association tables,
- custom foreign keys for relationships,
- back references for relationships,
- `allOf` inheritance for columns and models,
- joined and single table inheritance,
- `from_str` model methods to construct from JSON string,
- `from_dict` model methods to construct from dictionaries,
- `to_str` model methods to convert instances to JSON string,
- `__str__` model methods to support the python `str` function,
- `__repr__` model methods to support the python `repr` function,
- `to_dict` model methods to convert instances to dictionaries,
- `readOnly` and `writeOnly` for influence the conversion to and from
dictionaries,
- exposing created models under `open_alchemy.models` removing the need for
`models.py` files,
- ability to mix in arbitrary classes into a model,
- can use the short `x-` prefix or a namespaced `x-open-alchemy-` prefix for
extension properties and
- grouping models into schemas.## Contributing
Fork and checkout the repository. To install:
```bash
poetry install
```To run tests:
```bash
poetry run pytest
```Make your changes and raise a pull request.
## Compiling Docs
```bash
poetry shell
cd docs
make html
```This creates the `index.html` file in `docs/build/html/index.html`.
## Release Commands
```bash
rm -r dist/*
poetry build
poetry publish
```