Class: SharedTools::Tools::DatabaseTool
- Inherits:
-
RubyLLM::Tool
- Object
- RubyLLM::Tool
- SharedTools::Tools::DatabaseTool
- Defined in:
- lib/shared_tools/tools/database_tool.rb
Overview
Instance Attribute Summary collapse
-
#driver ⇒ Object
writeonly
Set driver after instantiation (useful when tool is discovered by RubyLLM).
Class Method Summary collapse
Instance Method Summary collapse
- #execute(statements:) ⇒ Array<Hash>
-
#initialize(driver: nil, logger: nil) ⇒ DatabaseTool
constructor
A new instance of DatabaseTool.
- #perform(statement:) ⇒ Object
Constructor Details
#initialize(driver: nil, logger: nil) ⇒ DatabaseTool
Returns a new instance of DatabaseTool.
68 69 70 71 |
# File 'lib/shared_tools/tools/database_tool.rb', line 68 def initialize(driver: nil, logger: nil) @driver = driver @logger = logger || RubyLLM.logger end |
Instance Attribute Details
#driver=(value) ⇒ Object (writeonly)
Set driver after instantiation (useful when tool is discovered by RubyLLM)
74 75 76 |
# File 'lib/shared_tools/tools/database_tool.rb', line 74 def driver=(value) @driver = value end |
Class Method Details
.name ⇒ Object
13 |
# File 'lib/shared_tools/tools/database_tool.rb', line 13 def self.name = 'database_tool' |
Instance Method Details
#execute(statements:) ⇒ Array<Hash>
83 84 85 86 87 88 89 90 91 92 93 |
# File 'lib/shared_tools/tools/database_tool.rb', line 83 def execute(statements:) raise ArgumentError, "driver is required for DatabaseTool#execute. Set via initialize(driver:) or tool.driver=" if @driver.nil? [].tap do |executions| statements.map do |statement| execution = perform(statement:).merge(statement:) executions << execution break unless execution[:status].eql?(:ok) end end end |
#perform(statement:) ⇒ Object
95 96 97 98 99 100 101 |
# File 'lib/shared_tools/tools/database_tool.rb', line 95 def perform(statement:) @logger&.info("#perform statement=#{statement.inspect}") @driver.perform(statement:).tap do |result| @logger&.info(JSON.generate(result)) end end |