1.4
This commit is contained in:
@@ -10,6 +10,8 @@ from app.schemas.conversation import (
|
||||
GroupCreate, GroupUpdate, MemberAdd, RoleUpdate,
|
||||
)
|
||||
from app.services.conversation_service import ConversationService
|
||||
from app.websocket.events import EventType
|
||||
from app.websocket.manager import manager
|
||||
|
||||
router = APIRouter()
|
||||
|
||||
@@ -97,6 +99,16 @@ async def add_members(
|
||||
service = ConversationService(db)
|
||||
try:
|
||||
await service.add_members(conversation_id, user.id, req.user_ids)
|
||||
# 通知新成员被加入群聊
|
||||
detail = await service.get_conversation_detail(conversation_id, user.id)
|
||||
group_name = detail.get("name", "群聊") if detail else "群聊"
|
||||
for mid in req.user_ids:
|
||||
await manager.send_to_user(mid, EventType.CONVERSATION_MEMBER_ADDED, {
|
||||
"conversation_id": conversation_id,
|
||||
"group_name": group_name,
|
||||
"added_by_user_id": user.id,
|
||||
"added_by_username": user.username,
|
||||
})
|
||||
return {"success": True, "message": "成员已添加"}
|
||||
except ValueError as e:
|
||||
raise HTTPException(status_code=400, detail=str(e))
|
||||
@@ -113,6 +125,12 @@ async def remove_member(
|
||||
service = ConversationService(db)
|
||||
try:
|
||||
await service.remove_member(conversation_id, user.id, target_user_id)
|
||||
# 通知被移除的用户
|
||||
await manager.send_to_user(target_user_id, EventType.CONVERSATION_MEMBER_REMOVED, {
|
||||
"conversation_id": conversation_id,
|
||||
"removed_by_user_id": user.id,
|
||||
"removed_by_username": user.username,
|
||||
})
|
||||
return {"success": True, "message": "成员已移除"}
|
||||
except ValueError as e:
|
||||
raise HTTPException(status_code=400, detail=str(e))
|
||||
@@ -133,6 +151,21 @@ async def leave_group(
|
||||
raise HTTPException(status_code=400, detail=str(e))
|
||||
|
||||
|
||||
@router.post("/{conversation_id}/dissolve")
|
||||
async def dissolve_group(
|
||||
conversation_id: str,
|
||||
user: User = Depends(get_current_user),
|
||||
db: AsyncSession = Depends(get_db),
|
||||
):
|
||||
"""解散群聊(仅群主)"""
|
||||
service = ConversationService(db)
|
||||
try:
|
||||
await service.dissolve_group(conversation_id, user.id)
|
||||
return {"success": True, "message": "群聊已解散"}
|
||||
except ValueError as e:
|
||||
raise HTTPException(status_code=400, detail=str(e))
|
||||
|
||||
|
||||
@router.put("/{conversation_id}/members/{target_user_id}/role")
|
||||
async def update_member_role(
|
||||
conversation_id: str,
|
||||
|
||||
Reference in New Issue
Block a user