Skip to content
Open
Changes from 1 commit
Commits
File filter

Filter by extension

Filter by extension

Conversations
Failed to load comments.
Loading
Jump to
Jump to file
Failed to load files.
Loading
Diff view
Diff view
Prev Previous commit
Next Next commit
security: override result_processor for SQLite safe deserialization
  • Loading branch information
daridor9 authored May 11, 2026
commit 8255302e8a0c3ed1a6b5440fd11a0d9389571bae
13 changes: 13 additions & 0 deletions src/google/adk/sessions/schemas/v0.py
Original file line number Diff line number Diff line change
Expand Up @@ -111,6 +111,19 @@ def process_bind_param(self, value, dialect):
return pickle.dumps(value)
return value

def result_processor(self, dialect, coltype):
if dialect.name in ("mysql", "spanner+spanner"):
return super().result_processor(dialect, coltype)

def process(value):
if value is None:
return None
if isinstance(value, memoryview):
value = bytes(value)
return _safe_pickle_loads(value)

return process

def process_result_value(self, value, dialect):
"""Ensures the raw bytes from the database are unpickled back into a Python object."""
if value is not None:
Expand Down