-
Notifications
You must be signed in to change notification settings - Fork 12
Commit
This commit does not belong to any branch on this repository, and may belong to a fork outside of the repository.
feat: implementing Startable and propagating stop() (#309)
Signed-off-by: Curtish <ch@curtish.me>
- Loading branch information
Showing
15 changed files
with
506 additions
and
256 deletions.
There are no files selected for viewing
This file contains bidirectional Unicode text that may be interpreted or compiled differently than what appears below. To review, open the file in an editor that reveals hidden Unicode characters.
Learn more about bidirectional Unicode characters
This file contains bidirectional Unicode text that may be interpreted or compiled differently than what appears below. To review, open the file in an editor that reveals hidden Unicode characters.
Learn more about bidirectional Unicode characters
This file contains bidirectional Unicode text that may be interpreted or compiled differently than what appears below. To review, open the file in an editor that reveals hidden Unicode characters.
Learn more about bidirectional Unicode characters
Original file line number | Diff line number | Diff line change |
---|---|---|
@@ -0,0 +1,82 @@ | ||
/** | ||
* Define controls for managing entity lifecycle. | ||
*/ | ||
export namespace Startable { | ||
/** | ||
* states for a Startable entity | ||
*/ | ||
export enum State { | ||
STOPPED = "stopped", | ||
STARTING = "starting", | ||
RUNNING = "running", | ||
STOPPING = "stopping", | ||
} | ||
|
||
/** | ||
* define the structure of a Startable entity | ||
*/ | ||
export interface IController { | ||
/** | ||
* current status of the entity | ||
*/ | ||
state: State; | ||
/** | ||
* handle the startup of an entity | ||
* | ||
* updates `state` according to lifecycle | ||
* | ||
* @returns {Promise<State>} | ||
*/ | ||
start(): Promise<State>; | ||
/** | ||
* handle the teardown of an entity | ||
* | ||
* updates `state` according to lifecycle | ||
* | ||
* @returns {Promise<State>} | ||
*/ | ||
stop(): Promise<State>; | ||
} | ||
|
||
export abstract class Controller implements IController { | ||
public state = State.STOPPED; | ||
|
||
/** | ||
* internal method to define specific startup routine | ||
* | ||
* used by `start()` internally | ||
* | ||
* implement with `protected` to keep hidden from class interface | ||
*/ | ||
protected abstract _start(): Promise<void>; | ||
|
||
/** | ||
* internal method to define teardown routine | ||
* | ||
* used by `stop()` internally | ||
* | ||
* implement with `protected` to keep hidden from class interface | ||
*/ | ||
protected abstract _stop(): Promise<void>; | ||
|
||
async start(): Promise<State> { | ||
if (this.state === Startable.State.STOPPED) { | ||
this.state = Startable.State.STARTING; | ||
await this._start(); | ||
this.state = Startable.State.RUNNING; | ||
} | ||
|
||
return this.state; | ||
} | ||
|
||
async stop(): Promise<State> { | ||
if (this.state === Startable.State.RUNNING) { | ||
this.state = Startable.State.STOPPING; | ||
await this._stop(); | ||
this.state = Startable.State.STOPPED; | ||
} | ||
|
||
return this.state; | ||
} | ||
} | ||
} |
This file contains bidirectional Unicode text that may be interpreted or compiled differently than what appears below. To review, open the file in an editor that reveals hidden Unicode characters.
Learn more about bidirectional Unicode characters
Original file line number | Diff line number | Diff line change |
---|---|---|
@@ -1 +1,2 @@ | ||
export * from "./KeyRestoration"; | ||
export * from "./Startable"; |
This file contains bidirectional Unicode text that may be interpreted or compiled differently than what appears below. To review, open the file in an editor that reveals hidden Unicode characters.
Learn more about bidirectional Unicode characters
This file contains bidirectional Unicode text that may be interpreted or compiled differently than what appears below. To review, open the file in an editor that reveals hidden Unicode characters.
Learn more about bidirectional Unicode characters
This file contains bidirectional Unicode text that may be interpreted or compiled differently than what appears below. To review, open the file in an editor that reveals hidden Unicode characters.
Learn more about bidirectional Unicode characters
Oops, something went wrong.
9e459c5
There was a problem hiding this comment.
Choose a reason for hiding this comment
The reason will be displayed to describe this comment to others. Learn more.