Skip to content
Merged
Show file tree
Hide file tree
Changes from all commits
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
2 changes: 1 addition & 1 deletion ATTRIBUTIONS.md
Original file line number Diff line number Diff line change
Expand Up @@ -360,7 +360,7 @@ SOFTWARE.

```

## aignostics-foundry-core (0.6.2) - MIT License
## aignostics-foundry-core (0.7.0) - MIT License

🏭 Foundational infrastructure for Foundry components.

Expand Down
4 changes: 2 additions & 2 deletions src/aignostics_foundry_core/api/auth.py
Original file line number Diff line number Diff line change
Expand Up @@ -300,13 +300,13 @@ async def me(user: Annotated[dict[str, Any], Depends(get_user)]):

try:
auth_client = get_auth_client(request)
session: dict[str, Any] = await auth_client.require_session(request, Response()) # pyright: ignore[reportAttributeAccessIssue, reportUnknownMemberType, reportUnknownVariableType]
session: dict = await auth_client.require_session(request, Response()) # type: ignore[reportUnknownVariableType]
except Exception: # noqa: BLE001
msg = "No session found"
logger.debug(msg)
return None

raw_user = session.get("user")
raw_user: dict | None = session.get("user") if isinstance(session, dict) else None # type: ignore[reportUnknownVariableType]
if not raw_user or not isinstance(raw_user, dict):
msg = "Failed to retrieve user information from session"
logger.critical(msg)
Expand Down
12 changes: 12 additions & 0 deletions tests/aignostics_foundry_core/api/auth_test.py
Original file line number Diff line number Diff line change
Expand Up @@ -168,6 +168,18 @@ async def test_get_user_returns_none_when_exp_claim_missing(self) -> None:

assert result is None

async def test_get_user_returns_none_when_session_is_not_a_dict(self) -> None:
"""get_user returns None when require_session returns a non-dict value."""
request = MagicMock()
cookie = "fake-cookie"
fake_client = MagicMock()
fake_client.require_session = AsyncMock(return_value="not-a-dict")
request.app.state.auth_client = fake_client

result = await get_user(request, cookie)

assert result is None

async def test_get_user_returns_user_for_valid_session(self) -> None:
"""get_user returns the user dict when the session is valid and not expired."""
request = MagicMock()
Expand Down
Loading