Skip to main content

Kiwix S3 Cache wrapper to use within Kiwix/OpenZIM projects

Project description

kiwixstorage

CodeFactor License: GPL v3 PyPI version shields.io

helpers for S3 storage, autoconf from URL + Wasabi (wasabisys.com) extras

Goal is mainly to provide a configured s3.client and s3.resource from an URL Users could limit usage to this and use boto3 directly from there.

A few additional wrappers are in place to simplify common actions. Also, non-S3, wasabi-specific features are exposed directly.

Usage

pip install kiwixstorage

Connection

from kiwixstorage import KiwixStorage
url = "https://s3.us-east-1.wasabisys.com/?keyId=x&secretAccessKey=y&bucketName=z"
s3 = KiwixStorage(url)
# test credentials and ensure we can list buckets
if not s3.check_credentials(list_buckets=True, failsafe=True):
    return # bad auth

Scraper use-case

online_url = "https://xxx"
fpath = "/local/path.ext"
# retrieve origin etag
etag = requests.head(online_url, allow_redirects=True).headers.get("Etag")
# check if we have that very same version in store
if s3.has_matching_object(key=url, etag=etag)
    # lastest version in our store, download from there (using progress output)
    s3.download_file(key=url, fpath=fpath, progress=True)
else:
    # download the origin file using your regular tools
    download_file(url, fpath)
    # upload it our storage
    s3.upload_file(fpath=fpath, key=url)
# now you have a local file of lastest version and the storage is up to date

Other use cases

# create a bucket
bucket = s3.create_bucket("bucket_name")

# set auto-delete on bucket
s3.set_bucket_autodelete_after(nb_days=7)

# allow public downloads from bucket
s3.allow_public_downloads_on()

# upload a file
s3.upload_file(fpath, "some/path/file.img", meta={"ENCODER_VERSION": "v1"})

# set autodelete on specific file
s3.set_object_autodelete_on(key, datetime.datetime.now())

# download a file
s3.download_file(key, fpath)

# get URL for external download
s3.get_download_url(key)

Resources:

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

kiwixstorage-0.8.3.tar.gz (38.0 kB view details)

Uploaded Source

Built Distribution

kiwixstorage-0.8.3-py3-none-any.whl (36.9 kB view details)

Uploaded Python 3

File details

Details for the file kiwixstorage-0.8.3.tar.gz.

File metadata

  • Download URL: kiwixstorage-0.8.3.tar.gz
  • Upload date:
  • Size: 38.0 kB
  • Tags: Source
  • Uploaded using Trusted Publishing? No
  • Uploaded via: twine/4.0.0 CPython/3.8.6

File hashes

Hashes for kiwixstorage-0.8.3.tar.gz
Algorithm Hash digest
SHA256 a4a304e512f4e7f62b5cdf7383d9b6c620cd92cb5c176ac0608e49b93462c26d
MD5 2d236a81dc4ac0402124c7350b436ee5
BLAKE2b-256 aea5be1485608dffce0515651ac6876e0ccf750c2e61e1f558098ea20d638b25

See more details on using hashes here.

Provenance

File details

Details for the file kiwixstorage-0.8.3-py3-none-any.whl.

File metadata

File hashes

Hashes for kiwixstorage-0.8.3-py3-none-any.whl
Algorithm Hash digest
SHA256 84cafa49b6b8b981fbe5fefa552ac912759d5324a9df7b3df5d4948f8c2ff11c
MD5 0e448e629a1185be81cdd20770a506a4
BLAKE2b-256 cab014f29c70c0bfe54ef26675b632256a73bfe61c44122cefd31c4f94ea0403

See more details on using hashes here.

Provenance

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