adrianhajdin / ai_saas_app

Build a REAL Software-as-a-Service app with AI features and payments & credits system that you might even turn into a side income or business idea using Next.js 14, Clerk, MongoDB, Cloudinary AI, and Stripe.
https://jsmastery.pro
1.07k stars 337 forks source link

Error: Error: User with clerkId user_2kQEy3NVpSvdKbiMsH2yBVKhHof not found #32

Open Legit-Sam opened 1 month ago

Legit-Sam commented 1 month ago

HERE IS MY CODES " "use server";

import { revalidatePath } from "next/cache";

import User from "../database/models/user.model"; import { connectToDatabase } from "../database/mongose"; import { handleError } from "../utils";

// CREATE export async function createUser(user: CreateUserParams) { try { await connectToDatabase();

const newUser = await User.create(user);

return JSON.parse(JSON.stringify(newUser));

} catch (error) { handleError(error); } }

// READ export async function getUserById(userId: string) { try { await connectToDatabase();

console.log(`Fetching user with clerkId: ${userId}`); // Log userId
const user = await User.findOne({ clerkId: userId });

if (!user) {
  console.error(`User not found with clerkId: ${userId}`); // Log error
  throw new Error(`User with clerkId ${userId} not found`);
}

return JSON.parse(JSON.stringify(user));

} catch (error) { handleError(error); } }

// UPDATE export async function updateUser(clerkId: string, user: UpdateUserParams) { try { await connectToDatabase();

console.log(`Updating user with clerkId: ${clerkId}`); // Log clerkId
const updatedUser = await User.findOneAndUpdate({ clerkId }, user, {
  new: true,
});

if (!updatedUser) {
  console.error(`User update failed for clerkId: ${clerkId}`); // Log error
  throw new Error(`User update failed for clerkId ${clerkId}`);
}

return JSON.parse(JSON.stringify(updatedUser));

} catch (error) { handleError(error); } }

// DELETE export async function deleteUser(clerkId: string) { try { await connectToDatabase();

console.log(`Deleting user with clerkId: ${clerkId}`); // Log clerkId
const userToDelete = await User.findOne({ clerkId });

if (!userToDelete) {
  console.error(`User not found for deletion with clerkId: ${clerkId}`); // Log error
  throw new Error(`User not found with clerkId ${clerkId}`);
}

const deletedUser = await User.findByIdAndDelete(userToDelete._id);
revalidatePath("/");

return deletedUser ? JSON.parse(JSON.stringify(deletedUser)) : null;

} catch (error) { handleError(error); } }

// USE CREDITS export async function updateCredits(userId: string, creditFee: number) { try { await connectToDatabase();

console.log(`Updating credits for user with _id: ${userId}`); // Log userId
const updatedUserCredits = await User.findOneAndUpdate(
  { _id: userId },
  { $inc: { creditBalance: creditFee }},
  { new: true }
);

if (!updatedUserCredits) {
  console.error(`User credits update failed for _id: ${userId}`); // Log error
  throw new Error(`User credits update failed for _id ${userId}`);
}

return JSON.parse(JSON.stringify(updatedUserCredits));

} catch (error) { handleError(error); } } " @adrianhajdin Screenshot 2024-08-10 123827