2023-07-27 05:31:52 +00:00
|
|
|
/*
|
2024-02-13 15:59:27 +00:00
|
|
|
* SPDX-FileCopyrightText: syuilo and misskey-project
|
2023-07-27 05:31:52 +00:00
|
|
|
* SPDX-License-Identifier: AGPL-3.0-only
|
|
|
|
*/
|
|
|
|
|
2021-12-29 13:13:09 +00:00
|
|
|
import * as Misskey from 'misskey-js';
|
|
|
|
import { markRaw } from 'vue';
|
2023-09-19 07:37:43 +00:00
|
|
|
import { $i } from '@/account.js';
|
2023-11-13 07:39:54 +00:00
|
|
|
import { wsOrigin } from '@/config.js';
|
2024-06-22 05:52:16 +00:00
|
|
|
import { StreamMock } from '@/scripts/stream-mock.js';
|
|
|
|
import { isEmbedPage } from '@/scripts/embed-page.js';
|
|
|
|
import { ColdDeviceStorage } from '@/store.js';
|
2021-12-29 13:13:09 +00:00
|
|
|
|
2024-03-17 09:47:29 +00:00
|
|
|
// heart beat interval in ms
|
|
|
|
const HEART_BEAT_INTERVAL = 1000 * 60;
|
|
|
|
|
2023-05-15 10:08:46 +00:00
|
|
|
let stream: Misskey.Stream | null = null;
|
2024-03-17 09:47:29 +00:00
|
|
|
let timeoutHeartBeat: ReturnType<typeof setTimeout> | null = null;
|
|
|
|
let lastHeartbeatCall = 0;
|
2023-05-15 10:08:46 +00:00
|
|
|
|
|
|
|
export function useStream(): Misskey.Stream {
|
|
|
|
if (stream) return stream;
|
|
|
|
|
2024-06-22 05:52:16 +00:00
|
|
|
if (isEmbedPage() || ColdDeviceStorage.get('disableWebsocket') === true) {
|
|
|
|
stream = markRaw(new StreamMock(wsOrigin, null) as unknown as Misskey.Stream);
|
|
|
|
return stream;
|
|
|
|
} else {
|
|
|
|
stream = markRaw(new Misskey.Stream(wsOrigin, $i ? {
|
|
|
|
token: $i.token,
|
|
|
|
} : null));
|
|
|
|
}
|
2023-05-15 10:08:46 +00:00
|
|
|
|
2024-03-17 09:47:29 +00:00
|
|
|
if (timeoutHeartBeat) window.clearTimeout(timeoutHeartBeat);
|
|
|
|
timeoutHeartBeat = window.setTimeout(heartbeat, HEART_BEAT_INTERVAL);
|
|
|
|
|
|
|
|
// send heartbeat right now when last send time is over HEART_BEAT_INTERVAL
|
|
|
|
document.addEventListener('visibilitychange', () => {
|
|
|
|
if (
|
|
|
|
!stream
|
|
|
|
|| document.visibilityState !== 'visible'
|
|
|
|
|| Date.now() - lastHeartbeatCall < HEART_BEAT_INTERVAL
|
|
|
|
) return;
|
|
|
|
heartbeat();
|
|
|
|
});
|
2023-06-06 00:04:57 +00:00
|
|
|
|
2023-05-15 10:08:46 +00:00
|
|
|
return stream;
|
|
|
|
}
|
2023-06-06 00:04:57 +00:00
|
|
|
|
|
|
|
function heartbeat(): void {
|
|
|
|
if (stream != null && document.visibilityState === 'visible') {
|
2023-06-06 00:16:38 +00:00
|
|
|
stream.heartbeat();
|
2023-06-06 00:04:57 +00:00
|
|
|
}
|
2024-03-17 09:47:29 +00:00
|
|
|
lastHeartbeatCall = Date.now();
|
|
|
|
if (timeoutHeartBeat) window.clearTimeout(timeoutHeartBeat);
|
|
|
|
timeoutHeartBeat = window.setTimeout(heartbeat, HEART_BEAT_INTERVAL);
|
2023-06-06 00:04:57 +00:00
|
|
|
}
|