
Security News
Deno 2.2 Improves Dependency Management and Expands Node.js Compatibility
Deno 2.2 enhances Node.js compatibility, improves dependency management, adds OpenTelemetry support, and expands linting and task automation for developers.
ZPy Core, Layer for build microservices
Zurck'z Py Flask Micro Services Core
This package contains some helpers features for build python microservices using Flask framework
ZPy use the following packages:
Use the package manager pip to install py flask micro service core .
pip install zpy-api-core
Contains some helper features.
Generate project using zpy CLI
# Generate project with basic information. for more type: zpy --help
zpy make -p awesome-api -d "My awsome users api" -c Users -uc UserSearcher -op
...
cd awesome-api
zpy will generate the project with the following structure
awesome-api
│ .env
│ .gitignore
│ CHANGELOG.md
│ CHANGELOG.md
│ README.md
│ requirements.txt
│
└───src
│ │ di.py
│ │ handler.py
│ │ local_deploy.py
│ │
│ └───┬api
│ │ routes.py
│ │ ...
│ └contexts
│ │ ...
│ └───users
│ │ ...
│ └───┬application
│ │ │ ...
│ └───┬domain
│ │ │ ...
│ └───┬infraestructure
│ │ ...
└───tests
│ user_searcher_test.py
Dependencies file
# 🛸 Generated by zPy
from zpy.utils import get_env_or_throw as var
from zpy.app.usecase import UseCase
from typing import Any
# * Setup Dependencies 📃
from contexts.users.domain.repositories import UserRepository
from contexts.users.infraestructure.payment_repository import AwesomeUserRepository
from contexts.users.application.user_searcher import UserSearcher
repository: UserRepository = AwesomeUserRepository()
# Setup UseCases
user_searcher_uc: UseCase[Any, None] = UserSearcher(repository)
print("🚀 Dependencies loaded successfully...")
routes.py
# 🛸 Generated by zPy
from di import user_searcher_uc
from flask import Flask
from zpy.api.http.response import response_builder
from zpy.api.flask import create_app
app: Flask = create_app()
@app.route("/api/users", methods=["GET"])
@response_builder
def users():
return user_searcher_uc.execute(None)
Use Case
# 🛸 Generated by zPy
from typing import Any
from zpy.app.usecase import UseCase
from ..domain.repositories import UserRepository
class UserSearcher(UseCase[Any, Any]):
"""
Use Case description.
"""
def __init__(self, repository: PaymentRepository) -> None:
self.repository = repository
def execute(self, data: Any, *args, **kwargs) -> None:
# TODO Do magic with business rules 😁
return self.repository.user_searcher(data)
Local Dev Deploy
# 🛸 Generated by zPy
from dotenv import load_dotenv
load_dotenv(
dotenv_path="|3:\\projects\\demos\\awesome-api\\.env"
)
from api.routes import app
if __name__ == "__main__":
app.run(host="127.0.0.1", port=5050, debug=True)
handler.py configure for aws lambda and api gateway
# 🛸 Generated by zPy
from zpy.api.cloud_handlers import aws_lambda
from api.routes import app
import aws_lambda_wsgi as awsgi
@aws_lambda()
def handle(event: dict, context: dict) -> any:
return awsgi.response(app, event, context)
Pull requests are welcome. For major changes, please open an issue first to discuss what you would like to change.
Please make sure to update tests as appropriate.
FAQs
Helper layer for backend application development to Aws Lambda
We found that zpy-api-core demonstrated a healthy version release cadence and project activity because the last version was released less than a year ago. It has 1 open source maintainer collaborating on the project.
Did you know?
Socket for GitHub automatically highlights issues in each pull request and monitors the health of all your open source dependencies. Discover the contents of your packages and block harmful activity before you install or update your dependencies.
Security News
Deno 2.2 enhances Node.js compatibility, improves dependency management, adds OpenTelemetry support, and expands linting and task automation for developers.
Security News
React's CRA deprecation announcement sparked community criticism over framework recommendations, leading to quick updates acknowledging build tools like Vite as valid alternatives.
Security News
Ransomware payment rates hit an all-time low in 2024 as law enforcement crackdowns, stronger defenses, and shifting policies make attacks riskier and less profitable.