Class: BioRuby::MCP::Server::KEGGOrganismTool

Inherits:
MCP::Tool
  • Object
show all
Defined in:
lib/bioruby/mcp/server/kegg_tools.rb

Overview

KEGG organism list tool

Constant Summary collapse

KEGG_REST_BASE =
'http://rest.kegg.jp'

Class Method Summary collapse

Class Method Details

.call(filter: nil, server_context: nil) ⇒ Object



360
361
362
363
364
365
366
367
368
369
370
371
372
373
374
375
376
377
378
379
380
381
382
383
384
385
386
387
388
389
390
391
392
393
394
395
396
397
398
399
400
401
# File 'lib/bioruby/mcp/server/kegg_tools.rb', line 360

def call(filter: nil, server_context: nil)
  # Get list of organisms from KEGG REST API
  organism_data = kegg_list_entries('organism')
  
  if organism_data.nil? || organism_data.empty?
    return ::MCP::Tool::Response.new([{
      type: 'text',
      text: 'No organisms found'
    }])
  end

  organisms = organism_data.split("\n").map do |line|
    parts = line.split("\t")
    if parts.length >= 2
      org_code = parts[0]
      org_name = parts[1]
      { code: org_code, name: org_name }
    end
  end.compact

  # Apply filter if provided
  if filter
    organisms = organisms.select do |org|
      org[:name].downcase.include?(filter.downcase) ||
      org[:code].downcase.include?(filter.downcase)
    end
  end

  # Limit results and format
  organisms = organisms.first(50)
  formatted_list = organisms.map { |org| "#{org[:code]}: #{org[:name]}" }

  ::MCP::Tool::Response.new([{
    type: 'text',
    text: "KEGG Organisms#{filter ? " (filtered by '#{filter}')" : ''} (first 50):\n#{formatted_list.join("\n")}"
  }])
rescue => e
  ::MCP::Tool::Response.new([{
    type: 'text',
    text: "Error listing organisms: #{e.message}"
  }])
end