mirror of
https://github.com/fosrl/pangolin.git
synced 2026-06-17 12:57:17 +00:00
fix: update resource rule routes to use shared policy rules
This commit is contained in:
committed by
GitHub
parent
b6862093d1
commit
0d960181a2
@@ -154,12 +154,8 @@ export async function createResourceRule(
|
|||||||
}
|
}
|
||||||
|
|
||||||
// Create the new resource rule
|
// Create the new resource rule
|
||||||
const isInlinePolicy =
|
if (resource.resourcePolicyId !== null) {
|
||||||
resource.resourcePolicyId === null &&
|
const policyId = resource.resourcePolicyId;
|
||||||
resource.defaultResourcePolicyId !== null;
|
|
||||||
|
|
||||||
if (isInlinePolicy) {
|
|
||||||
const policyId = resource.defaultResourcePolicyId!;
|
|
||||||
const [newRule] = await db
|
const [newRule] = await db
|
||||||
.insert(resourcePolicyRules)
|
.insert(resourcePolicyRules)
|
||||||
.values({
|
.values({
|
||||||
|
|||||||
@@ -2,7 +2,7 @@ import { Request, Response, NextFunction } from "express";
|
|||||||
import { z } from "zod";
|
import { z } from "zod";
|
||||||
import { db } from "@server/db";
|
import { db } from "@server/db";
|
||||||
import { resourceRules, resourcePolicyRules, resources } from "@server/db";
|
import { resourceRules, resourcePolicyRules, resources } from "@server/db";
|
||||||
import { eq } from "drizzle-orm";
|
import { and, eq } from "drizzle-orm";
|
||||||
import response from "@server/lib/response";
|
import response from "@server/lib/response";
|
||||||
import HttpCode from "@server/types/HttpCode";
|
import HttpCode from "@server/types/HttpCode";
|
||||||
import createHttpError from "http-errors";
|
import createHttpError from "http-errors";
|
||||||
@@ -73,14 +73,16 @@ export async function deleteResourceRule(
|
|||||||
);
|
);
|
||||||
}
|
}
|
||||||
|
|
||||||
const isInlinePolicy =
|
if (resource.resourcePolicyId !== null) {
|
||||||
resource.resourcePolicyId === null &&
|
const policyId = resource.resourcePolicyId;
|
||||||
resource.defaultResourcePolicyId !== null;
|
|
||||||
|
|
||||||
if (isInlinePolicy) {
|
|
||||||
const [deletedRule] = await db
|
const [deletedRule] = await db
|
||||||
.delete(resourcePolicyRules)
|
.delete(resourcePolicyRules)
|
||||||
.where(eq(resourcePolicyRules.ruleId, ruleId))
|
.where(
|
||||||
|
and(
|
||||||
|
eq(resourcePolicyRules.ruleId, ruleId),
|
||||||
|
eq(resourcePolicyRules.resourcePolicyId, policyId)
|
||||||
|
)
|
||||||
|
)
|
||||||
.returning();
|
.returning();
|
||||||
|
|
||||||
if (!deletedRule) {
|
if (!deletedRule) {
|
||||||
|
|||||||
@@ -141,16 +141,10 @@ export async function getResource(
|
|||||||
);
|
);
|
||||||
}
|
}
|
||||||
|
|
||||||
const isInlinePolicy =
|
|
||||||
resource.resourcePolicyId === null &&
|
|
||||||
resource.defaultResourcePolicyId !== null;
|
|
||||||
|
|
||||||
let returnData = resource;
|
let returnData = resource;
|
||||||
if (isInlinePolicy) {
|
if (resource.resourcePolicyId !== null) {
|
||||||
// get the policy
|
// get the policy
|
||||||
const policy = await queryInlinePolicy(
|
const policy = await queryInlinePolicy(resource.resourcePolicyId);
|
||||||
resource.defaultResourcePolicyId!
|
|
||||||
);
|
|
||||||
returnData = {
|
returnData = {
|
||||||
...returnData,
|
...returnData,
|
||||||
sso: policy?.sso || null,
|
sso: policy?.sso || null,
|
||||||
|
|||||||
@@ -140,15 +140,11 @@ export async function listResourceRules(
|
|||||||
);
|
);
|
||||||
}
|
}
|
||||||
|
|
||||||
const isInlinePolicy =
|
|
||||||
resource.resourcePolicyId === null &&
|
|
||||||
resource.defaultResourcePolicyId !== null;
|
|
||||||
|
|
||||||
let rulesList: Awaited<ReturnType<typeof queryResourceRules>>;
|
let rulesList: Awaited<ReturnType<typeof queryResourceRules>>;
|
||||||
let totalCount: number;
|
let totalCount: number;
|
||||||
|
|
||||||
if (isInlinePolicy) {
|
if (resource.resourcePolicyId !== null) {
|
||||||
const policyId = resource.defaultResourcePolicyId!;
|
const policyId = resource.resourcePolicyId;
|
||||||
const policyRules = await queryPolicyRules(policyId)
|
const policyRules = await queryPolicyRules(policyId)
|
||||||
.limit(limit)
|
.limit(limit)
|
||||||
.offset(offset);
|
.offset(offset);
|
||||||
|
|||||||
@@ -1,8 +1,8 @@
|
|||||||
import { Request, Response, NextFunction } from "express";
|
import { Request, Response, NextFunction } from "express";
|
||||||
import { z } from "zod";
|
import { z } from "zod";
|
||||||
import { db } from "@server/db";
|
import { db } from "@server/db";
|
||||||
import { resourceRules, resources } from "@server/db";
|
import { resourcePolicyRules, resourceRules, resources } from "@server/db";
|
||||||
import { eq } from "drizzle-orm";
|
import { and, eq } from "drizzle-orm";
|
||||||
import response from "@server/lib/response";
|
import response from "@server/lib/response";
|
||||||
import HttpCode from "@server/types/HttpCode";
|
import HttpCode from "@server/types/HttpCode";
|
||||||
import createHttpError from "http-errors";
|
import createHttpError from "http-errors";
|
||||||
@@ -128,6 +128,92 @@ export async function updateResourceRule(
|
|||||||
);
|
);
|
||||||
}
|
}
|
||||||
|
|
||||||
|
const policyId = resource.resourcePolicyId;
|
||||||
|
|
||||||
|
if (policyId !== null) {
|
||||||
|
const [existingRule] = await db
|
||||||
|
.select()
|
||||||
|
.from(resourcePolicyRules)
|
||||||
|
.where(
|
||||||
|
and(
|
||||||
|
eq(resourcePolicyRules.ruleId, ruleId),
|
||||||
|
eq(resourcePolicyRules.resourcePolicyId, policyId)
|
||||||
|
)
|
||||||
|
)
|
||||||
|
.limit(1);
|
||||||
|
|
||||||
|
if (!existingRule) {
|
||||||
|
return next(
|
||||||
|
createHttpError(
|
||||||
|
HttpCode.NOT_FOUND,
|
||||||
|
`Resource rule with ID ${ruleId} not found`
|
||||||
|
)
|
||||||
|
);
|
||||||
|
}
|
||||||
|
|
||||||
|
const match = updateData.match || existingRule.match;
|
||||||
|
const { value } = updateData;
|
||||||
|
|
||||||
|
if (value !== undefined) {
|
||||||
|
if (match === "CIDR") {
|
||||||
|
if (!isValidCIDR(value)) {
|
||||||
|
return next(
|
||||||
|
createHttpError(
|
||||||
|
HttpCode.BAD_REQUEST,
|
||||||
|
"Invalid CIDR provided"
|
||||||
|
)
|
||||||
|
);
|
||||||
|
}
|
||||||
|
} else if (match === "IP") {
|
||||||
|
if (!isValidIP(value)) {
|
||||||
|
return next(
|
||||||
|
createHttpError(
|
||||||
|
HttpCode.BAD_REQUEST,
|
||||||
|
"Invalid IP provided"
|
||||||
|
)
|
||||||
|
);
|
||||||
|
}
|
||||||
|
} else if (match === "PATH") {
|
||||||
|
if (!isValidUrlGlobPattern(value)) {
|
||||||
|
return next(
|
||||||
|
createHttpError(
|
||||||
|
HttpCode.BAD_REQUEST,
|
||||||
|
"Invalid URL glob pattern provided"
|
||||||
|
)
|
||||||
|
);
|
||||||
|
}
|
||||||
|
} else if (match === "REGION") {
|
||||||
|
if (!isValidRegionId(value)) {
|
||||||
|
return next(
|
||||||
|
createHttpError(
|
||||||
|
HttpCode.BAD_REQUEST,
|
||||||
|
"Invalid region ID provided"
|
||||||
|
)
|
||||||
|
);
|
||||||
|
}
|
||||||
|
}
|
||||||
|
}
|
||||||
|
|
||||||
|
const [updatedRule] = await db
|
||||||
|
.update(resourcePolicyRules)
|
||||||
|
.set(updateData)
|
||||||
|
.where(
|
||||||
|
and(
|
||||||
|
eq(resourcePolicyRules.ruleId, ruleId),
|
||||||
|
eq(resourcePolicyRules.resourcePolicyId, policyId)
|
||||||
|
)
|
||||||
|
)
|
||||||
|
.returning();
|
||||||
|
|
||||||
|
return response(res, {
|
||||||
|
data: updatedRule,
|
||||||
|
success: true,
|
||||||
|
error: false,
|
||||||
|
message: "Resource rule updated successfully",
|
||||||
|
status: HttpCode.OK
|
||||||
|
});
|
||||||
|
}
|
||||||
|
|
||||||
// Verify that the rule exists and belongs to the specified resource
|
// Verify that the rule exists and belongs to the specified resource
|
||||||
const [existingRule] = await db
|
const [existingRule] = await db
|
||||||
.select()
|
.select()
|
||||||
|
|||||||
Reference in New Issue
Block a user