mirror of
https://github.com/fosrl/pangolin.git
synced 2026-03-02 16:56:39 +00:00
Scoped Branch - Rule Templates:
- Add rule templates for reusable access control rules - Support template assignment to resources with automatic rule propagation - Add template management UI - Implement template rule protection on resource rules page
This commit is contained in:
60
server/routers/ruleTemplate/deleteRuleTemplate.ts
Normal file
60
server/routers/ruleTemplate/deleteRuleTemplate.ts
Normal file
@@ -0,0 +1,60 @@
|
||||
import { z } from "zod";
|
||||
import { db } from "@server/db";
|
||||
import { ruleTemplates, templateRules, resourceTemplates } from "@server/db";
|
||||
import { eq, and } from "drizzle-orm";
|
||||
import { OpenAPITags } from "@server/openApi";
|
||||
import { generateId } from "@server/auth/sessions/app";
|
||||
|
||||
const deleteRuleTemplateSchema = z.object({
|
||||
orgId: z.string().min(1),
|
||||
templateId: z.string().min(1)
|
||||
});
|
||||
|
||||
export async function deleteRuleTemplate(req: any, res: any) {
|
||||
try {
|
||||
const { orgId, templateId } = deleteRuleTemplateSchema.parse({
|
||||
orgId: req.params.orgId,
|
||||
templateId: req.params.templateId
|
||||
});
|
||||
|
||||
// Check if template exists and belongs to the organization
|
||||
const existingTemplate = await db
|
||||
.select()
|
||||
.from(ruleTemplates)
|
||||
.where(and(eq(ruleTemplates.orgId, orgId), eq(ruleTemplates.templateId, templateId)))
|
||||
.limit(1);
|
||||
|
||||
if (existingTemplate.length === 0) {
|
||||
return res.status(404).json({
|
||||
success: false,
|
||||
message: "Rule template not found"
|
||||
});
|
||||
}
|
||||
|
||||
// Delete template rules first (due to foreign key constraint)
|
||||
await db
|
||||
.delete(templateRules)
|
||||
.where(eq(templateRules.templateId, templateId));
|
||||
|
||||
// Delete resource template assignments
|
||||
await db
|
||||
.delete(resourceTemplates)
|
||||
.where(eq(resourceTemplates.templateId, templateId));
|
||||
|
||||
// Delete the template
|
||||
await db
|
||||
.delete(ruleTemplates)
|
||||
.where(and(eq(ruleTemplates.orgId, orgId), eq(ruleTemplates.templateId, templateId)));
|
||||
|
||||
return res.status(200).json({
|
||||
success: true,
|
||||
message: "Rule template deleted successfully"
|
||||
});
|
||||
} catch (error) {
|
||||
console.error("Error deleting rule template:", error);
|
||||
return res.status(500).json({
|
||||
success: false,
|
||||
message: "Internal server error"
|
||||
});
|
||||
}
|
||||
}
|
||||
Reference in New Issue
Block a user