Skip to main content

Lightweight file storage service

Project description

Lightweight File Storage Service (LFSS)

PyPI

My experiment on a lightweight and high-performance file/object storage service...

Highlights:

  • User storage limit and access control.
  • Pagination and sorted file listing for vast number of files.
  • High performance: high concurrency, near-native speed on stress tests.
  • Support range requests, so you can stream large files / resume download.
  • WebDAV compatible (NOTE).

It stores small files and metadata in sqlite, large files in the filesystem.
Tested on 2 million files, and it is still fast.

Usage:

pip install lfss
lfss-user add <username> <password>
lfss-serve

By default, the data will be stored in .storage_data. You can change storage directory using the LFSS_DATA environment variable.

I provide a simple client to interact with the service:

lfss-panel --open

Or, you can start a web server at /frontend and open index.html in your browser.

The API usage is simple, just GET, PUT, DELETE to the /<username>/file/url path.
The authentication can be acheived through one of the following methods:

  1. Authorization header with the value Bearer sha256(<username><password>).
  2. token query parameter with the value sha256(<username><password>).
  3. HTTP Basic Authentication with the username and password.

You can refer to frontend as an application example, lfss/api/connector.py for more APIs.

By default, the service exposes all files to the public for GET requests, but file-listing is restricted to the user's own files.
Please refer to docs/Permission.md for more details on the permission system.

Project details


Release history Release notifications | RSS feed

This version

0.9.1

Download files

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

Source Distribution

lfss-0.9.1.tar.gz (57.3 kB view details)

Uploaded Source

Built Distribution

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

lfss-0.9.1-py3-none-any.whl (71.6 kB view details)

Uploaded Python 3

File details

Details for the file lfss-0.9.1.tar.gz.

File metadata

  • Download URL: lfss-0.9.1.tar.gz
  • Upload date:
  • Size: 57.3 kB
  • Tags: Source
  • Uploaded using Trusted Publishing? No
  • Uploaded via: twine/5.1.0 CPython/3.10.5

File hashes

Hashes for lfss-0.9.1.tar.gz
Algorithm Hash digest
SHA256 5efa7c70cff3c40f67068fb286a7fb31ce1e5c0e893b391bf92280cc611e9e9e
MD5 831c947e65b18580cf3d231f3b357290
BLAKE2b-256 81cbdbbae9fc4d53592a7dc55deee949d6caaabcf7a77867a735d9b69a031693

See more details on using hashes here.

File details

Details for the file lfss-0.9.1-py3-none-any.whl.

File metadata

  • Download URL: lfss-0.9.1-py3-none-any.whl
  • Upload date:
  • Size: 71.6 kB
  • Tags: Python 3
  • Uploaded using Trusted Publishing? No
  • Uploaded via: twine/5.1.0 CPython/3.10.5

File hashes

Hashes for lfss-0.9.1-py3-none-any.whl
Algorithm Hash digest
SHA256 f4ea4fd340567d022a3a5fa7234132e5fee14386b5e3e0ccb3adb190b0ab265a
MD5 94a9e7d66a4a013bbdc8d9990fabbb09
BLAKE2b-256 bf0783b649e641e8553101cd3da567a536bd8c9d019474e5afd1d4002a1e510f

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