Files
Nas-Notification/server/api/notifications/templates/[id]/versions/[versionId]/restore.post.js

231 lines
7.0 KiB
JavaScript

import prisma from "~/server/utils/prisma";
export default defineEventHandler(async (event) => {
try {
// Get template ID and version ID from route parameters
const templateId = getRouterParam(event, "id");
const versionId = getRouterParam(event, "versionId");
if (!templateId || !versionId) {
throw createError({
statusCode: 400,
statusMessage: "Template ID and Version ID are required",
});
}
console.log(`Restoring version ${versionId} for template ${templateId}`);
// Get current user (assuming auth middleware provides this)
const user = event.context.user;
if (!user || !user.userID) {
throw createError({
statusCode: 401,
statusMessage: "Authentication required",
});
}
// Check if template exists
const template = await prisma.notification_templates.findUnique({
where: { id: templateId }
});
if (!template) {
throw createError({
statusCode: 404,
statusMessage: "Template not found",
});
}
// Check if version exists
const version = await prisma.notification_template_versions.findUnique({
where: { id: versionId }
});
if (!version || version.template_id !== templateId) {
throw createError({
statusCode: 404,
statusMessage: "Version not found",
});
}
// Generate new version number (increment current version)
const currentVersion = template.version || "1.0";
const versionParts = currentVersion.split('.');
const majorVersion = parseInt(versionParts[0]) || 1;
const minorVersion = parseInt(versionParts[1]) || 0;
const newVersion = `${majorVersion}.${minorVersion + 1}`;
// Create version history entry for current template state before restore
await prisma.notification_template_versions.create({
data: {
template_id: templateId,
version: currentVersion,
name: template.name,
description: template.description,
subject: template.subject,
preheader: template.preheader,
email_content: template.email_content,
push_title: template.push_title,
push_body: template.push_body,
push_icon: template.push_icon,
push_url: template.push_url,
sms_content: template.sms_content,
category: template.category,
channels: template.channels,
status: template.status,
tags: template.tags,
is_personal: template.is_personal,
from_name: template.from_name,
reply_to: template.reply_to,
track_opens: template.track_opens,
variables: template.variables,
is_active: template.is_active,
change_description: `Automatic backup before restoring version ${version.version}`,
is_current: false,
created_by: user.userID.toString(),
}
});
// Update the current template with the version data
const updatedTemplate = await prisma.notification_templates.update({
where: { id: templateId },
data: {
name: version.name,
description: version.description,
subject: version.subject,
preheader: version.preheader,
email_content: version.email_content,
push_title: version.push_title,
push_body: version.push_body,
push_icon: version.push_icon,
push_url: version.push_url,
sms_content: version.sms_content,
category: version.category,
channels: version.channels,
status: version.status,
tags: version.tags,
is_personal: version.is_personal,
from_name: version.from_name,
reply_to: version.reply_to,
track_opens: version.track_opens,
variables: version.variables,
is_active: version.is_active,
version: newVersion,
updated_by: user.userID.toString(),
updated_at: new Date(),
}
});
// Create version history entry for the restored version
await prisma.notification_template_versions.create({
data: {
template_id: templateId,
version: newVersion,
name: version.name,
description: version.description,
subject: version.subject,
preheader: version.preheader,
email_content: version.email_content,
push_title: version.push_title,
push_body: version.push_body,
push_icon: version.push_icon,
push_url: version.push_url,
sms_content: version.sms_content,
category: version.category,
channels: version.channels,
status: version.status,
tags: version.tags,
is_personal: version.is_personal,
from_name: version.from_name,
reply_to: version.reply_to,
track_opens: version.track_opens,
variables: version.variables,
is_active: version.is_active,
change_description: `Restored from version ${version.version}`,
is_current: true,
created_by: user.userID.toString(),
}
});
// Mark previous current version as not current
await prisma.notification_template_versions.updateMany({
where: {
template_id: templateId,
is_current: true,
version: { not: newVersion }
},
data: {
is_current: false
}
});
console.log(`Version ${version.version} restored successfully as version ${newVersion}`);
// Return success response
return {
success: true,
data: {
message: `Version ${version.version} has been restored successfully as version ${newVersion}`,
templateId,
restoredVersion: version.version,
newVersion,
template: {
id: updatedTemplate.id,
title: updatedTemplate.name,
version: updatedTemplate.version,
updatedAt: updatedTemplate.updated_at
}
}
};
} catch (error) {
console.error("Version restore error:", error);
console.error("Error details:", {
message: error.message,
stack: error.stack,
cause: error.cause,
code: error.code,
statusCode: error.statusCode
});
// Handle Prisma errors
if (error.code && error.code.startsWith('P')) {
console.error("Prisma error code:", error.code);
if (error.code === 'P2025') {
throw createError({
statusCode: 404,
statusMessage: "Template or version not found",
data: {
error: "The template or version you're looking for does not exist.",
code: error.code
}
});
}
throw createError({
statusCode: 400,
statusMessage: "Database operation failed",
data: {
error: error.message,
code: error.code
}
});
}
// Handle known errors with status codes
if (error.statusCode) {
throw error;
}
// Generic server error
throw createError({
statusCode: 500,
statusMessage: "Failed to restore version",
data: {
error: error.message
}
});
} finally {
}
});