mirror of
https://github.com/lensapp/lens.git
synced 2025-05-20 05:10:56 +00:00
Cleanup @k8slens/messaging and friends
- To fix type errors Signed-off-by: Sebastian Malton <sebastian@malton.name>
This commit is contained in:
parent
ea7a24d016
commit
a445fdd20d
@ -1,5 +0,0 @@
|
||||
export interface Channel<MessageTemplate = void, ReturnTemplate = void> {
|
||||
id: string;
|
||||
_messageTemplate?: MessageTemplate;
|
||||
_returnTemplate?: ReturnTemplate;
|
||||
}
|
||||
@ -6,8 +6,6 @@ export { getMessageChannel } from "./message/get-message-channel";
|
||||
|
||||
export { requestFromChannelInjectionToken } from "./request/request-from-channel-injection-token";
|
||||
|
||||
export type { Channel } from "./channel.no-coverage";
|
||||
|
||||
export { sendMessageToChannelInjectionToken } from "./message/message-to-channel-injection-token";
|
||||
export type { SendMessageToChannel } from "./message/message-to-channel-injection-token";
|
||||
|
||||
|
||||
@ -6,17 +6,24 @@ import { getStartableStoppable, StartableStoppable } from "@k8slens/startable-st
|
||||
import { computedInjectManyInjectable } from "@ogre-tools/injectable-extension-for-mobx";
|
||||
import { IComputedValue, reaction } from "mobx";
|
||||
|
||||
import { messageChannelListenerInjectionToken } from "../message/message-channel-listener-injection-token";
|
||||
import { requestChannelListenerInjectionToken } from "../request/request-channel-listener-injection-token";
|
||||
import {
|
||||
MessageChannel,
|
||||
messageChannelListenerInjectionToken,
|
||||
} from "../message/message-channel-listener-injection-token";
|
||||
import {
|
||||
RequestChannel,
|
||||
requestChannelListenerInjectionToken,
|
||||
} from "../request/request-channel-listener-injection-token";
|
||||
import { enlistRequestChannelListenerInjectionToken } from "../request/enlist-request-channel-listener-injection-token";
|
||||
import type { Channel } from "../channel.no-coverage";
|
||||
|
||||
export type ListeningOfChannels = StartableStoppable;
|
||||
export const listeningOfChannelsInjectionToken = getInjectionToken<ListeningOfChannels>({
|
||||
id: "listening-of-channels-injection-token",
|
||||
});
|
||||
|
||||
const listening = <T extends { id: string; channel: Channel<unknown> }>(
|
||||
const listening = <
|
||||
T extends { id: string; channel: MessageChannel<any> | RequestChannel<any, any> },
|
||||
>(
|
||||
channelListeners: IComputedValue<T[]>,
|
||||
enlistChannelListener: (listener: T) => () => void,
|
||||
getId: (listener: T) => string,
|
||||
|
||||
@ -1,3 +1,4 @@
|
||||
import type { Disposer } from "@k8slens/utilities/index";
|
||||
import { getInjectionToken } from "@ogre-tools/injectable";
|
||||
|
||||
import type {
|
||||
@ -5,9 +6,9 @@ import type {
|
||||
RequestChannelListener,
|
||||
} from "./request-channel-listener-injection-token";
|
||||
|
||||
export type EnlistRequestChannelListener = (
|
||||
listener: RequestChannelListener<RequestChannel<unknown, unknown>>,
|
||||
) => () => void;
|
||||
export type EnlistRequestChannelListener = <Request, Response>(
|
||||
listener: RequestChannelListener<RequestChannel<Request, Response>>,
|
||||
) => Disposer;
|
||||
|
||||
export const enlistRequestChannelListenerInjectionToken =
|
||||
getInjectionToken<EnlistRequestChannelListener>({
|
||||
|
||||
@ -1,5 +1,11 @@
|
||||
import type { DiContainer } from "@ogre-tools/injectable";
|
||||
import type { Channel, MessageChannelHandler, RequestChannelHandler } from "@k8slens/messaging";
|
||||
import type {
|
||||
MessageChannel,
|
||||
MessageChannelHandler,
|
||||
MessageChannelListener,
|
||||
RequestChannel,
|
||||
RequestChannelHandler,
|
||||
} from "@k8slens/messaging";
|
||||
|
||||
import {
|
||||
enlistMessageChannelListenerInjectionToken,
|
||||
@ -20,6 +26,8 @@ export type MessageBridgeFake = {
|
||||
setAsync: (value: boolean) => void;
|
||||
};
|
||||
|
||||
type MessageHandlers = Set<MessageChannelHandler<MessageChannel<any>>>;
|
||||
|
||||
const overrideMessaging = ({
|
||||
di,
|
||||
messageListenersByDi,
|
||||
@ -28,13 +36,13 @@ const overrideMessaging = ({
|
||||
}: {
|
||||
di: DiContainer;
|
||||
|
||||
messageListenersByDi: Map<DiContainer, Map<string, Set<MessageChannelHandler<Channel>>>>;
|
||||
messageListenersByDi: Map<DiContainer, Map<string, MessageHandlers>>;
|
||||
|
||||
messagePropagationBuffer: Set<{ resolve: () => Promise<void> }>;
|
||||
|
||||
getAsyncModeStatus: () => boolean;
|
||||
}) => {
|
||||
const messageHandlersByChannel = new Map<string, Set<MessageChannelHandler<Channel>>>();
|
||||
const messageHandlersByChannel = new Map<string, MessageHandlers>();
|
||||
|
||||
messageListenersByDi.set(di, messageHandlersByChannel);
|
||||
|
||||
@ -64,30 +72,36 @@ const overrideMessaging = ({
|
||||
});
|
||||
});
|
||||
|
||||
di.override(enlistMessageChannelListenerInjectionToken, () => (listener) => {
|
||||
if (!messageHandlersByChannel.has(listener.channel.id)) {
|
||||
messageHandlersByChannel.set(listener.channel.id, new Set());
|
||||
}
|
||||
di.override(
|
||||
enlistMessageChannelListenerInjectionToken,
|
||||
() =>
|
||||
<T>(listener: MessageChannelListener<MessageChannel<T>>) => {
|
||||
if (!messageHandlersByChannel.has(listener.channel.id)) {
|
||||
messageHandlersByChannel.set(listener.channel.id, new Set());
|
||||
}
|
||||
|
||||
const handlerSet = messageHandlersByChannel.get(listener.channel.id);
|
||||
const handlerSet = messageHandlersByChannel.get(listener.channel.id);
|
||||
|
||||
handlerSet?.add(listener.handler);
|
||||
handlerSet?.add(listener.handler);
|
||||
|
||||
return () => {
|
||||
handlerSet?.delete(listener.handler);
|
||||
};
|
||||
});
|
||||
return () => {
|
||||
handlerSet?.delete(listener.handler);
|
||||
};
|
||||
},
|
||||
);
|
||||
};
|
||||
|
||||
type RequestHandlers = Set<RequestChannelHandler<RequestChannel<any, any>>>;
|
||||
|
||||
const overrideRequesting = ({
|
||||
di,
|
||||
requestListenersByDi,
|
||||
}: {
|
||||
di: DiContainer;
|
||||
|
||||
requestListenersByDi: Map<DiContainer, Map<string, Set<RequestChannelHandler<Channel>>>>;
|
||||
requestListenersByDi: Map<DiContainer, Map<string, RequestHandlers>>;
|
||||
}) => {
|
||||
const requestHandlersByChannel = new Map<string, Set<RequestChannelHandler<Channel>>>();
|
||||
const requestHandlersByChannel = new Map<string, RequestHandlers>();
|
||||
|
||||
requestListenersByDi.set(di, requestHandlersByChannel);
|
||||
|
||||
@ -141,15 +155,8 @@ const overrideRequesting = ({
|
||||
};
|
||||
|
||||
export const getMessageBridgeFake = (): MessageBridgeFake => {
|
||||
const messageListenersByDi = new Map<
|
||||
DiContainer,
|
||||
Map<string, Set<MessageChannelHandler<Channel>>>
|
||||
>();
|
||||
|
||||
const requestListenersByDi = new Map<
|
||||
DiContainer,
|
||||
Map<string, Set<RequestChannelHandler<Channel>>>
|
||||
>();
|
||||
const messageListenersByDi = new Map<DiContainer, Map<string, MessageHandlers>>();
|
||||
const requestListenersByDi = new Map<DiContainer, Map<string, RequestHandlers>>();
|
||||
|
||||
const messagePropagationBuffer = new Set<AsyncFnMock<() => void>>();
|
||||
|
||||
|
||||
Loading…
Reference in New Issue
Block a user