Skip to main content

ORM-client with connect to dynamodb-database and s3-storage.

Project description

dynamodb_manager

Фреймворк для управления сервисами YandexCloud в serverless режиме на основе библиотеки botocore и pydantic. С помощью фреймворка можно создавать объекты таблицы базы данных dynamodb и стандартного хранилища s3. И управлять непосредственно ими с помощью оптимизированного интерфейса. Названия методов идентичны методам библиотеки botocore, поэтому работать с этим фреймворком опытным программистам будет не сложно. Поскольку во фреймворке реализована далеко не вся функциональность библиотеки botocore, то в методах классов оставлены аргументы **kwargs, где вы можете использовать более тонкие запросы к AWS-сервисам YandexCloud. Проект находится в пилотном режиме, поэтому, если есть какие предложения по совершенствованию проекта, буду рад сотрудничеству.

Работа с базой данных dynamodb

Для создания таблицы нужно определить ключевую схему с помощью класса KeySchema. Импортируем и объявим его экземпляр.

from boto_orm.models.db_model import KeySchema

key_schema = KeySchema(HASH='name', RANGE='user_id')

Также определим схему таблицы с помощью класса на базе модели DBModel. Имена ключей, объявленные в ключевой схеме, должны присутствовать в классе модели.

from boto_orm.models.db_model import DBModel

class Table(DBModel):
    name: str
    user_id: int
    create: float

Для ограничения пропускной способности, воспользуйтесь экземпляром класса ProvisionedThroughput.

from boto_orm.db_manager import ProvisionedThroughput
prov = ProvisionedThroughput(ReadCapacityUnits=1, WriteCapacityUnits=1)

Для работы с сервисами AWS необходимо использование переменных окружения. Для этого создадим файл boto-orm.yaml в корневом каталоге со следующим содержимым (example заменить на свои переменные):

session:
    access_key: 'key example'
    secret_key: 'secret example'
db_config:
    service_name: 'dynamodb'
    endpoint_url: 'https://example.com'
    region_name: 'ru-central1'
s3_config:
    service_name: 's3'
    endpoint_url: 'https://storage.example.com'
    region_name: 'ru-central1'

Либо создать свой конфиг на базе экземпляров классов AWSConfig и AWSSession.

from boto_orm.models.config import AWSConfig, AWSSession

session = AWSSession(access_key: str = 'example', secret_key: str = 'example')
config = AWSConfig(service_name: str = 'example', endpoint_url: str = 'example', region_name: str = 'example')

Можно создать свой файл конфигурации boto-orm.yaml, для этого необходимо сделать свой наследный класс от boto_orm.models.config.BaseConfig.

class Configure(BaseConfig):
    session: AWSSession
    db_config: AWSConfig
    s3_config: AWSConfig

Создать таблицу можно с помощью метода create_table экземпляра класса DynamodbManage

from boto_orm.db_manager import DynamodbManage

db = DynamodbManage(table_name='Table_test')
db.create_table(key_schema, attribute=Table, provisioned_throughput=prov)

Экземпляр класса DynamodbManage имеет следующие аргументы:

resource_name: str # название таблицы
config: Union[AWSConfig, dict] # конфигурация ресурсного клиента:
    service_name: Any['dynamodb', 's3'],
    endpoint_url: str
    region_name: str
session_aws: Union[AWSSession, dict] # конфигурация сессии botocore:
    access_key: str
    secret_key: str

Добавить элемент в таблицу можно с помощью команды:

from boto_orm.models.db_model import DBModel

class Table(DBModel):
    name: str
    user_id: int
    create: float

data = Table(name='Name', user_id=238, create=19.97)
db = DynamodbManage(table_name='Table_test')
db.put_item(data)

Запрос по параметрам значений ключей

response = db.query(Key('name').eq(value=['Tso']), range=Key('user_id').eq([239]))

Для запроса возможно использование значения только ключа партицирования. Также во фреймворке предусмотрена возможность фильтрации по параметрам, не являющимися ключами:

from boto_orm.filter import Key, Filter

response = db.query(Key('name').eq(value=['Tso']), filters=Filter('user_id').ge(249))

Для фильтрации используется экземпляр класса Filter, где в качестве параметра используется имя столбца, а значение аргумента вводится в методе. Для класса Key и Filter актуальны следующие методы:

  • eq - Операция эквивалентности
  • ne - Операция отрицания
  • begins_with - Операция поиска строки, начинайщийся с value
  • le - Операция меньше или равно
  • lt - Операция меньше
  • ge - Операция больше или равно
  • gt - Операция больше
  • between - Операция между. Для операции сканирования базы данных используется метод scan.
response = db.scan(filters=Filter('user_id').ge(237))

Метод может принимать следующие необязательные аргументы:

Работа с хранилищем s3

Создаём экземпляр клиента S3Manager для работы с бакетом

from boto_orm.s3_manager import S3Manager

s3 = S3Manager(bucket_name='serverless-shortener')

Для создания бакета можно воспользоваться метода create_bucket.

response = s3.create_bucket()

Загрузить строку или байты в бакет можно с помощью метода put_object.

response = s3.put_object('TEST', name_file='test.txt')

Загрузить файл можно указав путь файла в методе upload_file:

response = s3.upload_file(file_path='file/test.py', name_file='test.py')

Удалить один или несколько объектов можно следующим образом:

response = s3.delete_objects(['manager.py', 'test.txt'])

Загрузить список объектов бакета можно с помощью метода list_objects

response = s3.list_objects()

Загрузить объект файла можно с помощью метода get_object

response = s3.get_str_object('index.html')
print(response['Body'].read())

В качестве альтернативы можно воспользоваться методом строкового представления загружаемого файла get_str_object. Дополнительным параметром можно добавить кодировку.

response = s3.get_str_object('index.html', encoding='utf-8')

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

boto_orm-0.0.3.tar.gz (10.3 kB view details)

Uploaded Source

Built Distribution

boto_orm-0.0.3-py3-none-any.whl (12.2 kB view details)

Uploaded Python 3

File details

Details for the file boto_orm-0.0.3.tar.gz.

File metadata

  • Download URL: boto_orm-0.0.3.tar.gz
  • Upload date:
  • Size: 10.3 kB
  • Tags: Source
  • Uploaded using Trusted Publishing? No
  • Uploaded via: twine/5.1.1 CPython/3.11.9

File hashes

Hashes for boto_orm-0.0.3.tar.gz
Algorithm Hash digest
SHA256 4c89b90c1f0a3ff73e76612f2a29b044cc5603cae7950c1055570ff32a85d4bb
MD5 d1db7323f9ca40793c17705d3e4843e1
BLAKE2b-256 8ef3b066aed72eaf51f22575eb5d073630904b0cbb3fed621872322412c8a687

See more details on using hashes here.

File details

Details for the file boto_orm-0.0.3-py3-none-any.whl.

File metadata

  • Download URL: boto_orm-0.0.3-py3-none-any.whl
  • Upload date:
  • Size: 12.2 kB
  • Tags: Python 3
  • Uploaded using Trusted Publishing? No
  • Uploaded via: twine/5.1.1 CPython/3.11.9

File hashes

Hashes for boto_orm-0.0.3-py3-none-any.whl
Algorithm Hash digest
SHA256 9afe9b09d2fe331b46e0a8634a76101366d7ca021d08598a1c9afa5d6911b5a0
MD5 b7716d3e24a6eccc8e714d3cf91a5f42
BLAKE2b-256 834c5ab849d2c9d319472d8e779aabc32223589e363f96ba3002f34ffba8ae32

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