Skip to main content

Abstraction level for object storages.

Project description

Tests

file-keeper

Abstraction layer for reading, writing and managing file-like objects.

The package implements drivers for a number of storage types(local filesystem, redis, AWS S3, etc.) and defines a set of tools to simplify building your own drivers for storage you are using.

Read the documentation for a full user guide.

Usage

Initialize storage pointing to /tmp/example folder:

import os
from file_keeper import make_storage

storage = make_storage("sandbox", {
    "type": "file_keeper:fs",
    "path": "/tmp/example",
    # this option creates the folder if it does not exist.
    # Without it storage raises an error if folder is missing
    "create_path": True,
})
assert os.path.isdir("/tmp/example")

Upload file into the storage initialized in the previous step and play with it a bit:

from file_keeper import make_upload

# transform data into an object, that can be saved inside the storage
upload = make_upload(b"hello world")

# save the data and verify its presence in the system
result = storage.upload("hello.txt", upload)
assert result.size == 11
assert os.path.isfile("/tmp/example/hello.txt")

# change location of the file
moved_result = storage.move("moved-hello.txt", result, storage)
assert not os.path.exists("/tmp/example/hello.txt")
assert os.path.isfile("/tmp/example/moved-hello.txt")

# read the file
assert storage.content(moved_result) == b"hello world"

# remove the file
storage.remove(moved_result)
assert not os.path.exists("/tmp/example/moved-hello.txt")

Development

Install dev extras:

pip install -e '.[dev]'

Run unittests:

pytest

Run typecheck:

pyright

License

AGPL

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

file_keeper-0.0.2.post1.tar.gz (30.2 kB view details)

Uploaded Source

Built Distribution

If you're not sure about the file name format, learn more about wheel file names.

file_keeper-0.0.2.post1-py3-none-any.whl (37.7 kB view details)

Uploaded Python 3

File details

Details for the file file_keeper-0.0.2.post1.tar.gz.

File metadata

  • Download URL: file_keeper-0.0.2.post1.tar.gz
  • Upload date:
  • Size: 30.2 kB
  • Tags: Source
  • Uploaded using Trusted Publishing? No
  • Uploaded via: twine/5.1.1 CPython/3.9.19

File hashes

Hashes for file_keeper-0.0.2.post1.tar.gz
Algorithm Hash digest
SHA256 04ab0ee66f386d4b7239de63734c413d5e0174cf3e068a1d9996ea1046020a90
MD5 1b92a23f07f1c724af14528228d6c66d
BLAKE2b-256 fa1d4d2fddea798138e63903aaa00d420b06a12a166b8e2a4753e9b4d60e14fa

See more details on using hashes here.

File details

Details for the file file_keeper-0.0.2.post1-py3-none-any.whl.

File metadata

File hashes

Hashes for file_keeper-0.0.2.post1-py3-none-any.whl
Algorithm Hash digest
SHA256 55a3d5ad9f0af3e914119b20ffac22551f294a17efba65f4751cff0af0843d95
MD5 6dbb67c56382ae7412344387163c633f
BLAKE2b-256 d873ae6365ad274dd078ab159e25bc9744f211d8024f66caa85b5c5c3ec5a50c

See more details on using hashes here.

Supported by

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