import { NotFoundError } from "blitz";
import { Queue } from "quirrel/blitz";
import { PaddleSdkSubscriptionPaymentSucceededEvent } from "@devoxa/paddle-sdk";

import db from "db";
import appLogger from "integrations/logger";
import type { Metadata } from "integrations/paddle";
import { translateSubscriptionStatus } from "integrations/paddle";

const logger = appLogger.child({ queue: "subscription-payment-succeeded" });

type Payload = {
	event: PaddleSdkSubscriptionPaymentSucceededEvent<Metadata>;
};

export const subscriptionPaymentSucceededQueue = Queue<Payload>(
	"api/queue/subscription-payment-succeeded",
	async ({ event }) => {
		const paddleSubscriptionId = event.subscriptionId;
		const subscription = await db.subscription.findFirst({ where: { paddleSubscriptionId } });
		if (!subscription) {
			throw new NotFoundError();
		}

		const lastEventTime = event.eventTime;
		const isEventOlderThanLastUpdate = subscription.lastEventTime > lastEventTime;
		if (isEventOlderThanLastUpdate) {
			return;
		}

		await db.subscription.update({
			where: { paddleSubscriptionId },
			data: {
				paddleSubscriptionId,
				paddlePlanId: event.productId,
				paddleCheckoutId: event.checkoutId,
				nextBillDate: event.nextPaymentDate,
				status: translateSubscriptionStatus(event.status),
				lastEventTime,
				currency: event.currency,
				unitPrice: event.unitPrice,
			},
		});
	},
	{ retry: ["30s", "1m", "5m"] },
);

export default subscriptionPaymentSucceededQueue;