mirror of
https://github.com/open-webui/open-webui
synced 2024-12-28 06:42:47 +00:00
feat: channels backend
This commit is contained in:
parent
cb3e01de8a
commit
f4e5e5171f
@ -70,6 +70,13 @@ class UserResponse(BaseModel):
|
|||||||
profile_image_url: str
|
profile_image_url: str
|
||||||
|
|
||||||
|
|
||||||
|
class UserNameResponse(BaseModel):
|
||||||
|
id: str
|
||||||
|
name: str
|
||||||
|
role: str
|
||||||
|
profile_image_url: str
|
||||||
|
|
||||||
|
|
||||||
class UserRoleUpdateForm(BaseModel):
|
class UserRoleUpdateForm(BaseModel):
|
||||||
id: str
|
id: str
|
||||||
role: str
|
role: str
|
||||||
|
@ -8,6 +8,8 @@ from pydantic import BaseModel
|
|||||||
|
|
||||||
|
|
||||||
from open_webui.socket.main import sio
|
from open_webui.socket.main import sio
|
||||||
|
from open_webui.models.users import Users, UserNameResponse
|
||||||
|
|
||||||
from open_webui.models.channels import Channels, ChannelModel, ChannelForm
|
from open_webui.models.channels import Channels, ChannelModel, ChannelForm
|
||||||
from open_webui.models.messages import Messages, MessageModel, MessageForm
|
from open_webui.models.messages import Messages, MessageModel, MessageForm
|
||||||
|
|
||||||
@ -60,7 +62,11 @@ async def create_new_channel(form_data: ChannelForm, user=Depends(get_admin_user
|
|||||||
############################
|
############################
|
||||||
|
|
||||||
|
|
||||||
@router.get("/{id}/messages", response_model=list[MessageModel])
|
class MessageUserModel(MessageModel):
|
||||||
|
user: UserNameResponse
|
||||||
|
|
||||||
|
|
||||||
|
@router.get("/{id}/messages", response_model=list[MessageUserModel])
|
||||||
async def get_channel_messages(id: str, page: int = 1, user=Depends(get_verified_user)):
|
async def get_channel_messages(id: str, page: int = 1, user=Depends(get_verified_user)):
|
||||||
channel = Channels.get_channel_by_id(id)
|
channel = Channels.get_channel_by_id(id)
|
||||||
if not channel:
|
if not channel:
|
||||||
@ -76,7 +82,25 @@ async def get_channel_messages(id: str, page: int = 1, user=Depends(get_verified
|
|||||||
limit = 50
|
limit = 50
|
||||||
skip = (page - 1) * limit
|
skip = (page - 1) * limit
|
||||||
|
|
||||||
return Messages.get_messages_by_channel_id(id, skip, limit)
|
message_list = Messages.get_messages_by_channel_id(id, skip, limit)
|
||||||
|
users = {}
|
||||||
|
|
||||||
|
messages = []
|
||||||
|
for message in message_list:
|
||||||
|
if message.user_id not in users:
|
||||||
|
user = Users.get_user_by_id(message.user_id)
|
||||||
|
users[message.user_id] = user
|
||||||
|
|
||||||
|
messages.append(
|
||||||
|
MessageUserModel(
|
||||||
|
**{
|
||||||
|
**message.model_dump(),
|
||||||
|
"user": UserNameResponse(**users[message.user_id].model_dump()),
|
||||||
|
}
|
||||||
|
)
|
||||||
|
)
|
||||||
|
|
||||||
|
return messages
|
||||||
|
|
||||||
|
|
||||||
############################
|
############################
|
||||||
@ -108,7 +132,13 @@ async def post_new_message(
|
|||||||
{
|
{
|
||||||
"channel_id": channel.id,
|
"channel_id": channel.id,
|
||||||
"message_id": message.id,
|
"message_id": message.id,
|
||||||
"data": {"type": "message", "data": message.model_dump()},
|
"data": {
|
||||||
|
"type": "message",
|
||||||
|
"data": {
|
||||||
|
**message.model_dump(),
|
||||||
|
"user": UserNameResponse(**user.model_dump()).model_dump(),
|
||||||
|
},
|
||||||
|
},
|
||||||
},
|
},
|
||||||
to=f"channel:{channel.id}",
|
to=f"channel:{channel.id}",
|
||||||
)
|
)
|
||||||
|
Loading…
Reference in New Issue
Block a user