aboutsummaryrefslogtreecommitdiff
path: root/src/server/DashSession/Session/agents/process_message_router.ts
diff options
context:
space:
mode:
authorbob <bcz@cs.brown.edu>2020-02-10 12:22:15 -0500
committerbob <bcz@cs.brown.edu>2020-02-10 12:22:15 -0500
commit0a9e7f1c5847634cc495d8f571c2ecffcfa046f3 (patch)
treedff497c2e95615d4fd097c25e43ba3c831c6664b /src/server/DashSession/Session/agents/process_message_router.ts
parentf9fba837d850d33a38919962e575bc0ea4634d56 (diff)
parent8fac2ba9a9c8b6066cf6a011c4bb0988c9f652fa (diff)
Merge branch 'master' of https://github.com/browngraphicslab/Dash-Web
Diffstat (limited to 'src/server/DashSession/Session/agents/process_message_router.ts')
-rw-r--r--src/server/DashSession/Session/agents/process_message_router.ts41
1 files changed, 41 insertions, 0 deletions
diff --git a/src/server/DashSession/Session/agents/process_message_router.ts b/src/server/DashSession/Session/agents/process_message_router.ts
new file mode 100644
index 000000000..6cc8aa941
--- /dev/null
+++ b/src/server/DashSession/Session/agents/process_message_router.ts
@@ -0,0 +1,41 @@
+import { MessageHandler, PromisifiedIPCManager, HandlerMap } from "./promisified_ipc_manager";
+
+export default abstract class IPCMessageReceiver {
+
+ protected static IPCManager: PromisifiedIPCManager;
+ protected handlers: HandlerMap = {};
+
+ protected abstract configureInternalHandlers: () => void;
+
+ /**
+ * Add a listener at this message. When the monitor process
+ * receives a message, it will invoke all registered functions.
+ */
+ public on = (name: string, handler: MessageHandler) => {
+ const handlers = this.handlers[name];
+ if (!handlers) {
+ this.handlers[name] = [handler];
+ } else {
+ handlers.push(handler);
+ }
+ }
+
+ /**
+ * Unregister a given listener at this message.
+ */
+ public off = (name: string, handler: MessageHandler) => {
+ const handlers = this.handlers[name];
+ if (handlers) {
+ const index = handlers.indexOf(handler);
+ if (index > -1) {
+ handlers.splice(index, 1);
+ }
+ }
+ }
+
+ /**
+ * Unregister all listeners at this message.
+ */
+ public clearMessageListeners = (...names: string[]) => names.map(name => delete this.handlers[name]);
+
+} \ No newline at end of file