mirror of
				https://github.com/discourse/discourse-ai.git
				synced 2025-10-24 19:18:39 +00:00 
			
		
		
		
	* Well, it was quite a journey but now tools have "context" which can be critical for the stuff they generate This entire change was so Dall E and Artist generate images in the correct context * FIX: improve error handling around image generation - also corrects image markdown and clarifies code * fix spec
		
			
				
	
	
		
			63 lines
		
	
	
		
			1.5 KiB
		
	
	
	
		
			Ruby
		
	
	
	
	
	
			
		
		
	
	
			63 lines
		
	
	
		
			1.5 KiB
		
	
	
	
		
			Ruby
		
	
	
	
	
	
| # frozen_string_literal: true
 | |
| 
 | |
| module DiscourseAi
 | |
|   module AiBot
 | |
|     module Tools
 | |
|       class DbSchema < Tool
 | |
|         def self.signature
 | |
|           {
 | |
|             name: name,
 | |
|             description: "Will load schema information for specific tables in the database",
 | |
|             parameters: [
 | |
|               {
 | |
|                 name: "tables",
 | |
|                 description:
 | |
|                   "list of tables to load schema information for, comma separated list eg: (users,posts))",
 | |
|                 type: "string",
 | |
|                 required: true,
 | |
|               },
 | |
|             ],
 | |
|           }
 | |
|         end
 | |
| 
 | |
|         def self.name
 | |
|           "schema"
 | |
|         end
 | |
| 
 | |
|         def tables
 | |
|           parameters[:tables]
 | |
|         end
 | |
| 
 | |
|         def invoke
 | |
|           tables_arr = tables.split(",").map(&:strip)
 | |
| 
 | |
|           table_info = {}
 | |
|           DB
 | |
|             .query(<<~SQL, tables_arr)
 | |
|             select table_name, column_name, data_type from information_schema.columns
 | |
|             where table_schema = 'public'
 | |
|             and table_name in (?)
 | |
|             order by table_name
 | |
|           SQL
 | |
|             .each do |row|
 | |
|               (table_info[row.table_name] ||= []) << "#{row.column_name} #{row.data_type}"
 | |
|             end
 | |
| 
 | |
|           schema_info =
 | |
|             table_info
 | |
|               .map { |table_name, columns| "#{table_name}(#{columns.join(",")})" }
 | |
|               .join("\n")
 | |
| 
 | |
|           { schema_info: schema_info, tables: tables }
 | |
|         end
 | |
| 
 | |
|         protected
 | |
| 
 | |
|         def description_args
 | |
|           { tables: tables }
 | |
|         end
 | |
|       end
 | |
|     end
 | |
|   end
 | |
| end
 |