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.4.tar.gz (41.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_cli-3.5.4-py3-none-any.whl (52.2 kB view details)

Uploaded Python 3

File details

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

File metadata

  • Download URL: cave_cli-3.5.4.tar.gz
  • Upload date:
  • Size: 41.4 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.4.tar.gz
Algorithm Hash digest
SHA256 e2d224fdb62eaedbd38af512f589a19521772454eab9776b32500fac791eec73
MD5 45f526895f63b6c44392e05137ae668a
BLAKE2b-256 f236f5e277201fe25635e555f3d8a90bdaa2096cd6363a4e6b5108ae5d96e208

See more details on using hashes here.

File details

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

File metadata

  • Download URL: cave_cli-3.5.4-py3-none-any.whl
  • Upload date:
  • Size: 52.2 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.4-py3-none-any.whl
Algorithm Hash digest
SHA256 a22166a05d911859792c42df92c54ef167240eafa9298b19c521889ee6477436
MD5 979fc12df5468c9a2b3214d38b49d9ae
BLAKE2b-256 f8b1e95fb07888864904e69d8971c0cf87419f2403c794e2ab77b56b8a138e52

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