Skip to main content

Python wrapper for api use in the cave_app

Project description

Cave Utilities

PyPI version License: MIT

Python utilities for the CAVE App framework: API validation, data builders, and shared helpers.

Overview

cave_utils is a foundational library for building CAVE applications. It provides:

  • API validation: validate session_data dicts against the full CAVE API spec, with structured error and warning reporting
  • Data builders: helper classes for constructing hierarchical and date-based group structures
  • Shared utilities: logging, geographic calculations, coordinate systems, and argument parsing

It is designed to be embedded in a CAVE API server, but can also be used standalone for testing and data development.

Features

  • Validates all 10 top-level CAVE API keys (settings, appBar, pages, panes, maps, mapFeatures, globalOutputs, groupedOutputs, draggables, extraKwargs)
  • Cross-field validation with structured error paths (e.g. maps.data.myMap.currentProjection)
  • Time-series (timeValues) and ordering (order) validation built in
  • GroupsBuilder and DateGroupsBuilder for constructing hierarchical group structures from flat data
  • GeoUtils for shortest-path calculations over geographic networks
  • CustomCoordinateSystem for converting Cartesian 2D/3D coordinates to lat/long
  • Runtime type enforcement via type_enforced

Requirements

  • Python ≥ 3.11

Installation

pip install cave_utils

Quick Start

Validating Session Data

from cave_utils import Validator

session_data = {
    "settings": {
        "iconUrl": "https://example.com/icon.png",
    },
    "appBar": {
        "data": {
            "btn_home": {
                "icon": "md/MdHome",
                "type": "button",
            }
        }
    },
}

result = Validator(session_data=session_data)

# Inspect errors and warnings
for entry in result.log.log:
    print(entry)
# Empty list means fully valid

Using GroupsBuilder

from cave_utils.builders.groups import GroupsBuilder

builder = GroupsBuilder(
    data=[
        {"id": "region_east", "name": "East", "parent": None},
        {"id": "state_ny", "name": "New York", "parent": "region_east"},
        {"id": "state_ma", "name": "Massachusetts", "parent": "region_east"},
    ],
    id_field="id",
    name_field="name",
    parent_field="parent",
)

# Serialize to the CAVE API groupedOutputs format
groups_data = builder.serialize()

Public API

Class Import Description
Validator from cave_utils import Validator Validates a session_data dict against the full CAVE API spec
LogObject from cave_utils import LogObject Structured log container for errors and warnings
Socket from cave_utils import Socket No-op WebSocket stub for use in tests
Arguments from cave_utils import Arguments Parses kwargs, flags, and positional args from raw argument lists
GeoUtils from cave_utils import GeoUtils Geographic utilities including shortest-path via scgraph
CustomCoordinateSystem from cave_utils import CustomCoordinateSystem Converts 2D/3D Cartesian coordinates to lat/long

Full API reference: mit-cave.github.io/cave_utils

Development

All development tasks run inside Docker. Make sure Docker is installed and running.

Command Description
./run.sh Drop into an interactive Docker shell
./run.sh test Run all tests
./run.sh prettify Format code with autoflake + black
./run.sh docs Regenerate pdoc documentation

./run.sh requires a TTY. Run it directly in your terminal, not from a non-interactive CI environment.

Running Tests

Tests live in test/. The main test file (test_validator.py) imports every example in test/api_examples/, runs it through Validator, and asserts no errors or warnings are produced. Unit tests exist for each module.

./run.sh test

Hot-Reload with a Cave App

To develop cave_utils against a running Cave App, mount the local source as a Docker volume:

cave run --docker-args "--volume {local_path_to_cave_utils}/cave_utils:/cave_utils"

Then in the Cave App's utils/run_server.sh, add pip install -e /cave_utils before the server starts. Changes to cave_utils source will be reflected on the next API call without rebuilding the container.

Set LIVE_API_VALIDATION_PRINT=True in the Cave App's .env to see validation output on every API command.

Release Process

  1. Ensure all tests pass (./run.sh test) and code is formatted (./run.sh prettify)
  2. Update version in both pyproject.toml and setup.cfg
  3. Update the version in utils/docs.sh and regenerate docs (./run.sh docs)
  4. Build and publish:
    python3 -m virtualenv venv
    source venv/bin/activate
    pip install -r requirements.txt
    

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

cave_utils-3.5.0.tar.gz (61.4 kB view details)

Uploaded Source

Built Distribution

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

cave_utils-3.5.0-py3-none-any.whl (67.2 kB view details)

Uploaded Python 3

File details

Details for the file cave_utils-3.5.0.tar.gz.

File metadata

  • Download URL: cave_utils-3.5.0.tar.gz
  • Upload date:
  • Size: 61.4 kB
  • Tags: Source
  • Uploaded using Trusted Publishing? No
  • Uploaded via: twine/6.2.0 CPython/3.12.3

File hashes

Hashes for cave_utils-3.5.0.tar.gz
Algorithm Hash digest
SHA256 b3845c7d07056eb98e47de51a6bff4e22b6299c9f104e42facac708dfe812a6e
MD5 cc855d31e3f27ae4e2986eb099e84078
BLAKE2b-256 9e71220769ee0305910a71d18cb612fcea5f2194d9d4f82bf9ad70bd14acbffb

See more details on using hashes here.

File details

Details for the file cave_utils-3.5.0-py3-none-any.whl.

File metadata

  • Download URL: cave_utils-3.5.0-py3-none-any.whl
  • Upload date:
  • Size: 67.2 kB
  • Tags: Python 3
  • Uploaded using Trusted Publishing? No
  • Uploaded via: twine/6.2.0 CPython/3.12.3

File hashes

Hashes for cave_utils-3.5.0-py3-none-any.whl
Algorithm Hash digest
SHA256 567b5413d32e897a3003f3c76e4071935226143e71e1d0915f6cd4ab6d7f8b47
MD5 d9c64dae99d6d8dce26cac9e8462e6f0
BLAKE2b-256 c134ddac0cb8cf7f789aae2e00df80103dc877306799120a536fd653c6c4e1e4

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