@oxyhq/services 5.16.29 → 5.16.31
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/lib/commonjs/core/services/SessionService.js +2 -1
- package/lib/commonjs/core/services/SessionService.js.map +1 -1
- package/lib/commonjs/core/services/TokenService.js +17 -9
- package/lib/commonjs/core/services/TokenService.js.map +1 -1
- package/lib/commonjs/index.js +64 -0
- package/lib/commonjs/index.js.map +1 -1
- package/lib/commonjs/models/interfaces.js +9 -8
- package/lib/commonjs/models/interfaces.js.map +1 -1
- package/lib/commonjs/ui/context/OxyContext.js +40 -4
- package/lib/commonjs/ui/context/OxyContext.js.map +1 -1
- package/lib/commonjs/ui/context/hooks/useAuthOperations.js +25 -14
- package/lib/commonjs/ui/context/hooks/useAuthOperations.js.map +1 -1
- package/lib/commonjs/ui/hooks/auth/index.js +37 -0
- package/lib/commonjs/ui/hooks/auth/index.js.map +1 -0
- package/lib/commonjs/ui/hooks/auth/useUsernameValidation.js +171 -0
- package/lib/commonjs/ui/hooks/auth/useUsernameValidation.js.map +1 -0
- package/lib/commonjs/ui/hooks/index.js +20 -0
- package/lib/commonjs/ui/hooks/index.js.map +1 -1
- package/lib/commonjs/ui/hooks/mutations/index.js +12 -0
- package/lib/commonjs/ui/hooks/mutations/index.js.map +1 -1
- package/lib/commonjs/ui/hooks/mutations/useAccountMutations.js +45 -1
- package/lib/commonjs/ui/hooks/mutations/useAccountMutations.js.map +1 -1
- package/lib/commonjs/ui/hooks/queries/index.js +12 -0
- package/lib/commonjs/ui/hooks/queries/index.js.map +1 -1
- package/lib/commonjs/ui/hooks/queries/queryKeys.js +3 -1
- package/lib/commonjs/ui/hooks/queries/queryKeys.js.map +1 -1
- package/lib/commonjs/ui/hooks/queries/useAccountQueries.js +43 -1
- package/lib/commonjs/ui/hooks/queries/useAccountQueries.js.map +1 -1
- package/lib/commonjs/ui/hooks/queries/useServicesQueries.js +12 -4
- package/lib/commonjs/ui/hooks/queries/useServicesQueries.js.map +1 -1
- package/lib/commonjs/ui/hooks/useSessionManagement.js +8 -0
- package/lib/commonjs/ui/hooks/useSessionManagement.js.map +1 -1
- package/lib/commonjs/ui/screens/PrivacySettingsScreen.js +76 -97
- package/lib/commonjs/ui/screens/PrivacySettingsScreen.js.map +1 -1
- package/lib/commonjs/ui/utils/sessionHelpers.js +26 -11
- package/lib/commonjs/ui/utils/sessionHelpers.js.map +1 -1
- package/lib/commonjs/utils/sessionUtils.js +8 -1
- package/lib/commonjs/utils/sessionUtils.js.map +1 -1
- package/lib/module/core/services/SessionService.js +2 -1
- package/lib/module/core/services/SessionService.js.map +1 -1
- package/lib/module/core/services/TokenService.js +17 -9
- package/lib/module/core/services/TokenService.js.map +1 -1
- package/lib/module/index.js +3 -3
- package/lib/module/index.js.map +1 -1
- package/lib/module/models/interfaces.js +9 -8
- package/lib/module/models/interfaces.js.map +1 -1
- package/lib/module/ui/context/OxyContext.js +40 -4
- package/lib/module/ui/context/OxyContext.js.map +1 -1
- package/lib/module/ui/context/hooks/useAuthOperations.js +25 -14
- package/lib/module/ui/context/hooks/useAuthOperations.js.map +1 -1
- package/lib/module/ui/hooks/auth/index.js +7 -0
- package/lib/module/ui/hooks/auth/index.js.map +1 -0
- package/lib/module/ui/hooks/auth/useUsernameValidation.js +167 -0
- package/lib/module/ui/hooks/auth/useUsernameValidation.js.map +1 -0
- package/lib/module/ui/hooks/index.js +1 -0
- package/lib/module/ui/hooks/index.js.map +1 -1
- package/lib/module/ui/hooks/mutations/index.js +1 -1
- package/lib/module/ui/hooks/mutations/index.js.map +1 -1
- package/lib/module/ui/hooks/mutations/useAccountMutations.js +42 -0
- package/lib/module/ui/hooks/mutations/useAccountMutations.js.map +1 -1
- package/lib/module/ui/hooks/queries/index.js +1 -1
- package/lib/module/ui/hooks/queries/index.js.map +1 -1
- package/lib/module/ui/hooks/queries/queryKeys.js +3 -1
- package/lib/module/ui/hooks/queries/queryKeys.js.map +1 -1
- package/lib/module/ui/hooks/queries/useAccountQueries.js +40 -0
- package/lib/module/ui/hooks/queries/useAccountQueries.js.map +1 -1
- package/lib/module/ui/hooks/queries/useServicesQueries.js +13 -5
- package/lib/module/ui/hooks/queries/useServicesQueries.js.map +1 -1
- package/lib/module/ui/hooks/useSessionManagement.js +8 -0
- package/lib/module/ui/hooks/useSessionManagement.js.map +1 -1
- package/lib/module/ui/screens/PrivacySettingsScreen.js +77 -98
- package/lib/module/ui/screens/PrivacySettingsScreen.js.map +1 -1
- package/lib/module/ui/utils/sessionHelpers.js +26 -11
- package/lib/module/ui/utils/sessionHelpers.js.map +1 -1
- package/lib/module/utils/sessionUtils.js +8 -1
- package/lib/module/utils/sessionUtils.js.map +1 -1
- package/lib/typescript/core/services/SessionService.d.ts +4 -2
- package/lib/typescript/core/services/SessionService.d.ts.map +1 -1
- package/lib/typescript/core/services/TokenService.d.ts +8 -3
- package/lib/typescript/core/services/TokenService.d.ts.map +1 -1
- package/lib/typescript/index.d.ts +4 -2
- package/lib/typescript/index.d.ts.map +1 -1
- package/lib/typescript/models/interfaces.d.ts +9 -8
- package/lib/typescript/models/interfaces.d.ts.map +1 -1
- package/lib/typescript/models/session.d.ts +4 -2
- package/lib/typescript/models/session.d.ts.map +1 -1
- package/lib/typescript/ui/context/OxyContext.d.ts.map +1 -1
- package/lib/typescript/ui/context/hooks/useAuthOperations.d.ts.map +1 -1
- package/lib/typescript/ui/hooks/auth/index.d.ts +6 -0
- package/lib/typescript/ui/hooks/auth/index.d.ts.map +1 -0
- package/lib/typescript/ui/hooks/auth/useUsernameValidation.d.ts +32 -0
- package/lib/typescript/ui/hooks/auth/useUsernameValidation.d.ts.map +1 -0
- package/lib/typescript/ui/hooks/index.d.ts +1 -0
- package/lib/typescript/ui/hooks/index.d.ts.map +1 -1
- package/lib/typescript/ui/hooks/mutations/index.d.ts +1 -1
- package/lib/typescript/ui/hooks/mutations/index.d.ts.map +1 -1
- package/lib/typescript/ui/hooks/mutations/useAccountMutations.d.ts +12 -0
- package/lib/typescript/ui/hooks/mutations/useAccountMutations.d.ts.map +1 -1
- package/lib/typescript/ui/hooks/queries/index.d.ts +1 -1
- package/lib/typescript/ui/hooks/queries/index.d.ts.map +1 -1
- package/lib/typescript/ui/hooks/queries/queryKeys.d.ts +2 -0
- package/lib/typescript/ui/hooks/queries/queryKeys.d.ts.map +1 -1
- package/lib/typescript/ui/hooks/queries/useAccountQueries.d.ts +12 -0
- package/lib/typescript/ui/hooks/queries/useAccountQueries.d.ts.map +1 -1
- package/lib/typescript/ui/hooks/queries/useServicesQueries.d.ts.map +1 -1
- package/lib/typescript/ui/hooks/useSessionManagement.d.ts.map +1 -1
- package/lib/typescript/ui/screens/PrivacySettingsScreen.d.ts.map +1 -1
- package/lib/typescript/ui/utils/sessionHelpers.d.ts +6 -2
- package/lib/typescript/ui/utils/sessionHelpers.d.ts.map +1 -1
- package/lib/typescript/utils/sessionUtils.d.ts.map +1 -1
- package/package.json +1 -1
- package/src/core/services/SessionService.ts +4 -2
- package/src/core/services/TokenService.ts +18 -10
- package/src/index.ts +6 -0
- package/src/models/interfaces.ts +11 -10
- package/src/models/session.ts +5 -3
- package/src/ui/context/OxyContext.tsx +56 -20
- package/src/ui/context/hooks/useAuthOperations.ts +23 -15
- package/src/ui/hooks/auth/index.ts +7 -0
- package/src/ui/hooks/auth/useUsernameValidation.ts +177 -0
- package/src/ui/hooks/index.ts +2 -1
- package/src/ui/hooks/mutations/index.ts +2 -0
- package/src/ui/hooks/mutations/useAccountMutations.ts +36 -0
- package/src/ui/hooks/queries/index.ts +2 -0
- package/src/ui/hooks/queries/queryKeys.ts +2 -0
- package/src/ui/hooks/queries/useAccountQueries.ts +34 -0
- package/src/ui/hooks/queries/useServicesQueries.ts +8 -3
- package/src/ui/hooks/useSessionManagement.ts +8 -1
- package/src/ui/screens/PrivacySettingsScreen.tsx +67 -101
- package/src/ui/utils/sessionHelpers.ts +32 -15
- package/src/utils/sessionUtils.ts +8 -1
- package/lib/commonjs/ui/context/hooks/useSessionManagement.js +0 -281
- package/lib/commonjs/ui/context/hooks/useSessionManagement.js.map +0 -1
- package/lib/commonjs/ui/context/hooks/useStorage.js +0 -79
- package/lib/commonjs/ui/context/hooks/useStorage.js.map +0 -1
- package/lib/module/ui/context/hooks/useSessionManagement.js +0 -276
- package/lib/module/ui/context/hooks/useSessionManagement.js.map +0 -1
- package/lib/module/ui/context/hooks/useStorage.js +0 -74
- package/lib/module/ui/context/hooks/useStorage.js.map +0 -1
- package/lib/typescript/ui/context/hooks/useSessionManagement.d.ts +0 -41
- package/lib/typescript/ui/context/hooks/useSessionManagement.d.ts.map +0 -1
- package/lib/typescript/ui/context/hooks/useStorage.d.ts +0 -22
- package/lib/typescript/ui/context/hooks/useStorage.d.ts.map +0 -1
- package/src/ui/context/hooks/useSessionManagement.ts +0 -401
- package/src/ui/context/hooks/useStorage.ts +0 -104
|
@@ -1,281 +0,0 @@
|
|
|
1
|
-
"use strict";
|
|
2
|
-
|
|
3
|
-
Object.defineProperty(exports, "__esModule", {
|
|
4
|
-
value: true
|
|
5
|
-
});
|
|
6
|
-
exports.useSessionManagement = void 0;
|
|
7
|
-
var _react = require("react");
|
|
8
|
-
var _sessionUtils = require("../../../utils/sessionUtils");
|
|
9
|
-
var _sessionHelpers = require("../../utils/sessionHelpers");
|
|
10
|
-
var _storageHelpers = require("../../utils/storageHelpers");
|
|
11
|
-
var _errorHandlers = require("../../utils/errorHandlers");
|
|
12
|
-
var _queryClient = require("../../hooks/queryClient");
|
|
13
|
-
const DEFAULT_SAVE_ERROR_MESSAGE = 'Failed to save session data';
|
|
14
|
-
const CLEAR_STORAGE_ERROR = 'Failed to clear storage';
|
|
15
|
-
|
|
16
|
-
/**
|
|
17
|
-
* Manage session state, persistence, and high-level multi-session operations.
|
|
18
|
-
*
|
|
19
|
-
* @param options - Session management configuration
|
|
20
|
-
*/
|
|
21
|
-
const useSessionManagement = ({
|
|
22
|
-
oxyServices,
|
|
23
|
-
storage,
|
|
24
|
-
storageKeyPrefix,
|
|
25
|
-
loginSuccess,
|
|
26
|
-
logoutStore,
|
|
27
|
-
applyLanguagePreference,
|
|
28
|
-
onAuthStateChange,
|
|
29
|
-
onError,
|
|
30
|
-
setAuthError,
|
|
31
|
-
logger,
|
|
32
|
-
setTokenReady,
|
|
33
|
-
queryClient
|
|
34
|
-
}) => {
|
|
35
|
-
const [sessions, setSessions] = (0, _react.useState)([]);
|
|
36
|
-
const [activeSessionId, setActiveSessionId] = (0, _react.useState)(null);
|
|
37
|
-
const refreshInFlightRef = (0, _react.useRef)(null);
|
|
38
|
-
const removedSessionsRef = (0, _react.useRef)(new Set());
|
|
39
|
-
const lastRefreshRef = (0, _react.useRef)(0);
|
|
40
|
-
const storageKeys = (0, _react.useMemo)(() => (0, _storageHelpers.getStorageKeys)(storageKeyPrefix), [storageKeyPrefix]);
|
|
41
|
-
const saveSessionIds = (0, _react.useCallback)(async sessionIds => {
|
|
42
|
-
if (!storage) return;
|
|
43
|
-
try {
|
|
44
|
-
const uniqueIds = Array.from(new Set(sessionIds));
|
|
45
|
-
await storage.setItem(storageKeys.sessionIds, JSON.stringify(uniqueIds));
|
|
46
|
-
} catch (error) {
|
|
47
|
-
if (logger) {
|
|
48
|
-
logger(DEFAULT_SAVE_ERROR_MESSAGE, error);
|
|
49
|
-
} else if (__DEV__) {
|
|
50
|
-
console.warn('Failed to save session IDs:', error);
|
|
51
|
-
}
|
|
52
|
-
}
|
|
53
|
-
}, [logger, storage, storageKeys.sessionIds]);
|
|
54
|
-
const updateSessions = (0, _react.useCallback)((incoming, options = {}) => {
|
|
55
|
-
setSessions(prevSessions => {
|
|
56
|
-
const processed = options.merge ? (0, _sessionUtils.mergeSessions)(prevSessions, incoming, activeSessionId, false) : (0, _sessionUtils.normalizeAndSortSessions)(incoming, activeSessionId, false);
|
|
57
|
-
if (storage) {
|
|
58
|
-
void saveSessionIds(processed.map(session => session.sessionId));
|
|
59
|
-
}
|
|
60
|
-
if ((0, _sessionUtils.sessionsArraysEqual)(prevSessions, processed)) {
|
|
61
|
-
return prevSessions;
|
|
62
|
-
}
|
|
63
|
-
return processed;
|
|
64
|
-
});
|
|
65
|
-
}, [activeSessionId, saveSessionIds, storage]);
|
|
66
|
-
const saveActiveSessionId = (0, _react.useCallback)(async sessionId => {
|
|
67
|
-
if (!storage) return;
|
|
68
|
-
try {
|
|
69
|
-
await storage.setItem(storageKeys.activeSessionId, sessionId);
|
|
70
|
-
} catch (error) {
|
|
71
|
-
(0, _errorHandlers.handleAuthError)(error, {
|
|
72
|
-
defaultMessage: DEFAULT_SAVE_ERROR_MESSAGE,
|
|
73
|
-
code: 'SESSION_PERSISTENCE_ERROR',
|
|
74
|
-
onError,
|
|
75
|
-
setAuthError,
|
|
76
|
-
logger
|
|
77
|
-
});
|
|
78
|
-
}
|
|
79
|
-
}, [logger, onError, setAuthError, storage, storageKeys.activeSessionId]);
|
|
80
|
-
const removeActiveSessionId = (0, _react.useCallback)(async () => {
|
|
81
|
-
if (!storage) return;
|
|
82
|
-
try {
|
|
83
|
-
await storage.removeItem(storageKeys.activeSessionId);
|
|
84
|
-
} catch (error) {
|
|
85
|
-
(0, _errorHandlers.handleAuthError)(error, {
|
|
86
|
-
defaultMessage: DEFAULT_SAVE_ERROR_MESSAGE,
|
|
87
|
-
code: 'SESSION_PERSISTENCE_ERROR',
|
|
88
|
-
onError,
|
|
89
|
-
setAuthError,
|
|
90
|
-
logger
|
|
91
|
-
});
|
|
92
|
-
}
|
|
93
|
-
}, [logger, onError, setAuthError, storage, storageKeys.activeSessionId]);
|
|
94
|
-
const clearSessionStorage = (0, _react.useCallback)(async () => {
|
|
95
|
-
if (!storage) return;
|
|
96
|
-
try {
|
|
97
|
-
await storage.removeItem(storageKeys.activeSessionId);
|
|
98
|
-
await storage.removeItem(storageKeys.sessionIds);
|
|
99
|
-
// Clear identity sync state
|
|
100
|
-
await storage.removeItem('oxy_identity_synced').catch(() => {});
|
|
101
|
-
} catch (error) {
|
|
102
|
-
(0, _errorHandlers.handleAuthError)(error, {
|
|
103
|
-
defaultMessage: CLEAR_STORAGE_ERROR,
|
|
104
|
-
code: 'STORAGE_ERROR',
|
|
105
|
-
onError,
|
|
106
|
-
setAuthError,
|
|
107
|
-
logger
|
|
108
|
-
});
|
|
109
|
-
}
|
|
110
|
-
}, [logger, onError, setAuthError, storage, storageKeys.activeSessionId, storageKeys.sessionIds]);
|
|
111
|
-
const clearSessionState = (0, _react.useCallback)(async () => {
|
|
112
|
-
setSessions([]);
|
|
113
|
-
setActiveSessionId(null);
|
|
114
|
-
logoutStore();
|
|
115
|
-
|
|
116
|
-
// Clear TanStack Query cache (in-memory)
|
|
117
|
-
if (queryClient) {
|
|
118
|
-
queryClient.clear();
|
|
119
|
-
}
|
|
120
|
-
|
|
121
|
-
// Clear persisted query cache
|
|
122
|
-
if (storage) {
|
|
123
|
-
try {
|
|
124
|
-
await (0, _queryClient.clearQueryCache)(storage);
|
|
125
|
-
} catch (error) {
|
|
126
|
-
if (logger) {
|
|
127
|
-
logger('Failed to clear persisted query cache', error);
|
|
128
|
-
}
|
|
129
|
-
}
|
|
130
|
-
}
|
|
131
|
-
await clearSessionStorage();
|
|
132
|
-
onAuthStateChange?.(null);
|
|
133
|
-
}, [clearSessionStorage, logoutStore, onAuthStateChange, queryClient, storage, logger]);
|
|
134
|
-
const activateSession = (0, _react.useCallback)(async (sessionId, user) => {
|
|
135
|
-
await oxyServices.getTokenBySession(sessionId);
|
|
136
|
-
setTokenReady?.(true);
|
|
137
|
-
setActiveSessionId(sessionId);
|
|
138
|
-
loginSuccess(user);
|
|
139
|
-
await saveActiveSessionId(sessionId);
|
|
140
|
-
await applyLanguagePreference(user);
|
|
141
|
-
onAuthStateChange?.(user);
|
|
142
|
-
}, [applyLanguagePreference, loginSuccess, onAuthStateChange, oxyServices, saveActiveSessionId, setTokenReady]);
|
|
143
|
-
const trackRemovedSession = (0, _react.useCallback)(sessionId => {
|
|
144
|
-
removedSessionsRef.current.add(sessionId);
|
|
145
|
-
setTimeout(() => {
|
|
146
|
-
removedSessionsRef.current.delete(sessionId);
|
|
147
|
-
}, 5000);
|
|
148
|
-
}, []);
|
|
149
|
-
const findReplacementSession = (0, _react.useCallback)(async sessionIds => {
|
|
150
|
-
if (!sessionIds.length) {
|
|
151
|
-
return null;
|
|
152
|
-
}
|
|
153
|
-
const validationResults = await (0, _sessionHelpers.validateSessionBatch)(oxyServices, sessionIds, {
|
|
154
|
-
maxConcurrency: 3
|
|
155
|
-
});
|
|
156
|
-
const validSession = validationResults.find(result => result.valid);
|
|
157
|
-
if (!validSession) {
|
|
158
|
-
return null;
|
|
159
|
-
}
|
|
160
|
-
const validation = await oxyServices.validateSession(validSession.sessionId, {
|
|
161
|
-
useHeaderValidation: true
|
|
162
|
-
});
|
|
163
|
-
if (!validation?.valid || !validation.user) {
|
|
164
|
-
return null;
|
|
165
|
-
}
|
|
166
|
-
const user = validation.user;
|
|
167
|
-
await activateSession(validSession.sessionId, user);
|
|
168
|
-
return user;
|
|
169
|
-
}, [activateSession, oxyServices]);
|
|
170
|
-
const switchSession = (0, _react.useCallback)(async sessionId => {
|
|
171
|
-
try {
|
|
172
|
-
const validation = await oxyServices.validateSession(sessionId, {
|
|
173
|
-
useHeaderValidation: true
|
|
174
|
-
});
|
|
175
|
-
if (!validation?.valid) {
|
|
176
|
-
throw new Error('Session is invalid or expired');
|
|
177
|
-
}
|
|
178
|
-
if (!validation.user) {
|
|
179
|
-
throw new Error('User data not available from session validation');
|
|
180
|
-
}
|
|
181
|
-
const user = validation.user;
|
|
182
|
-
await activateSession(sessionId, user);
|
|
183
|
-
try {
|
|
184
|
-
const deviceSessions = await (0, _sessionHelpers.fetchSessionsWithFallback)(oxyServices, sessionId, {
|
|
185
|
-
fallbackUserId: user.id,
|
|
186
|
-
logger
|
|
187
|
-
});
|
|
188
|
-
updateSessions(deviceSessions, {
|
|
189
|
-
merge: true
|
|
190
|
-
});
|
|
191
|
-
} catch (error) {
|
|
192
|
-
if (__DEV__) {
|
|
193
|
-
console.warn('Failed to synchronize sessions after switch:', error);
|
|
194
|
-
}
|
|
195
|
-
}
|
|
196
|
-
return user;
|
|
197
|
-
} catch (error) {
|
|
198
|
-
const invalidSession = (0, _errorHandlers.isInvalidSessionError)(error);
|
|
199
|
-
if (invalidSession) {
|
|
200
|
-
updateSessions(sessions.filter(session => session.sessionId !== sessionId), {
|
|
201
|
-
merge: false
|
|
202
|
-
});
|
|
203
|
-
if (sessionId === activeSessionId) {
|
|
204
|
-
const otherSessionIds = sessions.filter(session => session.sessionId !== sessionId && !removedSessionsRef.current.has(session.sessionId)).map(session => session.sessionId);
|
|
205
|
-
const replacementUser = await findReplacementSession(otherSessionIds);
|
|
206
|
-
if (replacementUser) {
|
|
207
|
-
return replacementUser;
|
|
208
|
-
}
|
|
209
|
-
}
|
|
210
|
-
}
|
|
211
|
-
(0, _errorHandlers.handleAuthError)(error, {
|
|
212
|
-
defaultMessage: 'Failed to switch session',
|
|
213
|
-
code: invalidSession ? 'INVALID_SESSION' : 'SESSION_SWITCH_ERROR',
|
|
214
|
-
onError,
|
|
215
|
-
setAuthError,
|
|
216
|
-
logger
|
|
217
|
-
});
|
|
218
|
-
throw error instanceof Error ? error : new Error('Failed to switch session');
|
|
219
|
-
}
|
|
220
|
-
}, [activateSession, activeSessionId, findReplacementSession, logger, loginSuccess, onError, oxyServices, sessions, setAuthError, updateSessions]);
|
|
221
|
-
const refreshSessions = (0, _react.useCallback)(async activeUserId => {
|
|
222
|
-
if (!activeSessionId) return;
|
|
223
|
-
if (refreshInFlightRef.current) {
|
|
224
|
-
await refreshInFlightRef.current;
|
|
225
|
-
return;
|
|
226
|
-
}
|
|
227
|
-
const now = Date.now();
|
|
228
|
-
if (now - lastRefreshRef.current < 500) {
|
|
229
|
-
return;
|
|
230
|
-
}
|
|
231
|
-
lastRefreshRef.current = now;
|
|
232
|
-
const refreshPromise = (async () => {
|
|
233
|
-
try {
|
|
234
|
-
const deviceSessions = await (0, _sessionHelpers.fetchSessionsWithFallback)(oxyServices, activeSessionId, {
|
|
235
|
-
fallbackUserId: activeUserId,
|
|
236
|
-
logger
|
|
237
|
-
});
|
|
238
|
-
updateSessions(deviceSessions, {
|
|
239
|
-
merge: true
|
|
240
|
-
});
|
|
241
|
-
} catch (error) {
|
|
242
|
-
if ((0, _errorHandlers.isInvalidSessionError)(error)) {
|
|
243
|
-
const otherSessions = sessions.filter(session => session.sessionId !== activeSessionId && !removedSessionsRef.current.has(session.sessionId)).map(session => session.sessionId);
|
|
244
|
-
const replacementUser = await findReplacementSession(otherSessions);
|
|
245
|
-
if (!replacementUser) {
|
|
246
|
-
await clearSessionState();
|
|
247
|
-
}
|
|
248
|
-
return;
|
|
249
|
-
}
|
|
250
|
-
(0, _errorHandlers.handleAuthError)(error, {
|
|
251
|
-
defaultMessage: 'Failed to refresh sessions',
|
|
252
|
-
code: 'SESSION_REFRESH_ERROR',
|
|
253
|
-
onError,
|
|
254
|
-
setAuthError,
|
|
255
|
-
logger
|
|
256
|
-
});
|
|
257
|
-
} finally {
|
|
258
|
-
refreshInFlightRef.current = null;
|
|
259
|
-
lastRefreshRef.current = Date.now();
|
|
260
|
-
}
|
|
261
|
-
})();
|
|
262
|
-
refreshInFlightRef.current = refreshPromise;
|
|
263
|
-
await refreshPromise;
|
|
264
|
-
}, [activeSessionId, clearSessionState, findReplacementSession, logger, onError, oxyServices, sessions, setAuthError, updateSessions]);
|
|
265
|
-
const isRefreshInFlight = Boolean(refreshInFlightRef.current);
|
|
266
|
-
return {
|
|
267
|
-
sessions,
|
|
268
|
-
activeSessionId,
|
|
269
|
-
setActiveSessionId,
|
|
270
|
-
updateSessions,
|
|
271
|
-
switchSession,
|
|
272
|
-
refreshSessions,
|
|
273
|
-
clearSessionState,
|
|
274
|
-
saveActiveSessionId,
|
|
275
|
-
trackRemovedSession,
|
|
276
|
-
storageKeys,
|
|
277
|
-
isRefreshInFlight
|
|
278
|
-
};
|
|
279
|
-
};
|
|
280
|
-
exports.useSessionManagement = useSessionManagement;
|
|
281
|
-
//# sourceMappingURL=useSessionManagement.js.map
|
|
@@ -1 +0,0 @@
|
|
|
1
|
-
{"version":3,"names":["_react","require","_sessionUtils","_sessionHelpers","_storageHelpers","_errorHandlers","_queryClient","DEFAULT_SAVE_ERROR_MESSAGE","CLEAR_STORAGE_ERROR","useSessionManagement","oxyServices","storage","storageKeyPrefix","loginSuccess","logoutStore","applyLanguagePreference","onAuthStateChange","onError","setAuthError","logger","setTokenReady","queryClient","sessions","setSessions","useState","activeSessionId","setActiveSessionId","refreshInFlightRef","useRef","removedSessionsRef","Set","lastRefreshRef","storageKeys","useMemo","getStorageKeys","saveSessionIds","useCallback","sessionIds","uniqueIds","Array","from","setItem","JSON","stringify","error","__DEV__","console","warn","updateSessions","incoming","options","prevSessions","processed","merge","mergeSessions","normalizeAndSortSessions","map","session","sessionId","sessionsArraysEqual","saveActiveSessionId","handleAuthError","defaultMessage","code","removeActiveSessionId","removeItem","clearSessionStorage","catch","clearSessionState","clear","clearQueryCache","activateSession","user","getTokenBySession","trackRemovedSession","current","add","setTimeout","delete","findReplacementSession","length","validationResults","validateSessionBatch","maxConcurrency","validSession","find","result","valid","validation","validateSession","useHeaderValidation","switchSession","Error","deviceSessions","fetchSessionsWithFallback","fallbackUserId","id","invalidSession","isInvalidSessionError","filter","otherSessionIds","has","replacementUser","refreshSessions","activeUserId","now","Date","refreshPromise","otherSessions","isRefreshInFlight","Boolean","exports"],"sourceRoot":"../../../../../src","sources":["ui/context/hooks/useSessionManagement.ts"],"mappings":"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","ignoreList":[]}
|
|
@@ -1,79 +0,0 @@
|
|
|
1
|
-
"use strict";
|
|
2
|
-
|
|
3
|
-
Object.defineProperty(exports, "__esModule", {
|
|
4
|
-
value: true
|
|
5
|
-
});
|
|
6
|
-
exports.useStorage = void 0;
|
|
7
|
-
var _react = require("react");
|
|
8
|
-
var _storageHelpers = require("../../utils/storageHelpers");
|
|
9
|
-
var _errorHandlers = require("../../utils/errorHandlers");
|
|
10
|
-
const DEFAULT_ERROR_CODE = 'STORAGE_INIT_ERROR';
|
|
11
|
-
|
|
12
|
-
/**
|
|
13
|
-
* React hook that exposes a platform-agnostic storage reference.
|
|
14
|
-
* Handles initialization, error propagation, and lazy re-initialization.
|
|
15
|
-
*
|
|
16
|
-
* @param options - Optional configuration for error reporting and logging
|
|
17
|
-
*/
|
|
18
|
-
const useStorage = ({
|
|
19
|
-
onError,
|
|
20
|
-
logger,
|
|
21
|
-
errorCode = DEFAULT_ERROR_CODE
|
|
22
|
-
} = {}) => {
|
|
23
|
-
const [storage, setStorage] = (0, _react.useState)(null);
|
|
24
|
-
const [error, setError] = (0, _react.useState)(null);
|
|
25
|
-
const initializingRef = (0, _react.useRef)(null);
|
|
26
|
-
const notifyError = (0, _react.useCallback)(err => {
|
|
27
|
-
const message = (0, _errorHandlers.extractErrorMessage)(err, 'Failed to initialize storage');
|
|
28
|
-
setError(message);
|
|
29
|
-
if (logger) {
|
|
30
|
-
logger(message, err);
|
|
31
|
-
}
|
|
32
|
-
onError?.({
|
|
33
|
-
message,
|
|
34
|
-
code: errorCode,
|
|
35
|
-
status: 500
|
|
36
|
-
});
|
|
37
|
-
}, [errorCode, logger, onError]);
|
|
38
|
-
const createStorageInstance = (0, _react.useCallback)(async () => {
|
|
39
|
-
try {
|
|
40
|
-
const platformStorage = await (0, _storageHelpers.createPlatformStorage)();
|
|
41
|
-
setStorage(platformStorage);
|
|
42
|
-
setError(null);
|
|
43
|
-
return platformStorage;
|
|
44
|
-
} catch (err) {
|
|
45
|
-
notifyError(err);
|
|
46
|
-
setStorage(null);
|
|
47
|
-
return null;
|
|
48
|
-
}
|
|
49
|
-
}, [notifyError]);
|
|
50
|
-
const refresh = (0, _react.useCallback)(async () => {
|
|
51
|
-
if (!initializingRef.current) {
|
|
52
|
-
initializingRef.current = createStorageInstance().finally(() => {
|
|
53
|
-
initializingRef.current = null;
|
|
54
|
-
});
|
|
55
|
-
}
|
|
56
|
-
return initializingRef.current;
|
|
57
|
-
}, [createStorageInstance]);
|
|
58
|
-
(0, _react.useEffect)(() => {
|
|
59
|
-
refresh().catch(err => {
|
|
60
|
-
notifyError(err);
|
|
61
|
-
});
|
|
62
|
-
}, [refresh, notifyError]);
|
|
63
|
-
const withStorage = (0, _react.useCallback)(async callback => {
|
|
64
|
-
const resolvedStorage = storage ?? (await refresh());
|
|
65
|
-
if (!resolvedStorage) {
|
|
66
|
-
return null;
|
|
67
|
-
}
|
|
68
|
-
return callback(resolvedStorage);
|
|
69
|
-
}, [refresh, storage]);
|
|
70
|
-
return {
|
|
71
|
-
storage,
|
|
72
|
-
isReady: Boolean(storage) && !error,
|
|
73
|
-
error,
|
|
74
|
-
refresh,
|
|
75
|
-
withStorage
|
|
76
|
-
};
|
|
77
|
-
};
|
|
78
|
-
exports.useStorage = useStorage;
|
|
79
|
-
//# sourceMappingURL=useStorage.js.map
|
|
@@ -1 +0,0 @@
|
|
|
1
|
-
{"version":3,"names":["_react","require","_storageHelpers","_errorHandlers","DEFAULT_ERROR_CODE","useStorage","onError","logger","errorCode","storage","setStorage","useState","error","setError","initializingRef","useRef","notifyError","useCallback","err","message","extractErrorMessage","code","status","createStorageInstance","platformStorage","createPlatformStorage","refresh","current","finally","useEffect","catch","withStorage","callback","resolvedStorage","isReady","Boolean","exports"],"sourceRoot":"../../../../../src","sources":["ui/context/hooks/useStorage.ts"],"mappings":";;;;;;AAAA,IAAAA,MAAA,GAAAC,OAAA;AAEA,IAAAC,eAAA,GAAAD,OAAA;AACA,IAAAE,cAAA,GAAAF,OAAA;AAgBA,MAAMG,kBAAkB,GAAG,oBAAoB;;AAE/C;AACA;AACA;AACA;AACA;AACA;AACO,MAAMC,UAAU,GAAGA,CAAC;EACzBC,OAAO;EACPC,MAAM;EACNC,SAAS,GAAGJ;AACK,CAAC,GAAG,CAAC,CAAC,KAAuB;EAC9C,MAAM,CAACK,OAAO,EAAEC,UAAU,CAAC,GAAG,IAAAC,eAAQ,EAA0B,IAAI,CAAC;EACrE,MAAM,CAACC,KAAK,EAAEC,QAAQ,CAAC,GAAG,IAAAF,eAAQ,EAAgB,IAAI,CAAC;EACvD,MAAMG,eAAe,GAAG,IAAAC,aAAM,EAA0C,IAAI,CAAC;EAE7E,MAAMC,WAAW,GAAG,IAAAC,kBAAW,EAC5BC,GAAY,IAAK;IAChB,MAAMC,OAAO,GAAG,IAAAC,kCAAmB,EAACF,GAAG,EAAE,8BAA8B,CAAC;IACxEL,QAAQ,CAACM,OAAO,CAAC;IAEjB,IAAIZ,MAAM,EAAE;MACVA,MAAM,CAACY,OAAO,EAAED,GAAG,CAAC;IACtB;IAEAZ,OAAO,GAAG;MACRa,OAAO;MACPE,IAAI,EAAEb,SAAS;MACfc,MAAM,EAAE;IACV,CAAC,CAAC;EACJ,CAAC,EACD,CAACd,SAAS,EAAED,MAAM,EAAED,OAAO,CAC7B,CAAC;EAED,MAAMiB,qBAAqB,GAAG,IAAAN,kBAAW,EAAC,YAA8C;IACtF,IAAI;MACF,MAAMO,eAAe,GAAG,MAAM,IAAAC,qCAAqB,EAAC,CAAC;MACrDf,UAAU,CAACc,eAAe,CAAC;MAC3BX,QAAQ,CAAC,IAAI,CAAC;MACd,OAAOW,eAAe;IACxB,CAAC,CAAC,OAAON,GAAG,EAAE;MACZF,WAAW,CAACE,GAAG,CAAC;MAChBR,UAAU,CAAC,IAAI,CAAC;MAChB,OAAO,IAAI;IACb;EACF,CAAC,EAAE,CAACM,WAAW,CAAC,CAAC;EAEjB,MAAMU,OAAO,GAAG,IAAAT,kBAAW,EAAC,YAA8C;IACxE,IAAI,CAACH,eAAe,CAACa,OAAO,EAAE;MAC5Bb,eAAe,CAACa,OAAO,GAAGJ,qBAAqB,CAAC,CAAC,CAACK,OAAO,CAAC,MAAM;QAC9Dd,eAAe,CAACa,OAAO,GAAG,IAAI;MAChC,CAAC,CAAC;IACJ;IAEA,OAAOb,eAAe,CAACa,OAAO;EAChC,CAAC,EAAE,CAACJ,qBAAqB,CAAC,CAAC;EAE3B,IAAAM,gBAAS,EAAC,MAAM;IACdH,OAAO,CAAC,CAAC,CAACI,KAAK,CAAEZ,GAAG,IAAK;MACvBF,WAAW,CAACE,GAAG,CAAC;IAClB,CAAC,CAAC;EACJ,CAAC,EAAE,CAACQ,OAAO,EAAEV,WAAW,CAAC,CAAC;EAE1B,MAAMe,WAAW,GAAG,IAAAd,kBAAW,EAC7B,MAAWe,QAA2D,IAAwB;IAC5F,MAAMC,eAAe,GAAGxB,OAAO,KAAK,MAAMiB,OAAO,CAAC,CAAC,CAAC;IACpD,IAAI,CAACO,eAAe,EAAE;MACpB,OAAO,IAAI;IACb;IACA,OAAOD,QAAQ,CAACC,eAAe,CAAC;EAClC,CAAC,EACD,CAACP,OAAO,EAAEjB,OAAO,CACnB,CAAC;EAED,OAAO;IACLA,OAAO;IACPyB,OAAO,EAAEC,OAAO,CAAC1B,OAAO,CAAC,IAAI,CAACG,KAAK;IACnCA,KAAK;IACLc,OAAO;IACPK;EACF,CAAC;AACH,CAAC;AAACK,OAAA,CAAA/B,UAAA,GAAAA,UAAA","ignoreList":[]}
|
|
@@ -1,276 +0,0 @@
|
|
|
1
|
-
"use strict";
|
|
2
|
-
|
|
3
|
-
import { useCallback, useMemo, useRef, useState } from 'react';
|
|
4
|
-
import { mergeSessions, normalizeAndSortSessions, sessionsArraysEqual } from '../../../utils/sessionUtils';
|
|
5
|
-
import { fetchSessionsWithFallback, validateSessionBatch } from '../../utils/sessionHelpers';
|
|
6
|
-
import { getStorageKeys } from '../../utils/storageHelpers';
|
|
7
|
-
import { handleAuthError, isInvalidSessionError } from '../../utils/errorHandlers';
|
|
8
|
-
import { clearQueryCache } from '../../hooks/queryClient';
|
|
9
|
-
const DEFAULT_SAVE_ERROR_MESSAGE = 'Failed to save session data';
|
|
10
|
-
const CLEAR_STORAGE_ERROR = 'Failed to clear storage';
|
|
11
|
-
|
|
12
|
-
/**
|
|
13
|
-
* Manage session state, persistence, and high-level multi-session operations.
|
|
14
|
-
*
|
|
15
|
-
* @param options - Session management configuration
|
|
16
|
-
*/
|
|
17
|
-
export const useSessionManagement = ({
|
|
18
|
-
oxyServices,
|
|
19
|
-
storage,
|
|
20
|
-
storageKeyPrefix,
|
|
21
|
-
loginSuccess,
|
|
22
|
-
logoutStore,
|
|
23
|
-
applyLanguagePreference,
|
|
24
|
-
onAuthStateChange,
|
|
25
|
-
onError,
|
|
26
|
-
setAuthError,
|
|
27
|
-
logger,
|
|
28
|
-
setTokenReady,
|
|
29
|
-
queryClient
|
|
30
|
-
}) => {
|
|
31
|
-
const [sessions, setSessions] = useState([]);
|
|
32
|
-
const [activeSessionId, setActiveSessionId] = useState(null);
|
|
33
|
-
const refreshInFlightRef = useRef(null);
|
|
34
|
-
const removedSessionsRef = useRef(new Set());
|
|
35
|
-
const lastRefreshRef = useRef(0);
|
|
36
|
-
const storageKeys = useMemo(() => getStorageKeys(storageKeyPrefix), [storageKeyPrefix]);
|
|
37
|
-
const saveSessionIds = useCallback(async sessionIds => {
|
|
38
|
-
if (!storage) return;
|
|
39
|
-
try {
|
|
40
|
-
const uniqueIds = Array.from(new Set(sessionIds));
|
|
41
|
-
await storage.setItem(storageKeys.sessionIds, JSON.stringify(uniqueIds));
|
|
42
|
-
} catch (error) {
|
|
43
|
-
if (logger) {
|
|
44
|
-
logger(DEFAULT_SAVE_ERROR_MESSAGE, error);
|
|
45
|
-
} else if (__DEV__) {
|
|
46
|
-
console.warn('Failed to save session IDs:', error);
|
|
47
|
-
}
|
|
48
|
-
}
|
|
49
|
-
}, [logger, storage, storageKeys.sessionIds]);
|
|
50
|
-
const updateSessions = useCallback((incoming, options = {}) => {
|
|
51
|
-
setSessions(prevSessions => {
|
|
52
|
-
const processed = options.merge ? mergeSessions(prevSessions, incoming, activeSessionId, false) : normalizeAndSortSessions(incoming, activeSessionId, false);
|
|
53
|
-
if (storage) {
|
|
54
|
-
void saveSessionIds(processed.map(session => session.sessionId));
|
|
55
|
-
}
|
|
56
|
-
if (sessionsArraysEqual(prevSessions, processed)) {
|
|
57
|
-
return prevSessions;
|
|
58
|
-
}
|
|
59
|
-
return processed;
|
|
60
|
-
});
|
|
61
|
-
}, [activeSessionId, saveSessionIds, storage]);
|
|
62
|
-
const saveActiveSessionId = useCallback(async sessionId => {
|
|
63
|
-
if (!storage) return;
|
|
64
|
-
try {
|
|
65
|
-
await storage.setItem(storageKeys.activeSessionId, sessionId);
|
|
66
|
-
} catch (error) {
|
|
67
|
-
handleAuthError(error, {
|
|
68
|
-
defaultMessage: DEFAULT_SAVE_ERROR_MESSAGE,
|
|
69
|
-
code: 'SESSION_PERSISTENCE_ERROR',
|
|
70
|
-
onError,
|
|
71
|
-
setAuthError,
|
|
72
|
-
logger
|
|
73
|
-
});
|
|
74
|
-
}
|
|
75
|
-
}, [logger, onError, setAuthError, storage, storageKeys.activeSessionId]);
|
|
76
|
-
const removeActiveSessionId = useCallback(async () => {
|
|
77
|
-
if (!storage) return;
|
|
78
|
-
try {
|
|
79
|
-
await storage.removeItem(storageKeys.activeSessionId);
|
|
80
|
-
} catch (error) {
|
|
81
|
-
handleAuthError(error, {
|
|
82
|
-
defaultMessage: DEFAULT_SAVE_ERROR_MESSAGE,
|
|
83
|
-
code: 'SESSION_PERSISTENCE_ERROR',
|
|
84
|
-
onError,
|
|
85
|
-
setAuthError,
|
|
86
|
-
logger
|
|
87
|
-
});
|
|
88
|
-
}
|
|
89
|
-
}, [logger, onError, setAuthError, storage, storageKeys.activeSessionId]);
|
|
90
|
-
const clearSessionStorage = useCallback(async () => {
|
|
91
|
-
if (!storage) return;
|
|
92
|
-
try {
|
|
93
|
-
await storage.removeItem(storageKeys.activeSessionId);
|
|
94
|
-
await storage.removeItem(storageKeys.sessionIds);
|
|
95
|
-
// Clear identity sync state
|
|
96
|
-
await storage.removeItem('oxy_identity_synced').catch(() => {});
|
|
97
|
-
} catch (error) {
|
|
98
|
-
handleAuthError(error, {
|
|
99
|
-
defaultMessage: CLEAR_STORAGE_ERROR,
|
|
100
|
-
code: 'STORAGE_ERROR',
|
|
101
|
-
onError,
|
|
102
|
-
setAuthError,
|
|
103
|
-
logger
|
|
104
|
-
});
|
|
105
|
-
}
|
|
106
|
-
}, [logger, onError, setAuthError, storage, storageKeys.activeSessionId, storageKeys.sessionIds]);
|
|
107
|
-
const clearSessionState = useCallback(async () => {
|
|
108
|
-
setSessions([]);
|
|
109
|
-
setActiveSessionId(null);
|
|
110
|
-
logoutStore();
|
|
111
|
-
|
|
112
|
-
// Clear TanStack Query cache (in-memory)
|
|
113
|
-
if (queryClient) {
|
|
114
|
-
queryClient.clear();
|
|
115
|
-
}
|
|
116
|
-
|
|
117
|
-
// Clear persisted query cache
|
|
118
|
-
if (storage) {
|
|
119
|
-
try {
|
|
120
|
-
await clearQueryCache(storage);
|
|
121
|
-
} catch (error) {
|
|
122
|
-
if (logger) {
|
|
123
|
-
logger('Failed to clear persisted query cache', error);
|
|
124
|
-
}
|
|
125
|
-
}
|
|
126
|
-
}
|
|
127
|
-
await clearSessionStorage();
|
|
128
|
-
onAuthStateChange?.(null);
|
|
129
|
-
}, [clearSessionStorage, logoutStore, onAuthStateChange, queryClient, storage, logger]);
|
|
130
|
-
const activateSession = useCallback(async (sessionId, user) => {
|
|
131
|
-
await oxyServices.getTokenBySession(sessionId);
|
|
132
|
-
setTokenReady?.(true);
|
|
133
|
-
setActiveSessionId(sessionId);
|
|
134
|
-
loginSuccess(user);
|
|
135
|
-
await saveActiveSessionId(sessionId);
|
|
136
|
-
await applyLanguagePreference(user);
|
|
137
|
-
onAuthStateChange?.(user);
|
|
138
|
-
}, [applyLanguagePreference, loginSuccess, onAuthStateChange, oxyServices, saveActiveSessionId, setTokenReady]);
|
|
139
|
-
const trackRemovedSession = useCallback(sessionId => {
|
|
140
|
-
removedSessionsRef.current.add(sessionId);
|
|
141
|
-
setTimeout(() => {
|
|
142
|
-
removedSessionsRef.current.delete(sessionId);
|
|
143
|
-
}, 5000);
|
|
144
|
-
}, []);
|
|
145
|
-
const findReplacementSession = useCallback(async sessionIds => {
|
|
146
|
-
if (!sessionIds.length) {
|
|
147
|
-
return null;
|
|
148
|
-
}
|
|
149
|
-
const validationResults = await validateSessionBatch(oxyServices, sessionIds, {
|
|
150
|
-
maxConcurrency: 3
|
|
151
|
-
});
|
|
152
|
-
const validSession = validationResults.find(result => result.valid);
|
|
153
|
-
if (!validSession) {
|
|
154
|
-
return null;
|
|
155
|
-
}
|
|
156
|
-
const validation = await oxyServices.validateSession(validSession.sessionId, {
|
|
157
|
-
useHeaderValidation: true
|
|
158
|
-
});
|
|
159
|
-
if (!validation?.valid || !validation.user) {
|
|
160
|
-
return null;
|
|
161
|
-
}
|
|
162
|
-
const user = validation.user;
|
|
163
|
-
await activateSession(validSession.sessionId, user);
|
|
164
|
-
return user;
|
|
165
|
-
}, [activateSession, oxyServices]);
|
|
166
|
-
const switchSession = useCallback(async sessionId => {
|
|
167
|
-
try {
|
|
168
|
-
const validation = await oxyServices.validateSession(sessionId, {
|
|
169
|
-
useHeaderValidation: true
|
|
170
|
-
});
|
|
171
|
-
if (!validation?.valid) {
|
|
172
|
-
throw new Error('Session is invalid or expired');
|
|
173
|
-
}
|
|
174
|
-
if (!validation.user) {
|
|
175
|
-
throw new Error('User data not available from session validation');
|
|
176
|
-
}
|
|
177
|
-
const user = validation.user;
|
|
178
|
-
await activateSession(sessionId, user);
|
|
179
|
-
try {
|
|
180
|
-
const deviceSessions = await fetchSessionsWithFallback(oxyServices, sessionId, {
|
|
181
|
-
fallbackUserId: user.id,
|
|
182
|
-
logger
|
|
183
|
-
});
|
|
184
|
-
updateSessions(deviceSessions, {
|
|
185
|
-
merge: true
|
|
186
|
-
});
|
|
187
|
-
} catch (error) {
|
|
188
|
-
if (__DEV__) {
|
|
189
|
-
console.warn('Failed to synchronize sessions after switch:', error);
|
|
190
|
-
}
|
|
191
|
-
}
|
|
192
|
-
return user;
|
|
193
|
-
} catch (error) {
|
|
194
|
-
const invalidSession = isInvalidSessionError(error);
|
|
195
|
-
if (invalidSession) {
|
|
196
|
-
updateSessions(sessions.filter(session => session.sessionId !== sessionId), {
|
|
197
|
-
merge: false
|
|
198
|
-
});
|
|
199
|
-
if (sessionId === activeSessionId) {
|
|
200
|
-
const otherSessionIds = sessions.filter(session => session.sessionId !== sessionId && !removedSessionsRef.current.has(session.sessionId)).map(session => session.sessionId);
|
|
201
|
-
const replacementUser = await findReplacementSession(otherSessionIds);
|
|
202
|
-
if (replacementUser) {
|
|
203
|
-
return replacementUser;
|
|
204
|
-
}
|
|
205
|
-
}
|
|
206
|
-
}
|
|
207
|
-
handleAuthError(error, {
|
|
208
|
-
defaultMessage: 'Failed to switch session',
|
|
209
|
-
code: invalidSession ? 'INVALID_SESSION' : 'SESSION_SWITCH_ERROR',
|
|
210
|
-
onError,
|
|
211
|
-
setAuthError,
|
|
212
|
-
logger
|
|
213
|
-
});
|
|
214
|
-
throw error instanceof Error ? error : new Error('Failed to switch session');
|
|
215
|
-
}
|
|
216
|
-
}, [activateSession, activeSessionId, findReplacementSession, logger, loginSuccess, onError, oxyServices, sessions, setAuthError, updateSessions]);
|
|
217
|
-
const refreshSessions = useCallback(async activeUserId => {
|
|
218
|
-
if (!activeSessionId) return;
|
|
219
|
-
if (refreshInFlightRef.current) {
|
|
220
|
-
await refreshInFlightRef.current;
|
|
221
|
-
return;
|
|
222
|
-
}
|
|
223
|
-
const now = Date.now();
|
|
224
|
-
if (now - lastRefreshRef.current < 500) {
|
|
225
|
-
return;
|
|
226
|
-
}
|
|
227
|
-
lastRefreshRef.current = now;
|
|
228
|
-
const refreshPromise = (async () => {
|
|
229
|
-
try {
|
|
230
|
-
const deviceSessions = await fetchSessionsWithFallback(oxyServices, activeSessionId, {
|
|
231
|
-
fallbackUserId: activeUserId,
|
|
232
|
-
logger
|
|
233
|
-
});
|
|
234
|
-
updateSessions(deviceSessions, {
|
|
235
|
-
merge: true
|
|
236
|
-
});
|
|
237
|
-
} catch (error) {
|
|
238
|
-
if (isInvalidSessionError(error)) {
|
|
239
|
-
const otherSessions = sessions.filter(session => session.sessionId !== activeSessionId && !removedSessionsRef.current.has(session.sessionId)).map(session => session.sessionId);
|
|
240
|
-
const replacementUser = await findReplacementSession(otherSessions);
|
|
241
|
-
if (!replacementUser) {
|
|
242
|
-
await clearSessionState();
|
|
243
|
-
}
|
|
244
|
-
return;
|
|
245
|
-
}
|
|
246
|
-
handleAuthError(error, {
|
|
247
|
-
defaultMessage: 'Failed to refresh sessions',
|
|
248
|
-
code: 'SESSION_REFRESH_ERROR',
|
|
249
|
-
onError,
|
|
250
|
-
setAuthError,
|
|
251
|
-
logger
|
|
252
|
-
});
|
|
253
|
-
} finally {
|
|
254
|
-
refreshInFlightRef.current = null;
|
|
255
|
-
lastRefreshRef.current = Date.now();
|
|
256
|
-
}
|
|
257
|
-
})();
|
|
258
|
-
refreshInFlightRef.current = refreshPromise;
|
|
259
|
-
await refreshPromise;
|
|
260
|
-
}, [activeSessionId, clearSessionState, findReplacementSession, logger, onError, oxyServices, sessions, setAuthError, updateSessions]);
|
|
261
|
-
const isRefreshInFlight = Boolean(refreshInFlightRef.current);
|
|
262
|
-
return {
|
|
263
|
-
sessions,
|
|
264
|
-
activeSessionId,
|
|
265
|
-
setActiveSessionId,
|
|
266
|
-
updateSessions,
|
|
267
|
-
switchSession,
|
|
268
|
-
refreshSessions,
|
|
269
|
-
clearSessionState,
|
|
270
|
-
saveActiveSessionId,
|
|
271
|
-
trackRemovedSession,
|
|
272
|
-
storageKeys,
|
|
273
|
-
isRefreshInFlight
|
|
274
|
-
};
|
|
275
|
-
};
|
|
276
|
-
//# sourceMappingURL=useSessionManagement.js.map
|