Skip to content

Commit

Permalink
feat(session): add thread safety to SessionsCollection methods & impl…
Browse files Browse the repository at this point in the history
…ement .index
  • Loading branch information
teocns committed Nov 26, 2024
1 parent 3e115b6 commit 282e0ea
Showing 1 changed file with 39 additions and 13 deletions.
52 changes: 39 additions & 13 deletions agentops/session/session.py
Original file line number Diff line number Diff line change
Expand Up @@ -340,13 +340,30 @@ class SessionsCollection(WeakSet):
3. Standard WeakSet doesn't support indexing
"""

def __init__(self):
super().__init__()
self._lock = threading.Lock()

def __getitem__(self, index: int) -> Session:
"""
Enable indexing into the collection (e.g., sessions[0]).
"""
# Convert to list for indexing since sets aren't ordered
items = list(self)
return items[index]
with self._lock:
# Convert to list for indexing since sets aren't ordered
items = list(self)
return items[index]

def __setitem__(self, index: int, session: Session) -> None:
"""
Enable item assignment (e.g., sessions[0] = new_session).
"""
with self._lock:
items = list(self)
if 0 <= index < len(items):
self.remove(items[index])
self.add(session)
else:
raise IndexError("list assignment index out of range")

def __iter__(self):
"""
Expand All @@ -356,26 +373,35 @@ def __iter__(self):
WARNING: Using _create_ts as a fallback for ordering may lead to unexpected results
if init_timestamp is not set correctly.
"""
return iter(
sorted(
super().__iter__(),
key=lambda session: (
session.init_timestamp if hasattr(session, "init_timestamp") else session._create_ts
),
with self._lock:
return iter(
sorted(
super().__iter__(),
key=lambda session: (
session.init_timestamp if hasattr(session, "init_timestamp") else session._create_ts
),
)
)
)

def append(self, session: Session) -> None:
"""Append a session to the collection"""
super().add(session)
with self._lock:
super().add(session)

def remove(self, session: Session) -> None:
"""Remove a session from the collection"""
super().discard(session)
with self._lock:
super().discard(session)

def __len__(self) -> int:
"""Return the number of sessions in the collection"""
return len(list(super().__iter__()))
with self._lock:
return len(list(super().__iter__()))

def index(self, session: Session) -> int:
"""Return the index of a session in the collection"""
with self._lock:
return list(super().__iter__()).index(session)


active_sessions = SessionsCollection()
Expand Down

0 comments on commit 282e0ea

Please sign in to comment.