multiAI Summary Pending

add-backend-tool

Add a new tool to the backend OpenAI function calling system. Use when user mentions "new tool", "add tool", "backend function", "agent capability", or wants to extend what the AI agent can do.

231 stars

Installation

Claude Code / Cursor / Codex

$curl -o ~/.claude/skills/add-backend-tool/SKILL.md --create-dirs "https://raw.githubusercontent.com/aiskillstore/marketplace/main/skills/applelamps/add-backend-tool/SKILL.md"

Manual Installation

  1. Download SKILL.md from GitHub
  2. Place it in .claude/skills/add-backend-tool/SKILL.md inside your project
  3. Restart your AI agent — it will auto-discover the skill

How add-backend-tool Compares

Feature / Agentadd-backend-toolStandard Approach
Platform SupportmultiLimited / Varies
Context Awareness High Baseline
Installation ComplexityUnknownN/A

Frequently Asked Questions

What does this skill do?

Add a new tool to the backend OpenAI function calling system. Use when user mentions "new tool", "add tool", "backend function", "agent capability", or wants to extend what the AI agent can do.

Which AI agents support this skill?

This skill is compatible with multi.

Where can I find the source code?

You can find the source code on GitHub using the link provided at the top of the page.

SKILL.md Source

# Add Backend Tool

## Instructions
1. Read `backend/main.py` to understand existing tool patterns:
   - Find the `tools` list with function definitions
   - Review helper functions (read_file, write_file, run_terminal_command, web_search)

2. Create the helper function:
   ```python
   def new_tool_name(param1: str, param2: int = 10) -> str:
       """Docstring explaining the tool."""
       try:
           # Implementation
           return result
       except Exception as e:
           return f"Error: {str(e)}"
   ```

3. Add tool definition to the `tools` list:
   ```python
   {
       "type": "function",
       "function": {
           "name": "new_tool_name",
           "description": "What this tool does and when to use it",
           "parameters": {
               "type": "object",
               "properties": {
                   "param1": {"type": "string", "description": "..."},
                   "param2": {"type": "integer", "description": "..."}
               },
               "required": ["param1"]
           }
       }
   }
   ```

4. Add tool invocation handler in the WebSocket message loop:
   ```python
   elif func_name == "new_tool_name":
       result = new_tool_name(**args)
   ```

5. Update mode restrictions if needed:
   - Agent mode: full access
   - Chat mode: add to allowed list only if read-only/safe

## Examples
- "Add a tool to list directory contents"
- "Create a tool for git operations"
- "Add web scraping capability"

## Guardrails
- Include proper error handling with try/except
- Add timeout for any long-running operations
- Consider security implications (Chat mode restrictions)
- Never hardcode API keys or secrets
- Document the tool's purpose in the function docstring