diff --git a/src/utils/hooks/useLoginStatus.ts b/src/utils/hooks/useLoginStatus.ts index 567e9c135..6e1f39431 100644 --- a/src/utils/hooks/useLoginStatus.ts +++ b/src/utils/hooks/useLoginStatus.ts @@ -4,6 +4,7 @@ import { AppState } from 'store/reducers'; import { hentInnloggingsstatus, fornyInnlogging } from 'store/reducers/innloggingsstatus-duck'; import { getLogOutUrl, getLoginUrl } from 'utils/login'; import { useLoginDebug } from './useLoginDebug'; +import { logAmplitudeEvent } from '../analytics/amplitude'; const stateSelector = (state: AppState) => ({ innloggetStatus: state.innloggingsstatus.data, @@ -13,7 +14,8 @@ const stateSelector = (state: AppState) => ({ let timeoutId: NodeJS.Timeout | null = null; -let didLogExpiry = false; +const logPeriodMs = 60000; +let lastExpireLog = 0; export const useLoginStatus = () => { const dispatch = useDispatch(); @@ -73,13 +75,21 @@ export const useLoginStatus = () => { const _isTokenExpiring = _innloggetStatus.authenticated && secondsToTokenExpires < 60 * 5; const _isSessionExpiring = secondsToSessionExpires < 60 * 10; - if ((_isTokenExpiring || _isSessionExpiring) && !didLogExpiry) { - console.error( - `Session is timing out - Now: ${new Date().toISOString()} - Session: ${secondsToSessionExpires} / ${ - _innloggetStatus.session.endsAt - } - Token: ${secondsToTokenExpires} / ${_innloggetStatus.token.endsAt}` - ); - didLogExpiry = true; + const now = new Date(); + const nowTs = now.getTime(); + + if ((_isTokenExpiring || _isSessionExpiring) && nowTs > lastExpireLog + logPeriodMs) { + logAmplitudeEvent('session-timeout', { + now: now.toISOString(), + nowTs, + session: _innloggetStatus.session, + token: _innloggetStatus.token, + secondsToSessionExpires, + secondsToTokenExpires, + securityLevel: _innloggetStatus.securityLevel, + }); + + lastExpireLog = nowTs; } setIsTokenExpiring(_isTokenExpiring);