feat(room): use participated user count as participant count for playlist room

This commit is contained in:
MingxuanGame
2025-09-14 06:31:29 +00:00
parent 19f94fffbb
commit 61639454a3
2 changed files with 32 additions and 10 deletions

View File

@@ -59,9 +59,10 @@ class ItemAttemptsCount(AsyncAttrs, ItemAttemptsCountBase, table=True):
self.attempts = sum(score.attempts for score in playlist_scores)
self.total_score = sum(score.total_score for score in playlist_scores)
self.pp = sum(score.score.pp for score in playlist_scores)
self.completed = len([score for score in playlist_scores if score.score.passed])
passed_scores = [score for score in playlist_scores if score.score.passed]
self.completed = len(passed_scores)
self.accuracy = (
sum(score.score.accuracy for score in playlist_scores) / self.completed if self.completed > 0 else 0.0
sum(score.score.accuracy for score in passed_scores) / self.completed if self.completed > 0 else 0.0
)
await session.commit()
await session.refresh(self)

View File

@@ -27,6 +27,7 @@ from sqlmodel import (
Relationship,
SQLModel,
col,
func,
select,
)
from sqlmodel.ext.asyncio.session import AsyncSession
@@ -118,15 +119,35 @@ class RoomResp(RoomBase):
resp.difficulty_range = difficulty_range
resp.current_playlist_item = resp.playlist[-1] if resp.playlist else None
resp.recent_participants = []
for recent_participant in await session.exec(
select(RoomParticipatedUser)
.where(
RoomParticipatedUser.room_id == room.id,
col(RoomParticipatedUser.left_at).is_(None),
if room.category == RoomCategory.REALTIME:
query = (
select(RoomParticipatedUser)
.where(
RoomParticipatedUser.room_id == room.id,
col(RoomParticipatedUser.left_at).is_(None),
)
.limit(8)
.order_by(col(RoomParticipatedUser.joined_at).desc())
)
.limit(8)
.order_by(col(RoomParticipatedUser.joined_at).desc())
):
else:
query = (
select(RoomParticipatedUser)
.where(
RoomParticipatedUser.room_id == room.id,
)
.limit(8)
.order_by(col(RoomParticipatedUser.joined_at).desc())
)
resp.participant_count = (
await session.exec(
select(func.count())
.select_from(RoomParticipatedUser)
.where(
RoomParticipatedUser.room_id == room.id,
)
)
).first() or 0
for recent_participant in await session.exec(query):
resp.recent_participants.append(
await UserResp.from_db(
await recent_participant.awaitable_attrs.user,