vision-agent / lib /db /functions.ts
MingruiZhang's picture
feat: Directly us DBMessage as UIMessage + Code viewer (#74)
4af6326 unverified
raw
history blame
4.38 kB
'use server';
import { sessionUser } from '@/auth';
import prisma from './prisma';
import {
ChatWithMessages,
MessageAssistantResponse,
MessageUserInput,
} from '../types';
import { revalidatePath } from 'next/cache';
import { Chat } from '@prisma/client';
async function getUserConnect() {
const { id: userId } = await sessionUser();
return userId
? {
user: {
connect: { id: userId }, // Connect the chat to an existing user
},
}
: {};
}
/**
* Finds or creates a user in the database based on the provided email and name.
* If the user already exists, it returns the existing user.
* If the user doesn't exist, it creates a new user and returns it.
*
* @param email - The email of the user.
* @param name - The name of the user.
* @returns A promise that resolves to the user object.
*/
export async function dbFindOrCreateUser(email: string, name: string) {
// Try to find the user by email
const user = await prisma.user.findUnique({
where: { email: email },
});
// If the user doesn't exist, create it
if (user) {
return user;
} else {
return prisma.user.create({
data: {
email: email,
name: name,
},
});
}
}
/**
* Retrieves all chat records from the database for the current user.
* @returns A promise that resolves to an array of Chat objects.
*/
export async function dbGetMyChatList(): Promise<Chat[]> {
const { id: userId } = await sessionUser();
if (!userId) return [];
return prisma.chat.findMany({
where: { userId },
orderBy: {
createdAt: 'desc',
},
});
}
/**
* Retrieves a chat with messages from the database based on the provided ID.
* @param id - The ID of the chat to retrieve.
* @returns A Promise that resolves to a ChatWithMessages object if found, or null if not found.
*/
export async function dbGetChat(id: string): Promise<ChatWithMessages | null> {
return prisma.chat.findUnique({
where: { id },
include: {
messages: {
orderBy: {
createdAt: 'asc',
},
},
},
});
}
/**
* Creates a new chat in the database with the provided information.
* @param {Object} options - The options for creating the chat.
* @param {string} options.id - The ID of the chat (optional).
* @param {string} options.title - The title of the chat (optional).
* @param {MessageUserInput} options.message - The message to be added to the chat.
* @returns {Promise<Chat>} - A promise that resolves to the created chat.
*/
export async function dbPostCreateChat({
id,
title,
mediaUrl,
message,
}: {
id?: string;
title?: string;
mediaUrl: string;
message: MessageUserInput;
}) {
const userConnect = await getUserConnect();
try {
const response = await prisma.chat.create({
data: {
id,
...userConnect,
mediaUrl,
title,
messages: {
create: [{ ...message, ...userConnect }],
},
},
include: {
messages: true,
},
});
revalidatePath('/chat');
return response;
} catch (error) {
console.error(error);
}
}
/**
* Creates a new message in the database for a given chat.
* @param chatId - The ID of the chat where the message will be created.
* @param message - The message to be created.
*/
export async function dbPostCreateMessage(
chatId: string,
message: MessageUserInput,
) {
const userConnect = await getUserConnect();
const resp = await prisma.message.create({
data: {
...message,
...userConnect,
chat: {
connect: { id: chatId },
},
},
});
revalidatePath('/chat');
return resp;
}
/**
* Updates a message in the database with the provided response.
* @param messageId - The ID of the message to update.
* @param messageResponse - The response to update the message with.
*/
export async function dbPostUpdateMessageResponse(
messageId: string,
messageResponse: MessageAssistantResponse,
) {
await prisma.message.update({
data: {
response: messageResponse.response,
result: messageResponse.result ?? undefined,
},
where: {
id: messageId,
},
});
revalidatePath('/chat');
}
export async function dbDeleteChat(chatId: string) {
await prisma.chat.delete({
where: { id: chatId },
});
revalidatePath('/chat');
return;
}