PCLI2
Install v0.2.27
PCLI2 - Physna Command Line Interface v2
Documentation: https://jchultarsky101.github.io/pcli2/
PCLI2 is a powerful command-line interface for the Physna public API, designed for advanced 3D geometry search and analysis. Built with an intuitive nested sub-command structure, it offers sensible defaults and comprehensive configuration management.
🚀 Quick Start
Get up and running with PCLI2 in minutes:
# 1. Authenticate with your Physna tenant pcli2 auth login --client-id YOUR_CLIENT_ID --client-secret YOUR_CLIENT_SECRET # 2. Verify your setup pcli2 auth get # 3. Start managing your assets and folders pcli2 folder list --format tree
📋 Table of Contents
✨ Features
- Intuitive Command Structure - Nested sub-commands like Git CLI
- Comprehensive Asset Management - Create, list, get, delete, and analyze
- Folder Operations - Organize assets with full folder management
- Geometric Matching - Find similar 3D geometries
- Part Matching - Find part matches within assemblies
- Visual Matching - Find visually similar assets
- Text Matching - Find assets using text search
- Metadata Operations - Manage custom properties efficiently
- Bulk Operations - Process multiple assets with batch commands
- Secure Authentication - OAuth2 with system keyring integration
- Flexible Output Formats - JSON, CSV, and tree views
- Resume Capability - Continue interrupted downloads seamlessly
- Performance Optimizations - Concurrent operations and caching for faster processing
💻 Installation
Prerequisites
- Physna tenant with API client credentials
- Compatible OS (Windows, macOS, or Linux)
Installation Methods
📦 Pre-built Installers (Recommended)
Download from the Latest Release:
macOS/Linux Universal Script:
curl --proto '=https' --tlsv1.2 -LsSf https://github.com/jchultarsky101/pcli2/releases/latest/download/pcli2-installer.sh | sh
Windows PowerShell:
irm https://github.com/jchultarsky101/pcli2/releases/latest/download/pcli2-installer.ps1 | iex
🔧 Building from Source
git clone https://github.com/jchultarsky101/pcli2.git cd pcli2 cargo build --release # Binary located at target/release/pcli2
Verification
pcli2 --version
Updating PCLI2
The update mechanism depends on how you installed PCLI2:
If Installed via Universal Installer Script (macOS/Linux) or Shell/PowerShell Scripts:
pcli2-update
This command checks if a new version is available and automatically installs it.
For macOS/Linux users:
curl --proto '=https' --tlsv1.2 -LsSf https://github.com/jchultarsky101/pcli2/releases/latest/download/pcli2-installer.sh | sh
For Windows users using PowerShell:
irm https://github.com/jchultarsky101/pcli2/releases/latest/download/pcli2-installer.ps1 | iex
If Installed via Windows MSI Installer:
The Windows MSI installer does not include a pcli2-update executable. To upgrade to a new version, you must download and run the new version of the MSI installer from the releases page.
For source builds:
cd /path/to/pcli2 git pull cargo build --release sudo cp target/release/pcli2 /usr/local/bin/
🔐 Authentication
Securely authenticate with your Physna tenant:
# First-time login pcli2 auth login --client-id YOUR_CLIENT_ID --client-secret YOUR_CLIENT_SECRET # Subsequent logins (uses cached credentials) pcli2 auth login # Verify authentication pcli2 auth get # Check token expiration pcli2 auth expiration
Credentials are securely stored using your system's keyring:
- macOS: Keychain Services
- Windows: Credential Manager
- Linux: Secret Service API
🛠️ Basic Usage
🏢 Tenant Management
Set and manage your active tenant:
# List available tenants pcli2 tenant list --format csv # Set active tenant pcli2 tenant use # Get current tenant pcli2 tenant current
📁 Folder Operations
Manage your folder structure:
# List folders in tree format pcli2 folder list --format tree # Create a new folder pcli2 folder create --name "New Folder" --parent-folder-path "/Root/Parent" # Download all assets from a folder pcli2 folder download --folder-path "/Root/MyFolder" --output "backup" --resume # Upload all assets from a local directory to a Physna folder pcli2 folder upload --local-path "./local_models" --folder-path "/Root/MyFolder" --skip-existing # Download thumbnails for all assets in a folder pcli2 folder thumbnail --folder-path "/Root/MyFolder" --output "thumbnails" --progress
📦 Asset Management
Upload, download, and manage assets:
# Upload a single asset pcli2 asset create --file path/to/model.stl --path "/Root/Models/" # List assets in a folder pcli2 asset list --path "/Root/Models/" --format json # Recursively list assets in subfolders pcli2 asset list --path "/Root/Models/" --recursive --format csv --headers # Download an asset pcli2 asset download --path "/Root/Models/model.stl" # View asset details pcli2 asset get --path "/Root/Models/model.stl" --metadata # Reprocess an asset to refresh its analysis pcli2 asset reprocess --path "/Root/Models/model.stl" # or pcli2 asset reprocess --uuid 550e8400-e29b-41d4-a716-446655440000 # Download asset thumbnail pcli2 asset thumbnail --path "/Root/Models/model.stl" # or pcli2 asset thumbnail --uuid 550e8400-e29b-41d4-a716-446655440000 # Specify custom output file pcli2 asset thumbnail --uuid 550e8400-e29b-41d4-a716-446655440000 --file "my_thumbnail.png"
🔍 Geometric Matching
Find similar 3D geometries:
# Find similar assets to a reference model pcli2 asset geometric-match --path "/Root/Models/reference.stl" --threshold 85.0 # Bulk matching across folders pcli2 folder geometric-match --folder-path "/Root/SearchFolder/" --threshold 90.0 --progress # Exclusive matching - only show matches where both assets belong to the specified paths pcli2 folder geometric-match --folder-path "/Root/SearchFolder/" --threshold 90.0 --exclusive
Exclusive Matching
The --exclusive flag restricts results to only show matches where both the reference asset and the matched asset belong to the specified folder paths. Without this flag, matches between assets in the specified folder and assets in other folders will also be included.
For example:
- Without
--exclusive: Assets in/FolderAcan match assets in/FolderB - With
--exclusive: Only assets in/FolderAmatching other assets in/FolderAwill be shown
🏷️ Metadata Operations
Manage custom properties:
# Add metadata to an asset pcli2 asset metadata create --path "/Root/Models/part.stl" --name "Material" --value "Steel" # Get all metadata for an asset pcli2 asset metadata get --path "/Root/Models/part.stl" # Bulk metadata update from CSV pcli2 asset metadata create-batch --csv-file "metadata.csv"
🚀 Advanced Features
⚡ Performance Options
Optimize operations for large datasets:
# Concurrent downloads (faster for many files) pcli2 folder download --folder-path "/Root/LargeFolder/" --concurrent 5 --progress # Add delays to prevent rate limiting pcli2 folder download --folder-path "/Root/Folder/" --delay 2 # Continue on errors pcli2 folder download --folder-path "/Root/Folder/" --continue-on-error # Download thumbnails for all assets in a folder pcli2 folder thumbnail --folder-path "/Root/Folder/" --progress --concurrent 3
🔄 Resume Interrupted Downloads
Skip existing files to resume large downloads:
# Resume a partially completed download pcli2 folder download --folder-path "/Root/LargeFolder/" --resume --progress
📊 Download and Upload Statistics Reports
When using folder download and upload commands, you'll receive detailed statistics reports:
Download Statistics Report:
📊 Download Statistics Report =========================== ✅ Successfully downloaded: 125 assets ⏭️ Skipped (already existed): 75 assets ❌ Failed downloads: 2 assets 📁 Total assets processed: 202 assets ⏳ Operation completed successfully!
Upload Statistics Report:
📊 Upload Statistics Report ========================== ✅ Successfully uploaded: 150 assets ⏭️ Skipped (already existed): 0 assets ❌ Failed uploads: 1 asset 📁 Total assets processed: 151 assets ⏳ Operation completed successfully!
📊 Output Formats
Choose the right format for your needs:
# JSON for scripting pcli2 asset list --format json # CSV for spreadsheets pcli2 asset list --format csv --headers # Recursively list assets in subfolders pcli2 asset list --folder-path "/Root/Models/" --recursive --format csv --headers # Tree for visual hierarchy pcli2 folder list --format tree
🔗 UNIX Pipeline Integration
Chain commands with other tools:
# Filter assets with grep pcli2 asset list --format csv | grep "bearing" # Process with jq pcli2 asset list --format json | jq '.[] | select(.size > 10000)' # Count results pcli2 asset list --format csv | wc -l # Advanced filtering with NuShell (nushell) # Filter assets by metadata values like weight in specific range pcli2 asset list --folder-path "/Root/MyFolder" --metadata --format json | nu -c 'from json | where ((metadata | get-or-null Weight) | default 0) >= 5.0 and ((metadata | get-or-null Weight) | default 0) <= 50.0 | select name path metadata.Material metadata.Weight' # Group assets by material type using NuShell pcli2 asset list --folder-path "/Root/Inventory" --metadata --format json | nu -c 'from json | where metadata.Material != null | group-by metadata.Material | each {|it| {material: ($it | get 0).metadata.Material, count: ($it | length), avg_weight: ($it | get metadata.Weight | compact | math avg)}}'
⚙️ Configuration Management
Manage multiple environments:
# Add a development environment pcli2 config environment add --name "development" \ --api-url "https://dev-api.physna.com/v3" # Switch environments pcli2 config environment use --name development # List all environments pcli2 config environment list
🛠️ Troubleshooting
Common Issues
| Issue | Solution |
|---|---|
| API Rate Limiting | Reduce concurrency with --concurrent N |
| Timeout Errors | Operations now have 30-minute timeouts |
| Authentication Expired | Run pcli2 auth login |
| Large Folder Processing | Use --progress for feedback |
| Memory Issues | Reduce concurrency for limited RAM systems |
Error Messages
- "Asset not found" - Verify the asset path exists in your tenant
- "API rate limit exceeded" - Reduce concurrency or add delays
- "Permission denied" - Check your access permissions
- "Configuration file not found" - Run
pcli2 config get path
Debugging Tips
# Check authentication status pcli2 auth get # Verify current context pcli2 tenant current # Review configuration pcli2 config get
📜 Commands Reference
Asset Commands
Manage individual assets in your Physna tenant.
pcli2 asset create # Upload a file as an asset pcli2 asset create-batch # Upload multiple files as assets using glob patterns pcli2 asset list # List assets in a folder with optional recursive listing (--recursive) pcli2 asset get # Get asset details pcli2 asset download # Download an asset pcli2 asset delete # Delete an asset pcli2 asset dependencies # Get dependencies for an asset pcli2 asset geometric-match # Find geometrically similar assets pcli2 asset part-match # Find part matches for an asset pcli2 asset visual-match # Find visually similar assets pcli2 asset text-match # Find assets using text search pcli2 asset reprocess # Reprocess an asset to refresh its analysis pcli2 asset thumbnail # Download asset thumbnail pcli2 asset metadata # Manage asset metadata
Asset Metadata Commands
Manage custom properties for assets.
pcli2 asset metadata get # Get metadata for an asset pcli2 asset metadata create # Add metadata to an asset pcli2 asset metadata delete # Delete specific metadata fields from an asset pcli2 asset metadata create-batch # Create metadata for multiple assets from a CSV file pcli2 asset metadata inference # Apply metadata from a reference asset to geometrically similar assets
Asset Metadata Create-Batch CSV Format
The CSV file for asset metadata create-batch must have the following columns in the specified order:
ASSET_PATH,NAME,VALUE /Root/Folder/Model1.stl,Material,Steel /Root/Folder/Model1.stl,Weight,"15.5 kg" /Root/Folder/Model2.ipt,Material,Aluminum /Root/Folder/Model2.ipt,Supplier,Richardson Electronics
CSV File Requirements:
- The first row must contain the headers
ASSET_PATH,NAME,VALUE - The file must be UTF-8 encoded
- Values containing commas, quotes, or newlines must be enclosed in double quotes
- Empty rows will be ignored
- Each row represents a single metadata field assignment for an asset
- If an asset has multiple metadata fields to update, include multiple rows with the same
ASSET_PATHbut differentNAMEandVALUEcombinations
Folder Commands
Manage folder structures and bulk operations.
pcli2 folder list # List folder structure (defaults to root path if no path/UUID specified) pcli2 folder create # Create a new folder pcli2 folder get # Get folder details pcli2 folder delete # Delete a folder pcli2 folder rename # Rename a folder pcli2 folder move # Move a folder to a new parent folder pcli2 folder resolve # Resolve a folder path to its UUID pcli2 folder download # Download all assets in a folder (supports --resume flag) pcli2 folder upload # Upload all assets from a local directory to a Physna folder pcli2 folder dependencies # Get dependencies for all assembly assets in folder pcli2 folder geometric-match # Find geometrically similar assets for all assets in folder pcli2 folder part-match # Find part matches for all assets in folder pcli2 folder visual-match # Find visually similar assets for all assets in folder pcli2 folder thumbnail # Download thumbnails for all assets in a folder
Important Note: Folder paths are case-sensitive. Make sure to use the exact capitalization when specifying folder paths.
Folder List Command
The folder list command allows you to list folders in your Physna tenant. When no folder path or UUID is specified, it defaults to listing the root folder.
# List all folders in the root directory (default behavior) pcli2 folder list # List folders in a specific path pcli2 folder list --folder-path "/Root/MyFolder" # List folders using folder UUID pcli2 folder list --folder-uuid 123e4567-e89b-12d3-a456-426614174000 # List folders with specific output format pcli2 folder list --format tree
Key Features:
- Default Root Path: When no folder identifier is provided, defaults to the root path (
/) - Mutual Exclusivity: You can specify either
--folder-pathor--folder-uuid, but not both - Flexible Output: Supports JSON, CSV, and tree formats
- Folder Hierarchy: Shows the complete folder structure when using tree format
Tenant Commands
Manage tenant-level operations.
pcli2 tenant list # List all tenants pcli2 tenant get # Get tenant details pcli2 tenant use # Set the active tenant pcli2 tenant current # Get the active tenant pcli2 tenant clear # Clear the active tenant pcli2 tenant state # Get asset state counts for the current tenant
Authentication Commands
Manage authentication with your Physna tenant.
pcli2 auth login # Authenticate with Physna using client credentials pcli2 auth logout # Logout and clear session pcli2 auth get # Get current access token pcli2 auth clear-token # Clear the cached access token pcli2 auth expiration # Show token expiration time
Configuration Commands
Manage PCLI2 configuration settings.
pcli2 config get # Get configuration details pcli2 config export # Export configuration to file pcli2 config import # Import configuration from file pcli2 config environment # Manage environment configurations
Environment Configuration Commands
Manage multiple Physna environment configurations.
pcli2 config environment add --name <name> # Add a new environment configuration pcli2 config environment add -n <name> # Short form of add with name pcli2 config environment use --name <name> # Switch to an environment pcli2 config environment use -n <name> # Short form of use with name pcli2 config environment remove --name <name> # Remove an environment pcli2 config environment remove -n <name> # Short form of remove with name pcli2 config environment list # List all environments pcli2 config environment reset # Reset all environment configurations pcli2 config environment get --name <name> # Get environment details pcli2 config environment get -n <name> # Short form of get with name
Other Commands
Additional utility commands.
pcli2 completions # Generate shell completions for various shells
Shell Completions
Generate shell completions for various shells to enable tab completion for PCLI2 commands.
# Generate shell completions for various shells pcli2 completions bash # Generate bash completions pcli2 completions zsh # Generate zsh completions pcli2 completions fish # Generate fish completions pcli2 completions powershell # Generate PowerShell completions pcli2 completions elvish # Generate Elvish completions # Install bash completions (system-wide) sudo pcli2 completions bash > /etc/bash_completion.d/pcli2 # Or for user-specific installation: mkdir -p ~/.local/share/bash-completion/completions pcli2 completions bash > ~/.local/share/bash-completion/completions/pcli2 # Install zsh completions (MacOS/Linux) # For system-wide installation (requires sudo): sudo pcli2 completions zsh > /usr/local/share/zsh/site-functions/_pcli2 # For user-specific installation: mkdir -p ~/.zsh/completions # Standard location (note the 's' at the end) pcli2 completions zsh > ~/.zsh/completions/_pcli2 # Then add to your ~/.zshrc: # fpath=(~/.zsh/completions $fpath) # autoload -U compinit && compinit # Alternative location (if your system uses the singular form): # mkdir -p ~/.zsh/completion # pcli2 completions zsh > ~/.zsh/completion/_pcli2 # Alternative zsh installation method (works on most systems): pcli2 completions zsh > ~/.zfunc/_pcli2 # Add the following line to your ~/.zshrc: # fpath+=~/.zfunc; autoload -U compinit && compinit # Install fish completions # For user-specific installation: mkdir -p ~/.config/fish/completions pcli2 completions fish > ~/.config/fish/completions/pcli2.fish # Install PowerShell completions # Add to your PowerShell profile: pcli2 completions powershell > pcli2-completion.ps1 # Then dot source it in your PowerShell profile: # . "/path/to/pcli2-completion.ps1"
🤝 Support
Need help?
- Check the GitHub Issues for known issues
- Search for similar problems in the issue tracker
- Create a new issue with:
- Your OS and PCLI2 version
- The command you're executing
- The error message received
- Steps to reproduce the issue
🛠️ Code Quality
This project maintains high code quality standards:
- Clean Code: All code passes Rust clippy with
-D warnings(deny warnings) - Formatted: All code follows Rust fmt standards
- Well Tested: Comprehensive unit and integration tests
- Documented: Thorough documentation for all public APIs
📄 License
This project is licensed under the Apache License 2.0 - see the LICENSE file for details.