mirror of
https://github.com/Dokploy/dokploy.git
synced 2026-06-16 04:35:24 +02:00
353 lines
7.2 KiB
TypeScript
353 lines
7.2 KiB
TypeScript
import { db } from "@dokploy/server/db";
|
|
import { apikey, member, users_temp } from "@dokploy/server/db/schema";
|
|
import { TRPCError } from "@trpc/server";
|
|
import { and, eq } from "drizzle-orm";
|
|
import { auth } from "../lib/auth";
|
|
|
|
export type User = typeof users_temp.$inferSelect;
|
|
|
|
export const addNewProject = async (
|
|
userId: string,
|
|
projectId: string,
|
|
organizationId: string,
|
|
) => {
|
|
const userR = await findMemberById(userId, organizationId);
|
|
|
|
await db
|
|
.update(member)
|
|
.set({
|
|
accessedProjects: [...userR.accessedProjects, projectId],
|
|
})
|
|
.where(
|
|
and(eq(member.id, userR.id), eq(member.organizationId, organizationId)),
|
|
);
|
|
};
|
|
|
|
export const addNewEnvironment = async (
|
|
userId: string,
|
|
environmentId: string,
|
|
organizationId: string,
|
|
) => {
|
|
const userR = await findMemberById(userId, organizationId);
|
|
|
|
await db
|
|
.update(member)
|
|
.set({
|
|
accessedEnvironments: [...userR.accessedEnvironments, environmentId],
|
|
})
|
|
.where(
|
|
and(eq(member.id, userR.id), eq(member.organizationId, organizationId)),
|
|
);
|
|
};
|
|
|
|
export const addNewService = async (
|
|
userId: string,
|
|
serviceId: string,
|
|
organizationId: string,
|
|
) => {
|
|
const userR = await findMemberById(userId, organizationId);
|
|
await db
|
|
.update(member)
|
|
.set({
|
|
accessedServices: [...userR.accessedServices, serviceId],
|
|
})
|
|
.where(
|
|
and(eq(member.id, userR.id), eq(member.organizationId, organizationId)),
|
|
);
|
|
};
|
|
|
|
export const canPerformCreationService = async (
|
|
userId: string,
|
|
projectId: string,
|
|
organizationId: string,
|
|
) => {
|
|
const { accessedProjects, canCreateServices } = await findMemberById(
|
|
userId,
|
|
organizationId,
|
|
);
|
|
const haveAccessToProject = accessedProjects.includes(projectId);
|
|
|
|
if (canCreateServices && haveAccessToProject) {
|
|
return true;
|
|
}
|
|
|
|
return false;
|
|
};
|
|
|
|
export const canPerformAccessService = async (
|
|
userId: string,
|
|
serviceId: string,
|
|
organizationId: string,
|
|
) => {
|
|
const { accessedServices } = await findMemberById(userId, organizationId);
|
|
const haveAccessToService = accessedServices.includes(serviceId);
|
|
|
|
if (haveAccessToService) {
|
|
return true;
|
|
}
|
|
|
|
return false;
|
|
};
|
|
|
|
export const canPeformDeleteService = async (
|
|
userId: string,
|
|
serviceId: string,
|
|
organizationId: string,
|
|
) => {
|
|
const { accessedServices, canDeleteServices } = await findMemberById(
|
|
userId,
|
|
organizationId,
|
|
);
|
|
const haveAccessToService = accessedServices.includes(serviceId);
|
|
|
|
if (canDeleteServices && haveAccessToService) {
|
|
return true;
|
|
}
|
|
|
|
return false;
|
|
};
|
|
|
|
export const canPerformCreationProject = async (
|
|
userId: string,
|
|
organizationId: string,
|
|
) => {
|
|
const { canCreateProjects } = await findMemberById(userId, organizationId);
|
|
|
|
if (canCreateProjects) {
|
|
return true;
|
|
}
|
|
|
|
return false;
|
|
};
|
|
|
|
export const canPerformDeleteProject = async (
|
|
userId: string,
|
|
organizationId: string,
|
|
) => {
|
|
const { canDeleteProjects } = await findMemberById(userId, organizationId);
|
|
|
|
if (canDeleteProjects) {
|
|
return true;
|
|
}
|
|
|
|
return false;
|
|
};
|
|
|
|
export const canPerformAccessProject = async (
|
|
userId: string,
|
|
projectId: string,
|
|
organizationId: string,
|
|
) => {
|
|
const { accessedProjects } = await findMemberById(userId, organizationId);
|
|
|
|
const haveAccessToProject = accessedProjects.includes(projectId);
|
|
|
|
if (haveAccessToProject) {
|
|
return true;
|
|
}
|
|
return false;
|
|
};
|
|
|
|
export const canPerformAccessEnvironment = async (
|
|
userId: string,
|
|
environmentId: string,
|
|
organizationId: string,
|
|
) => {
|
|
const { accessedEnvironments } = await findMemberById(userId, organizationId);
|
|
const haveAccessToEnvironment = accessedEnvironments.includes(environmentId);
|
|
|
|
if (haveAccessToEnvironment) {
|
|
return true;
|
|
}
|
|
|
|
return false;
|
|
};
|
|
|
|
export const canAccessToTraefikFiles = async (
|
|
userId: string,
|
|
organizationId: string,
|
|
) => {
|
|
const { canAccessToTraefikFiles } = await findMemberById(
|
|
userId,
|
|
organizationId,
|
|
);
|
|
return canAccessToTraefikFiles;
|
|
};
|
|
|
|
export const checkServiceAccess = async (
|
|
userId: string,
|
|
serviceId: string,
|
|
organizationId: string,
|
|
action = "access" as "access" | "create" | "delete",
|
|
) => {
|
|
let hasPermission = false;
|
|
switch (action) {
|
|
case "create":
|
|
hasPermission = await canPerformCreationService(
|
|
userId,
|
|
serviceId,
|
|
organizationId,
|
|
);
|
|
break;
|
|
case "access":
|
|
hasPermission = await canPerformAccessService(
|
|
userId,
|
|
serviceId,
|
|
organizationId,
|
|
);
|
|
break;
|
|
case "delete":
|
|
hasPermission = await canPeformDeleteService(
|
|
userId,
|
|
serviceId,
|
|
organizationId,
|
|
);
|
|
break;
|
|
default:
|
|
hasPermission = false;
|
|
}
|
|
if (!hasPermission) {
|
|
throw new TRPCError({
|
|
code: "UNAUTHORIZED",
|
|
message: "Permission denied",
|
|
});
|
|
}
|
|
};
|
|
|
|
export const checkEnvironmentAccess = async (
|
|
userId: string,
|
|
environmentId: string,
|
|
organizationId: string,
|
|
action = "access" as const,
|
|
) => {
|
|
let hasPermission = false;
|
|
switch (action) {
|
|
case "access":
|
|
hasPermission = await canPerformAccessEnvironment(
|
|
userId,
|
|
environmentId,
|
|
organizationId,
|
|
);
|
|
break;
|
|
default:
|
|
hasPermission = false;
|
|
}
|
|
if (!hasPermission) {
|
|
throw new TRPCError({
|
|
code: "UNAUTHORIZED",
|
|
message: "Permission denied",
|
|
});
|
|
}
|
|
};
|
|
|
|
export const checkProjectAccess = async (
|
|
authId: string,
|
|
action: "create" | "delete" | "access",
|
|
organizationId: string,
|
|
projectId?: string,
|
|
) => {
|
|
let hasPermission = false;
|
|
switch (action) {
|
|
case "access":
|
|
hasPermission = await canPerformAccessProject(
|
|
authId,
|
|
projectId as string,
|
|
organizationId,
|
|
);
|
|
break;
|
|
case "create":
|
|
hasPermission = await canPerformCreationProject(authId, organizationId);
|
|
break;
|
|
case "delete":
|
|
hasPermission = await canPerformDeleteProject(authId, organizationId);
|
|
break;
|
|
default:
|
|
hasPermission = false;
|
|
}
|
|
if (!hasPermission) {
|
|
throw new TRPCError({
|
|
code: "UNAUTHORIZED",
|
|
message: "Permission denied",
|
|
});
|
|
}
|
|
};
|
|
|
|
export const findMemberById = async (
|
|
userId: string,
|
|
organizationId: string,
|
|
) => {
|
|
const result = await db.query.member.findFirst({
|
|
where: and(
|
|
eq(member.userId, userId),
|
|
eq(member.organizationId, organizationId),
|
|
),
|
|
with: {
|
|
user: true,
|
|
},
|
|
});
|
|
|
|
if (!result) {
|
|
throw new TRPCError({
|
|
code: "UNAUTHORIZED",
|
|
message: "Permission denied",
|
|
});
|
|
}
|
|
return result;
|
|
};
|
|
|
|
export const updateUser = async (userId: string, userData: Partial<User>) => {
|
|
const user = await db
|
|
.update(users_temp)
|
|
.set({
|
|
...userData,
|
|
})
|
|
.where(eq(users_temp.id, userId))
|
|
.returning()
|
|
.then((res) => res[0]);
|
|
|
|
return user;
|
|
};
|
|
|
|
export const createApiKey = async (
|
|
userId: string,
|
|
input: {
|
|
name: string;
|
|
prefix?: string;
|
|
expiresIn?: number;
|
|
metadata: {
|
|
organizationId: string;
|
|
};
|
|
rateLimitEnabled?: boolean;
|
|
rateLimitTimeWindow?: number;
|
|
rateLimitMax?: number;
|
|
remaining?: number;
|
|
refillAmount?: number;
|
|
refillInterval?: number;
|
|
},
|
|
) => {
|
|
const apiKey = await auth.createApiKey({
|
|
body: {
|
|
name: input.name,
|
|
expiresIn: input.expiresIn,
|
|
prefix: input.prefix,
|
|
rateLimitEnabled: input.rateLimitEnabled,
|
|
rateLimitTimeWindow: input.rateLimitTimeWindow,
|
|
rateLimitMax: input.rateLimitMax,
|
|
remaining: input.remaining,
|
|
refillAmount: input.refillAmount,
|
|
refillInterval: input.refillInterval,
|
|
userId,
|
|
},
|
|
});
|
|
|
|
if (input.metadata) {
|
|
await db
|
|
.update(apikey)
|
|
.set({
|
|
metadata: JSON.stringify(input.metadata),
|
|
})
|
|
.where(eq(apikey.id, apiKey.id));
|
|
}
|
|
return apiKey;
|
|
};
|