123456789101112131415161718192021222324252627282930313233343536373839404142434445464748495051525354555657585960616263646566676869707172737475767778798081828384858687888990919293949596979899100101102103104105106107108109110111112113114115116117118119120121122123124125126127128129130131132133134135136137138139140141142143144145146147148149150151152153154155156157158159160161162163164165166167168169170171172173174175176177178179180181182183184185186187188189190191192193194195196197198199200201202203204205206207208209210211212213214215216217218219220221 |
- import { pluck, distinctUntilChanged } from "rxjs/operators"
- import { Socket as SocketV2 } from "socket.io-client-v2"
- import { Socket as SocketV3 } from "socket.io-client-v3"
- import { Socket as SocketV4 } from "socket.io-client-v4"
- import DispatchingStore, { defineDispatchers } from "./DispatchingStore"
- import {
- HoppRealtimeLog,
- HoppRealtimeLogLine,
- } from "~/helpers/types/HoppRealtimeLog"
- type SocketIO = SocketV2 | SocketV3 | SocketV4
- type HoppSIORequest = {
- endpoint: string
- path: string
- version: string
- }
- type HoppSIOSession = {
- request: HoppSIORequest
- connectingState: boolean
- connectionState: boolean
- log: HoppRealtimeLog
- socket: SocketIO | null
- }
- const defaultSIORequest: HoppSIORequest = {
- endpoint: "wss://hoppscotch-socketio.herokuapp.com",
- path: "/socket.io",
- version: "v4",
- }
- const defaultSIOSession: HoppSIOSession = {
- request: defaultSIORequest,
- connectionState: false,
- connectingState: false,
- socket: null,
- log: [],
- }
- const dispatchers = defineDispatchers({
- setRequest(
- _: HoppSIOSession,
- { newRequest }: { newRequest: HoppSIORequest }
- ) {
- return {
- request: newRequest,
- }
- },
- setEndpoint(curr: HoppSIOSession, { newEndpoint }: { newEndpoint: string }) {
- return {
- request: {
- ...curr.request,
- endpoint: newEndpoint,
- },
- }
- },
- setPath(curr: HoppSIOSession, { newPath }: { newPath: string }) {
- return {
- request: {
- ...curr.request,
- path: newPath,
- },
- }
- },
- setVersion(curr: HoppSIOSession, { newVersion }: { newVersion: string }) {
- return {
- request: {
- ...curr.request,
- version: newVersion,
- },
- }
- },
- setSocket(_: HoppSIOSession, { socket }: { socket: SocketIO }) {
- return {
- socket,
- }
- },
- setConnectionState(_: HoppSIOSession, { state }: { state: boolean }) {
- return {
- connectionState: state,
- }
- },
- setConnectingState(_: HoppSIOSession, { state }: { state: boolean }) {
- return {
- connectingState: state,
- }
- },
- setLog(_: HoppSIOSession, { log }: { log: HoppRealtimeLog }) {
- return {
- log,
- }
- },
- addLogLine(curr: HoppSIOSession, { line }: { line: HoppRealtimeLogLine }) {
- return {
- log: [...curr.log, line],
- }
- },
- })
- const SIOSessionStore = new DispatchingStore(defaultSIOSession, dispatchers)
- export function setSIORequest(newRequest?: HoppSIORequest) {
- SIOSessionStore.dispatch({
- dispatcher: "setRequest",
- payload: {
- newRequest: newRequest ?? defaultSIORequest,
- },
- })
- }
- export function setSIOEndpoint(newEndpoint: string) {
- SIOSessionStore.dispatch({
- dispatcher: "setEndpoint",
- payload: {
- newEndpoint,
- },
- })
- }
- export function setSIOVersion(newVersion: string) {
- SIOSessionStore.dispatch({
- dispatcher: "setVersion",
- payload: {
- newVersion,
- },
- })
- }
- export function setSIOPath(newPath: string) {
- SIOSessionStore.dispatch({
- dispatcher: "setPath",
- payload: {
- newPath,
- },
- })
- }
- export function setSIOSocket(socket: SocketIO) {
- SIOSessionStore.dispatch({
- dispatcher: "setSocket",
- payload: {
- socket,
- },
- })
- }
- export function setSIOConnectionState(state: boolean) {
- SIOSessionStore.dispatch({
- dispatcher: "setConnectionState",
- payload: {
- state,
- },
- })
- }
- export function setSIOConnectingState(state: boolean) {
- SIOSessionStore.dispatch({
- dispatcher: "setConnectingState",
- payload: {
- state,
- },
- })
- }
- export function setSIOLog(log: HoppRealtimeLog) {
- SIOSessionStore.dispatch({
- dispatcher: "setLog",
- payload: {
- log,
- },
- })
- }
- export function addSIOLogLine(line: HoppRealtimeLogLine) {
- SIOSessionStore.dispatch({
- dispatcher: "addLogLine",
- payload: {
- line,
- },
- })
- }
- export const SIORequest$ = SIOSessionStore.subject$.pipe(
- pluck("request"),
- distinctUntilChanged()
- )
- export const SIOEndpoint$ = SIOSessionStore.subject$.pipe(
- pluck("request", "endpoint"),
- distinctUntilChanged()
- )
- export const SIOVersion$ = SIOSessionStore.subject$.pipe(
- pluck("request", "version"),
- distinctUntilChanged()
- )
- export const SIOPath$ = SIOSessionStore.subject$.pipe(
- pluck("request", "path"),
- distinctUntilChanged()
- )
- export const SIOConnectingState$ = SIOSessionStore.subject$.pipe(
- pluck("connectingState"),
- distinctUntilChanged()
- )
- export const SIOConnectionState$ = SIOSessionStore.subject$.pipe(
- pluck("connectionState"),
- distinctUntilChanged()
- )
- export const SIOSocket$ = SIOSessionStore.subject$.pipe(
- pluck("socket"),
- distinctUntilChanged()
- )
- export const SIOLog$ = SIOSessionStore.subject$.pipe(
- pluck("log"),
- distinctUntilChanged()
- )
|