diff --git a/.next/trace b/.next/trace index b278d862..1c12c6eb 100644 --- a/.next/trace +++ b/.next/trace @@ -8,3 +8,4 @@ [{"name":"check-page","duration":2002086,"timestamp":884349566424,"id":1304,"parentId":1285,"tags":{"page":"/api/calendars/[id]/events/[eventId]"},"startTime":1767360587115,"traceId":"1ada4263024251ab"},{"name":"is-page-static","duration":1858675,"timestamp":884349710071,"id":1414,"parentId":1298,"tags":{},"startTime":1767360587259,"traceId":"1ada4263024251ab"},{"name":"check-page","duration":2004018,"timestamp":884349564750,"id":1298,"parentId":1285,"tags":{"page":"/api/announcements/[id]"},"startTime":1767360587113,"traceId":"1ada4263024251ab"},{"name":"is-page-static","duration":1879975,"timestamp":884349710650,"id":1428,"parentId":1315,"tags":{},"startTime":1767360587259,"traceId":"1ada4263024251ab"},{"name":"check-page","duration":1936114,"timestamp":884349655840,"id":1315,"parentId":1285,"tags":{"page":"/api/courrier/account-list"},"startTime":1767360587204,"traceId":"1ada4263024251ab"},{"name":"is-page-static","duration":1887621,"timestamp":884349710508,"id":1420,"parentId":1307,"tags":{},"startTime":1767360587259,"traceId":"1ada4263024251ab"},{"name":"check-page","duration":2031147,"timestamp":884349567065,"id":1307,"parentId":1285,"tags":{"page":"/api/calendars/[id]/share"},"startTime":1767360587116,"traceId":"1ada4263024251ab"},{"name":"is-page-static","duration":1887674,"timestamp":884349710659,"id":1429,"parentId":1313,"tags":{},"startTime":1767360587259,"traceId":"1ada4263024251ab"},{"name":"check-page","duration":1942832,"timestamp":884349655535,"id":1313,"parentId":1285,"tags":{"page":"/api/courrier/account-details"},"startTime":1767360587204,"traceId":"1ada4263024251ab"},{"name":"is-page-static","duration":1887865,"timestamp":884349710571,"id":1423,"parentId":1306,"tags":{},"startTime":1767360587259,"traceId":"1ada4263024251ab"},{"name":"check-page","duration":2031578,"timestamp":884349566876,"id":1306,"parentId":1285,"tags":{"page":"/api/calendars/[id]"},"startTime":1767360587115,"traceId":"1ada4263024251ab"},{"name":"is-page-static","duration":1899487,"timestamp":884349710640,"id":1427,"parentId":1305,"tags":{},"startTime":1767360587259,"traceId":"1ada4263024251ab"},{"name":"check-page","duration":2043529,"timestamp":884349566657,"id":1305,"parentId":1285,"tags":{"page":"/api/calendars/[id]/events"},"startTime":1767360587115,"traceId":"1ada4263024251ab"},{"name":"is-page-static","duration":2172477,"timestamp":884349710610,"id":1425,"parentId":1311,"tags":{},"startTime":1767360587259,"traceId":"1ada4263024251ab"},{"name":"check-page","duration":2231178,"timestamp":884349652083,"id":1311,"parentId":1285,"tags":{"page":"/api/courrier/[id]/mark-read"},"startTime":1767360587201,"traceId":"1ada4263024251ab"},{"name":"is-page-static","duration":2178649,"timestamp":884349710741,"id":1435,"parentId":1321,"tags":{},"startTime":1767360587259,"traceId":"1ada4263024251ab"},{"name":"check-page","duration":2231940,"timestamp":884349657557,"id":1321,"parentId":1285,"tags":{"page":"/api/courrier/fix-folders"},"startTime":1767360587206,"traceId":"1ada4263024251ab"},{"name":"is-page-static","duration":2182248,"timestamp":884349710756,"id":1436,"parentId":1318,"tags":{},"startTime":1767360587259,"traceId":"1ada4263024251ab"},{"name":"check-page","duration":2236738,"timestamp":884349656330,"id":1318,"parentId":1285,"tags":{"page":"/api/courrier/debug-account"},"startTime":1767360587205,"traceId":"1ada4263024251ab"},{"name":"is-page-static","duration":2188461,"timestamp":884349710774,"id":1437,"parentId":1322,"tags":{},"startTime":1767360587259,"traceId":"1ada4263024251ab"},{"name":"check-page","duration":2241584,"timestamp":884349657712,"id":1322,"parentId":1285,"tags":{"page":"/api/courrier/microsoft/callback"},"startTime":1767360587206,"traceId":"1ada4263024251ab"},{"name":"is-page-static","duration":2194373,"timestamp":884349710799,"id":1438,"parentId":1316,"tags":{},"startTime":1767360587259,"traceId":"1ada4263024251ab"},{"name":"check-page","duration":2249262,"timestamp":884349655967,"id":1316,"parentId":1285,"tags":{"page":"/api/courrier/account"},"startTime":1767360587204,"traceId":"1ada4263024251ab"},{"name":"is-page-static","duration":2198089,"timestamp":884349710810,"id":1439,"parentId":1327,"tags":{},"startTime":1767360587259,"traceId":"1ada4263024251ab"},{"name":"check-page","duration":2249499,"timestamp":884349659554,"id":1327,"parentId":1285,"tags":{"page":"/api/courrier/send"},"startTime":1767360587208,"traceId":"1ada4263024251ab"},{"name":"is-page-static","duration":2211723,"timestamp":884349710830,"id":1440,"parentId":1326,"tags":{},"startTime":1767360587259,"traceId":"1ada4263024251ab"},{"name":"check-page","duration":2263558,"timestamp":884349659433,"id":1326,"parentId":1285,"tags":{"page":"/api/courrier"},"startTime":1767360587208,"traceId":"1ada4263024251ab"},{"name":"is-page-static","duration":2222101,"timestamp":884349710842,"id":1441,"parentId":1325,"tags":{},"startTime":1767360587259,"traceId":"1ada4263024251ab"},{"name":"check-page","duration":2273673,"timestamp":884349659301,"id":1325,"parentId":1285,"tags":{"page":"/api/courrier/refresh"},"startTime":1767360587208,"traceId":"1ada4263024251ab"},{"name":"is-page-static","duration":2226104,"timestamp":884349710851,"id":1442,"parentId":1323,"tags":{},"startTime":1767360587259,"traceId":"1ada4263024251ab"},{"name":"check-page","duration":2278473,"timestamp":884349658501,"id":1323,"parentId":1285,"tags":{"page":"/api/courrier/microsoft"},"startTime":1767360587207,"traceId":"1ada4263024251ab"},{"name":"is-page-static","duration":2229093,"timestamp":884349710712,"id":1433,"parentId":1320,"tags":{},"startTime":1767360587259,"traceId":"1ada4263024251ab"},{"name":"check-page","duration":2282460,"timestamp":884349657376,"id":1320,"parentId":1285,"tags":{"page":"/api/courrier/emails"},"startTime":1767360587206,"traceId":"1ada4263024251ab"},{"name":"is-page-static","duration":2230011,"timestamp":884349710858,"id":1443,"parentId":1324,"tags":{},"startTime":1767360587259,"traceId":"1ada4263024251ab"},{"name":"check-page","duration":2282026,"timestamp":884349658883,"id":1324,"parentId":1285,"tags":{"page":"/api/courrier/recache"},"startTime":1767360587207,"traceId":"1ada4263024251ab"},{"name":"is-page-static","duration":2233235,"timestamp":884349710728,"id":1434,"parentId":1319,"tags":{},"startTime":1767360587259,"traceId":"1ada4263024251ab"},{"name":"check-page","duration":2287115,"timestamp":884349657219,"id":1319,"parentId":1285,"tags":{"page":"/api/courrier/delete"},"startTime":1767360587206,"traceId":"1ada4263024251ab"},{"name":"is-page-static","duration":2238265,"timestamp":884349710899,"id":1446,"parentId":1331,"tags":{},"startTime":1767360587259,"traceId":"1ada4263024251ab"},{"name":"check-page","duration":2289824,"timestamp":884349660209,"id":1331,"parentId":1285,"tags":{"page":"/api/debug-email"},"startTime":1767360587209,"traceId":"1ada4263024251ab"},{"name":"is-page-static","duration":2244495,"timestamp":884349710624,"id":1426,"parentId":1312,"tags":{},"startTime":1767360587259,"traceId":"1ada4263024251ab"},{"name":"check-page","duration":2302496,"timestamp":884349652641,"id":1312,"parentId":1285,"tags":{"page":"/api/courrier/[id]"},"startTime":1767360587203,"traceId":"1ada4263024251ab"},{"name":"is-page-static","duration":2247998,"timestamp":884349710885,"id":1445,"parentId":1329,"tags":{},"startTime":1767360587259,"traceId":"1ada4263024251ab"},{"name":"check-page","duration":2298965,"timestamp":884349659946,"id":1329,"parentId":1285,"tags":{"page":"/api/courrier/test-connection"},"startTime":1767360587208,"traceId":"1ada4263024251ab"},{"name":"is-page-static","duration":2250703,"timestamp":884349710672,"id":1430,"parentId":1310,"tags":{},"startTime":1767360587259,"traceId":"1ada4263024251ab"},{"name":"check-page","duration":2309526,"timestamp":884349651866,"id":1310,"parentId":1285,"tags":{"page":"/api/courrier/[id]/flag"},"startTime":1767360587200,"traceId":"1ada4263024251ab"},{"name":"is-page-static","duration":2251167,"timestamp":884349710932,"id":1449,"parentId":1333,"tags":{},"startTime":1767360587259,"traceId":"1ada4263024251ab"},{"name":"check-page","duration":2301482,"timestamp":884349660641,"id":1333,"parentId":1285,"tags":{"page":"/api/debug/leantime-methods"},"startTime":1767360587209,"traceId":"1ada4263024251ab"},{"name":"is-page-static","duration":2254225,"timestamp":884349710921,"id":1448,"parentId":1334,"tags":{},"startTime":1767360587259,"traceId":"1ada4263024251ab"},{"name":"check-page","duration":2304352,"timestamp":884349660833,"id":1334,"parentId":1285,"tags":{"page":"/api/debug/notifications"},"startTime":1767360587209,"traceId":"1ada4263024251ab"},{"name":"is-page-static","duration":2254870,"timestamp":884349710976,"id":1451,"parentId":1328,"tags":{},"startTime":1767360587260,"traceId":"1ada4263024251ab"},{"name":"check-page","duration":2306114,"timestamp":884349659749,"id":1328,"parentId":1285,"tags":{"page":"/api/courrier/session"},"startTime":1767360587208,"traceId":"1ada4263024251ab"},{"name":"is-page-static","duration":2257118,"timestamp":884349711001,"id":1453,"parentId":1336,"tags":{},"startTime":1767360587260,"traceId":"1ada4263024251ab"},{"name":"check-page","duration":2306995,"timestamp":884349661384,"id":1336,"parentId":1285,"tags":{"page":"/api/emails"},"startTime":1767360587210,"traceId":"1ada4263024251ab"},{"name":"is-page-static","duration":2260846,"timestamp":884349710992,"id":1452,"parentId":1338,"tags":{},"startTime":1767360587260,"traceId":"1ada4263024251ab"},{"name":"check-page","duration":2310302,"timestamp":884349661994,"id":1338,"parentId":1285,"tags":{"page":"/api/events"},"startTime":1767360587211,"traceId":"1ada4263024251ab"},{"name":"is-page-static","duration":2263723,"timestamp":884349711015,"id":1454,"parentId":1339,"tags":{},"startTime":1767360587260,"traceId":"1ada4263024251ab"},{"name":"check-page","duration":2312735,"timestamp":884349662210,"id":1339,"parentId":1285,"tags":{"page":"/api/groups/[groupId]/members"},"startTime":1767360587211,"traceId":"1ada4263024251ab"},{"name":"is-page-static","duration":2264992,"timestamp":884349711037,"id":1455,"parentId":1340,"tags":{},"startTime":1767360587260,"traceId":"1ada4263024251ab"},{"name":"check-page","duration":2313548,"timestamp":884349662497,"id":1340,"parentId":1285,"tags":{"page":"/api/groups/[groupId]"},"startTime":1767360587211,"traceId":"1ada4263024251ab"},{"name":"is-page-static","duration":2268538,"timestamp":884349711057,"id":1456,"parentId":1342,"tags":{},"startTime":1767360587260,"traceId":"1ada4263024251ab"},{"name":"check-page","duration":2316795,"timestamp":884349662815,"id":1342,"parentId":1285,"tags":{"page":"/api/leantime/status-labels"},"startTime":1767360587211,"traceId":"1ada4263024251ab"},{"name":"is-page-static","duration":2295569,"timestamp":884349710955,"id":1450,"parentId":1330,"tags":{},"startTime":1767360587259,"traceId":"1ada4263024251ab"},{"name":"check-page","duration":2346516,"timestamp":884349660084,"id":1330,"parentId":1285,"tags":{"page":"/api/courrier/unread-counts"},"startTime":1767360587209,"traceId":"1ada4263024251ab"},{"name":"is-page-static","duration":2299775,"timestamp":884349711100,"id":1459,"parentId":1343,"tags":{},"startTime":1767360587260,"traceId":"1ada4263024251ab"},{"name":"check-page","duration":2348035,"timestamp":884349662936,"id":1343,"parentId":1285,"tags":{"page":"/api/leantime/tasks"},"startTime":1767360587211,"traceId":"1ada4263024251ab"},{"name":"is-page-static","duration":2301806,"timestamp":884349710687,"id":1431,"parentId":1314,"tags":{},"startTime":1767360587259,"traceId":"1ada4263024251ab"},{"name":"check-page","duration":2356817,"timestamp":884349655706,"id":1314,"parentId":1285,"tags":{"page":"/api/courrier/account-folders"},"startTime":1767360587204,"traceId":"1ada4263024251ab"},{"name":"is-page-static","duration":2304266,"timestamp":884349711113,"id":1460,"parentId":1341,"tags":{},"startTime":1767360587260,"traceId":"1ada4263024251ab"},{"name":"check-page","duration":2352752,"timestamp":884349662670,"id":1341,"parentId":1285,"tags":{"page":"/api/groups"},"startTime":1767360587211,"traceId":"1ada4263024251ab"},{"name":"is-page-static","duration":2323885,"timestamp":884349710698,"id":1432,"parentId":1317,"tags":{},"startTime":1767360587259,"traceId":"1ada4263024251ab"},{"name":"check-page","duration":2378577,"timestamp":884349656089,"id":1317,"parentId":1285,"tags":{"page":"/api/courrier/credentials"},"startTime":1767360587205,"traceId":"1ada4263024251ab"},{"name":"is-page-static","duration":2323678,"timestamp":884349711149,"id":1462,"parentId":1348,"tags":{},"startTime":1767360587260,"traceId":"1ada4263024251ab"},{"name":"check-page","duration":2371221,"timestamp":884349663634,"id":1348,"parentId":1285,"tags":{"page":"/api/missions/all"},"startTime":1767360587212,"traceId":"1ada4263024251ab"},{"name":"is-page-static","duration":2329002,"timestamp":884349711425,"id":1464,"parentId":1353,"tags":{},"startTime":1767360587260,"traceId":"1ada4263024251ab"},{"name":"check-page","duration":2376252,"timestamp":884349664218,"id":1353,"parentId":1285,"tags":{"page":"/api/news"},"startTime":1767360587213,"traceId":"1ada4263024251ab"},{"name":"is-page-static","duration":2334939,"timestamp":884349711185,"id":1463,"parentId":1346,"tags":{},"startTime":1767360587260,"traceId":"1ada4263024251ab"},{"name":"check-page","duration":2382796,"timestamp":884349663392,"id":1346,"parentId":1285,"tags":{"page":"/api/missions/[missionId]/attachments"},"startTime":1767360587212,"traceId":"1ada4263024251ab"},{"name":"is-page-static","duration":2690306,"timestamp":884349711463,"id":1466,"parentId":1351,"tags":{},"startTime":1767360587260,"traceId":"1ada4263024251ab"},{"name":"check-page","duration":2738231,"timestamp":884349663969,"id":1351,"parentId":1285,"tags":{"page":"/api/missions/upload"},"startTime":1767360587213,"traceId":"1ada4263024251ab"},{"name":"is-page-static","duration":2691567,"timestamp":884349710908,"id":1447,"parentId":1332,"tags":{},"startTime":1767360587259,"traceId":"1ada4263024251ab"},{"name":"check-page","duration":2742111,"timestamp":884349660398,"id":1332,"parentId":1285,"tags":{"page":"/api/debug/create-all-folders"},"startTime":1767360587209,"traceId":"1ada4263024251ab"},{"name":"is-page-static","duration":2691490,"timestamp":884349711070,"id":1457,"parentId":1344,"tags":{},"startTime":1767360587260,"traceId":"1ada4263024251ab"},{"name":"check-page","duration":2739447,"timestamp":884349663130,"id":1344,"parentId":1285,"tags":{"page":"/api/missions/[missionId]/attachments/[attachmentId]"},"startTime":1767360587212,"traceId":"1ada4263024251ab"},{"name":"is-page-static","duration":2691780,"timestamp":884349711442,"id":1465,"parentId":1349,"tags":{},"startTime":1767360587260,"traceId":"1ada4263024251ab"},{"name":"check-page","duration":2739515,"timestamp":884349663747,"id":1349,"parentId":1285,"tags":{"page":"/api/missions/image/[...path]"},"startTime":1767360587212,"traceId":"1ada4263024251ab"},{"name":"is-page-static","duration":2692230,"timestamp":884349711080,"id":1458,"parentId":1345,"tags":{},"startTime":1767360587260,"traceId":"1ada4263024251ab"},{"name":"check-page","duration":2740062,"timestamp":884349663267,"id":1345,"parentId":1285,"tags":{"page":"/api/missions/[missionId]/attachments/download/[attachmentId]"},"startTime":1767360587212,"traceId":"1ada4263024251ab"},{"name":"is-page-static","duration":2692493,"timestamp":884349710872,"id":1444,"parentId":1335,"tags":{},"startTime":1767360587259,"traceId":"1ada4263024251ab"},{"name":"check-page","duration":2742290,"timestamp":884349661095,"id":1335,"parentId":1285,"tags":{"page":"/api/debug/s3"},"startTime":1767360587210,"traceId":"1ada4263024251ab"},{"name":"is-page-static","duration":2692308,"timestamp":884349711137,"id":1461,"parentId":1347,"tags":{},"startTime":1767360587260,"traceId":"1ada4263024251ab"},{"name":"check-page","duration":2739948,"timestamp":884349663506,"id":1347,"parentId":1285,"tags":{"page":"/api/missions/[missionId]"},"startTime":1767360587212,"traceId":"1ada4263024251ab"},{"name":"is-page-static","duration":2697139,"timestamp":884349711536,"id":1471,"parentId":1352,"tags":{},"startTime":1767360587260,"traceId":"1ada4263024251ab"},{"name":"check-page","duration":2744817,"timestamp":884349664081,"id":1352,"parentId":1285,"tags":{"page":"/api/news/purge-cache"},"startTime":1767360587213,"traceId":"1ada4263024251ab"},{"name":"is-page-static","duration":2698394,"timestamp":884349711479,"id":1467,"parentId":1356,"tags":{},"startTime":1767360587260,"traceId":"1ada4263024251ab"},{"name":"check-page","duration":2742173,"timestamp":884349667783,"id":1356,"parentId":1285,"tags":{"page":"/api/nextcloud/files"},"startTime":1767360587216,"traceId":"1ada4263024251ab"},{"name":"is-page-static","duration":2698875,"timestamp":884349711528,"id":1470,"parentId":1355,"tags":{},"startTime":1767360587260,"traceId":"1ada4263024251ab"},{"name":"check-page","duration":2742959,"timestamp":884349667470,"id":1355,"parentId":1285,"tags":{"page":"/api/nextcloud/files/content"},"startTime":1767360587216,"traceId":"1ada4263024251ab"},{"name":"is-page-static","duration":2698977,"timestamp":884349711492,"id":1468,"parentId":1354,"tags":{},"startTime":1767360587260,"traceId":"1ada4263024251ab"},{"name":"check-page","duration":2745160,"timestamp":884349665355,"id":1354,"parentId":1285,"tags":{"page":"/api/news/test-backend"},"startTime":1767360587214,"traceId":"1ada4263024251ab"},{"name":"is-page-static","duration":2714404,"timestamp":884349711605,"id":1477,"parentId":1368,"tags":{},"startTime":1767360587260,"traceId":"1ada4263024251ab"},{"name":"check-page","duration":2755745,"timestamp":884349670500,"id":1368,"parentId":1285,"tags":{"page":"/api/storage/files"},"startTime":1767360587219,"traceId":"1ada4263024251ab"}] [{"name":"is-page-static","duration":2721924,"timestamp":884349711546,"id":1472,"parentId":1358,"tags":{},"startTime":1767360587260,"traceId":"1ada4263024251ab"},{"name":"check-page","duration":2765360,"timestamp":884349668256,"id":1358,"parentId":1285,"tags":{"page":"/api/nextcloud/status"},"startTime":1767360587217,"traceId":"1ada4263024251ab"},{"name":"is-page-static","duration":2722281,"timestamp":884349711555,"id":1473,"parentId":1359,"tags":{},"startTime":1767360587260,"traceId":"1ada4263024251ab"},{"name":"check-page","duration":2765452,"timestamp":884349668426,"id":1359,"parentId":1285,"tags":{"page":"/api/notifications/[id]/read"},"startTime":1767360587217,"traceId":"1ada4263024251ab"},{"name":"is-page-static","duration":2722737,"timestamp":884349711519,"id":1469,"parentId":1350,"tags":{},"startTime":1767360587260,"traceId":"1ada4263024251ab"},{"name":"check-page","duration":2770419,"timestamp":884349663858,"id":1350,"parentId":1285,"tags":{"page":"/api/missions"},"startTime":1767360587212,"traceId":"1ada4263024251ab"},{"name":"is-page-static","duration":2722831,"timestamp":884349711575,"id":1475,"parentId":1360,"tags":{},"startTime":1767360587260,"traceId":"1ada4263024251ab"},{"name":"check-page","duration":2766512,"timestamp":884349668550,"id":1360,"parentId":1285,"tags":{"page":"/api/notifications/count"},"startTime":1767360587217,"traceId":"1ada4263024251ab"},{"name":"is-page-static","duration":2723585,"timestamp":884349711567,"id":1474,"parentId":1362,"tags":{},"startTime":1767360587260,"traceId":"1ada4263024251ab"},{"name":"check-page","duration":2766121,"timestamp":884349669057,"id":1362,"parentId":1285,"tags":{"page":"/api/notifications"},"startTime":1767360587218,"traceId":"1ada4263024251ab"},{"name":"is-page-static","duration":2729428,"timestamp":884349711677,"id":1482,"parentId":1365,"tags":{},"startTime":1767360587260,"traceId":"1ada4263024251ab"},{"name":"check-page","duration":2771486,"timestamp":884349669663,"id":1365,"parentId":1285,"tags":{"page":"/api/rocket-chat/messages"},"startTime":1767360587218,"traceId":"1ada4263024251ab"},{"name":"is-page-static","duration":2730163,"timestamp":884349711614,"id":1478,"parentId":1364,"tags":{},"startTime":1767360587260,"traceId":"1ada4263024251ab"},{"name":"check-page","duration":2772346,"timestamp":884349669461,"id":1364,"parentId":1285,"tags":{"page":"/api/redis/status"},"startTime":1767360587218,"traceId":"1ada4263024251ab"},{"name":"is-page-static","duration":2730939,"timestamp":884349711621,"id":1479,"parentId":1361,"tags":{},"startTime":1767360587260,"traceId":"1ada4263024251ab"},{"name":"check-page","duration":2773756,"timestamp":884349668830,"id":1361,"parentId":1285,"tags":{"page":"/api/notifications/read-all"},"startTime":1767360587217,"traceId":"1ada4263024251ab"},{"name":"is-page-static","duration":2730998,"timestamp":884349711643,"id":1481,"parentId":1366,"tags":{},"startTime":1767360587260,"traceId":"1ada4263024251ab"},{"name":"check-page","duration":2772697,"timestamp":884349669959,"id":1366,"parentId":1285,"tags":{"page":"/api/roles"},"startTime":1767360587218,"traceId":"1ada4263024251ab"},{"name":"is-page-static","duration":2731010,"timestamp":884349711691,"id":1483,"parentId":1371,"tags":{},"startTime":1767360587260,"traceId":"1ada4263024251ab"},{"name":"check-page","duration":2771850,"timestamp":884349670864,"id":1371,"parentId":1285,"tags":{"page":"/api/storage/status"},"startTime":1767360587219,"traceId":"1ada4263024251ab"},{"name":"is-page-static","duration":2731599,"timestamp":884349711632,"id":1480,"parentId":1370,"tags":{},"startTime":1767360587260,"traceId":"1ada4263024251ab"},{"name":"check-page","duration":2772520,"timestamp":884349670726,"id":1370,"parentId":1285,"tags":{"page":"/api/storage/init"},"startTime":1767360587219,"traceId":"1ada4263024251ab"},{"name":"is-page-static","duration":2735697,"timestamp":884349712307,"id":1488,"parentId":1369,"tags":{},"startTime":1767360587261,"traceId":"1ada4263024251ab"},{"name":"check-page","duration":2777440,"timestamp":884349670618,"id":1369,"parentId":1285,"tags":{"page":"/api/storage/init/folder"},"startTime":1767360587219,"traceId":"1ada4263024251ab"},{"name":"is-page-static","duration":2737065,"timestamp":884349712493,"id":1489,"parentId":1375,"tags":{},"startTime":1767360587261,"traceId":"1ada4263024251ab"},{"name":"check-page","duration":2778049,"timestamp":884349671540,"id":1375,"parentId":1285,"tags":{"page":"/api/users/[userId]"},"startTime":1767360587220,"traceId":"1ada4263024251ab"},{"name":"is-page-static","duration":2737337,"timestamp":884349712294,"id":1487,"parentId":1357,"tags":{},"startTime":1767360587261,"traceId":"1ada4263024251ab"},{"name":"check-page","duration":2781605,"timestamp":884349668035,"id":1357,"parentId":1285,"tags":{"page":"/api/nextcloud/init"},"startTime":1767360587217,"traceId":"1ada4263024251ab"},{"name":"is-page-static","duration":2737945,"timestamp":884349711727,"id":1485,"parentId":1372,"tags":{},"startTime":1767360587260,"traceId":"1ada4263024251ab"},{"name":"check-page","duration":2778716,"timestamp":884349670969,"id":1372,"parentId":1285,"tags":{"page":"/api/sync-users"},"startTime":1767360587219,"traceId":"1ada4263024251ab"},{"name":"is-page-static","duration":2738890,"timestamp":884349711704,"id":1484,"parentId":1367,"tags":{},"startTime":1767360587260,"traceId":"1ada4263024251ab"},{"name":"check-page","duration":2780276,"timestamp":884349670335,"id":1367,"parentId":1285,"tags":{"page":"/api/storage/files/content"},"startTime":1767360587219,"traceId":"1ada4263024251ab"},{"name":"is-page-static","duration":2740087,"timestamp":884349712527,"id":1490,"parentId":1381,"tags":{},"startTime":1767360587261,"traceId":"1ada4263024251ab"},{"name":"check-page","duration":2780303,"timestamp":884349672347,"id":1381,"parentId":1285,"tags":{"page":"/courrier/[id]"},"startTime":1767360587221,"traceId":"1ada4263024251ab"},{"name":"is-page-static","duration":2739865,"timestamp":884349714843,"id":1493,"parentId":1337,"tags":{},"startTime":1767360587263,"traceId":"1ada4263024251ab"},{"name":"check-page","duration":2793050,"timestamp":884349661690,"id":1337,"parentId":1285,"tags":{"page":"/api/events/[id]"},"startTime":1767360587210,"traceId":"1ada4263024251ab"},{"name":"is-page-static","duration":2741957,"timestamp":884349712987,"id":1491,"parentId":1376,"tags":{},"startTime":1767360587262,"traceId":"1ada4263024251ab"},{"name":"check-page","duration":2783257,"timestamp":884349671699,"id":1376,"parentId":1285,"tags":{"page":"/api/users"},"startTime":1767360587220,"traceId":"1ada4263024251ab"},{"name":"is-page-static","duration":2743258,"timestamp":884349713168,"id":1492,"parentId":1373,"tags":{},"startTime":1767360587262,"traceId":"1ada4263024251ab"},{"name":"check-page","duration":2785368,"timestamp":884349671072,"id":1373,"parentId":1285,"tags":{"page":"/api/users/[userId]/password"},"startTime":1767360587220,"traceId":"1ada4263024251ab"},{"name":"is-page-static","duration":2747006,"timestamp":884349712277,"id":1486,"parentId":1374,"tags":{},"startTime":1767360587261,"traceId":"1ada4263024251ab"},{"name":"check-page","duration":2788036,"timestamp":884349671285,"id":1374,"parentId":1285,"tags":{"page":"/api/users/[userId]/roles"},"startTime":1767360587220,"traceId":"1ada4263024251ab"},{"name":"is-page-static","duration":2737453,"timestamp":884349743326,"id":1498,"parentId":1295,"tags":{},"startTime":1767360587292,"traceId":"1ada4263024251ab"},{"name":"check-page","duration":2917053,"timestamp":884349563867,"id":1295,"parentId":1285,"tags":{"page":"/announcement"},"startTime":1767360587112,"traceId":"1ada4263024251ab"},{"name":"is-page-static","duration":2746102,"timestamp":884349746691,"id":1500,"parentId":1385,"tags":{},"startTime":1767360587295,"traceId":"1ada4263024251ab"},{"name":"check-page","duration":2819694,"timestamp":884349673259,"id":1385,"parentId":1285,"tags":{"page":"/equipes"},"startTime":1767360587222,"traceId":"1ada4263024251ab"},{"name":"is-page-static","duration":2780209,"timestamp":884349746839,"id":1501,"parentId":1383,"tags":{},"startTime":1767360587295,"traceId":"1ada4263024251ab"},{"name":"check-page","duration":2854259,"timestamp":884349672837,"id":1383,"parentId":1285,"tags":{"page":"/crm"},"startTime":1767360587221,"traceId":"1ada4263024251ab"},{"name":"is-page-static","duration":2787628,"timestamp":884349743296,"id":1496,"parentId":1293,"tags":{},"startTime":1767360587292,"traceId":"1ada4263024251ab"},{"name":"check-page","duration":2967943,"timestamp":884349563100,"id":1293,"parentId":1285,"tags":{"page":"/agilite"},"startTime":1767360587112,"traceId":"1ada4263024251ab"},{"name":"is-page-static","duration":2785896,"timestamp":884349746903,"id":1502,"parentId":1379,"tags":{},"startTime":1767360587295,"traceId":"1ada4263024251ab"},{"name":"check-page","duration":2860729,"timestamp":884349672114,"id":1379,"parentId":1285,"tags":{"page":"/calcul"},"startTime":1767360587221,"traceId":"1ada4263024251ab"},{"name":"is-page-static","duration":2790801,"timestamp":884349743311,"id":1497,"parentId":1294,"tags":{},"startTime":1767360587292,"traceId":"1ada4263024251ab"},{"name":"check-page","duration":2970655,"timestamp":884349563505,"id":1294,"parentId":1285,"tags":{"page":"/alma"},"startTime":1767360587112,"traceId":"1ada4263024251ab"},{"name":"is-page-static","duration":2791930,"timestamp":884349746925,"id":1504,"parentId":1389,"tags":{},"startTime":1767360587295,"traceId":"1ada4263024251ab"},{"name":"check-page","duration":2863898,"timestamp":884349674998,"id":1389,"parentId":1285,"tags":{"page":"/mediation"},"startTime":1767360587224,"traceId":"1ada4263024251ab"},{"name":"is-page-static","duration":2797202,"timestamp":884349746971,"id":1506,"parentId":1386,"tags":{},"startTime":1767360587296,"traceId":"1ada4263024251ab"},{"name":"check-page","duration":2870543,"timestamp":884349673668,"id":1386,"parentId":1285,"tags":{"page":"/gite"},"startTime":1767360587222,"traceId":"1ada4263024251ab"},{"name":"is-page-static","duration":2799111,"timestamp":884349746916,"id":1503,"parentId":1388,"tags":{},"startTime":1767360587295,"traceId":"1ada4263024251ab"},{"name":"check-page","duration":2871717,"timestamp":884349674336,"id":1388,"parentId":1285,"tags":{"page":"/livres"},"startTime":1767360587223,"traceId":"1ada4263024251ab"},{"name":"is-page-static","duration":2803201,"timestamp":884349746946,"id":1505,"parentId":1384,"tags":{},"startTime":1767360587295,"traceId":"1ada4263024251ab"},{"name":"check-page","duration":2877198,"timestamp":884349673046,"id":1384,"parentId":1285,"tags":{"page":"/dossiers"},"startTime":1767360587222,"traceId":"1ada4263024251ab"},{"name":"is-page-static","duration":2804117,"timestamp":884349746995,"id":1507,"parentId":1398,"tags":{},"startTime":1767360587296,"traceId":"1ada4263024251ab"},{"name":"check-page","duration":2872470,"timestamp":884349678656,"id":1398,"parentId":1285,"tags":{"page":"/"},"startTime":1767360587227,"traceId":"1ada4263024251ab"},{"name":"is-page-static","duration":2816194,"timestamp":884349747005,"id":1508,"parentId":1402,"tags":{},"startTime":1767360587296,"traceId":"1ada4263024251ab"},{"name":"check-page","duration":2883286,"timestamp":884349679966,"id":1402,"parentId":1285,"tags":{"page":"/radio"},"startTime":1767360587228,"traceId":"1ada4263024251ab"},{"name":"is-page-static","duration":2816286,"timestamp":884349747052,"id":1510,"parentId":1401,"tags":{},"startTime":1767360587296,"traceId":"1ada4263024251ab"},{"name":"check-page","duration":2883710,"timestamp":884349679648,"id":1401,"parentId":1285,"tags":{"page":"/press"},"startTime":1767360587228,"traceId":"1ada4263024251ab"},{"name":"is-page-static","duration":2821335,"timestamp":884349747078,"id":1512,"parentId":1396,"tags":{},"startTime":1767360587296,"traceId":"1ada4263024251ab"},{"name":"check-page","duration":2890371,"timestamp":884349678113,"id":1396,"parentId":1285,"tags":{"page":"/ms"},"startTime":1767360587227,"traceId":"1ada4263024251ab"},{"name":"is-page-static","duration":2827429,"timestamp":884349747044,"id":1509,"parentId":1400,"tags":{},"startTime":1767360587296,"traceId":"1ada4263024251ab"},{"name":"check-page","duration":2895016,"timestamp":884349679509,"id":1400,"parentId":1285,"tags":{"page":"/parole"},"startTime":1767360587228,"traceId":"1ada4263024251ab"},{"name":"is-page-static","duration":2831851,"timestamp":884349743232,"id":1494,"parentId":1292,"tags":{},"startTime":1767360587292,"traceId":"1ada4263024251ab"},{"name":"check-page","duration":3012510,"timestamp":884349562602,"id":1292,"parentId":1285,"tags":{"page":"/agenda"},"startTime":1767360587111,"traceId":"1ada4263024251ab"},{"name":"is-page-static","duration":2829339,"timestamp":884349747087,"id":1513,"parentId":1387,"tags":{},"startTime":1767360587296,"traceId":"1ada4263024251ab"},{"name":"check-page","duration":2902416,"timestamp":884349674034,"id":1387,"parentId":1285,"tags":{"page":"/groups"},"startTime":1767360587223,"traceId":"1ada4263024251ab"},{"name":"is-page-static","duration":2833010,"timestamp":884349747070,"id":1511,"parentId":1378,"tags":{},"startTime":1767360587296,"traceId":"1ada4263024251ab"},{"name":"check-page","duration":2908133,"timestamp":884349671992,"id":1378,"parentId":1285,"tags":{"page":"/artlab"},"startTime":1767360587221,"traceId":"1ada4263024251ab"},{"name":"is-page-static","duration":2835642,"timestamp":884349747114,"id":1516,"parentId":1405,"tags":{},"startTime":1767360587296,"traceId":"1ada4263024251ab"},{"name":"check-page","duration":2901637,"timestamp":884349681139,"id":1405,"parentId":1285,"tags":{"page":"/signout"},"startTime":1767360587230,"traceId":"1ada4263024251ab"},{"name":"is-page-static","duration":2837909,"timestamp":884349747122,"id":1517,"parentId":1409,"tags":{},"startTime":1767360587296,"traceId":"1ada4263024251ab"},{"name":"check-page","duration":2901165,"timestamp":884349683890,"id":1409,"parentId":1285,"tags":{"page":"/vision"},"startTime":1767360587232,"traceId":"1ada4263024251ab"},{"name":"is-page-static","duration":2839628,"timestamp":884349748452,"id":1518,"parentId":1380,"tags":{},"startTime":1767360587297,"traceId":"1ada4263024251ab"},{"name":"check-page","duration":2915906,"timestamp":884349672232,"id":1380,"parentId":1285,"tags":{"page":"/chapitre"},"startTime":1767360587221,"traceId":"1ada4263024251ab"},{"name":"is-page-static","duration":2845805,"timestamp":884349743277,"id":1495,"parentId":1291,"tags":{},"startTime":1767360587292,"traceId":"1ada4263024251ab"},{"name":"check-page","duration":3026947,"timestamp":884349562153,"id":1291,"parentId":1285,"tags":{"page":"/[section]"},"startTime":1767360587111,"traceId":"1ada4263024251ab"},{"name":"is-page-static","duration":2842063,"timestamp":884349747096,"id":1514,"parentId":1399,"tags":{},"startTime":1767360587296,"traceId":"1ada4263024251ab"},{"name":"check-page","duration":2910296,"timestamp":884349678871,"id":1399,"parentId":1285,"tags":{"page":"/pages"},"startTime":1767360587227,"traceId":"1ada4263024251ab"},{"name":"is-page-static","duration":2844704,"timestamp":884349746641,"id":1499,"parentId":1377,"tags":{},"startTime":1767360587295,"traceId":"1ada4263024251ab"},{"name":"check-page","duration":2919533,"timestamp":884349671823,"id":1377,"parentId":1285,"tags":{"page":"/apprendre"},"startTime":1767360587220,"traceId":"1ada4263024251ab"},{"name":"is-page-static","duration":2843304,"timestamp":884349748499,"id":1519,"parentId":1408,"tags":{},"startTime":1767360587297,"traceId":"1ada4263024251ab"},{"name":"check-page","duration":2909150,"timestamp":884349682665,"id":1408,"parentId":1285,"tags":{"page":"/users"},"startTime":1767360587231,"traceId":"1ada4263024251ab"},{"name":"is-page-static","duration":2831720,"timestamp":884349762091,"id":1522,"parentId":1397,"tags":{},"startTime":1767360587311,"traceId":"1ada4263024251ab"},{"name":"check-page","duration":2915466,"timestamp":884349678356,"id":1397,"parentId":1285,"tags":{"page":"/observatory"},"startTime":1767360587227,"traceId":"1ada4263024251ab"},{"name":"is-page-static","duration":2838442,"timestamp":884349755522,"id":1520,"parentId":1410,"tags":{},"startTime":1767360587304,"traceId":"1ada4263024251ab"},{"name":"check-page","duration":2909828,"timestamp":884349684150,"id":1410,"parentId":1285,"tags":{"page":"/wp-admin"},"startTime":1767360587233,"traceId":"1ada4263024251ab"},{"name":"is-page-static","duration":2834356,"timestamp":884349762138,"id":1524,"parentId":1395,"tags":{},"startTime":1767360587311,"traceId":"1ada4263024251ab"},{"name":"check-page","duration":2919114,"timestamp":884349677405,"id":1395,"parentId":1285,"tags":{"page":"/missions"},"startTime":1767360587226,"traceId":"1ada4263024251ab"},{"name":"is-page-static","duration":2836408,"timestamp":884349762152,"id":1525,"parentId":1391,"tags":{},"startTime":1767360587311,"traceId":"1ada4263024251ab"},{"name":"check-page","duration":2923066,"timestamp":884349675509,"id":1391,"parentId":1285,"tags":{"page":"/mission-tab"},"startTime":1767360587224,"traceId":"1ada4263024251ab"},{"name":"is-page-static","duration":2851923,"timestamp":884349747105,"id":1515,"parentId":1403,"tags":{},"startTime":1767360587296,"traceId":"1ada4263024251ab"}] [{"name":"check-page","duration":2919373,"timestamp":884349680292,"id":1403,"parentId":1285,"tags":{"page":"/showcase"},"startTime":1767360587229,"traceId":"1ada4263024251ab"},{"name":"is-page-static","duration":2853757,"timestamp":884349765358,"id":1529,"parentId":1406,"tags":{},"startTime":1767360587314,"traceId":"1ada4263024251ab"},{"name":"check-page","duration":2937788,"timestamp":884349681354,"id":1406,"parentId":1285,"tags":{"page":"/the-message"},"startTime":1767360587230,"traceId":"1ada4263024251ab"},{"name":"is-page-static","duration":2861200,"timestamp":884349762178,"id":1527,"parentId":1392,"tags":{},"startTime":1767360587311,"traceId":"1ada4263024251ab"},{"name":"check-page","duration":2947083,"timestamp":884349676346,"id":1392,"parentId":1285,"tags":{"page":"/missions/[missionId]/edit"},"startTime":1767360587225,"traceId":"1ada4263024251ab"},{"name":"is-page-static","duration":2864255,"timestamp":884349762166,"id":1526,"parentId":1393,"tags":{},"startTime":1767360587311,"traceId":"1ada4263024251ab"},{"name":"check-page","duration":2949768,"timestamp":884349676685,"id":1393,"parentId":1285,"tags":{"page":"/missions/[missionId]"},"startTime":1767360587225,"traceId":"1ada4263024251ab"},{"name":"is-page-static","duration":2869029,"timestamp":884349762121,"id":1523,"parentId":1390,"tags":{},"startTime":1767360587311,"traceId":"1ada4263024251ab"},{"name":"check-page","duration":2956030,"timestamp":884349675143,"id":1390,"parentId":1285,"tags":{"page":"/mission-tab/[missionId]"},"startTime":1767360587224,"traceId":"1ada4263024251ab"},{"name":"is-page-static","duration":2868978,"timestamp":884349768587,"id":1531,"parentId":1394,"tags":{},"startTime":1767360587317,"traceId":"1ada4263024251ab"},{"name":"check-page","duration":2960761,"timestamp":884349676838,"id":1394,"parentId":1285,"tags":{"page":"/missions/new"},"startTime":1767360587225,"traceId":"1ada4263024251ab"},{"name":"is-page-static","duration":2872836,"timestamp":884349765117,"id":1528,"parentId":1404,"tags":{},"startTime":1767360587314,"traceId":"1ada4263024251ab"},{"name":"check-page","duration":2957221,"timestamp":884349680937,"id":1404,"parentId":1285,"tags":{"page":"/signin"},"startTime":1767360587229,"traceId":"1ada4263024251ab"},{"name":"is-page-static","duration":2900953,"timestamp":884349761124,"id":1521,"parentId":1407,"tags":{},"startTime":1767360587310,"traceId":"1ada4263024251ab"},{"name":"check-page","duration":2979951,"timestamp":884349682156,"id":1407,"parentId":1285,"tags":{"page":"/timetracker"},"startTime":1767360587231,"traceId":"1ada4263024251ab"},{"name":"is-page-static","duration":3117133,"timestamp":884349766749,"id":1530,"parentId":1382,"tags":{},"startTime":1767360587315,"traceId":"1ada4263024251ab"},{"name":"check-page","duration":3211495,"timestamp":884349672591,"id":1382,"parentId":1285,"tags":{"page":"/courrier"},"startTime":1767360587221,"traceId":"1ada4263024251ab"},{"name":"is-page-static","duration":3926802,"timestamp":884349711586,"id":1476,"parentId":1363,"tags":{},"startTime":1767360587260,"traceId":"1ada4263024251ab"},{"name":"check-page","duration":3970606,"timestamp":884349669246,"id":1363,"parentId":1285,"tags":{"page":"/api/parse-email"},"startTime":1767360587218,"traceId":"1ada4263024251ab"},{"name":"static-check","duration":4368635,"timestamp":884349278547,"id":1285,"parentId":1,"tags":{},"startTime":1767360586827,"traceId":"1ada4263024251ab"},{"name":"generate-required-server-files","duration":11514,"timestamp":884353665309,"id":1533,"parentId":1,"tags":{},"startTime":1767360591214,"traceId":"1ada4263024251ab"},{"name":"write-routes-manifest","duration":21417,"timestamp":884353750817,"id":1535,"parentId":1,"tags":{},"startTime":1767360591299,"traceId":"1ada4263024251ab"},{"name":"load-dotenv","duration":198,"timestamp":884357219816,"id":1538,"parentId":1537,"tags":{},"startTime":1767360594768,"traceId":"1ada4263024251ab"},{"name":"run-export-path-map","duration":1361,"timestamp":884358495390,"id":1539,"parentId":1537,"tags":{},"startTime":1767360596044,"traceId":"1ada4263024251ab"},{"name":"next-export","duration":3793919,"timestamp":884357218808,"id":1537,"parentId":1,"tags":{},"startTime":1767360594767,"traceId":"1ada4263024251ab"},{"name":"move-exported-app-not-found-","duration":123,"timestamp":884361016008,"id":1540,"parentId":1536,"tags":{},"startTime":1767360598565,"traceId":"1ada4263024251ab"},{"name":"move-exported-page","duration":17607,"timestamp":884361016272,"id":1541,"parentId":1536,"tags":{},"startTime":1767360598565,"traceId":"1ada4263024251ab"},{"name":"static-generation","duration":3922672,"timestamp":884357209136,"id":1536,"parentId":1,"tags":{},"startTime":1767360594758,"traceId":"1ada4263024251ab"},{"name":"write-routes-manifest","duration":46254,"timestamp":884361131836,"id":1542,"parentId":1,"tags":{},"startTime":1767360598680,"traceId":"1ada4263024251ab"},{"name":"node-file-trace-build","duration":14968888,"timestamp":884353732617,"id":1534,"parentId":1,"tags":{"isTurbotrace":"false"},"startTime":1767360591281,"traceId":"1ada4263024251ab"},{"name":"apply-include-excludes","duration":1013,"timestamp":884368701522,"id":1543,"parentId":1,"tags":{},"startTime":1767360606250,"traceId":"1ada4263024251ab"},{"name":"print-tree-view","duration":12772,"timestamp":884368702781,"id":1544,"parentId":1,"tags":{},"startTime":1767360606251,"traceId":"1ada4263024251ab"},{"name":"telemetry-flush","duration":31,"timestamp":884368715567,"id":1545,"parentId":1,"tags":{},"startTime":1767360606264,"traceId":"1ada4263024251ab"},{"name":"next-build","duration":47305807,"timestamp":884321409793,"id":1,"tags":{"buildMode":"default","isTurboBuild":"false","version":"15.3.1","has-custom-webpack-config":"true","use-build-worker":"false"},"startTime":1767360558958,"traceId":"1ada4263024251ab"}] +[{"name":"next-dev","duration":188286902071,"timestamp":809988579621,"id":1,"tags":{},"startTime":1767286226065,"traceId":"addfab527030c4f5"}] diff --git a/app/api/auth/options.ts b/app/api/auth/options.ts index 44d2836d..ee6f390b 100644 --- a/app/api/auth/options.ts +++ b/app/api/auth/options.ts @@ -194,6 +194,7 @@ export const authOptions: NextAuthOptions = { }, callbacks: { async jwt({ token, account, profile }) { + // Initial sign-in: account and profile are present if (account && profile) { const keycloakProfile = profile as KeycloakProfile; const roles = keycloakProfile.realm_access?.roles || []; @@ -204,13 +205,20 @@ export const authOptions: NextAuthOptions = { token.accessToken = account.access_token ?? ''; token.refreshToken = account.refresh_token ?? ''; token.idToken = account.id_token ?? ''; - token.accessTokenExpires = account.expires_at ?? 0; + // expires_at from Keycloak is in seconds since epoch, convert to milliseconds + token.accessTokenExpires = account.expires_at ? account.expires_at * 1000 : Date.now() + 3600 * 1000; token.sub = keycloakProfile.sub; token.role = cleanRoles; token.username = keycloakProfile.preferred_username ?? ''; token.first_name = keycloakProfile.given_name ?? ''; token.last_name = keycloakProfile.family_name ?? ''; - } else if (token.accessToken) { + + // Return immediately on initial sign-in - don't try to refresh tokens we just received + return token; + } + + // Subsequent requests: check existing token + if (token.accessToken) { try { const decoded = jwtDecode(token.accessToken as string); if (decoded.realm_access?.roles) { @@ -226,7 +234,7 @@ export const authOptions: NextAuthOptions = { } // Check if token is expired and needs refresh - // accessTokenExpires is in milliseconds (Date.now() + expires_in * 1000) + // accessTokenExpires is in milliseconds const expiresAt = token.accessTokenExpires as number; if (expiresAt && Date.now() < expiresAt) { // Token is still valid, return as-is @@ -273,7 +281,7 @@ export const authOptions: NextAuthOptions = { return refreshedToken; }, async session({ session, token }) { - // If session was invalidated or tokens are missing, return null to sign out + // If session was invalidated or tokens are missing, throw error to trigger sign out if (token.error === "SessionNotActive" || token.error === "NoRefreshToken" || !token.accessToken || @@ -284,11 +292,9 @@ export const authOptions: NextAuthOptions = { hasRefreshToken: !!token.refreshToken }); - // Return null to make NextAuth treat user as unauthenticated + // Throw error to make NextAuth treat user as unauthenticated // This will trigger automatic redirect to sign-in page - // The client-side code will detect session invalidation by checking for - // session cookie existence when status is unauthenticated - return null as any; + throw new Error(token.error || "SessionInvalidated"); } // For other errors, throw to trigger error handling