mirror of
https://github.com/toeverything/AFFiNE.git
synced 2026-02-14 13:25:12 +00:00
feat: add retry support for copilot (#6947)
This commit is contained in:
@@ -82,14 +82,21 @@ export class CopilotController {
|
||||
|
||||
private async appendSessionMessage(
|
||||
sessionId: string,
|
||||
messageId: string
|
||||
messageId?: string
|
||||
): Promise<ChatSession> {
|
||||
const session = await this.chatSession.get(sessionId);
|
||||
if (!session) {
|
||||
throw new BadRequestException('Session not found');
|
||||
}
|
||||
|
||||
await session.pushByMessageId(messageId);
|
||||
if (messageId) {
|
||||
await session.pushByMessageId(messageId);
|
||||
} else {
|
||||
// revert the latest message generated by the assistant
|
||||
// if messageId is not provided, then we can retry the action
|
||||
await this.chatSession.revertLatestMessage(sessionId);
|
||||
session.revertLatestMessage();
|
||||
}
|
||||
|
||||
return session;
|
||||
}
|
||||
@@ -129,7 +136,6 @@ export class CopilotController {
|
||||
@CurrentUser() user: CurrentUser,
|
||||
@Req() req: Request,
|
||||
@Param('sessionId') sessionId: string,
|
||||
@Query('messageId') messageId: string,
|
||||
@Query() params: Record<string, string | string[]>
|
||||
): Promise<string> {
|
||||
const { model } = await this.checkRequest(user.id, sessionId);
|
||||
@@ -141,6 +147,9 @@ export class CopilotController {
|
||||
throw new InternalServerErrorException('No provider available');
|
||||
}
|
||||
|
||||
const messageId = Array.isArray(params.messageId)
|
||||
? params.messageId[0]
|
||||
: params.messageId;
|
||||
const session = await this.appendSessionMessage(sessionId, messageId);
|
||||
|
||||
try {
|
||||
@@ -174,7 +183,6 @@ export class CopilotController {
|
||||
@CurrentUser() user: CurrentUser,
|
||||
@Req() req: Request,
|
||||
@Param('sessionId') sessionId: string,
|
||||
@Query('messageId') messageId: string,
|
||||
@Query() params: Record<string, string>
|
||||
): Promise<Observable<ChatEvent>> {
|
||||
try {
|
||||
@@ -187,6 +195,9 @@ export class CopilotController {
|
||||
throw new InternalServerErrorException('No provider available');
|
||||
}
|
||||
|
||||
const messageId = Array.isArray(params.messageId)
|
||||
? params.messageId[0]
|
||||
: params.messageId;
|
||||
const session = await this.appendSessionMessage(sessionId, messageId);
|
||||
delete params.messageId;
|
||||
|
||||
@@ -237,10 +248,12 @@ export class CopilotController {
|
||||
@CurrentUser() user: CurrentUser,
|
||||
@Req() req: Request,
|
||||
@Param('sessionId') sessionId: string,
|
||||
@Query('messageId') messageId: string,
|
||||
@Query() params: Record<string, string>
|
||||
): Promise<Observable<ChatEvent>> {
|
||||
try {
|
||||
const messageId = Array.isArray(params.messageId)
|
||||
? params.messageId[0]
|
||||
: params.messageId;
|
||||
const { model, hasAttachment } = await this.checkRequest(
|
||||
user.id,
|
||||
sessionId,
|
||||
|
||||
Reference in New Issue
Block a user