# 🌼 RAPS
<div align="center">
<img src="https://raw.githubusercontent.com/dmytro-yemelianov/raps/main/docs/logo/output/raps-logo-512.webp" alt="RAPS Logo" width="200"/>
<h3>🌼 RAPS — rapeseed</h3>
<p><strong>R</strong>ust <strong>A</strong>utodesk <strong>P</strong>latform <strong>S</strong>ervices CLI</p>
[](https://crates.io/crates/raps)
[](https://app.fossa.com/projects/git%2Bgithub.com%2Fdmytro-yemelianov%2Fraps?ref=badge_shield)
[](https://crates.io/crates/raps)
[](https://rapscli.xyz)
[](https://opensource.org/licenses/Apache-2.0)
[](https://www.rust-lang.org/)
[](https://github.com/dmytro-yemelianov/raps/actions)
[](https://codecov.io/gh/dmytro-yemelianov/raps)
</div>
**🌼 RAPS** (rapeseed) — **R**ust **A**utodesk **P**latform **S**ervices CLI. A comprehensive command-line interface for Autodesk Platform Services (APS), written in Rust.
[](https://app.fossa.com/projects/git%2Bgithub.com%2Fdmytro-yemelianov%2Fraps?ref=badge_large)
## Features
### Authentication
- **2-legged OAuth** (Client Credentials) for server-to-server operations
- **3-legged OAuth** (Authorization Code) with browser login for user data access
- **Device-code authentication** (`--device`) for headless/server environments
- **Token-based login** (`--token`) for CI/CD scenarios
- **Token inspection** (`auth inspect-token`) - view scopes, expiry, and warnings
- Secure token storage with automatic refresh
- User profile information with `auth whoami`
### Object Storage Service (OSS)
- Create, list, and delete buckets (with multi-region support: US & EMEA)
- Get detailed bucket information with `bucket info`
- Upload, download, list, and delete objects
- **Resumable multipart uploads** for large files (auto-chunking for files > 5MB)
- **Batch uploads** with parallel processing (`--batch`, `--parallel`)
- **Signed S3 URLs** for direct download bypassing OSS servers
- Progress bars for file transfers
### Model Derivative
- Translate CAD files to various formats (SVF2, OBJ, STL, STEP, etc.)
- Check translation status with optional polling
- View manifest and available derivatives
- **Download derivatives** (`translate download`) - export translated models
- **Translation presets** (`translate preset`) - save and reuse common configurations
### Data Management (BIM 360/ACC)
- Browse hubs, projects, folders, and items
- Create folders
- View item versions
- **Bind OSS objects to ACC folders** (`item bind`) - link external uploads
- Requires 3-legged authentication
### Webhooks
- Create, list, and delete webhook subscriptions
- Support for data management and model derivative events
- **Test webhook endpoints** (`webhook test`) - validate with sample payloads
### Design Automation
- List available engines (AutoCAD, Revit, Inventor, 3ds Max)
- Manage app bundles and activities
- **Create activities** (`da activity create`)
- **Submit work items** (`da workitem run`) with input/output URLs
- **Get work item results** (`da workitem get`) - download reports
- Monitor work item status
### ACC Issues (Construction Cloud)
- List, create, and update issues
- View issue types (categories) and subtypes
- Filter by status
- **Issue comments** (`issue comment`) - list, add, delete
- **Issue attachments** (`issue attachment`) - upload, download
- **State transitions** (`issue transition`) - change issue status
### ACC RFIs (Requests for Information) (v1.0.0+)
- **List RFIs** (`rfi list`) - view all RFIs in a project
- **Get RFI details** (`rfi get`) - view full RFI information
- **Create RFIs** (`rfi create`) - submit new requests for information
- **Update RFIs** (`rfi update`) - answer RFIs, change status
### ACC Assets (v1.0.0+)
- **List assets** (`acc asset list`) - view project assets
- **CRUD operations** - get, create, update assets
### ACC Submittals (v1.0.0+)
- **List submittals** (`acc submittal list`) - view project submittals
- **CRUD operations** - get, create, update submittals
### ACC Checklists (v1.0.0+)
- **List checklists** (`acc checklist list`) - view project checklists
- **List templates** (`acc checklist templates`) - view available templates
- **CRUD operations** - get, create, update checklists
### Reality Capture
- Create photoscenes for photogrammetry
- Upload photos and start processing
- Monitor progress and download results (OBJ, FBX, RCS, etc.)
### Pipeline Automation
- **Execute pipelines** from YAML/JSON files (`pipeline run`)
- **Variable substitution** and conditional step execution
- **Dry-run mode** for validation
- **Continue-on-error** for robust automation
- **Sample generation** (`pipeline sample`)
### Configuration & Profiles
- **Profile management** - create, switch, delete configurations
- **Profile import/export** - backup and share configurations
- Config precedence: CLI flags > env vars > profile > defaults
### Plugin System (v1.0.0+)
- **External plugins** - extend RAPS with `raps-<name>` executables
- **Command hooks** - run pre/post command scripts
- **Command aliases** - create shortcuts for frequent operations
- **Plugin management** (`plugin list/enable/disable`)
### Development Tools (v1.0.0+)
- **Test Data Generation** (`generate`) - create synthetic OBJ, IFC, and other files for testing
- **Demo Scenarios** (`demo`) - run end-to-end scenarios like bucket lifecycle or model pipeline
### MCP Server (v3.0.0+)
- **AI Assistant Integration** (`serve`) - Model Context Protocol server for Claude, Cursor, and other MCP clients
- **14 MCP Tools** - Direct access to APS APIs from AI assistants:
- Authentication: `auth_test`, `auth_status`
- Buckets: `bucket_list`, `bucket_create`, `bucket_get`, `bucket_delete`
- Objects: `object_list`, `object_delete`, `object_signed_url`, `object_urn`
- Translation: `translate_start`, `translate_status`
- Data Management: `hub_list`, `project_list`
## Installation
### Prerequisites
- APS account with application credentials from [APS Developer Portal](https://aps.autodesk.com/myapps)
### Install from crates.io
```bash
cargo install raps
```
### Install from Pre-built Binaries
Download the latest release for your platform from the [Releases](https://github.com/dmytro-yemelianov/raps/releases) page:
| Windows | x64 | `raps-windows-x64.zip` |
| macOS | Intel | `raps-macos-x64.tar.gz` |
| macOS | Apple Silicon | `raps-macos-arm64.tar.gz` |
| Linux | x64 | `raps-linux-x64.tar.gz` |
| Linux | ARM64 | `raps-linux-arm64.tar.gz` |
Extract and add to your PATH:
**Windows (PowerShell):**
```powershell
# Extract to a directory in your PATH
Expand-Archive raps-windows-x64.zip -DestinationPath "$env:USERPROFILE\bin"
# Add to PATH (if not already)
$env:PATH += ";$env:USERPROFILE\bin"
```
**macOS/Linux:**
```bash
# Extract
tar -xzf raps-*.tar.gz
# Move to PATH
sudo mv raps /usr/local/bin/
chmod +x /usr/local/bin/raps
```
### Build from Source
```bash
# Requires Rust 1.70 or later (https://rustup.rs/)
cd raps
cargo build --release
```
## Shell Completions
RAPS supports auto-completion for bash, zsh, fish, PowerShell, and elvish.
### PowerShell
```powershell
# Add to your PowerShell profile ($PROFILE)
# Or save to a file and source it
raps completions powershell > "$env:USERPROFILE\Documents\PowerShell\raps.ps1"
# Then add to $PROFILE: . "$env:USERPROFILE\Documents\PowerShell\raps.ps1"
```
### Bash
```bash
# Add to ~/.bashrc
eval "$(raps completions bash)"
# Or save to completions directory
raps completions bash > ~/.local/share/bash-completion/completions/raps
```
### Zsh
```zsh
# Add to ~/.zshrc (before compinit)
eval "$(raps completions zsh)"
# Or save to fpath directory
raps completions zsh > ~/.zfunc/_raps
# Add to ~/.zshrc: fpath=(~/.zfunc $fpath)
```
### Fish
```fish
# Save to completions directory
raps completions fish > ~/.config/fish/completions/raps.fish
```
### Elvish
```elvish
# Add to ~/.elvish/rc.elv
eval (raps completions elvish | slurp)
```
## Configuration
### Profile Management (v0.4.0+)
Manage multiple configurations for different environments:
```bash
# Create a profile
raps config profile create production
# Set profile values
raps config set client_id "your_client_id"
raps config set client_secret "your_client_secret"
# Switch between profiles
raps config profile use production
# List all profiles
raps config profile list
# Show current profile
raps config profile current
```
**Config Precedence:** CLI flags > Environment variables > Active profile > Defaults
### Environment Variables
```powershell
# Required
$env:APS_CLIENT_ID = "your_client_id"
$env:APS_CLIENT_SECRET = "your_client_secret"
# Optional
$env:APS_CALLBACK_URL = "http://localhost:8080/callback" # For 3-legged OAuth
$env:APS_DA_NICKNAME = "your_nickname" # For Design Automation
```
### Using .env File
Create a `.env` file in your working directory:
```env
APS_CLIENT_ID=your_client_id
APS_CLIENT_SECRET=your_client_secret
APS_CALLBACK_URL=http://localhost:8080/callback
```
## Usage
### Authentication
```bash
# Test 2-legged authentication
raps auth test
# Login with 3-legged OAuth (opens browser)
raps auth login
# Login with device code (headless/server environments)
raps auth login --device
# Login with token (CI/CD scenarios)
raps auth login --token <access_token> --refresh-token <refresh_token>
# Check authentication status (shows token expiry)
raps auth status
# Show logged-in user profile
raps auth whoami
# Logout
raps auth logout
```
### Buckets & Objects
```bash
# Create a bucket
raps bucket create
# List buckets (from all regions)
raps bucket list
# Get bucket details
raps bucket info my-bucket
# Upload a file
raps object upload my-bucket model.dwg
# Download a file
raps object download my-bucket model.dwg
# Get signed S3 download URL (direct download, expires in 2-60 minutes)
raps object signed-url my-bucket model.dwg --minutes 10
```
### Translation
```bash
# Start translation
raps translate start <urn> --format svf2
# Check status
raps translate status <urn> --wait
# View manifest
raps translate manifest <urn>
```
### Output Formats
RAPS supports multiple output formats for CI/CD integration:
```bash
# JSON output (machine-readable)
raps bucket list --output json
# YAML output
raps bucket list --output yaml
# CSV output
raps bucket list --output csv
# Table output (default, human-readable)
raps bucket list --output table
# Plain text
raps bucket list --output plain
```
### Global Flags
```bash
# Disable colors
raps bucket list --no-color
# Quiet mode (only output data)
raps bucket list --quiet
# Set HTTP request timeout (seconds, default: 120)
raps bucket list --timeout 60
# Set maximum concurrent operations for bulk commands (default: 5)
raps demo batch-processing --concurrency 10
# Verbose mode (show request summaries)
raps bucket list --verbose
# Debug mode (full trace with secret redaction)
raps bucket list --debug
# Non-interactive mode (fail on prompts)
raps bucket create --non-interactive --key my-bucket
# Auto-confirm prompts
raps bucket delete my-bucket --yes
```
### Exit Codes
RAPS uses standardized exit codes for scripting:
- `0` - Success
- `2` - Invalid arguments
- `3` - Authentication failure
- `4` - Not found
- `5` - Remote/API error
- `6` - Internal error
See [Exit Codes Documentation](docs/cli/exit-codes.md) for details.
### Data Management (requires login)
```bash
# List hubs
raps hub list
# List projects in a hub
raps project list <hub-id>
# List folder contents
raps folder list <project-id> <folder-id>
# View item versions
raps item versions <project-id> <item-id>
```
### Webhooks
```bash
# List all webhooks
raps webhook list
# Create a webhook
raps webhook create --url https://example.com/hook --event dm.version.added
# List available events
raps webhook events
```
### Design Automation
```bash
# List available engines
raps da engines
# List app bundles
raps da appbundles
# List activities
raps da activities
# Check work item status
raps da status <workitem-id> --wait
```
### Issues (ACC/BIM 360, requires login)
```bash
# List issues in a project
raps issue list <project-id>
# Create an issue
raps issue create <project-id> --title "My Issue"
# List issue types (categories)
raps issue types <project-id>
```
**Note:** The project-id should NOT include the "b." prefix used by the Data Management API.
### Reality Capture
```bash
# Create a photoscene
raps reality create --name "My Scene" --scene-type object --format obj
# Upload photos
raps reality upload <photoscene-id> photo1.jpg photo2.jpg photo3.jpg
# Start processing
raps reality process <photoscene-id>
# Check status
raps reality status <photoscene-id> --wait
# Get download link
raps reality result <photoscene-id>
```
### MCP Server (v3.0.0+)
Start the MCP server for AI assistant integration:
```bash
raps serve
```
**Configure in Claude Desktop** (`claude_desktop_config.json`):
```json
{
"mcpServers": {
"raps": {
"command": "raps",
"args": ["serve"],
"env": {
"APS_CLIENT_ID": "your_client_id",
"APS_CLIENT_SECRET": "your_client_secret"
}
}
}
}
```
**Configure in Cursor** (`.cursor/mcp.json`):
```json
{
"mcpServers": {
"raps": {
"command": "raps",
"args": ["serve"]
}
}
}
```
Once configured, AI assistants can directly manage APS resources using natural language commands like:
- "List all my OSS buckets"
- "Create a bucket named 'my-test-bucket' with transient policy"
- "Start translating the uploaded CAD file to SVF2 format"
- "Show me all projects in my BIM 360 hub"
## Command Reference
| `auth` | Authentication (test, login, logout, status, whoami, inspect-token) |
| `bucket` | OSS bucket operations (create, list, info, delete) |
| `object` | OSS object operations (upload, download, list, delete, signed-url) |
| `translate` | Model Derivative (start, status, manifest, download, preset) |
| `hub` | List/view hubs |
| `project` | List/view projects |
| `folder` | Folder operations |
| `item` | Item operations (versions, bind) |
| `webhook` | Webhook subscriptions (create, list, delete, test) |
| `da` | Design Automation (engines, appbundles, activities, workitem) |
| `issue` | ACC/BIM 360 issues (list, create, update, comment, attachment, transition) |
| `acc` | ACC extended modules (assets, submittals, checklists) |
| `rfi` | ACC RFIs (list, get, create, update) |
| `reality` | Reality Capture photogrammetry |
| `pipeline` | Pipeline automation (run, validate, sample) |
| `plugin` | Plugin management (list, install, remove) |
| `generate` | Generate (synthetic files for testing) |
| `demo` | Run demo scenarios |
| `config` | Configuration and profile management (import, export) |
| `completions` | Generate shell completions (bash, zsh, fish, powershell, elvish) |
| `serve` | Start MCP server for AI assistant integration (v3.0.0+) |
## API Coverage
This CLI covers the following APS APIs (validated against OpenAPI specs):
- **Authentication API v2** - OAuth 2.0 flows, user profile
- **OSS API v2** - Buckets, objects, signed S3 URLs
- **Model Derivative API v2** - Translation jobs, manifests
- **Data Management API v1** - Hubs, projects, folders, items
- **Webhooks API v1** - Event subscriptions
- **Design Automation API v3** - Engines, activities, work items
- **Construction Issues API v1** - Issues, issue types
- **ACC RFIs API v1** - Requests for Information
- **ACC Assets API v1** - Assets, categories, status
- **ACC Submittals API v1** - Submittals, spec sections
- **ACC Checklists API v1** - Checklists, templates
- **Reality Capture API v1** - Photogrammetry processing
## Release Verification
All releases include SHA256 checksums for verification. See [Checksums Documentation](docs/cli/checksums.md) for instructions on verifying downloads.
## Contributing
Contributions are welcome! Please read our [Contributing Guide](CONTRIBUTING.md) for details on:
- Development setup
- Code style guidelines
- Pull request process
## License
Apache 2.0 License
## Documentation
- **[🌼 rapscli.xyz](https://rapscli.xyz)** - Official website
- **[Full Documentation](https://rapscli.xyz/docs)** - Complete user guide
- **[Changelog](https://rapscli.xyz/changelog)** - Version history
- **[Blog](https://rapscli.xyz/blog)** - Technical articles on APS automation
## Resources
- [APS Developer Portal](https://aps.autodesk.com)
- [APS Documentation](https://aps.autodesk.com/developer/documentation)
- [APS OpenAPI Specifications](https://github.com/autodesk-platform-services/aps-sdk-openapi)
- [Data Management API](https://aps.autodesk.com/en/docs/data/v2/)
- [Model Derivative API](https://aps.autodesk.com/en/docs/model-derivative/v2/)
- [Design Automation API](https://aps.autodesk.com/en/docs/design-automation/v3/)
- [Webhooks API](https://aps.autodesk.com/en/docs/webhooks/v1/)
- [Reality Capture API](https://aps.autodesk.com/en/docs/reality-capture/v1/)
- [ACC Issues API](https://aps.autodesk.com/en/docs/acc/v1/reference/http/issues-issues-GET/)