Skip to main content

Python library for interacting with multiple object storage APIs.

Project description

Pilot Platform Storage Manager

Run Tests Python PyPI

Provides a simple and flexible Python library for efficient and reliable object storage solutions. Enables direct interaction with multiple object storage APIs, starting with Azure Blob API and with plans to add more in the future

Getting Started

Manager

import asyncio
from object_storage.factories import get_manager

connection_string = 'DefaultEndpointsProtocol=https;AccountName=pilot;AccountKey=any;EndpointSuffix=core.windows.net'
azr_manager = get_manager('azure', connection_string)

account_sas = asyncio.run(azr_manager.get_container_sas('test'))
print(blob_sas)
> 'https://pilot.blob.core.windows.net/test/file.txt?sp=rw&st=2023-04-28T15:15:14Z&se=2023-04-28T23:15:14Z&spr=https&sv=2021-12-02&sr=b&sig=account_signature'


blob_sas = asyncio.run(azr_manager.get_blob_sas('test', 'small.txt'))

print(blob_sas)
> 'https://pilot.blob.core.windows.net/test/file.txt?sp=rw&st=2023-04-28T15:15:14Z&se=2023-04-28T23:15:14Z&spr=https&sv=2021-12-02&sr=b&sig=blob_signature'


blobs_list = asyncio.run(azr_manager.list_objects('test'))
print(blobs_list)
> [<class 'azure.storage.blob._models.BlobProperties'>, ...]


blobs_list = asyncio.run(azr_manager.create_container('test'))

File Client

import asyncio
from object_storage.factories import get_file_client

blob_sas_url = 'https://pilot.blob.core.windows.net/test/file.txt?sp=rw&st=2023-04-28T15:15:14Z&se=2023-04-28T23:15:14Z&spr=https&sv=2021-12-02&sr=b&sig=account_signature'
azr_file_client = get_file_client('azure', blob_sas_url)
asyncio.run(azr_file_client.upload_file('./small.txt'))

Container Client

import asyncio
from object_storage.factories import get_container_client

container_sas_url = 'https://pilot.blob.core.windows.net/test?sp=rw&st=2023-04-28T15:15:14Z&se=2023-04-28T23:15:14Z&spr=https&sv=2021-12-02&sr=b&sig=account_signature'
azr_container_client = get_container_client('azure', container_sas_url)
asyncio.run(azr_container_client.upload_file('small.txt', './small.txt'))

Installation & Quick Start

The latest version of the object-storage package is available on PyPi and can be installed into another service via Pip.

Pip install from PyPi:

pip install pilot-platform-object-storage

In pyproject.toml:

pilot-platform-object-storage = "^<VERSION>"

Pip install from a local .whl file:

pip install pilot_platform_object_storage-<VERSION>-py3-none-any.whl

Documentation

API Reference and User Guide available at pilotdataplatform.github.io/object-storage

Contribution

You can contribute the project in following ways:

  • Report a bug.
  • Suggest a feature.
  • Open a pull request for fixing issues or adding functionality. Please consider using pre-commit in this case.
  • For general guidelines on how to contribute to the project, please take a look at the contribution guide.

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

pilot_platform_object_storage-1.7.0.tar.gz (10.7 kB view details)

Uploaded Source

Built Distribution

pilot_platform_object_storage-1.7.0-py3-none-any.whl (15.4 kB view details)

Uploaded Python 3

File details

Details for the file pilot_platform_object_storage-1.7.0.tar.gz.

File metadata

File hashes

Hashes for pilot_platform_object_storage-1.7.0.tar.gz
Algorithm Hash digest
SHA256 a48ea9ae12454d0cfe0ebf6aa574f7be09f12e6532d8093e77784e2fada88b09
MD5 c38104efa0a7f95529c9249f785ec9ab
BLAKE2b-256 9dce24b36f79694b7b80cd2282ad73740f2b31e10ae06b317170231eadec14dc

See more details on using hashes here.

File details

Details for the file pilot_platform_object_storage-1.7.0-py3-none-any.whl.

File metadata

File hashes

Hashes for pilot_platform_object_storage-1.7.0-py3-none-any.whl
Algorithm Hash digest
SHA256 b73532dd9e7891541539a0d1bc6f09757b7a7354cd9df0e6856ab37fb4270aeb
MD5 d3ba0cbdf63cb269a75a1d99b44bf208
BLAKE2b-256 a203e61474523b585c95fb6e2f3fb4ff7097f87a682bfcac2a16c2fe730f1ff8

See more details on using hashes here.

Supported by

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