fix and segrregate debug stream state.

This commit is contained in:
muzam1l
2022-03-07 17:14:53 +05:30
parent 2e3a0e557e
commit ce91182c7b
2 changed files with 52 additions and 33 deletions

View File

@@ -1,12 +1,24 @@
import { useCallback, useEffect } from "react"; import { useCallback, useEffect } from "react";
import { useSnapshot } from "valtio"; import { proxy, ref, useSnapshot } from "valtio";
import { Select } from "."; import { Select } from ".";
import state, { ILog } from "../state"; import state, { ILog } from "../state";
import { extractJSON } from "../utils/json"; import { extractJSON } from "../utils/json";
import LogBox from "./LogBox"; import LogBox from "./LogBox";
interface ISelect<T = string> {
label: string;
value: T;
}
const streamState = proxy({
selectedAccount: null as ISelect | null,
logs: [] as ILog[],
socket: undefined as WebSocket | undefined,
});
const DebugStream = () => { const DebugStream = () => {
const { ds_selectedAccount, ds_logs, accounts } = useSnapshot(state); const { selectedAccount, logs, socket } = useSnapshot(streamState);
const { accounts } = useSnapshot(state);
const accountOptions = accounts.map(acc => ({ const accountOptions = accounts.map(acc => ({
label: acc.name, label: acc.name,
@@ -20,8 +32,8 @@ const DebugStream = () => {
placeholder="Select account" placeholder="Select account"
options={accountOptions} options={accountOptions}
hideSelectedOptions hideSelectedOptions
value={ds_selectedAccount} value={selectedAccount}
onChange={acc => (state.ds_selectedAccount = acc as any)} onChange={acc => (streamState.selectedAccount = acc as any)}
css={{ width: "100%" }} css={{ width: "100%" }}
/> />
</> </>
@@ -34,11 +46,17 @@ const DebugStream = () => {
const [_, tm, msg] = match || []; const [_, tm, msg] = match || [];
const extracted = extractJSON(msg); const extracted = extractJSON(msg);
const timestamp = isNaN(Date.parse(tm || '') ) ? tm : new Date(tm).toLocaleTimeString(); const timestamp = isNaN(Date.parse(tm || ""))
? tm
: new Date(tm).toLocaleTimeString();
const message = !extracted ? msg : msg.slice(0, extracted.start) + msg.slice(extracted.end + 1); const message = !extracted
? msg
: msg.slice(0, extracted.start) + msg.slice(extracted.end + 1);
const jsonData = extracted ? JSON.stringify(extracted.result, null, 2) : undefined; const jsonData = extracted
? JSON.stringify(extracted.result, null, 2)
: undefined;
return { return {
type: "log", type: "log",
@@ -50,35 +68,48 @@ const DebugStream = () => {
}, []); }, []);
useEffect(() => { useEffect(() => {
const account = ds_selectedAccount?.value; const account = selectedAccount?.value;
if (!account) { if (account && (!socket || !socket.url.endsWith(account))) {
return; socket?.close();
streamState.socket = ref(
new WebSocket(
`wss://hooks-testnet-debugstream.xrpl-labs.com/${account}`
)
);
} else if (!account && socket) {
socket.close();
streamState.socket = undefined;
} }
const socket = new WebSocket(`wss://hooks-testnet-debugstream.xrpl-labs.com/${account}`); }, [selectedAccount?.value, socket]);
useEffect(() => {
const account = selectedAccount?.value;
const socket = streamState.socket;
if (!socket) return;
const onOpen = () => { const onOpen = () => {
state.ds_logs = []; streamState.logs = [];
state.ds_logs.push({ streamState.logs.push({
type: "success", type: "success",
message: `Debug stream opened for account ${account}`, message: `Debug stream opened for account ${account}`,
}); });
}; };
const onError = () => { const onError = () => {
state.ds_logs.push({ streamState.logs.push({
type: "error", type: "error",
message: "Something went wrong! Check your connection and try again.", message: "Something went wrong! Check your connection and try again.",
}); });
}; };
const onClose = (e: CloseEvent) => { const onClose = (e: CloseEvent) => {
state.ds_logs.push({ streamState.logs.push({
type: "error", type: "error",
message: `Connection was closed [${e.code}].`, message: `Connection was closed. [code: ${e.code}]`,
}); });
state.ds_selectedAccount = null; streamState.selectedAccount = null;
}; };
const onMessage = (event: any) => { const onMessage = (event: any) => {
if (!event.data) return; if (!event.data) return;
state.ds_logs.push(prepareLog(event.data)); streamState.logs.push(prepareLog(event.data));
}; };
socket.addEventListener("open", onOpen); socket.addEventListener("open", onOpen);
@@ -91,17 +122,15 @@ const DebugStream = () => {
socket.removeEventListener("close", onClose); socket.removeEventListener("close", onClose);
socket.removeEventListener("message", onMessage); socket.removeEventListener("message", onMessage);
socket.removeEventListener("error", onError); socket.removeEventListener("error", onError);
socket.close();
}; };
}, [ds_selectedAccount?.value, prepareLog]); }, [prepareLog, selectedAccount?.value, socket]);
return ( return (
<LogBox <LogBox
enhanced enhanced
renderNav={renderNav} renderNav={renderNav}
title="Debug stream" title="Debug stream"
logs={ds_logs} logs={logs}
clearLog={() => (state.ds_logs = [])} clearLog={() => (streamState.logs = [])}
/> />
); );
}; };

View File

@@ -40,11 +40,6 @@ export interface ILog {
defaultCollapsed?: boolean defaultCollapsed?: boolean
} }
export interface ISelect<T = string> {
label: string;
value: T;
}
export interface IState { export interface IState {
files: IFile[]; files: IFile[];
gistId?: string | null; gistId?: string | null;
@@ -67,9 +62,6 @@ export interface IState {
clientStatus: "offline" | "online"; clientStatus: "offline" | "online";
mainModalOpen: boolean; mainModalOpen: boolean;
accounts: IAccount[]; accounts: IAccount[];
// TODO Maybe time to have multilple separate state proxies.
ds_selectedAccount: ISelect | null;
ds_logs: ILog[];
} }
// let localStorageState: null | string = null; // let localStorageState: null | string = null;
@@ -97,8 +89,6 @@ let initialState: IState = {
clientStatus: "offline" as "offline", clientStatus: "offline" as "offline",
mainModalOpen: false, mainModalOpen: false,
accounts: [], accounts: [],
ds_logs: [],
ds_selectedAccount: null
}; };
let localStorageAccounts: string | null = null; let localStorageAccounts: string | null = null;