Skip to main content

Client for Lychee, written in Python.

Project description

pychee

Client for Lychee, written in Python.

Lychee is a photo management system I've been using for years. I had the idea to make a « Lychee filesystem » with FUSE, so I needed an API client.

Installation

python3 -m pip install pychee

Notes

My reference is this documentation. The API is partially implemented and focused on photo management, i.e. only Albums, Photo, Frame, Sharing and Settings::setLogin. Users can do whatever they want with their albums and photos and change their password.

Disclaimer : I usually suck at coding, so use with caution and at your own risks. Tested with Lychee v4.7.0. The code probably won't be retrocompatible and should just work with the latest version.

TODO

Add tests

Example usage

⚠️ pychee returns exactly what the API sends back, just parsing it to dict if necessary. As sample answers are not documented in the API and because answers tend to change over time, you should inspect requests in browser if your client code does not works anymore.

A sample of common API calls :

#!/usr/bin/env python
# coding=utf-8
from pychee import pychee

# Initialize instance
client = pychee.LycheeClient('https://pic.chosto.me')

# Login
client.login('login', 'password')

# Create a new album
album_name = 'test_name'
album_id = client.add_album(album_name)['id']

# Add a photo in the created album
path_to_your_photo = '/your/path/photo.jpg'
with open(path_to_your_photo, 'rb') as f:
    photo_id = client.add_photo(f, 'photo.jpg', album_id)['id']

# Set uploaded photo public
client.set_photo_public(photo_id)

# Set licence of uploaded photo
client.set_photo_license(photo_id, 'CC0')

# Download an archive of the created album
output_path = '/tmp/photos.zip'
with(open(output_path, 'wb')) as f:
     f.write(client.get_albums_archive([album_id]))

# Logout
client.logout()

Documentation

Documentation is automatically published on GitHub: https://chostakovitch.github.io/pychee/index.html

Project details


Download files

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

Source Distributions

No source distribution files available for this release.See tutorial on generating distribution archives.

Built Distribution

pychee-0.2.2-py3-none-any.whl (31.6 kB view details)

Uploaded Python 3

File details

Details for the file pychee-0.2.2-py3-none-any.whl.

File metadata

  • Download URL: pychee-0.2.2-py3-none-any.whl
  • Upload date:
  • Size: 31.6 kB
  • Tags: Python 3
  • Uploaded using Trusted Publishing? No
  • Uploaded via: twine/4.0.2 CPython/3.11.3

File hashes

Hashes for pychee-0.2.2-py3-none-any.whl
Algorithm Hash digest
SHA256 1065d8ec76c6dfe0a9d3403b9ecf0f16825704a1af00abd36d358eeb71c771d9
MD5 0eea7a57573af6662e7e2535afb72437
BLAKE2b-256 80718a08727e5128ae451073a59b9bdb14134ef3d025afe3c183d92fc805760b

See more details on using hashes here.

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