UTCP communication protocol plugin for wrapping local command-line tools.
Project description
UTCP CLI Plugin
Command-line interface plugin for UTCP, enabling integration with command-line tools and processes.
Features
- Multi-Command Execution: Execute multiple commands sequentially in a single subprocess
- State Preservation: Directory changes and environment persist between commands
- Cross-Platform Script Generation: PowerShell on Windows, Bash on Unix/Linux/macOS
- Flexible Output Control: Choose which command outputs to include in final result
- Argument Substitution:
UTCP_ARG_argname_UTCP_ENDplaceholder system - Output Referencing: Access previous command outputs with
$CMD_0_OUTPUT,$CMD_1_OUTPUT - Environment Variables: Secure credential and configuration passing
- Working Directory Control: Execute commands in specific directories
- Timeout Management: Configurable execution timeouts
- Error Handling: Comprehensive subprocess error management
Installation
pip install utcp-cli
Quick Start
from utcp.utcp_client import UtcpClient
# Multi-step CLI tool
client = await UtcpClient.create(config={
"manual_call_templates": [{
"name": "file_analysis",
"call_template_type": "cli",
"commands": [
{
"command": "cd UTCP_ARG_target_dir_UTCP_END",
"append_to_final_output": false
},
{
"command": "find . -type f -name '*.py' | wc -l"
}
]
}]
})
result = await client.call_tool("file_analysis.count_python_files", {"target_dir": "/project"})
Configuration Examples
Basic Multi-Command Operation
{
"name": "file_analysis",
"call_template_type": "cli",
"commands": [
{
"command": "cd UTCP_ARG_target_dir_UTCP_END",
"append_to_final_output": false
},
{
"command": "ls -la"
}
],
"working_dir": "/tmp"
}
With Environment Variables and Output Control
{
"name": "python_pipeline",
"call_template_type": "cli",
"commands": [
{
"command": "python setup.py install",
"append_to_final_output": false
},
{
"command": "python script.py --input UTCP_ARG_input_file_UTCP_END --result \"$CMD_0_OUTPUT\"",
"append_to_final_output": true
}
],
"env_vars": {
"PYTHONPATH": "/custom/path",
"API_KEY": "${API_KEY}"
}
}
Cross-Platform Git Operations
{
"name": "git_analysis",
"call_template_type": "cli",
"commands": [
{
"command": "git clone UTCP_ARG_repo_url_UTCP_END temp_repo",
"append_to_final_output": false
},
{
"command": "cd temp_repo",
"append_to_final_output": false
},
{
"command": "git log --oneline -10",
"append_to_final_output": true
},
{
"command": "echo \"Repository has $(find . -name '*.py' | wc -l) Python files\"",
"append_to_final_output": true
}
],
"env_vars": {
"GIT_AUTHOR_NAME": "UTCP Bot",
"GIT_AUTHOR_EMAIL": "bot@utcp.dev"
}
}
Referencing Previous Command Output
{
"name": "conditional_processor",
"call_template_type": "cli",
"commands": [
{
"command": "git status --porcelain",
"append_to_final_output": false
},
{
"command": "echo \"Changes detected: $CMD_0_OUTPUT\"",
"append_to_final_output": true
}
]
}
Cross-Platform Considerations
Command Syntax
Commands should use appropriate syntax for the target platform:
Windows (PowerShell):
{
"commands": [
{"command": "Get-ChildItem UTCP_ARG_path_UTCP_END"},
{"command": "Set-Location UTCP_ARG_dir_UTCP_END"}
]
}
Unix/Linux/macOS (Bash):
{
"commands": [
{"command": "ls -la UTCP_ARG_path_UTCP_END"},
{"command": "cd UTCP_ARG_dir_UTCP_END"}
]
}
Universal Commands
Some commands work across platforms:
{
"commands": [
{"command": "git status"},
{"command": "python --version"},
{"command": "node -v"}
]
}
Security Considerations
- Commands execute in isolated subprocesses with controlled environment
- Environment variables provide secure credential passing
- Previous command outputs should be used carefully to avoid injection
- Commands should use platform-appropriate syntax
Error Handling
from utcp.exceptions import ToolCallError
try:
result = await client.call_tool("cli_tool.multi_command", {
"repo_url": "https://github.com/example/repo.git",
"target_dir": "analysis_temp"
})
except ToolCallError as e:
print(f"CLI tool execution failed: {e}")
# Script execution failed - check individual command outputs
Common Use Cases
- Multi-step Builds: setup → compile → test → package
- Git Workflows: clone → analyze → commit → push
- Data Pipelines: fetch → transform → validate → output
- File Operations: navigate → search → process → report
- Development Tools: install dependencies → run tests → generate docs
- System Administration: check status → backup → cleanup → verify
- Custom Workflows: Any sequence of command-line operations
Testing CLI Tools
import pytest
from utcp.utcp_client import UtcpClient
@pytest.mark.asyncio
async def test_multi_command_cli_tool():
client = await UtcpClient.create(config={
"manual_call_templates": [{
"name": "test_cli",
"call_template_type": "cli",
"commands": [
{
"command": "echo UTCP_ARG_message_UTCP_END",
"append_to_final_output": false
},
{
"command": "echo \"Previous: $CMD_0_OUTPUT\""
}
]
}]
})
result = await client.call_tool("test_cli.echo_chain", {"message": "hello"})
assert "Previous: hello" in result
Related Documentation
Examples
For complete examples, see the UTCP examples repository.
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
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 utcp_cli-1.1.3.tar.gz.
File metadata
- Download URL: utcp_cli-1.1.3.tar.gz
- Upload date:
- Size: 29.6 kB
- Tags: Source
- Uploaded using Trusted Publishing? No
- Uploaded via: twine/6.2.0 CPython/3.12.0
File hashes
| Algorithm | Hash digest | |
|---|---|---|
| SHA256 |
4e312fa49a7b2b27177f4d565a2e91ad4715a92835a4491aaf22ab0be614e001
|
|
| MD5 |
5669335e3846b15f7b896942a397ee91
|
|
| BLAKE2b-256 |
4aa4418328735352d6f5f8d713d1e26460f3028a7c7390488d7ee3ed9f8f2f1f
|
File details
Details for the file utcp_cli-1.1.3-py3-none-any.whl.
File metadata
- Download URL: utcp_cli-1.1.3-py3-none-any.whl
- Upload date:
- Size: 18.7 kB
- Tags: Python 3
- Uploaded using Trusted Publishing? No
- Uploaded via: twine/6.2.0 CPython/3.12.0
File hashes
| Algorithm | Hash digest | |
|---|---|---|
| SHA256 |
10709cfb70e9d63d8c2a4290d83704086bf3f136e15987b47abbfedcc720c913
|
|
| MD5 |
fc88f0e7fd8aca84443dbe5c2f6a7095
|
|
| BLAKE2b-256 |
07c97277ab286942a0656919822b6c3ea457a6cb6e6f950b119ccaa931016925
|