Lager CLI - Box and Docker connectivity
Project description
Lager CLI
A powerful command-line interface for controlling embedded hardware, test equipment, and development boards through Lager Data box devices.
Features
Hardware Control
- Power Management: Control power supplies, battery simulators, solar simulators, and electronic loads
- I/O Operations: ADC/DAC, GPIO, thermocouple sensors
- Test Instruments: Oscilloscopes, logic analyzers, multimeters, signal generators
Embedded Development
- Debugging: ARM Cortex-M debugging with J-Link, CMSIS-DAP, ST-Link support
- Firmware Flashing: Flash firmware via debug probes
- Serial Communication: UART terminal with test framework integration
- Robotics: Robot arm control for automated testing
Wireless & Connectivity
- Bluetooth LE: Scan, connect, and interact with BLE devices
- USB: Programmable USB hub control
- Webcam: Video streaming from box devices
Installation
Install the Lager CLI using pip:
pip install lager-cli
Or upgrade to the latest version:
pip install -U lager-cli
Quick Start
-
Configure your box:
lager defaults set box <your-box-id>
-
Test connectivity:
lager hello -
List available instruments:
lager instruments -
Control a power supply:
lager supply <net> voltage 3.3 --box <box-id>
Core Commands
Power Supply Control
# Set voltage and enable output
lager supply <net> voltage 3.3 --yes
# Set current limit
lager supply <net> current 0.5
# Check power state
lager supply <net> state
ADC/DAC Operations
# Read ADC voltage
lager adc <net>
# Set DAC output
lager dac <net> 1.8
Embedded Debugging
# Connect to debug probe
lager debug <net> connect --box <box>
# Flash firmware (auto-connects if needed)
lager debug <net> flash --hex firmware.hex --box <box>
# Reset and halt target
lager debug <net> reset --halt --box <box>
# Stream RTT logs
lager debug <net> rtt --box <box>
# Read memory
lager debug <net> memrd 0x08000000 256 --box <box>
Oscilloscope & Logic Analyzer
# Measure frequency on scope channel
lager scope <net> measure freq
# Configure edge trigger
lager logic <net> trigger edge --slope rising --level 1.8
Battery & Solar Simulation
# Set battery state of charge
lager battery <net> soc 80
# Configure solar irradiance
lager solar <net> irradiance 1000
Serial Communication
# Connect to UART
lager uart --baudrate 115200
# Interactive mode with test runner
lager uart -i --test-runner unity
# Show the tty path for a UART net
lager uart <net> serial-port
# Create a UART net for an adapter without a USB serial number (store /dev path directly)
lager nets create <net> uart /dev/ttyUSB0 <label> --box <box>
# Warning: tty names can change after reboot; prefer device-serial mode when available
Bluetooth LE
# Scan for BLE devices
lager ble scan --timeout 5.0
# Connect to device
lager ble connect <address>
Configuration
Box Setup
The CLI can connect to boxes via:
- Cloud API: Using box IDs
- Direct IP: Using Tailscale or VPN IP addresses
Create a .lager file in your project directory:
{
"boxes": {
"my-box": "box-abc123",
"local-box": "<BOX_IP>"
}
}
Direct IP Access
For direct IP connections, ensure SSH key authentication is configured:
# Configure SSH key for a box
ssh-copy-id lagerdata@<box-ip>
# Then connect via the CLI
lager ssh --box <box-ip>
Environment Variables
LAGER_BOX: Default box ID or IP addressLAGER_DEBUG: Enable debug outputLAGER_COMMAND_DATA: Command data (used internally)
Net Management
Lager uses "nets" to represent physical test points or signals on your PCB:
# List all configured nets
lager nets
# Create a new power supply net
lager nets create VDD_3V3 supply 1 USB0::0x1AB1::0x0E11::DP8C0000001
# Auto-discover and create all nets
lager nets create-all
# Interactive TUI for net management
lager nets tui
Advanced Features
Remote Python Execution
# Run a Python script on the box
lager python my_script.py --box <box-id>
# Run with port forwarding
lager python --port 5000:5000/tcp server.py
Development Environment
# Create a development environment
lager devenv create --image python:3.10
# Open interactive terminal
lager devenv terminal
Package Management
# Install packages on box
lager pip install numpy
Supported Hardware
Debug Probes
- SEGGER J-Link
- ARM CMSIS-DAP
- ST-Link v2/v3
- Xilinx XDS110
Power Supplies
- Rigol DP800 series
- Keysight E36200/E36300 series
- Keithley 2200/2280 series
Battery Simulators
- Keithley 2281S
Solar Simulators
- EA PSI/EL series (two-quadrant)
Oscilloscopes
- Rigol MSO5000 series
I/O Hardware
- LabJack T7 (ADC/DAC/GPIO)
- MCC USB-202 (ADC/DAC/GPIO)
USB Hubs
- Acroname USBHub3+
- YKUSH
Robotics
- Rotrics Dexarm
Temperature
- Phidget Thermocouples
Target Microcontrollers
Supports debugging and flashing for:
- STM32 (F0/F1/F2/F3/F4/F7/G0/G4/H7/L0/L1/L4/WB/WL series)
- Nordic nRF52/nRF91
- Atmel/Microchip SAM D/E/4S/70
- Texas Instruments CC32xx
- NXP i.MX RT, LPC54xx/55xx
- Silicon Labs EFM32
- Microchip PIC32MM
Authentication & Access
The CLI authenticates to boxes via VPN access (Tailscale or similar). Access control is managed by your VPN permissions - if you have VPN access to a box, you can control it with the CLI.
Prerequisites
- VPN Access: Connect to your organization's VPN (Tailscale, etc.)
- SSH Keys: Configure SSH key authentication for direct box access:
ssh-copy-id lagerdata@<box-ip> - SSH to Box: Use the CLI to connect:
lager ssh --box <box-ip-or-name>
Verify Connectivity
# Test box connectivity
lager hello --box <box-id-or-ip>
# Check box status
lager status
Documentation
For detailed documentation, visit: https://docs.lagerdata.com
Command Help
Every command has built-in help:
lager --help # Show all commands
lager supply --help # Show supply command options
lager debug --help # Show debug command options
Examples
Automated Test Script
#!/bin/bash
BOX="my-box"
# Configure power supply
lager supply VDD voltage 3.3 --box $BOX --yes
# Flash firmware
lager debug DEBUG_SWD flash --hex build/firmware.hex --box $BOX
# Reset and start
lager debug DEBUG_SWD reset --box $BOX
# Monitor UART output
lager uart --baudrate 115200 --test-runner unity --box $BOX
# Read sensor values
voltage=$(lager adc SENSOR_OUT --box $BOX)
temp=$(lager thermocouple TEMP1 --box $BOX)
echo "Voltage: $voltage V"
echo "Temperature: $temp °C"
# Disable power
lager supply VDD disable --box $BOX
Interactive Python Control
# example_test.py - Run on box with: lager python example_test.py
from lager.supply import supply
from lager.adc import adc
import time
# Set power supply voltage
supply.set_voltage("VDD_3V3", 3.3)
supply.enable("VDD_3V3")
# Wait for stabilization
time.sleep(0.1)
# Measure voltage
voltage = adc.read("VOUT")
print(f"Output voltage: {voltage:.3f} V")
# Disable supply
supply.disable("VDD_3V3")
Troubleshooting
Connection Issues
# Test box connectivity
lager hello --box <box-id>
# Check box status
lager status --box <box-id>
Permission Errors
For Tailscale/direct IP connections, ensure SSH keys are configured:
# Set up SSH keys
ssh-copy-id lagerdata@<box-ip>
# Test SSH access
lager ssh --box <box-ip-or-name>
Debug Probe Not Found
Verify J-Link GDB Server is installed on the box:
# Download J-Link to /tmp/ on your local machine
# Visit: https://www.segger.com/downloads/jlink/
# Download: JLink_Linux_V794a_x86_64.tgz to /tmp/
# Deploy box (J-Link will be installed automatically)
cd deployment
./setup_and_deploy_box.sh <box-ip>
Authentication Issues
If you encounter connection issues:
- Verify VPN connection: Ensure you're connected to the correct VPN
- Check SSH keys: Verify SSH key authentication is configured
ssh-copy-id lagerdata@<box-ip> - Test SSH access: Try connecting to the box
lager ssh --box <box-ip-or-name>
- Test connectivity: Use
lager helloto verify the box is reachablelager hello --box <box-ip-or-name>
Contributing
We welcome contributions! Please see our contribution guidelines for more information.
Support
- Documentation: https://docs.lagerdata.com
- Issues: Report bugs and request features via your support channel
- Email: hello@lagerdata.com
License
MIT License - Copyright (c) Lager Data LLC
Testing
Comprehensive test suites are available in the test/ directory:
# Hardware-dependent tests (require instruments)
cd test
./supply.sh <BOX> <SUPPLY_NET>
./battery.sh <BOX> <BATTERY_NET>
./debug.sh <BOX> <DEBUG_NET> <HEXFILE> <ELFFILE>
./labjack.sh <BOX> <GPIO_NET> <ADC_NET> <DAC_NET>
# Box-only tests (no instruments required)
./deployment.sh <box-ip>
See test/README.md for test format and how to write new tests.
Changelog
Recent Updates
- Renamed test scripts for clarity (
test_*_commands.sh→*.sh) - Unified box deployment script (
setup_and_deploy_box.sh) - Added comprehensive test documentation (
test/README.md) - Enhanced debug command with RTT streaming and memory operations
- Improved error handling and validation across all commands
See full changelog in the releases.
Project details
Release history Release notifications | RSS feed
Download files
Download the file for your platform. If you're not sure which to choose, learn more about installing packages.
Source Distribution
Built Distribution
Filter files by name, interpreter, ABI, and platform.
If you're not sure about the file name format, learn more about wheel file names.
Copy a direct link to the current filters
File details
Details for the file lager_cli-0.3.19.tar.gz.
File metadata
- Download URL: lager_cli-0.3.19.tar.gz
- Upload date:
- Size: 429.8 kB
- Tags: Source
- Uploaded using Trusted Publishing? No
- Uploaded via: twine/6.2.0 CPython/3.10.18
File hashes
| Algorithm | Hash digest | |
|---|---|---|
| SHA256 |
18d906285f8b5f4fa7f9f4cf0235abb3ea07928e25295842a0b1aede14abe0ae
|
|
| MD5 |
3038c97db691213dad7259db43f458c4
|
|
| BLAKE2b-256 |
981ba80c6defa2f376f98a40b5efe6613ead1a33fcd815884d63dba5f493fd56
|
File details
Details for the file lager_cli-0.3.19-py3-none-any.whl.
File metadata
- Download URL: lager_cli-0.3.19-py3-none-any.whl
- Upload date:
- Size: 506.6 kB
- Tags: Python 3
- Uploaded using Trusted Publishing? No
- Uploaded via: twine/6.2.0 CPython/3.10.18
File hashes
| Algorithm | Hash digest | |
|---|---|---|
| SHA256 |
7c441b401f958d7e55bed878e7f97da25c004f3ef54d3ff1ec2b639ab526cd58
|
|
| MD5 |
287413c130a543cd5e9e542b1653afd2
|
|
| BLAKE2b-256 |
97280ae0a2618bd3f0fcccbabf19d8b9b4a94767fe282d925bf993849180fbf3
|