Skip to main content

No project description provided

Project description

datasette-paper

PyPI Changelog Tests License

Collaborative document editor for Datasette. ProseMirror frontend, SQLite-backed storage in Datasette's internal database, real-time collaboration over SSE.

Installation

Install in the same environment as Datasette:

datasette install datasette-paper

Quickstart

datasette --internal papers.db \
  -s permissions.datasette-paper-list true \
  -s permissions.datasette-paper-create true \
  -s permissions.datasette-paper-view true \
  -s permissions.datasette-paper-edit true

No user database is required — papers live in Datasette's internal database.

Pass --internal <path> to persist papers across restarts. Without it, Datasette uses an ephemeral tempfile for the internal DB that is deleted when the process exits. The plugin emits a startup warning when it detects this, so you don't lose your papers to a forgotten flag.

Permissions

Four actions gate access. The view/edit actions are per-paper; list/create are global.

Action Scope Gates
datasette-paper-list global The paper index page and the list endpoint.
datasette-paper-create global (also-requires list) Creating new papers.
datasette-paper-view per-paper (PaperResource) Reading a specific paper (bootstrap, SSE, document, tasks).
datasette-paper-edit per-paper (PaperResource, also-requires view) Modifying a specific paper (events, presence, rename, snapshot, share).

The plugin registers a permission_resources_sql hook that resolves per-paper view/edit grants from the _datasette_paper_doc.created_by column (owners) and the _datasette_paper_share table (explicit grants

  • link-visibility levels).

Sharing

Each paper has one of three visibility levels:

  • private — only the owner and explicitly-shared actors can access.
  • link-view — any authenticated actor with the link can view.
  • link-edit — any authenticated actor with the link can view and edit.

Plus per-actor share rows that grant a specific actor a viewer or editor role on a single paper.

The owner is whoever created the paper (created_by, captured from the actor cookie at create time). Only the owner can change visibility or mutate shares.

Papers as data

Paper data lives in Datasette's internal database under tables prefixed with _datasette_paper_:

  • _datasette_paper_doc — one row per paper (id, name, visibility, created_by).
  • _datasette_paper_step — append-only log of ProseMirror steps.
  • _datasette_paper_snapshot — periodic full-document snapshots.
  • _datasette_paper_share — per-actor view/edit grants.

Wire protocol

JSON API rooted at /-/paper/api/... — no per-database segment. List/create docs, bootstrap a paper, post step batches, stream updates over SSE, manage shares, render markdown / extract tasks. See CLAUDE.md for the full endpoint table.

Frontend stack

Vite + Svelte 5 + ProseMirror. Bundle outputs to datasette_paper/static/.

Development

npm install --prefix frontend
just frontend          # build the bundle
just dev               # run datasette with the plugin + permissions granted
just dev-with-hmr      # vite dev server + watchexec restart

Run the test layers:

just test              # backend pytest
just test-frontend     # vitest
just test-e2e          # playwright (requires built bundle)

Always invoke Python with uv run --prerelease=allow …datasette is on a >=1a23 pre-release pin.

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

datasette_paper-0.0.1a6.tar.gz (439.1 kB view details)

Uploaded Source

Built Distribution

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

datasette_paper-0.0.1a6-py3-none-any.whl (427.4 kB view details)

Uploaded Python 3

File details

Details for the file datasette_paper-0.0.1a6.tar.gz.

File metadata

  • Download URL: datasette_paper-0.0.1a6.tar.gz
  • Upload date:
  • Size: 439.1 kB
  • Tags: Source
  • Uploaded using Trusted Publishing? Yes
  • Uploaded via: uv/0.11.11 {"installer":{"name":"uv","version":"0.11.11","subcommand":["publish"]},"python":null,"implementation":{"name":null,"version":null},"distro":{"name":"Ubuntu","version":"24.04","id":"noble","libc":null},"system":{"name":null,"release":null},"cpu":null,"openssl_version":null,"setuptools_version":null,"rustc_version":null,"ci":true}

File hashes

Hashes for datasette_paper-0.0.1a6.tar.gz
Algorithm Hash digest
SHA256 d345a9a42a90b5c77079d227075764ad8aa5d269c7bc8b05bcf0d48d58806a48
MD5 926efb996440082c97a8ab74b8fa1b22
BLAKE2b-256 44767faa4e4fe7b8c0320ef08a610c1f28c7c70fd428edcfc67ae7b0e9c6c088

See more details on using hashes here.

File details

Details for the file datasette_paper-0.0.1a6-py3-none-any.whl.

File metadata

  • Download URL: datasette_paper-0.0.1a6-py3-none-any.whl
  • Upload date:
  • Size: 427.4 kB
  • Tags: Python 3
  • Uploaded using Trusted Publishing? Yes
  • Uploaded via: uv/0.11.11 {"installer":{"name":"uv","version":"0.11.11","subcommand":["publish"]},"python":null,"implementation":{"name":null,"version":null},"distro":{"name":"Ubuntu","version":"24.04","id":"noble","libc":null},"system":{"name":null,"release":null},"cpu":null,"openssl_version":null,"setuptools_version":null,"rustc_version":null,"ci":true}

File hashes

Hashes for datasette_paper-0.0.1a6-py3-none-any.whl
Algorithm Hash digest
SHA256 86164a4a895579413b4813e40962a4c949baeea2c32c112f2a237fb3388ed8fd
MD5 56fdf5c857257d783bb8fa23edc118a7
BLAKE2b-256 6e0c33ed1e294852b3b73e2d754fe4f649f1c52d8581779fb5681d0eb496f9ff

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