File size: 1,585 Bytes
cd1bfbe
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
1
2
3
4
5
6
7
8
9
10
11
12
13
14
15
16
17
18
19
20
21
22
23
24
25
26
27
28
29
30
31
32
33
34
35
36
37
38
39
40
41
42
43
44
45
46
47
48
49
50
51
52
53
from psycopg2 import connect
from transformers.tools import Tool


class PostgreSQLTool(Tool):
    name = "postgres_database_tool"
    description = (
        "This tool is used to query a PostgreSQL database with a SQL request. "
        "The tool is already connected to the database. "
        "Example: postgres_tool('SELECT field FROM my_table;')"
        "It takes a SQL request as argument and returns the result of the query. "
    )

    inputs = ["text"]
    outputs = ["text"]

    debug = False

    database = None
    cursor = None

    def __init__(self, debug: bool = False, **kwargs):
        super().__init__(**kwargs)
        self.debug = debug

    def connect(self, host: str, database: str, user: str, password: str, port: int = 5432):
        # Connect to the database and create a cursor
        self.database = connect(
            database=database, host=host, user=user, password=password, port=port)
        self.cursor = self.database.cursor()

    def disconnect(self):
        # Close the connection to the database
        self.database.close()

    def __call__(self, query: str):
        if self.debug:
            print(f"[POSTGRESQL_TOOL] Executing: {query}")

        try:
            # Execute the query
            self.cursor.execute(query)
        except Exception as e:

            if self.debug:
                print(f"[POSTGRESQL_TOOL] Query failed: {e}")

            # Return the error message
            return "[POSTGRESQL_TOOL] Query failed: " + str(e)

        # Return the result of the query
        return self.cursor.fetchall()