Class: SchwabMCP::Tools::ListMoversTool
- Inherits:
-
MCP::Tool
- Object
- MCP::Tool
- SchwabMCP::Tools::ListMoversTool
- Extended by:
- Loggable
- Defined in:
- lib/schwab_mcp/tools/list_movers_tool.rb
Class Method Summary collapse
Methods included from Loggable
log_debug, log_error, log_fatal, log_info, log_warn, logger
Class Method Details
.call(index:, sort_order: nil, frequency: nil, server_context:) ⇒ Object
40 41 42 43 44 45 46 47 48 49 50 51 52 53 54 55 56 57 58 59 60 61 62 63 64 65 66 67 68 69 70 71 72 73 74 75 76 77 78 79 80 |
# File 'lib/schwab_mcp/tools/list_movers_tool.rb', line 40 def self.call(index:, sort_order: nil, frequency: nil, server_context:) log_info("Getting movers for index: #{index}, sort_order: #{sort_order}, frequency: #{frequency}") begin client = SchwabClientFactory.create_client return SchwabClientFactory.client_error_response unless client log_debug("Making API request for movers - index: #{index}, sort_order: #{sort_order}, frequency: #{frequency}") market_movers = client.get_movers( index, sort_order: sort_order, frequency: frequency ) if market_movers && market_movers.count > 0 log_info("Successfully retrieved #{market_movers.count} movers for index #{index}") formatted_output = format_movers_response(market_movers, index, sort_order, frequency) MCP::Tool::Response.new([{ type: "text", text: formatted_output }]) else log_warn("No movers data returned from Schwab API for index #{index}") MCP::Tool::Response.new([{ type: "text", text: "**No Data**: No movers found for index #{index}" }]) end rescue => e log_error("Error retrieving movers: #{e.}") log_debug("Backtrace: #{e.backtrace.first(3).join('\n')}") MCP::Tool::Response.new([{ type: "text", text: "**Error** retrieving movers: #{e.}\n\n#{e.backtrace.first(3).join('\n')}" }]) end end |