tooling_execute
Execute Tooling API requests to interact with Salesforce metadata, enabling actions like retrieving, creating, updating, or deleting records using specified endpoints and HTTP methods.
Instructions
Executes a Tooling API request
Input Schema
TableJSON Schema
| Name | Required | Description | Default |
|---|---|---|---|
| action | Yes | The Tooling API endpoint to call (e.g., 'sobjects/ApexClass') | |
| data | No | Data for POST/PATCH requests | |
| method | No | The HTTP method (default: 'GET') | GET |
Implementation Reference
- src/salesforce/server.py:413-429 (handler)The handler logic within handle_call_tool that processes arguments and executes the Salesforce Tooling API call using sf_client.sf.toolingexecute.elif name == "tooling_execute": action = arguments.get("action") method = arguments.get("method", "GET") data = arguments.get("data") if not action: raise ValueError("Missing 'action' argument") if not sf_client.sf: raise ValueError("Salesforce connection not established.") results = sf_client.sf.toolingexecute(action, method=method, data=data) return [ types.TextContent( type="text", text=f"Tooling Execute Result (JSON):\n{json.dumps(results, indent=2)}", ) ]
- src/salesforce/server.py:227-252 (registration)Tool registration in the list_tools handler, including name, description, and input schema for JSON Schema validation.types.Tool( name="tooling_execute", description="Executes a Tooling API request", inputSchema={ "type": "object", "properties": { "action": { "type": "string", "description": "The Tooling API endpoint to call (e.g., 'sobjects/ApexClass')", }, "method": { "type": "string", "description": "The HTTP method (default: 'GET')", "enum": ["GET", "POST", "PATCH", "DELETE"], "default": "GET", }, "data": { "type": "object", "description": "Data for POST/PATCH requests", "properties": {}, "additionalProperties": True, }, }, "required": ["action"], }, ),