Skip to main content

Library-first Python client for the reMarkable cloud API

Project description

remarkapy

A Python package for interacting with the reMarkable Cloud API.

Quickstart

from remarkapy import Client

client = Client()
items = client.list_items()
for item in items[:5]:
    print(item.type, item.visibleName, item.parent, item.id, item.hash)

Use client.list_items() for cheap library scans and lookup workflows. client.list_hydrated_items() is the explicit full-hydration variant and fetches each item's manifest, metadata, and .content blob.

Download a raw bundle:

from remarkapy import Client

client = Client()
first = client.list_items()[0]
client.download_raw_bundle(first.hash, "bundle.zip")

Upload a PDF:

from remarkapy import Client

client = Client()
with open("example.pdf", "rb") as handle:
    created = client.put_pdf("Example.pdf", handle.read())
print(created)

CLI examples:

uv run remarkapy init
uv run rkpy ls
uv run rkpy ls Papers/
uv run rkpy ls -r Papers/
uv run rkpy get Papers/Example.pdf
uv run rkpy get Papers/Example.pdf --output ./Example.pdf
uv run rkpy get "Meeting Notes" --format bundle
uv run rkpy export "Meeting Notes" ./exports --format pdf
uv run rkpy info Papers/Example.pdf
uv run remarkapy get-id <item-id-or-hash>
uv run rkpy put-pdf ./example.pdf --parent Papers/
uv run rkpy mkdir Inbox
uv run rkpy rename Papers/Example.pdf "New Name"
uv run rkpy move Papers/Example.pdf Inbox/
uv run rkpy trash Papers/Old Draft.pdf

Why another

As far as I can tell, the major reMarkable client SDKs have all suffered from API churn.

  • rmapy is archived.
  • rmapi is archived (but resurrected??)
  • reMarkable continues to change endpoints and backend behavior.

remarkapy aims to stay useful by:

  • discovering the current public webapp/raw hosts at runtime,
  • supporting the current immutable-manifest sync protocol,
  • exposing a clean Python library API first,
  • keeping real integration tests available behind an explicit opt-in flag.

Optional export backends

  • remarkapy does not render annotations itself.
  • Install the remarks command separately if you want export support (for example: uv tool install git+https://github.com/avncharlie/remarks.git).
  • rkpy export shells out to that installed remarks executable by default, but --remarks-cmd still lets you override it.
  • For single-file PDF/Markdown exports, you can pass an exact output file path like ./notes.pdf; otherwise pass an output directory.
  • remarks needs the system Cairo library for PDF rendering; on macOS install it with brew install cairo.
  • Export output is staged in a temporary bundle and copied back into your requested output directory.

Features

  • Base authentication and device-token reuse
  • Endpoint discovery
  • List documents and folders
  • Download original PDFs and EPUBs
  • Download raw item bundles as zip archives
  • Upload PDFs and EPUBs
  • Create folders
  • Rename items
  • Move items
  • Delete items by moving them to trash
  • Mock-backed pytest suite
  • Read-only live-account smoke tests

Roadmap

  • Download annotated PDFs rendered by the service, if available
  • Add a small CLI wrapper for common operations
  • Add safer live mutation tests using temporary fixtures
  • Add sync-to-directory and sync-from-directory helpers
  • Add device registration from a dedicated command-line flow

Testing

Dangerzone Safety

There are live tests in this repo that interact with the real reMarkable Cloud API. These tests are marked with the live pytest marker and are skipped by default to prevent accidental mutations of real accounts.

The live tests in this repo are intentionally read-only by default.

To run them, opt in explicitly:

REMARKAPY_RUN_LIVE=1 uv run pytest -q -m live

The destructive paths (rename, move, delete, put_*) are covered by the mock test suite. Before adding live destructive tests, use temporary folders or dummy uploads that are safe to clean up.

Injected or mock-backed clients should use in-memory tokens or an explicit test config path; they must not fall back to the default rmapi config location.

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

remarkapy-0.2.0.tar.gz (37.9 kB view details)

Uploaded Source

Built Distribution

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

remarkapy-0.2.0-py3-none-any.whl (30.6 kB view details)

Uploaded Python 3

File details

Details for the file remarkapy-0.2.0.tar.gz.

File metadata

  • Download URL: remarkapy-0.2.0.tar.gz
  • Upload date:
  • Size: 37.9 kB
  • Tags: Source
  • Uploaded using Trusted Publishing? No
  • Uploaded via: uv/0.9.11 {"installer":{"name":"uv","version":"0.9.11"},"python":null,"implementation":{"name":null,"version":null},"distro":{"name":"macOS","version":null,"id":null,"libc":null},"system":{"name":null,"release":null},"cpu":null,"openssl_version":null,"setuptools_version":null,"rustc_version":null,"ci":null}

File hashes

Hashes for remarkapy-0.2.0.tar.gz
Algorithm Hash digest
SHA256 70131d6fe9fd28a865276f46c65d17295687563fa8f6790403a6c28c4263b45c
MD5 0616914d57b3db2e9c0451ae0cd60a3c
BLAKE2b-256 4d3a67f3c3c5449344d187297e01b97dadd236164c4222b2decf2b6ba4fe6ff5

See more details on using hashes here.

File details

Details for the file remarkapy-0.2.0-py3-none-any.whl.

File metadata

  • Download URL: remarkapy-0.2.0-py3-none-any.whl
  • Upload date:
  • Size: 30.6 kB
  • Tags: Python 3
  • Uploaded using Trusted Publishing? No
  • Uploaded via: uv/0.9.11 {"installer":{"name":"uv","version":"0.9.11"},"python":null,"implementation":{"name":null,"version":null},"distro":{"name":"macOS","version":null,"id":null,"libc":null},"system":{"name":null,"release":null},"cpu":null,"openssl_version":null,"setuptools_version":null,"rustc_version":null,"ci":null}

File hashes

Hashes for remarkapy-0.2.0-py3-none-any.whl
Algorithm Hash digest
SHA256 123245e0f6b88e4d64e0a1886057b8b7d5b8750139e572d8731c5295f02081ad
MD5 10efabec0e78beab5d1404866187dd55
BLAKE2b-256 bc630aa2b2bcc2fbe1aaedb24bb1e9bb1464ff18f818032fd5335614343c86f8

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