Opus MCP Server
Model Context Protocol (MCP) server for the Opus Job Operator API. This server provides tools to programmatically interact with Opus workflows, including job initiation, execution, monitoring, and file uploads.
Quick Start: See QUICKSTART.md for 3-minute setup!
Installation: See INSTALL.md for detailed instructions
Distribution: See DISTRIBUTION.md for sharing options
Features
Workflow Management: Get workflow details and schemas
Job Operations: Initiate, execute, and monitor jobs
File Handling: Generate presigned URLs for secure file uploads
Monitoring: Check job status, retrieve results, and view audit logs
Installation
Install dependencies:
Build the project:
Set up environment variables:
Getting Your API Key
Navigate to the Opus platform
Click My Organization at the top
Click the gear icon next to your Organization's name
Select API Keys from the settings menu
Click + Generate API Key
Copy the key (shown only once) and add to
.envfile
Configuration
For Claude Desktop
Add to your Claude Desktop config file:
macOS: ~/Library/Application Support/Claude/claude_desktop_config.json
Windows: %APPDATA%\Claude\claude_desktop_config.json
For Other MCP Clients
Use the built executable with environment variable:
Available Tools
1. get_workflow_details
Get workflow details including the jobPayloadSchema that defines required inputs.
Parameters:
workflowId(string, required): The workflow ID from Opus
Returns: Full workflow details including schema, execution estimation, and input requirements
2. initiate_job
Create a new job instance for a workflow.
Parameters:
workflowId(string, required): The workflow IDtitle(string, required): Job titledescription(string, required): Job description
Returns: jobExecutionId needed for subsequent operations
3. generate_file_upload_url
Generate presigned URLs for secure file uploads.
Parameters:
fileExtension(string, required): File extension with dot (e.g.,.pdf,.jpeg,.png,.docx)accessScope(string, optional): Access scope -all,user,workspace, ororganization(default)
Returns:
presignedUrl: Use for uploading file via PUT requestfileUrl: Use this URL in job execution payload
Supported File Types: .jpeg, .png, .jpg, .pdf, .docx, .csv, .xls, .xlsx, .txt, .json, .html, .xml
4. execute_job
Execute a job with populated input values.
Parameters:
jobExecutionId(string, required): Frominitiate_jobresponsejobPayloadSchemaInstance(object, required): Job inputs structured according to workflow schema
Example jobPayloadSchemaInstance:
5. get_job_status
Check current job execution status.
Parameters:
jobExecutionId(string, required): The job ID
Returns: Status - IN PROGRESS, COMPLETED, or FAILED
6. get_job_results
Retrieve results from a completed job.
Parameters:
jobExecutionId(string, required): The job ID
Returns: Job results including output files and data (only works when status is COMPLETED)
7. get_job_audit_log
Get detailed audit log of job execution.
Parameters:
jobExecutionId(string, required): The job ID
Returns: Timestamped log of all system actions
Workflow Example
Development
Watch mode for development:
API Documentation
For complete API details, see the markdown files in the root directory:
opus-00-get-workflow-details.md- Workflow schema retrievalopus-03-initiate-job.md- Job initiationopus-04-uploading-files-for-job-inputs.md- File uploadsopus-05-execute-job.md- Job executionopus-06-get-job-execution-status.md- Status monitoringopus-07-get-job-execution-results.md- Results retrievalopus-08-job-audit-log.md- Audit logs
Base URL
All requests are made to: https://operator.opus.com
Troubleshooting
Error: OPUS_SERVICE_KEY environment variable is required
Ensure your
.envfile exists with the correct key, orSet the environment variable in your MCP client configuration
Error: Authentication failed
Verify your service key is valid and not expired
Check that the key has proper permissions in Opus
File upload issues
Ensure file extension matches the actual file type
Use PUT request without authentication headers for presigned URL
Verify file size limits (if any) in Opus documentation
License
MIT
This server cannot be installed