Skip to content

Commit

Permalink
feat: use the same transaction id for matching roles and context
Browse files Browse the repository at this point in the history
  • Loading branch information
LucianBuzzo committed Oct 31, 2024
1 parent 2999b12 commit 1e0fa22
Showing 1 changed file with 9 additions and 0 deletions.
9 changes: 9 additions & 0 deletions src/index.ts
Original file line number Diff line number Diff line change
Expand Up @@ -76,6 +76,7 @@ export type CustomAbilities<

export type GetContextFn<ContextKeys extends string = string> = () => {
role: string;
transactionId?: string;
context?: {
[key in ContextKeys]: string | number | string[];
};
Expand Down Expand Up @@ -250,6 +251,14 @@ export const createClient = (
// See https://github.com/prisma/prisma/issues/18276
const queryResults = await prisma.$transaction(
async (tx) => {
if (ctx.transactionId) {
(tx as any)[Symbol.for("prisma.client.transaction.id")] =
ctx.transactionId;
} else {
const txId = hashWithPrefix("yates_tx_", JSON.stringify(ctx));
(tx as any)[Symbol.for("prisma.client.transaction.id")] =
txId;
}
// Switch to the user role, We can't use a prepared statement here, due to limitations in PG not allowing prepared statements to be used in SET ROLE
await tx.$queryRawUnsafe(`SET ROLE ${pgRole}`);
// Now set all the context variables using `set_config` so that they can be used in RLS
Expand Down

0 comments on commit 1e0fa22

Please sign in to comment.