mirror of
https://github.com/paricafe/misskey.git
synced 2025-02-17 13:37:29 -06:00
lint
This commit is contained in:
parent
584ae24743
commit
28efba1996
1 changed files with 63 additions and 63 deletions
|
@ -24,73 +24,73 @@ let lastHeartbeatCall = 0;
|
|||
let reconnectAttempts = 0;
|
||||
let reconnectTimeout: number | null = null;
|
||||
|
||||
function getReconnectDelay(): number {
|
||||
const delay = RECONNECT_INITIAL_DELAY * Math.pow(2, reconnectAttempts);
|
||||
return Math.min(delay, RECONNECT_MAX_DELAY);
|
||||
}
|
||||
|
||||
function createStream(): Misskey.IStream {
|
||||
const newStream = markRaw(new Misskey.Stream(wsOrigin, $i ? {
|
||||
token: $i.token,
|
||||
} : null));
|
||||
|
||||
newStream.on('_disconnected_', () => {
|
||||
console.log('Stream disconnected, attempting to reconnect...');
|
||||
if (reconnectAttempts < RECONNECT_MAX_ATTEMPTS) {
|
||||
const delay = getReconnectDelay();
|
||||
reconnectTimeout = window.setTimeout(() => {
|
||||
reconnectAttempts++;
|
||||
stream = null;
|
||||
useStream();
|
||||
}, delay);
|
||||
} else {
|
||||
console.error('Max reconnection attempts reached');
|
||||
}
|
||||
});
|
||||
|
||||
newStream.on('_connected_', () => {
|
||||
console.log('Stream connected successfully');
|
||||
reconnectAttempts = 0;
|
||||
if (reconnectTimeout) {
|
||||
clearTimeout(reconnectTimeout);
|
||||
reconnectTimeout = null;
|
||||
}
|
||||
});
|
||||
|
||||
return newStream;
|
||||
}
|
||||
|
||||
export function useStream(): Misskey.IStream {
|
||||
if (stream) return stream;
|
||||
|
||||
stream = createStream();
|
||||
|
||||
if (timeoutHeartBeat) window.clearTimeout(timeoutHeartBeat);
|
||||
timeoutHeartBeat = window.setTimeout(heartbeat, HEART_BEAT_INTERVAL);
|
||||
|
||||
const target = () => {
|
||||
if (
|
||||
!stream
|
||||
|| document.visibilityState !== 'visible'
|
||||
|| Date.now() - lastHeartbeatCall < HEART_BEAT_INTERVAL
|
||||
) return;
|
||||
heartbeat();
|
||||
}
|
||||
// send heartbeat right now when last send time is over HEART_BEAT_INTERVAL
|
||||
document.addEventListener('visibilitychange', target);
|
||||
|
||||
stream.on('_disconnected_', () => {
|
||||
document.removeEventListener('visibilitychange', target);
|
||||
});
|
||||
|
||||
return stream;
|
||||
}
|
||||
|
||||
function heartbeat(): void {
|
||||
if (stream != null && document.visibilityState === 'visible') {
|
||||
stream.heartbeat();
|
||||
stream.heartbeat();
|
||||
}
|
||||
lastHeartbeatCall = Date.now();
|
||||
if (timeoutHeartBeat) window.clearTimeout(timeoutHeartBeat);
|
||||
timeoutHeartBeat = window.setTimeout(heartbeat, HEART_BEAT_INTERVAL);
|
||||
}
|
||||
|
||||
function getReconnectDelay(): number {
|
||||
const delay = RECONNECT_INITIAL_DELAY * Math.pow(2, reconnectAttempts);
|
||||
return Math.min(delay, RECONNECT_MAX_DELAY);
|
||||
}
|
||||
|
||||
function createStream(): Misskey.IStream {
|
||||
const newStream = markRaw(new Misskey.Stream(wsOrigin, $i ? {
|
||||
token: $i.token,
|
||||
} : null));
|
||||
|
||||
newStream.on('_disconnected_', () => {
|
||||
console.log('Stream disconnected, attempting to reconnect...');
|
||||
if (reconnectAttempts < RECONNECT_MAX_ATTEMPTS) {
|
||||
const delay = getReconnectDelay();
|
||||
reconnectTimeout = window.setTimeout(() => {
|
||||
reconnectAttempts++;
|
||||
stream = null;
|
||||
useStream();
|
||||
}, delay);
|
||||
} else {
|
||||
console.error('Max reconnection attempts reached');
|
||||
}
|
||||
});
|
||||
|
||||
newStream.on('_connected_', () => {
|
||||
console.log('Stream connected successfully');
|
||||
reconnectAttempts = 0;
|
||||
if (reconnectTimeout) {
|
||||
clearTimeout(reconnectTimeout);
|
||||
reconnectTimeout = null;
|
||||
}
|
||||
});
|
||||
|
||||
return newStream;
|
||||
}
|
||||
|
||||
export function useStream(): Misskey.IStream {
|
||||
if (stream) return stream;
|
||||
|
||||
stream = createStream();
|
||||
|
||||
if (timeoutHeartBeat) window.clearTimeout(timeoutHeartBeat);
|
||||
timeoutHeartBeat = window.setTimeout(heartbeat, HEART_BEAT_INTERVAL);
|
||||
|
||||
const target = () => {
|
||||
if (
|
||||
!stream
|
||||
|| document.visibilityState !== 'visible'
|
||||
|| Date.now() - lastHeartbeatCall < HEART_BEAT_INTERVAL
|
||||
) return;
|
||||
heartbeat();
|
||||
}
|
||||
// send heartbeat right now when last send time is over HEART_BEAT_INTERVAL
|
||||
document.addEventListener('visibilitychange', target);
|
||||
|
||||
stream.on('_disconnected_', () => {
|
||||
document.removeEventListener('visibilitychange', target);
|
||||
});
|
||||
|
||||
return stream;
|
||||
}
|
||||
|
|
Loading…
Add table
Reference in a new issue