Class: Llmemory::ShortTerm::Stores::PostgresStore
- Defined in:
- lib/llmemory/short_term/stores/postgres_store.rb
Instance Method Summary collapse
- #delete(user_id, session_id) ⇒ Object
-
#initialize(database_url: nil) ⇒ PostgresStore
constructor
A new instance of PostgresStore.
- #list_sessions(user_id:) ⇒ Object
- #list_users ⇒ Object
- #load(user_id, session_id) ⇒ Object
- #save(user_id, session_id, state) ⇒ Object
Constructor Details
#initialize(database_url: nil) ⇒ PostgresStore
Returns a new instance of PostgresStore.
9 10 11 12 |
# File 'lib/llmemory/short_term/stores/postgres_store.rb', line 9 def initialize(database_url: nil) @database_url = database_url || Llmemory.configuration.database_url @connection = nil end |
Instance Method Details
#delete(user_id, session_id) ⇒ Object
38 39 40 41 42 43 44 45 |
# File 'lib/llmemory/short_term/stores/postgres_store.rb', line 38 def delete(user_id, session_id) ensure_table! conn.exec_params( "DELETE FROM llmemory_checkpoints WHERE user_id = $1 AND session_id = $2", [user_id, session_id] ) true end |
#list_sessions(user_id:) ⇒ Object
53 54 55 56 57 58 59 60 |
# File 'lib/llmemory/short_term/stores/postgres_store.rb', line 53 def list_sessions(user_id:) ensure_table! result = conn.exec_params( "SELECT session_id FROM llmemory_checkpoints WHERE user_id = $1", [user_id] ) result.map { |r| r["session_id"] } end |
#list_users ⇒ Object
47 48 49 50 51 |
# File 'lib/llmemory/short_term/stores/postgres_store.rb', line 47 def list_users ensure_table! result = conn.exec("SELECT DISTINCT user_id FROM llmemory_checkpoints") result.map { |r| r["user_id"] } end |
#load(user_id, session_id) ⇒ Object
28 29 30 31 32 33 34 35 36 |
# File 'lib/llmemory/short_term/stores/postgres_store.rb', line 28 def load(user_id, session_id) ensure_table! result = conn.exec_params( "SELECT state FROM llmemory_checkpoints WHERE user_id = $1 AND session_id = $2", [user_id, session_id] ) row = result.first row ? deserialize(row["state"]) : nil end |
#save(user_id, session_id, state) ⇒ Object
14 15 16 17 18 19 20 21 22 23 24 25 26 |
# File 'lib/llmemory/short_term/stores/postgres_store.rb', line 14 def save(user_id, session_id, state) ensure_table! conn.exec_params( <<~SQL, INSERT INTO llmemory_checkpoints (user_id, session_id, state, updated_at) VALUES ($1, $2, $3, $4) ON CONFLICT (user_id, session_id) DO UPDATE SET state = $3, updated_at = $4 SQL [user_id, session_id, serialize(state), Time.now.utc.iso8601] ) true end |