Skip to content

Commit

Permalink
migrate session data in trpc context creating function (#311)
Browse files Browse the repository at this point in the history
Signed-off-by: Aaron Sutula <[email protected]>
Co-authored-by: Aaron Sutula <[email protected]>
  • Loading branch information
asutula and asutula authored Aug 13, 2024
1 parent 8e4f983 commit cc22f0c
Showing 1 changed file with 14 additions and 17 deletions.
31 changes: 14 additions & 17 deletions packages/api/src/trpc.ts
Original file line number Diff line number Diff line change
Expand Up @@ -8,7 +8,7 @@ import { type Store } from "@tableland/studio-store";
import { TRPCError, initTRPC } from "@trpc/server";
import superjson from "superjson";
import { ZodError, z } from "zod";
import { type IronSession, getIronSession } from "iron-session";
import { getIronSession } from "iron-session";
import { type SessionData, sessionOptions } from "./session-data";

// TODO: the types and interfaces below are from iron-session, but they aren't exported.
Expand Down Expand Up @@ -77,6 +77,14 @@ export interface GetSessionArgs {
export const createTRPCContext = async (args: GetSessionArgs) => {
const session = await getSession(args);

// Migrate personalTeam to personalOrg.
// TODO: Remove this after it runs for a while.
if (session.auth?.personalTeam) {
session.auth.personalOrg = session.auth.personalTeam;
session.auth.personalTeam = undefined;
await session.save();
}

logTrpcSource(args.headers, session);

return { session };
Expand All @@ -88,26 +96,15 @@ export const getSession = async function ({
req,
res,
}: GetSessionArgs) {
let session: IronSession<SessionData> | undefined;
if (typeof cookies !== "undefined") {
session = await getIronSession<SessionData>(cookies, sessionOptions);
return await getIronSession<SessionData>(cookies, sessionOptions);
}
if (typeof req !== "undefined" && typeof res !== "undefined") {
session = await getIronSession<SessionData>(req, res, sessionOptions);
return await getIronSession<SessionData>(req, res, sessionOptions);
}
if (!session) {
throw new Error(
"cannot get session from context must supply cookies or req and res",
);
}

if (session.auth?.personalTeam) {
session.auth.personalOrg = session.auth.personalTeam;
session.auth.personalTeam = undefined;
await session.save();
}

return session;
throw new Error(
"cannot get session from context must supply cookies or req and res",
);
};

// get a header from either of the accepted header types
Expand Down

1 comment on commit cc22f0c

@vercel
Copy link

@vercel vercel bot commented on cc22f0c Aug 13, 2024

Choose a reason for hiding this comment

The reason will be displayed to describe this comment to others. Learn more.

Please sign in to comment.