Share Links
Share links create publicly accessible URLs for individual documents without requiring authentication. They support the full CRUD lifecycle.
Models
See pypaperless/models/share_links.py for all fields and pypaperless/models/types.py for enum and filter types, and the Paperless-ngx API docs for the upstream schema.
Fetch one
link = await paperless.share_links(8)
print(link.slug) # "abc123xyz"
print(link.document) # 42
print(link.expiration) # datetime(2024, 12, 31, ...) or None
Iterate
async for link in paperless.share_links:
print(link.id, link.document, link.slug)
# Find links for a specific document
doc_links = [
lnk async for lnk in paperless.share_links
if lnk.document == 42
]
Create
import datetime
from pypaperless.models.share_links import ShareLinkFileVersion
draft = paperless.share_links.create()
draft.document = 42
draft.file_version = ShareLinkFileVersion.ARCHIVE
draft.expiration = datetime.datetime(2025, 1, 1, tzinfo=datetime.timezone.utc)
slug = await paperless.share_links.save(draft)
print(slug) # "abc123xyz" (str, not an int)
Note
save() returns the link's slug string, not an integer primary key.
Update
import datetime
link = await paperless.share_links(8)
link.expiration = datetime.datetime(2026, 6, 1, tzinfo=datetime.timezone.utc)
changed = await paperless.share_links.update(link)
Delete
Raises DeletionError on failure. Pass silent_fail=True to suppress it.