@sylphx/sdk 0.15.0 → 0.15.1
This diff represents the content of publicly available package versions that have been released to one of the supported registries. The information contained in this diff is provided for informational purposes only and reflects changes between package versions as they appear in their respective public registries.
- package/dist/nextjs/index.mjs +22 -3
- package/dist/nextjs/index.mjs.map +1 -1
- package/package.json +1 -1
package/dist/nextjs/index.mjs
CHANGED
|
@@ -1214,9 +1214,22 @@ async function handleSwitchOrg(request, ctx) {
|
|
|
1214
1214
|
if (request.method !== "POST") {
|
|
1215
1215
|
return NextResponse.json({ error: "Method not allowed" }, { status: 405 });
|
|
1216
1216
|
}
|
|
1217
|
-
const
|
|
1218
|
-
|
|
1219
|
-
|
|
1217
|
+
const currentSessionToken = request.cookies.get(ctx.cookieNames.SESSION)?.value;
|
|
1218
|
+
let sessionToken = currentSessionToken && !isTokenExpired(currentSessionToken) ? currentSessionToken : null;
|
|
1219
|
+
let restoredBaseSession = null;
|
|
1220
|
+
if (!sessionToken) {
|
|
1221
|
+
restoredBaseSession = await refreshSessionFromCookie(request, ctx, currentSessionToken);
|
|
1222
|
+
sessionToken = restoredBaseSession?.tokens.accessToken ?? null;
|
|
1223
|
+
}
|
|
1224
|
+
if (!sessionToken) {
|
|
1225
|
+
const response = NextResponse.json(
|
|
1226
|
+
{ error: "Not authenticated", accessToken: null },
|
|
1227
|
+
{ status: 401 }
|
|
1228
|
+
);
|
|
1229
|
+
if (currentSessionToken || request.cookies.has(ctx.cookieNames.REFRESH)) {
|
|
1230
|
+
clearAuthCookiesMiddleware(response, ctx.namespace);
|
|
1231
|
+
}
|
|
1232
|
+
return response;
|
|
1220
1233
|
}
|
|
1221
1234
|
let orgId = null;
|
|
1222
1235
|
let requestedOrgSlug = null;
|
|
@@ -1258,6 +1271,12 @@ async function handleSwitchOrg(request, ctx) {
|
|
|
1258
1271
|
user: data.user ?? null,
|
|
1259
1272
|
organization: activeOrganization
|
|
1260
1273
|
});
|
|
1274
|
+
if (restoredBaseSession) {
|
|
1275
|
+
setAuthCookiesMiddleware(response, ctx.namespace, restoredBaseSession.tokens);
|
|
1276
|
+
if (restoredBaseSession.activeOrganization) {
|
|
1277
|
+
setActiveOrganizationCookies(response, ctx, restoredBaseSession.activeOrganization);
|
|
1278
|
+
}
|
|
1279
|
+
}
|
|
1261
1280
|
response.cookies.set(ctx.cookieNames.SESSION, accessToken, {
|
|
1262
1281
|
...SECURE_COOKIE_OPTIONS,
|
|
1263
1282
|
maxAge: expiresIn
|