admin roadmap done, reupload request, submission history, manual override
This commit is contained in:
@@ -4,7 +4,11 @@ import { getServerSession } from "next-auth";
|
||||
import { revalidatePath } from "next/cache";
|
||||
import { authOptions } from "@/lib/auth";
|
||||
import { isAdminEmail } from "@/lib/admin";
|
||||
import { organizerService } from "@/server/services/organizer.service";
|
||||
import {
|
||||
isReuploadField,
|
||||
organizerService,
|
||||
type ReuploadField,
|
||||
} from "@/server/services/organizer.service";
|
||||
import { auditLog } from "@/server/services/audit-log.service";
|
||||
import { submitVerificationSchema, reviewVerificationSchema } from "./schemas";
|
||||
|
||||
@@ -125,3 +129,81 @@ export async function reopenVerificationAction(
|
||||
return { error: (err as Error).message };
|
||||
}
|
||||
}
|
||||
|
||||
/**
|
||||
* Phase 2: admin minta organizer upload ulang field tertentu — daripada
|
||||
* reject penuh, set flag `reuploadRequested` + daftar field + note.
|
||||
*/
|
||||
export async function requestReuploadAction(
|
||||
verificationId: string,
|
||||
fields: string[],
|
||||
note: string
|
||||
) {
|
||||
const session = await getServerSession(authOptions);
|
||||
if (!session?.user || !isAdminEmail(session.user.email)) {
|
||||
return { error: "Tidak memiliki akses admin" };
|
||||
}
|
||||
const valid = fields.filter(isReuploadField) as ReuploadField[];
|
||||
|
||||
try {
|
||||
await organizerService.requestReupload({
|
||||
verificationId,
|
||||
adminId: session.user.id,
|
||||
fields: valid,
|
||||
note,
|
||||
});
|
||||
await auditLog.record({
|
||||
admin: { id: session.user.id, email: session.user.email },
|
||||
action: "VERIFICATION_REQUEST_REUPLOAD",
|
||||
entityType: "OrganizerVerification",
|
||||
entityId: verificationId,
|
||||
payload: { fields: valid, note: note.trim() },
|
||||
});
|
||||
revalidatePath("/admin/verifications");
|
||||
revalidatePath("/verify");
|
||||
return { success: true as const };
|
||||
} catch (err) {
|
||||
return { error: (err as Error).message };
|
||||
}
|
||||
}
|
||||
|
||||
/**
|
||||
* Phase 4: admin verify user tanpa upload KYC (partner trusted referral).
|
||||
* Bikin row APPROVED dengan flag `isManualOverride = true`.
|
||||
*/
|
||||
export async function manualOverrideVerificationAction(input: {
|
||||
userId: string;
|
||||
note: string;
|
||||
bankName: string;
|
||||
bankAccountNumber: string;
|
||||
bankAccountName: string;
|
||||
}) {
|
||||
const session = await getServerSession(authOptions);
|
||||
if (!session?.user || !isAdminEmail(session.user.email)) {
|
||||
return { error: "Tidak memiliki akses admin" };
|
||||
}
|
||||
|
||||
try {
|
||||
const result = await organizerService.manualOverrideVerification({
|
||||
userId: input.userId,
|
||||
adminId: session.user.id,
|
||||
note: input.note,
|
||||
bankName: input.bankName,
|
||||
bankAccountNumber: input.bankAccountNumber,
|
||||
bankAccountName: input.bankAccountName,
|
||||
});
|
||||
await auditLog.record({
|
||||
admin: { id: session.user.id, email: session.user.email },
|
||||
action: "VERIFICATION_MANUAL_OVERRIDE",
|
||||
entityType: "OrganizerVerification",
|
||||
entityId: result.id,
|
||||
payload: { userId: input.userId, note: input.note.trim() },
|
||||
});
|
||||
revalidatePath("/admin/verifications");
|
||||
revalidatePath(`/admin/users/${input.userId}`);
|
||||
revalidatePath("/verify");
|
||||
return { success: true as const, verificationId: result.id };
|
||||
} catch (err) {
|
||||
return { error: (err as Error).message };
|
||||
}
|
||||
}
|
||||
|
||||
Reference in New Issue
Block a user