Class: RosettAi::Mcp::Tools::BehaviourManageTool

Inherits:
Object
  • Object
show all
Defined in:
lib/rosett_ai/mcp/tools/behaviour_manage_tool.rb

Overview

MCP tool: manage behaviour files.

Add, modify, or delete behaviour configurations. Write operation — destructive when action is 'delete'.

Author:

  • hugo

  • claude

Constant Summary collapse

TOOL_NAME =
'rai_behaviour_manage'
DESCRIPTION =
'Add, modify, or delete rai behaviour files'
ANNOTATIONS =
{
  'readOnlyHint' => false,
  'destructiveHint' => true,
  'idempotentHint' => false,
  'openWorldHint' => false
}.freeze
VALID_ACTIONS =
['add', 'modify', 'delete'].freeze
INPUT_SCHEMA =
{
  type: 'object',
  properties: {
    action: {
      type: 'string',
      enum: ['add', 'modify', 'delete'],
      description: 'Management action to perform'
    },
    name: {
      type: 'string',
      description: 'Behaviour name'
    },
    description: {
      type: 'string',
      description: 'Behaviour description (for add/modify)'
    },
    force: {
      type: 'boolean',
      description: 'Skip confirmation for delete (default: false)'
    }
  },
  required: ['action', 'name']
}.freeze

Instance Method Summary collapse

Instance Method Details

#call(action:, name:, description: nil, force: false) ⇒ Hash

Executes the behaviour management operation.

Parameters:

  • action (String)

    one of 'add', 'modify', 'delete'

  • name (String)

    behaviour name

  • description (String, nil) (defaults to: nil)

    behaviour description (for add/modify)

  • force (Boolean) (defaults to: false)

    skip confirmation for delete

Returns:

  • (Hash)

    operation result



60
61
62
63
64
65
66
67
68
69
70
71
# File 'lib/rosett_ai/mcp/tools/behaviour_manage_tool.rb', line 60

def call(action:, name:, description: nil, force: false)
  return ResponseHelper.error("Invalid action: #{action}") unless VALID_ACTIONS.include?(action)
  return ResponseHelper.error('Name is required') if name.nil? || name.empty?

  case action
  when 'add' then action_add(name, description: description)
  when 'modify' then action_modify(name, description: description)
  when 'delete' then action_delete(name, force: force)
  end
rescue StandardError => e
  ResponseHelper.error("Behaviour #{action} failed: #{e.message}")
end