mirror of
https://github.com/Dokploy/dokploy.git
synced 2026-06-15 20:25:23 +02:00
- Added functionality to toggle sharing of Git providers with the organization. - Introduced a new column "sharedWithOrganization" in the git_provider table to track sharing status. - Updated user permissions to include accessedGitProviders, allowing for more granular access control. - Enhanced API routes to support fetching accessible Git providers based on user roles and permissions. - Implemented UI components for managing Git provider sharing and permissions in the dashboard.
101 lines
2.5 KiB
TypeScript
101 lines
2.5 KiB
TypeScript
import {
|
|
findGithubById,
|
|
getAccessibleGitProviderIds,
|
|
getGithubBranches,
|
|
getGithubRepositories,
|
|
haveGithubRequirements,
|
|
updateGithub,
|
|
updateGitProvider,
|
|
} from "@dokploy/server";
|
|
import { db } from "@dokploy/server/db";
|
|
import { TRPCError } from "@trpc/server";
|
|
import {
|
|
createTRPCRouter,
|
|
protectedProcedure,
|
|
withPermission,
|
|
} from "@/server/api/trpc";
|
|
import { audit } from "@/server/api/utils/audit";
|
|
import {
|
|
apiFindGithubBranches,
|
|
apiFindOneGithub,
|
|
apiUpdateGithub,
|
|
} from "@/server/db/schema";
|
|
|
|
export const githubRouter = createTRPCRouter({
|
|
one: protectedProcedure.input(apiFindOneGithub).query(async ({ input }) => {
|
|
return await findGithubById(input.githubId);
|
|
}),
|
|
getGithubRepositories: protectedProcedure
|
|
.input(apiFindOneGithub)
|
|
.query(async ({ input }) => {
|
|
return await getGithubRepositories(input.githubId);
|
|
}),
|
|
getGithubBranches: protectedProcedure
|
|
.input(apiFindGithubBranches)
|
|
.query(async ({ input }) => {
|
|
return await getGithubBranches(input);
|
|
}),
|
|
githubProviders: protectedProcedure.query(async ({ ctx }) => {
|
|
const accessibleIds = await getAccessibleGitProviderIds(ctx.session);
|
|
|
|
let result = await db.query.github.findMany({
|
|
with: {
|
|
gitProvider: true,
|
|
},
|
|
});
|
|
|
|
result = result.filter(
|
|
(provider) =>
|
|
provider.gitProvider.organizationId ===
|
|
ctx.session.activeOrganizationId &&
|
|
accessibleIds.has(provider.gitProvider.gitProviderId),
|
|
);
|
|
|
|
const filtered = result
|
|
.filter((provider) => haveGithubRequirements(provider))
|
|
.map((provider) => {
|
|
return {
|
|
githubId: provider.githubId,
|
|
gitProvider: {
|
|
...provider.gitProvider,
|
|
},
|
|
};
|
|
});
|
|
|
|
return filtered;
|
|
}),
|
|
|
|
testConnection: protectedProcedure
|
|
.input(apiFindOneGithub)
|
|
.mutation(async ({ input }) => {
|
|
try {
|
|
const result = await getGithubRepositories(input.githubId);
|
|
return `Found ${result.length} repositories`;
|
|
} catch (err) {
|
|
throw new TRPCError({
|
|
code: "BAD_REQUEST",
|
|
message: err instanceof Error ? err?.message : `Error: ${err}`,
|
|
});
|
|
}
|
|
}),
|
|
update: withPermission("gitProviders", "create")
|
|
.input(apiUpdateGithub)
|
|
.mutation(async ({ input, ctx }) => {
|
|
await updateGitProvider(input.gitProviderId, {
|
|
name: input.name,
|
|
organizationId: ctx.session.activeOrganizationId,
|
|
});
|
|
|
|
await updateGithub(input.githubId, {
|
|
...input,
|
|
});
|
|
|
|
await audit(ctx, {
|
|
action: "update",
|
|
resourceType: "gitProvider",
|
|
resourceId: input.gitProviderId,
|
|
resourceName: input.name,
|
|
});
|
|
}),
|
|
});
|