Skip to main content

A Python client for the LabArchives API.

Project description

labapi

A Python client for the LabArchives API.

Python Version Tests DOI License: CC0-1.0

labapi helps you authenticate with LabArchives, navigate notebook trees, and create or update notebook content from Python.

Source | Docs | Issues

Start Here

Install

Requirements:

  • Python 3.10+
  • uv (recommended) or pip

Recommended install for local use:

uv add "labapi[dotenv,builtin-auth]"
# or
pip install "labapi[dotenv,builtin-auth]"

Other install options:

# Minimal install
uv add labapi
# or
pip install labapi

# Minimal install plus .env loading
uv add "labapi[dotenv]"
# or
pip install "labapi[dotenv]"

Extras:

  • dotenv loads API_URL, ACCESS_KEYID, and ACCESS_PWD from a local .env file.
  • builtin-auth enables default_authenticate() to open the LabArchives login flow in a local browser.

Configure Credentials

Add your LabArchives API credentials to a .env file:

API_URL=https://api.labarchives.com
ACCESS_KEYID=your_access_key_id
ACCESS_PWD=your_access_password

Or set them directly in your shell:

export API_URL=https://api.labarchives.com
export ACCESS_KEYID=your_access_key_id
export ACCESS_PWD=your_access_password
$env:API_URL="https://api.labarchives.com"
$env:ACCESS_KEYID="your_access_key_id"
$env:ACCESS_PWD="your_access_password"

.env files are only auto-loaded when python-dotenv is installed, such as with labapi[dotenv].

Quick Start

from datetime import datetime

from labapi import Client, NotebookPage, TextEntry

with Client() as client:
    user = client.default_authenticate()

    notebook_name = next(iter(user.notebooks))
    notebook = user.notebooks[notebook_name]
    page = notebook.create(
        NotebookPage,
        f"API tutorial - {datetime.now():%Y-%m-%d %H:%M:%S}",
    )
    page.entries.create(TextEntry, "<p>Hello from labapi!</p>")

This is the recommended local workflow:

  1. Install labapi[dotenv,builtin-auth].
  2. Set API_URL, ACCESS_KEYID, and ACCESS_PWD.
  3. Call default_authenticate() once the client is open.
  4. Start creating or updating notebooks, folders, pages, and entries through the object model.

Common Tasks

Authenticate in a service or callback-based app:

from labapi import Client

with Client() as client:
    auth_url = client.generate_auth_url(callback_url)
    # Redirect the user to auth_url, then read email + auth_code
    user = client.login(email, auth_code)

Create different entry types:

from labapi import HeaderEntry, PlainTextEntry, TextEntry

page.entries.create(TextEntry, "<p>Rich text content</p>")
page.entries.create(HeaderEntry, "Final Conclusions")
page.entries.create(PlainTextEntry, "<p>Literal text</p>")
page.entries.create_json_entry({"yield": 0.85, "purity": "99%"})

Browse notebooks by name and path:

for name in user.notebooks:
    print(name)

notebook = user.notebooks["My Research Notebook"]
page = notebook.traverse("Experiments/2026/Results")

Documentation Map

  • First Success Tutorial: shortest path from install to a successful write.
  • Quick Start: setup, navigation, page creation, uploads, and basic write operations.
  • Authentication Guide: local browser auth, manual flows, and callback-based integration patterns.
  • User Guide: paths, entries, API behavior, exceptions, limits, and architecture notes.
  • Examples: end-to-end scripts for real workflows.
  • FAQ: troubleshooting and environment questions.

Development

Clone the repo and install development dependencies:

git clone https://github.com/nimh-dsst/labapi.git
cd labapi
uv sync --all-groups
pre-commit install --hook-type pre-commit --hook-type pre-push

Common checks:

uv run pytest
uv run ruff check --fix .
uv run ruff format .
uv run pyright

Integration tests are opt-in and require live credentials. See CONTRIBUTING.md for the full setup, including AUTH_EMAIL and AUTH_KEY.

License

This project is licensed under the CC0 1.0 Universal License. See the LICENSE file for details.

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

labapi-1.1.0.tar.gz (324.7 kB view details)

Uploaded Source

Built Distribution

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

labapi-1.1.0-py3-none-any.whl (56.6 kB view details)

Uploaded Python 3

File details

Details for the file labapi-1.1.0.tar.gz.

File metadata

  • Download URL: labapi-1.1.0.tar.gz
  • Upload date:
  • Size: 324.7 kB
  • Tags: Source
  • Uploaded using Trusted Publishing? Yes
  • Uploaded via: uv/0.11.18 {"installer":{"name":"uv","version":"0.11.18","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 labapi-1.1.0.tar.gz
Algorithm Hash digest
SHA256 40f2726d87c4d5b02435c9a5afab0d370a686a686dda3b76826947e8032943d5
MD5 50349d8b747746d8a8e9fbd81c1d1df8
BLAKE2b-256 ba5b8edfcd2f752021a64d0bde9c0ed249367ff3f82de81620862bc2a256b29d

See more details on using hashes here.

File details

Details for the file labapi-1.1.0-py3-none-any.whl.

File metadata

  • Download URL: labapi-1.1.0-py3-none-any.whl
  • Upload date:
  • Size: 56.6 kB
  • Tags: Python 3
  • Uploaded using Trusted Publishing? Yes
  • Uploaded via: uv/0.11.18 {"installer":{"name":"uv","version":"0.11.18","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 labapi-1.1.0-py3-none-any.whl
Algorithm Hash digest
SHA256 fa456430b7ce11d7e7582d4989707bfb11ba3cec0bdd4647adea159a1a1deb80
MD5 84f72c34f941eccf5408e59344656f2a
BLAKE2b-256 4c16a2af1f5a508c616dfe3c3b52a593eaf22398aebf286af9589e1858341c21

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