fix(web): workflow org visibility issues
This commit is contained in:
parent
8190740abf
commit
40d9060fda
@ -18,6 +18,7 @@ import {
|
|||||||
import { getRelativeTime } from "@/lib/getRelativeTime";
|
import { getRelativeTime } from "@/lib/getRelativeTime";
|
||||||
import { getMachines } from "@/server/curdMachine";
|
import { getMachines } from "@/server/curdMachine";
|
||||||
import { findFirstTableWithVersion } from "@/server/findFirstTableWithVersion";
|
import { findFirstTableWithVersion } from "@/server/findFirstTableWithVersion";
|
||||||
|
import { redirect } from "next/navigation";
|
||||||
|
|
||||||
export default async function Page({
|
export default async function Page({
|
||||||
params,
|
params,
|
||||||
|
@ -15,8 +15,8 @@ export default async function Layout({
|
|||||||
{workflow}
|
{workflow}
|
||||||
{deployment}
|
{deployment}
|
||||||
</div>
|
</div>
|
||||||
|
|
||||||
{runs}
|
{runs}
|
||||||
|
{children}
|
||||||
</div>
|
</div>
|
||||||
);
|
);
|
||||||
}
|
}
|
||||||
|
13
web/src/app/(app)/workflows/[workflow_id]/page.tsx
Normal file
13
web/src/app/(app)/workflows/[workflow_id]/page.tsx
Normal file
@ -0,0 +1,13 @@
|
|||||||
|
import { findWorkflowById } from "@/server/findFirstTableWithVersion";
|
||||||
|
import { redirect } from "next/navigation";
|
||||||
|
|
||||||
|
export default async function Page({
|
||||||
|
params,
|
||||||
|
}: {
|
||||||
|
params: { workflow_id: string };
|
||||||
|
}) {
|
||||||
|
const workflow = await findWorkflowById(params.workflow_id);
|
||||||
|
if (!workflow) redirect("/workflows");
|
||||||
|
|
||||||
|
return <></>;
|
||||||
|
}
|
@ -1,10 +1,35 @@
|
|||||||
import { db } from "@/db/db";
|
import { db } from "@/db/db";
|
||||||
import { workflowTable, workflowVersionTable } from "@/db/schema";
|
import { workflowTable, workflowVersionTable } from "@/db/schema";
|
||||||
import { desc, eq } from "drizzle-orm";
|
import { auth } from "@clerk/nextjs";
|
||||||
|
import { and, desc, eq, isNull } from "drizzle-orm";
|
||||||
|
|
||||||
export async function findFirstTableWithVersion(workflow_id: string) {
|
export async function findFirstTableWithVersion(workflow_id: string) {
|
||||||
|
const { userId, orgId } = auth();
|
||||||
|
if (!userId) throw new Error("No auth");
|
||||||
return await db.query.workflowTable.findFirst({
|
return await db.query.workflowTable.findFirst({
|
||||||
with: { versions: { orderBy: desc(workflowVersionTable.version) } },
|
with: { versions: { orderBy: desc(workflowVersionTable.version) } },
|
||||||
where: eq(workflowTable.id, workflow_id),
|
where: and(
|
||||||
|
eq(workflowTable.id, workflow_id),
|
||||||
|
orgId
|
||||||
|
? eq(workflowTable.org_id, orgId)
|
||||||
|
: and(eq(workflowTable.user_id, userId), isNull(workflowTable.org_id))
|
||||||
|
),
|
||||||
|
});
|
||||||
|
}
|
||||||
|
|
||||||
|
export function findWorkflowById(workflow_id: string) {
|
||||||
|
const { userId, orgId } = auth();
|
||||||
|
if (!userId) throw new Error("No auth");
|
||||||
|
|
||||||
|
return db.query.workflowTable.findFirst({
|
||||||
|
columns: {
|
||||||
|
id: true,
|
||||||
|
},
|
||||||
|
where: and(
|
||||||
|
eq(workflowTable.id, workflow_id),
|
||||||
|
orgId
|
||||||
|
? eq(workflowTable.org_id, orgId)
|
||||||
|
: and(eq(workflowTable.user_id, userId), isNull(workflowTable.org_id))
|
||||||
|
),
|
||||||
});
|
});
|
||||||
}
|
}
|
||||||
|
Loading…
x
Reference in New Issue
Block a user