Skip to main content

CLI for creating and managing Docker-based CAVE web applications.

Project description

CAVE CLI

A cross-platform CLI for creating and managing Docker-based CAVE web applications.

Developed by MIT-CAVE (Center for Transportation & Logistics). Licensed under Apache 2.0.

Prerequisites

Ubuntu
# Install Docker
curl -fsSL https://get.docker.com -o get-docker.sh
sudo sh ./get-docker.sh
# Add the current user to the docker group
dockerd-rootless-setuptool.sh install
# Make sure it works outside of sudo
docker run hello-world
macOS
Windows

Installation

Install with pipx (recommended — keeps the CLI isolated from your system Python):

pipx install cave_cli

If you don't have pipx, install it first:

macOS
# With Homebrew (recommended)
brew install pipx
pipx ensurepath

# Or with pip
pip3 install --user pipx
pipx ensurepath
Other Linux / Windows
python3 -m pip install --user pipx
pipx ensurepath

For more options see the pipx installation guide.

Verify the installation and check your environment health:

cave doctor

Quick Start

cave create my_app
cd my_app
cave run
# Open http://localhost:8000/ in your browser

CLI Commands

cave --help

Core Commands

Command Description
cave create <name> Create a new CAVE app from the template repository
cave run Build Docker image and run the app with a live TUI dashboard
cave doctor Check the health of your Docker, Git, and Pipx environment

Peripheral Commands

Command Description
cave reset Remove containers/volumes and rebuild from scratch
cave upgrade Upgrade app files from the upstream template
cave sync --url <url> Merge files from another repository into the app
cave test Run tests in cave_api/tests/
cave prettify Format code with autoflake and black
cave purge <path> Remove an app and all its Docker resources

Utility Commands

Command Description
cave list List running CAVE apps
cave kill Stop Docker containers for an app
cave list-versions List available CAVE app versions
cave theme <name> Set the CLI color theme (dark, light, solarized, monokai)
cave update Update the CAVE CLI itself
cave uninstall Remove the CAVE CLI
cave version Print version information

Global Flags

Flag Description
-v, --verbose Enable verbose (DEBUG) logging output
--loglevel LEVEL Set log level: DEBUG, INFO, WARN, ERROR, SILENT
-y, --yes Automatically answer confirmation prompts with yes

cave run Options

Flag Description
--all Show raw container output instead of the TUI dashboard
-it, --interactive Run in interactive mode (drops into a bash shell)
ip:port Optional argument for LAN hosting (e.g. 192.168.1.1:8000)

Updating

cave update

Or directly via pipx:

pipx upgrade cave_cli

License Notice

Copyright 2023 Massachusetts Institute of Technology (MIT), Center for Transportation & Logistics (CTL)

Licensed under the Apache License, Version 2.0 (the "License"); you may not use this file except in compliance with the License. You may obtain a copy of the License at

http://www.apache.org/licenses/LICENSE-2.0

Unless required by applicable law or agreed to in writing, software distributed under the License is distributed on an "AS IS" BASIS, WITHOUT WARRANTIES OR CONDITIONS OF ANY KIND, either express or implied. See the License for the specific language governing permissions and limitations under the License.

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_cli-3.5.2.tar.gz (41.2 kB view details)

Uploaded Source

Built Distribution

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

cave_cli-3.5.2-py3-none-any.whl (51.7 kB view details)

Uploaded Python 3

File details

Details for the file cave_cli-3.5.2.tar.gz.

File metadata

  • Download URL: cave_cli-3.5.2.tar.gz
  • Upload date:
  • Size: 41.2 kB
  • Tags: Source
  • Uploaded using Trusted Publishing? No
  • Uploaded via: twine/6.2.0 CPython/3.12.13

File hashes

Hashes for cave_cli-3.5.2.tar.gz
Algorithm Hash digest
SHA256 9d3609d66254be0ec9765080a3789d4d7c72f8534c7a5765a08cc6e46998d67c
MD5 e841e289fbbf8f0957737a5ce85219b0
BLAKE2b-256 9d3625b3be86a69e679d444a7509a1d1b08afdbde09dbeaca8569af8ca18bde8

See more details on using hashes here.

File details

Details for the file cave_cli-3.5.2-py3-none-any.whl.

File metadata

  • Download URL: cave_cli-3.5.2-py3-none-any.whl
  • Upload date:
  • Size: 51.7 kB
  • Tags: Python 3
  • Uploaded using Trusted Publishing? No
  • Uploaded via: twine/6.2.0 CPython/3.12.13

File hashes

Hashes for cave_cli-3.5.2-py3-none-any.whl
Algorithm Hash digest
SHA256 b90e06805e0f1a937b5a07f89ec0a0e71ba27450c0011192a428c7a77570cf7a
MD5 b7434dadbca79b9d6854357b1b85a2ab
BLAKE2b-256 463839357bb831c08e142d75c63e8ef29b6fb023f6bbbdba24e7d9f92d538f99

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