Skip to main content

Lightweight image gallery server - no database, no files left behind

Project description

Lenslet

A lightweight image gallery server that runs entirely in-memory. Point it at a directory of images and browse them in your browser. No database, no metadata files left behind.

Introduction

image

Lenslet is a self-contained image gallery server designed for simplicity and speed. It indexes directories on-the-fly, generates thumbnails in memory, and serves everything through a clean web interface. Perfect for quickly browsing local image collections without modifying the source directory.

Features

  • Clean operation: No files written to your image directories
  • In-memory indexing: Fast directory scanning and caching
  • On-demand thumbnails: Generated and cached in RAM
  • Full web UI: Browse, search, and view images in your browser
  • Metadata support: Add tags, notes, and ratings (session-only)
  • Single command: Just point to a directory and go

Installation

pip install lenslet

Usage

Command Line Interface

lenslet /path/to/images

Then open the URL printed in the terminal (default http://127.0.0.1:7070, or the next available port).

Options:

lenslet <directory> [options]

Options:
  -p, --port PORT              Port to listen on (default: 7070; auto-increment if in use)
  -H, --host HOST              Host to bind to (default: 127.0.0.1)
  --thumb-size SIZE            Thumbnail short edge in pixels (default: 256)
  --thumb-quality QUALITY      Thumbnail WebP quality 1-100 (default: 70)
  --reload                     Enable auto-reload for development
  --share                      Create a public share URL via cloudflared
  --verbose                    Show detailed server logs
  -v, --version                Show version and exit

Examples:

# Serve images from your Pictures folder
lenslet ~/Pictures

# Use a custom port
lenslet ~/Photos --port 8080

# Make accessible on local network
lenslet ~/Images --host 0.0.0.0 --port 7070

# Create a public share URL (prints a trycloudflare.com link)
lenslet ~/Images --share

Programmatic API (Python/Jupyter)

Launch lenslet directly from Python code or notebooks:

import lenslet

datasets = {
    "my_images": ["/path/to/img1.jpg", "/path/to/img2.jpg"],
    "more_images": [
        "s3://bucket/img3.jpg",           # S3 URIs
        "https://example.com/img4.jpg",   # HTTP/HTTPS URLs
    ],
}

# Launch in non-blocking mode (returns immediately)
lenslet.launch(datasets, blocking=False, port=7070)

Key Features:

  • 🚀 Jupyter-friendly: Non-blocking mode for notebooks
  • ☁️ S3 support: Automatically handles S3 URIs via presigned URLs
  • 📁 Multiple datasets: Organize images into named collections
  • 🔗 Mixed sources: Combine local files and S3 images

See Programmatic API Documentation for details and examples.

Notes

  • All indexes, thumbnails, and metadata are kept in memory
  • Metadata changes (tags, ratings, notes) are lost when the server stops
  • Supports JPEG, PNG, and WebP formats
  • Hidden files and folders (starting with .) are ignored

License

MIT License

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

lenslet-0.2.5.tar.gz (489.2 kB view details)

Uploaded Source

Built Distribution

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

lenslet-0.2.5-py3-none-any.whl (150.5 kB view details)

Uploaded Python 3

File details

Details for the file lenslet-0.2.5.tar.gz.

File metadata

  • Download URL: lenslet-0.2.5.tar.gz
  • Upload date:
  • Size: 489.2 kB
  • Tags: Source
  • Uploaded using Trusted Publishing? No
  • Uploaded via: twine/6.2.0 CPython/3.10.16

File hashes

Hashes for lenslet-0.2.5.tar.gz
Algorithm Hash digest
SHA256 c0c342a0fc47dbf9d92c16e98b099e85785f517b5abb52dfa311907528812af1
MD5 39c05c0625234f500381e849f1d1c251
BLAKE2b-256 09cbb9aba9f26bde6fa1ffe1102a2dd6db3c96dfc737c99277da3af7ebd8bc7f

See more details on using hashes here.

File details

Details for the file lenslet-0.2.5-py3-none-any.whl.

File metadata

  • Download URL: lenslet-0.2.5-py3-none-any.whl
  • Upload date:
  • Size: 150.5 kB
  • Tags: Python 3
  • Uploaded using Trusted Publishing? No
  • Uploaded via: twine/6.2.0 CPython/3.10.16

File hashes

Hashes for lenslet-0.2.5-py3-none-any.whl
Algorithm Hash digest
SHA256 2d4fd10cd86c1dc44d783b64fd878bd93494616e39e735e64ca848ad14608887
MD5 2d72459cce4030af49c85ecdcfc3de5a
BLAKE2b-256 da25981251d05d8b2235767a8c2e12cb6573cb9a779f7e16fab79e3cef9447dd

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