mirror of
https://github.com/Dokploy/dokploy
synced 2025-06-26 18:27:59 +00:00
- Introduced a new userId column in the git_provider table to associate git providers with users. - Updated the foreign key reference for userId to point to the users_temp table instead of the account table. - Modified the UnauthorizedGitProvider component to include a dialog action for disconnecting repositories, enhancing user experience. - Added a migration script to update existing git providers with the new userId values based on the organization owner.
72 lines
2.0 KiB
TypeScript
72 lines
2.0 KiB
TypeScript
import { relations } from "drizzle-orm";
|
|
import { pgEnum, pgTable, text } from "drizzle-orm/pg-core";
|
|
import { createInsertSchema } from "drizzle-zod";
|
|
import { nanoid } from "nanoid";
|
|
import { z } from "zod";
|
|
import { organization } from "./account";
|
|
import { bitbucket } from "./bitbucket";
|
|
import { gitea } from "./gitea";
|
|
import { github } from "./github";
|
|
import { gitlab } from "./gitlab";
|
|
import { users_temp } from "./user";
|
|
|
|
export const gitProviderType = pgEnum("gitProviderType", [
|
|
"github",
|
|
"gitlab",
|
|
"bitbucket",
|
|
"gitea",
|
|
]);
|
|
|
|
export const gitProvider = pgTable("git_provider", {
|
|
gitProviderId: text("gitProviderId")
|
|
.notNull()
|
|
.primaryKey()
|
|
.$defaultFn(() => nanoid()),
|
|
name: text("name").notNull(),
|
|
providerType: gitProviderType("providerType").notNull().default("github"),
|
|
createdAt: text("createdAt")
|
|
.notNull()
|
|
.$defaultFn(() => new Date().toISOString()),
|
|
organizationId: text("organizationId")
|
|
.notNull()
|
|
.references(() => organization.id, { onDelete: "cascade" }),
|
|
userId: text("userId")
|
|
.notNull()
|
|
.references(() => users_temp.id, { onDelete: "cascade" }),
|
|
});
|
|
|
|
export const gitProviderRelations = relations(gitProvider, ({ one }) => ({
|
|
github: one(github, {
|
|
fields: [gitProvider.gitProviderId],
|
|
references: [github.gitProviderId],
|
|
}),
|
|
gitlab: one(gitlab, {
|
|
fields: [gitProvider.gitProviderId],
|
|
references: [gitlab.gitProviderId],
|
|
}),
|
|
bitbucket: one(bitbucket, {
|
|
fields: [gitProvider.gitProviderId],
|
|
references: [bitbucket.gitProviderId],
|
|
}),
|
|
gitea: one(gitea, {
|
|
fields: [gitProvider.gitProviderId],
|
|
references: [gitea.gitProviderId],
|
|
}),
|
|
organization: one(organization, {
|
|
fields: [gitProvider.organizationId],
|
|
references: [organization.id],
|
|
}),
|
|
user: one(users_temp, {
|
|
fields: [gitProvider.userId],
|
|
references: [users_temp.id],
|
|
}),
|
|
}));
|
|
|
|
const createSchema = createInsertSchema(gitProvider);
|
|
|
|
export const apiRemoveGitProvider = createSchema
|
|
.extend({
|
|
gitProviderId: z.string().min(1),
|
|
})
|
|
.pick({ gitProviderId: true });
|