Skip to main content

A collection of Python libraries for A360

Project description

a360-python-libraries

Python shared libraries for a360 applications

License

This software is proprietary and is intended solely for use by Aesthetics-360 Inc.. Unauthorized use, distribution, or modification of this software outside of Aesthetics-360 Inc. is strictly prohibited.

Add package into your project

poetry add a360-python-libraries

Usage

Role based access control

from fastapi import APIRouter, Depends

from a360_security.depends import require_role
from a360_security.enums import Role

router = APIRouter()

@router.get(
    ...,
    dependencies=[Depends(require_role(Role.ADMIN))]
)
def get() -> dict:
    ...

You can provide multiple roles to the require_role dependency, and they will be checked in OR fashion.

from fastapi import APIRouter, Depends

from a360_security.depends import require_role
from a360_security.enums import Role

router = APIRouter()

@router.get(
    ...,
    dependencies=[Depends(require_role(Role.ADMIN, Role.SERVICE))]
)
def get() -> dict:
    ...

User dependency

from fastapi import APIRouter, Depends

from a360_security.depends import require_user
from a360_security.dto import UserDTO

router = APIRouter()

@router.get(
    ...,
)
def get(user: UserDTO = Depends(require_user)) -> dict:
    ...

Client platform

from fastapi import APIRouter, Depends

from a360_security.depends import require_client_platform
from a360_security.enums import ClientPlatform

router = APIRouter()

@router.get(
    ...,
)
def get(client_platform: ClientPlatform = Depends(require_client_platform)) -> dict:
    ...

Internal services

from fastapi import APIRouter, Depends

from a360_services import get_dictionary_service
from a360_services.services import DictionaryService

router = APIRouter()

@router.get(
    ...,
)
def get(dict_service: DictionaryService = Depends(get_dictionary_service)) -> dict:
    medical_conditions = dict_service.get_medical_conditions()

Email notification

from fastapi import APIRouter, Depends

from a360_notification import get_mail_service
from a360_notification.services import AWSSesService

router = APIRouter()

@router.post(
    ...,
)
def create(mail_service: AWSSesService = Depends(get_mail_service)):
    mail_service.send_email(
        recipient_name='John Doe',
        recipient_address='john.doe@example.com',
        subject='Test email',
        html_content='<h1>Test email</h1>',
    )

Project details


Download files

Download the file for your platform. If you're not sure which to choose, learn more about installing packages.

Source Distribution

a360_python_libraries-0.8.4.tar.gz (9.0 kB view details)

Uploaded Source

Built Distribution

a360_python_libraries-0.8.4-py3-none-any.whl (15.8 kB view details)

Uploaded Python 3

File details

Details for the file a360_python_libraries-0.8.4.tar.gz.

File metadata

  • Download URL: a360_python_libraries-0.8.4.tar.gz
  • Upload date:
  • Size: 9.0 kB
  • Tags: Source
  • Uploaded using Trusted Publishing? No
  • Uploaded via: poetry/1.8.3 CPython/3.11.10 Linux/6.8.0-1015-azure

File hashes

Hashes for a360_python_libraries-0.8.4.tar.gz
Algorithm Hash digest
SHA256 8854ec93f31f9402f1b161f805f0750a652a54b7f9fa501d07b6acbdf7abd43d
MD5 3d4caf3f88714b4c92feb5e7b7b3c7ad
BLAKE2b-256 ad6c8b63e62865f9c4993cca0f3b00d6f2f8d73295e925ca435337b64d16280f

See more details on using hashes here.

File details

Details for the file a360_python_libraries-0.8.4-py3-none-any.whl.

File metadata

File hashes

Hashes for a360_python_libraries-0.8.4-py3-none-any.whl
Algorithm Hash digest
SHA256 a753dad7094b7d37eff3f657cc21984f4f906a115f67dc09b52ad3fd9aba8d04
MD5 3f7d45f44e7ec5df07b5224c7a447b05
BLAKE2b-256 0db8d5974a7fa15f89052f3d19144e38204c0585906049c4b64299f55d5da88b

See more details on using hashes here.

Supported by

AWS AWS Cloud computing and Security Sponsor Datadog Datadog Monitoring Fastly Fastly CDN Google Google Download Analytics Microsoft Microsoft PSF Sponsor Pingdom Pingdom Monitoring Sentry Sentry Error logging StatusPage StatusPage Status page