devon4py is an incubator project within devonfw, Capgemini'sOpen Source initiative which specifies a standardized open source architecture blueprint for state of the art cloud native (micro-) services and multi-platform rich client applications based on open source best-of-breed technology stacks.
devon4py provides a fully featured Python based solution for API service applications based on:
- a scalable & easy to maintain template,
- Python development standardization,
- production ready for API applications and
- industrialized & standards based
For more information, see the presentation.
- Swagger / OpenAPI integration
- Configuration file for each environment
- Enable/Disable Swagger
- API Port configuration
- Log Configuration
- Database Configuration
- ASYNC Database Configuration
- Swagger Configuration
- JWT / Keycloak Integration
- CORS Configuration
- Google Firebase Authentication Integration
- Google Firestore Database Repository Integration
- Google Storage Integration
- Google Clour Run Integration
- Global Exception Management
- DB Entity Generation
- SSE Support
- Code generation using Templates
- Log to files integration
- Log to Cloud Run Google Cloud
- Log to Database integration
- Log to GrayLog integration
- Log to Splunk integration
- Kafka integration
FastAPI is a modern, fast (high-performance), web framework for building APIs with Python 3.6+ based on standard Python type hints.
The key features are:
-
Fast: Very high performance, on par with NodeJS and Go (thanks to Starlette and Pydantic). One of the fastest Python frameworks available.
-
Fast to code: Increase the speed to develop features by about 200% to 300%.
-
Fewer bugs: Reduce about 40% of human (developer) induced errors.
-
Intuitive: Great editor support. Completion everywhere. Less time debugging.
-
Easy: Designed to be easy to use and learn. Less time reading docs.
-
Short: Minimize code duplication. Multiple features from each parameter declaration. Fewer bugs.
-
Robust: Get production-ready code. With automatic interactive documentation.
-
Standards-based: Based on (and fully compatible with) the open standards for APIs: OpenAPI (previously known as Swagger) and JSON Schema.
FastAPI works on Uvicorn, an ASGI web server implementation for Python.
Unlike Flask, FastAPI is an ASGI (Asynchronous Server Gateway Interface) framework, brings together Starlette, Pydantic, OpenAPI, and JSON Schema. Under the hood, FastAPI uses Pydantic for data validation and Starlette for tooling, making it blazing fast compared to Flask, giving comparable performance to high-speed web APIs in Node or Go. Starlette + Uvicorn offers async request capability, something that Flask lacks. With Pydantic along with type hints, you get a nice editor experience with autocompletion. You also get data validation, serialization and deserialization (for building an API), and automatic documentation (via JSON Schema and OpenAPI).
Or in other way, no need for them, import and use the code you need.
Any integration is designed to be so simple to use (with dependencies) that you can create a "plug-in" for your application in 2 lines of code using the same structure and syntax used for your path operations.
- 100% test coverage.
- 100% type annotated code base.
- Used in production applications.
FastAPI is fully compatible with (and based on) Starlette. So, any additional Starlette code you have, will also work.
FastAPI is actually a sub-class of Starlette. So, if you already know or use Starlette, most of the functionality will work the same way.
With FastAPI you get all of Starlette's features (as FastAPI is just Starlette on steroids):
- Seriously impressive performance. It is one of the fastest Python frameworks available, on par with NodeJS and Go.
- WebSocket support.
- In-process background tasks.
- Startup and shutdown events.
- Test client built on requests.
- CORS, GZip, Static Files, Streaming responses.
- Session and Cookie support.
- 100% test coverage.
- 100% type annotated codebase.
In this section you will find an overview on how to execute and configure the project.
Dependencies are automatically managed by Poetry
To install dependencies run
poetry install
in same folder where your .toml
file is located.
Poetry will take care of:
- Installing the required Python interpreter
- Installing all the libraries and modules
- Creating the virtual environment for you
Refer to this link to configure Poetry on PyCharm
You can launch the uvicorn server programmatically running directly the main.py file.
python main.py
It is also possible to start the uvicorn live directly server with the command:
uvicorn main:api --reload
- main: the file main.py (the Python "module").
- app: the object created inside of main.py with the line app = FastAPI().
- --reload: make the server restart after code changes. Only use for development.
You can run all test scenarios using:
python -m coverage run -m unittest
To display the coverage results:
coverage report
or with a nicer report as html page:
coverage html
You can use Pydantic Settings to handle the settings or configurations for your application, with all the power of Pydantic models. The project uses Dependency Injection for managing dependencies across the application and easy mocking for testing.
Create an .env file for each environment configuration. The use of @lru_cache() lets you avoid reading the dotenv file again and again for each request, while allowing you to override it during testing.
Even when using a dotenv file, the application will still read environment variables as well as the dotenv file, environment variables will always take priority over values loaded from a dotenv file.
You can also specify the environment when launching the server. Corresponding .env file will be automatically loaded.
Settings and environment variables are managed by Pydantic, refer to the documentation for more info.
ENV=PROD uvicorn main:app --reload
ENV=PROD python main.py
The Port and Hosting configuration can be set directly on the .env file if launching the main.py file.
However, this configuration is related with the uvicorn server itself and can also be set with the --port [int] flag.
Refer to the uvicorn documentation for more info.
The application uses the default logging module.
To use it inside an specific module init it first with the command:
logger = logging.getLogger(__name__)
You can use the name variable to take the current file name as the default or specify a custom module name manually.
Configure the logging properties in the logging.yaml file. You can find more information in the logging documentation.
TODO
https://github.com/devonfw-forge/jump-the-queue-devon4py
https://github.com/devonfw-forge/wayat-flutter-python-mvp
Copyright 2022 Capgemini
The source code on this site is licensed under the Apache Public License 2.0. See LICENSE.txt for details.
The documentation (not the source code) available on this site is licensed under a Creative Commons Attribution 4.0 International License.