mirror of
https://github.com/i701/sarlink-portal.git
synced 2025-02-22 17:42:00 +00:00
- Added new omada-actions.ts file to handle fetching and updating device groups in Omada. - Updated authMiddleware to include new payment routes. - Enhanced createPayment function to add devices to a group upon successful payment verification. - Improved payment verification process to include device management. - Refactored PaymentsTable and DevicesToPay components for better UI and state handling. - Removed unused hasSession function from auth-guard.ts for cleaner code.
95 lines
1.9 KiB
TypeScript
95 lines
1.9 KiB
TypeScript
"use server";
|
|
|
|
import prisma from "@/lib/db";
|
|
import type { PaymentType } from "@/lib/types";
|
|
import { revalidatePath } from "next/cache";
|
|
import { addDevicesToGroup } from "./omada-actions";
|
|
|
|
export async function createPayment(data: PaymentType) {
|
|
console.log("data", data);
|
|
const payment = await prisma.payment.create({
|
|
data: {
|
|
amount: data.amount,
|
|
numberOfMonths: data.numberOfMonths,
|
|
paid: data.paid,
|
|
userId: data.userId,
|
|
devices: {
|
|
connect: data.deviceIds.map((id) => {
|
|
return {
|
|
id,
|
|
};
|
|
}),
|
|
},
|
|
},
|
|
});
|
|
revalidatePath("/devices");
|
|
return payment;
|
|
}
|
|
|
|
type VerifyPaymentType = {
|
|
paymentId?: string;
|
|
benefName: string;
|
|
accountNo?: string;
|
|
absAmount: string;
|
|
time: string;
|
|
};
|
|
|
|
export async function verifyPayment(data: VerifyPaymentType) {
|
|
console.log({ data });
|
|
try {
|
|
const payment = await prisma.payment.findUnique({
|
|
where: {
|
|
id: data.paymentId,
|
|
},
|
|
include: {
|
|
devices: true,
|
|
},
|
|
});
|
|
const response = await fetch(
|
|
"https://verifypaymentsapi.baraveli.dev/verify-payment",
|
|
{
|
|
method: "POST",
|
|
headers: {
|
|
"Content-Type": "application/json",
|
|
},
|
|
body: JSON.stringify(data),
|
|
},
|
|
);
|
|
const json = await response.json();
|
|
console.log(json);
|
|
const newDevices = payment?.devices.map((d) => {
|
|
return {
|
|
name: d.name,
|
|
macAddress: d.mac,
|
|
};
|
|
});
|
|
if (json.success === true) {
|
|
await Promise.all([
|
|
prisma.payment.update({
|
|
where: {
|
|
id: payment?.id,
|
|
},
|
|
data: {
|
|
paid: true,
|
|
},
|
|
}),
|
|
addDevicesToGroup({
|
|
groupId: process.env.OMADA_GROUP_ID,
|
|
omadacId: process.env.OMADA_CID,
|
|
siteId: process.env.OMADA_SITE_ID,
|
|
newDevices: newDevices || [],
|
|
}),
|
|
]);
|
|
}
|
|
|
|
revalidatePath("/payment[paymentId]");
|
|
return json;
|
|
} catch (error) {
|
|
console.error(error);
|
|
}
|
|
}
|
|
|
|
export async function addDevicesToOmada() {
|
|
console.log("hi");
|
|
}
|