diff options
author | Sam Wilkins <samwilkins333@gmail.com> | 2020-01-10 06:35:30 -0500 |
---|---|---|
committer | Sam Wilkins <samwilkins333@gmail.com> | 2020-01-10 06:35:30 -0500 |
commit | a1760ecbb780dc17a7675bd60fb50aa1103fa961 (patch) | |
tree | 8cdaae6f81ea00d27183d03f9373fde26ae3ec7d /src/server/session/agents/applied_session_agent.ts | |
parent | cf3e869023d3027ae42c828ba3670b77d838ac50 (diff) |
added hierarchical structure to session
Diffstat (limited to 'src/server/session/agents/applied_session_agent.ts')
-rw-r--r-- | src/server/session/agents/applied_session_agent.ts | 55 |
1 files changed, 55 insertions, 0 deletions
diff --git a/src/server/session/agents/applied_session_agent.ts b/src/server/session/agents/applied_session_agent.ts new file mode 100644 index 000000000..cb7f63c34 --- /dev/null +++ b/src/server/session/agents/applied_session_agent.ts @@ -0,0 +1,55 @@ +import { isMaster } from "cluster"; +import { Monitor } from "./monitor"; +import { ServerWorker } from "./server_worker"; + +export type ExitHandler = (reason: Error | boolean) => void | Promise<void>; + +export abstract class AppliedSessionAgent { + + // the following two methods allow the developer to create a custom + // session and use the built in customization options for each thread + protected abstract async launchMonitor(): Promise<Monitor>; + protected abstract async launchServerWorker(): Promise<ServerWorker>; + + private launched = false; + + public killSession = (reason: string, graceful = true, errorCode = 0) => { + const target = isMaster ? this.sessionMonitor : this.serverWorker; + target.killSession(reason, graceful, errorCode); + } + + private sessionMonitorRef: Monitor | undefined; + public get sessionMonitor(): Monitor { + if (!isMaster) { + this.serverWorker.sendMonitorAction("kill", { + graceful: false, + reason: "Cannot access the session monitor directly from the server worker thread.", + errorCode: 1 + }); + throw new Error(); + } + return this.sessionMonitorRef!; + } + + private serverWorkerRef: ServerWorker | undefined; + public get serverWorker(): ServerWorker { + if (isMaster) { + throw new Error("Cannot access the server worker directly from the session monitor thread"); + } + return this.serverWorkerRef!; + } + + public async launch(): Promise<void> { + if (!this.launched) { + this.launched = true; + if (isMaster) { + this.sessionMonitorRef = await this.launchMonitor(); + } else { + this.serverWorkerRef = await this.launchServerWorker(); + } + } else { + throw new Error("Cannot launch a session thread more than once per process."); + } + } + +}
\ No newline at end of file |