mirror of
				https://github.com/i701/sarlink-portal.git
				synced 2025-10-24 17:43:08 +00:00 
			
		
		
		
	feat: implement user verification and rejection functionality with improved error handling ✨
This commit is contained in:
		| @@ -1,16 +1,20 @@ | ||||
| "use server"; | ||||
|  | ||||
| import { revalidatePath } from "next/cache"; | ||||
| import { redirect } from "next/navigation"; | ||||
| import { getServerSession } from "next-auth"; | ||||
| import { authOptions } from "@/app/auth"; | ||||
| import type { RejectUserFormState } from "@/components/user/user-reject-dialog"; | ||||
| import type { ApiError } from "@/lib/backend-types"; | ||||
| import type { User, UserProfile } from "@/lib/types/user"; | ||||
| import { handleApiResponse } from "@/utils/tryCatch"; | ||||
|  | ||||
| export async function VerifyUser(userId: string) { | ||||
| export async function VerifyUser(_userId: string) { | ||||
| 	// const user = await prisma.user.findUnique({ | ||||
| 	// 	where: { | ||||
| 	// 		id: userId, | ||||
| 	// 	}, | ||||
| 	// 	include: { | ||||
| 	// 	include: {Rejectuser | ||||
| 	// 		atoll: true, | ||||
| 	// 		island: true, | ||||
| 	// 	}, | ||||
| @@ -87,3 +91,41 @@ export async function getProfileById(userId: string) { | ||||
| 	return handleApiResponse<UserProfile>(response, "getProfilebyId"); | ||||
| } | ||||
|  | ||||
| export async function rejectUser( | ||||
| 	_prevState: RejectUserFormState, | ||||
| 	formData: FormData | ||||
| ): Promise<RejectUserFormState> { | ||||
| 	const userId = formData.get("userId") as string; | ||||
| 	const rejection_details = formData.get("rejection_details") as string; | ||||
| 	const session = await getServerSession(authOptions); | ||||
| 	const response = await fetch( | ||||
| 		`${process.env.SARLINK_API_BASE_URL}/api/auth/users/${userId}/reject/`, | ||||
| 		{ | ||||
| 			method: "DELETE", | ||||
| 			headers: { | ||||
| 				"Content-Type": "application/json", | ||||
| 				Authorization: `Token ${session?.apiToken}`, | ||||
| 			}, | ||||
| 			body: JSON.stringify({ rejection_details: rejection_details }), | ||||
| 		}, | ||||
| 	); | ||||
|  | ||||
| 	if (!response.ok) { | ||||
| 		const errorData = await response.json(); | ||||
| 		throw new Error(errorData.message || errorData.detail || "Failed to reject user"); | ||||
| 	} | ||||
|  | ||||
| 	// Handle 204 No Content response (successful deletion) | ||||
| 	if (response.status === 204) { | ||||
| 		revalidatePath("/users"); | ||||
| 		redirect("/users"); | ||||
| 	} | ||||
|  | ||||
| 	revalidatePath("/users"); | ||||
| 	const error = await response.json() | ||||
| 	return { | ||||
| 		message: (error as ApiError).message || (error as ApiError).detail || "An unexpected error occurred.", | ||||
| 		fieldErrors: {}, | ||||
| 		payload: formData | ||||
| 	}; | ||||
| } | ||||
|   | ||||
		Reference in New Issue
	
	Block a user