mirror of
https://github.com/Dokploy/dokploy
synced 2025-06-26 18:27:59 +00:00
* refactor: add sidebar * chore: add deps * refactor: update sidebar * refactor: another layout * refactor: update variant * refactor: change layout * refactor: change variant * refactor: enhance sidebar navigation with active state management * feat: add project button to dashboard * Merge branch 'canary' into feat/add-sidebar * refactor: add loader * refactor: update destinations and refactor * refactor: ui refactor certificates * refactor: delete unused files * refactor: remove unused files and duplicate registry * refactor: update style registry * refactor: add new design registry * refactor: enhance git providers * refactor: remove duplicate files * refactor: update * refactor: update users * refactor: delete unused files * refactor: update profile * refactor: apply changes * refactor: update UI * refactor: enhance Docker monitoring UI layout * refactor: add theme toggle and language selection to user navigation (#1083) * refactor: remove unused files * feat: add filter to services * refactor: add active items * refactor: remove tab prop * refactor: remove unused files * refactor: remove duplicated files * refactor: remove unused files * refactor: remove duplicate files * refactor: remove unused files * refactor: delete unused files * refactor: remove unsued files * refactor: delete unused files * refactor: lint * refactor: remove unused secuirty * refactor: delete unused files * refactor: delete unused files * remove imports * refactor: add update button * refactor: delete unused files * refactor: remove unused code * refactor: remove unused files * refactor: update login page * refactor: update login UI * refactor: update ui reset password * refactor: add justify end * feat: add suscriptions * feat: add sheet * feat: add logs for postgres * feat: add logs for all databases * feat: add server logs with drawer logs * refactor: remove unused files * refactor: add refetch when closing * refactor: fix linter * chore: bump node-20 * revert * refactor: fix conflicts * refactor: update * refactor: add missing deps * refactor: delete duplicate files * refactor: delete unsued files * chore: lint * refactor: remove unsued file * refactor: add refetch * refactor: remove duplicated files * refactor: delete unused files * refactor: update setup onboarding * refactor: add breadcrumb * refactor: apply updates * refactor: add faker * refactor: use 0 in validation * refactor: show correct state * refactor: update --------- Co-authored-by: vishalkadam47 <vishal@jeevops.com> Co-authored-by: Vishal kadam <107353260+vishalkadam47@users.noreply.github.com>
131 lines
3.0 KiB
TypeScript
131 lines
3.0 KiB
TypeScript
import { db } from "@dokploy/server/db";
|
|
import { type apiCreateRedis, redis } from "@dokploy/server/db/schema";
|
|
import { buildAppName, cleanAppName } from "@dokploy/server/db/schema";
|
|
import { generatePassword } from "@dokploy/server/templates/utils";
|
|
import { buildRedis } from "@dokploy/server/utils/databases/redis";
|
|
import { pullImage } from "@dokploy/server/utils/docker/utils";
|
|
import { TRPCError } from "@trpc/server";
|
|
import { eq } from "drizzle-orm";
|
|
import { validUniqueServerAppName } from "./project";
|
|
|
|
import { execAsyncRemote } from "@dokploy/server/utils/process/execAsync";
|
|
|
|
export type Redis = typeof redis.$inferSelect;
|
|
|
|
// https://github.com/drizzle-team/drizzle-orm/discussions/1483#discussioncomment-7523881
|
|
export const createRedis = async (input: typeof apiCreateRedis._type) => {
|
|
const appName = buildAppName("redis", input.appName);
|
|
|
|
const valid = await validUniqueServerAppName(appName);
|
|
if (!valid) {
|
|
throw new TRPCError({
|
|
code: "CONFLICT",
|
|
message: "Service with this 'AppName' already exists",
|
|
});
|
|
}
|
|
|
|
const newRedis = await db
|
|
.insert(redis)
|
|
.values({
|
|
...input,
|
|
databasePassword: input.databasePassword
|
|
? input.databasePassword
|
|
: generatePassword(),
|
|
appName,
|
|
})
|
|
.returning()
|
|
.then((value) => value[0]);
|
|
|
|
if (!newRedis) {
|
|
throw new TRPCError({
|
|
code: "BAD_REQUEST",
|
|
message: "Error input: Inserting redis database",
|
|
});
|
|
}
|
|
|
|
return newRedis;
|
|
};
|
|
|
|
export const findRedisById = async (redisId: string) => {
|
|
const result = await db.query.redis.findFirst({
|
|
where: eq(redis.redisId, redisId),
|
|
with: {
|
|
project: true,
|
|
mounts: true,
|
|
server: true,
|
|
},
|
|
});
|
|
if (!result) {
|
|
throw new TRPCError({
|
|
code: "NOT_FOUND",
|
|
message: "Redis not found",
|
|
});
|
|
}
|
|
return result;
|
|
};
|
|
|
|
export const updateRedisById = async (
|
|
redisId: string,
|
|
redisData: Partial<Redis>,
|
|
) => {
|
|
const { appName, ...rest } = redisData;
|
|
const result = await db
|
|
.update(redis)
|
|
.set({
|
|
...rest,
|
|
})
|
|
.where(eq(redis.redisId, redisId))
|
|
.returning();
|
|
|
|
return result[0];
|
|
};
|
|
|
|
export const removeRedisById = async (redisId: string) => {
|
|
const result = await db
|
|
.delete(redis)
|
|
.where(eq(redis.redisId, redisId))
|
|
.returning();
|
|
|
|
return result[0];
|
|
};
|
|
|
|
export const deployRedis = async (
|
|
redisId: string,
|
|
onData?: (data: any) => void,
|
|
) => {
|
|
const redis = await findRedisById(redisId);
|
|
try {
|
|
await updateRedisById(redisId, {
|
|
applicationStatus: "running",
|
|
});
|
|
|
|
onData?.("Starting redis deployment...");
|
|
if (redis.serverId) {
|
|
await execAsyncRemote(
|
|
redis.serverId,
|
|
`docker pull ${redis.dockerImage}`,
|
|
onData,
|
|
);
|
|
} else {
|
|
await pullImage(redis.dockerImage, onData);
|
|
}
|
|
|
|
await buildRedis(redis);
|
|
await updateRedisById(redisId, {
|
|
applicationStatus: "done",
|
|
});
|
|
onData?.("Deployment completed successfully!");
|
|
} catch (error) {
|
|
onData?.(`Error: ${error}`);
|
|
await updateRedisById(redisId, {
|
|
applicationStatus: "error",
|
|
});
|
|
|
|
throw new TRPCError({
|
|
code: "INTERNAL_SERVER_ERROR",
|
|
message: `Error on deploy redis${error}`,
|
|
});
|
|
}
|
|
return redis;
|
|
};
|