Constructor
new Context(client)
- Source:
Parameters:
Name | Type | Description |
---|---|---|
client |
client.Client | The soundworks client instance. |
Throws:
Will throw if the first argument is not a soundworks client instance.
Members
(readonly) client :client.Client
- Description:
The soundworks client instance.
- Source:
The soundworks client instance.
Type:
(readonly) name :string
- Description:
Optionnal user-defined name of the context (defaults to the class name).
The context manager will match the client-side and server-side contexts based on this name. If the server.ContextManager don't find a corresponding user-defined context with the same name, it will use a default (noop) context.
- Source:
Optionnal user-defined name of the context (defaults to the class name).
The context manager will match the client-side and server-side contexts based on this name. If the server.ContextManager don't find a corresponding user-defined context with the same name, it will use a default (noop) context.
Type:
- string
Example
// server-side and client-side contexts are matched based on their respective `name`
class MyContext extends Context {
get name() {
return 'my-user-defined-context-name';
}
}
(readonly) status :string
- Description:
Status of the context, i.e. 'idle', 'inited', 'started', 'errored'
- Source:
Status of the context, i.e. 'idle', 'inited', 'started', 'errored'
Type:
- string
Methods
(async) enter() → {Promise}
- Description:
Enter the context. Implement this method to define the logic that should be done (e.g. creating a shared state, etc.) when the context is entered.
If a server-side part of the context is defined (i.e. a context with the same client.Context#name), the corresponding server-side
enter()
method will be executed before the returned Promise is fulfilled.If the context has not been started yet, the
start
method is implicitely executed.
- Source:
Example
class MyContext extends Context {
async enter() {
await super.enter();
this.state = await this.client.stateManager.create('my-context-state');
}
async exit() {
await super.exit();
await this.state.delete();
}
}
Returns:
- Promise that resolves when the context is entered.
- Type
- Promise
(async) exit() → {Promise}
- Description:
Exit the context. Implement this method to define the logic that should be done (e.g. delete a shared state, etc.) when the context is exited.
If a server-side part of the context is defined (i.e. a context with the same client.Context#name), the corresponding server-side
exit()
method will be executed before the returned Promise is fulfilled.
- Source:
Example
class MyContext extends Context {
async enter() {
await super.enter();
this.state = await this.client.stateManager.create('my-context-state');
}
async exit() {
await super.exit();
await this.state.delete();
}
}
Returns:
- Promise that resolves when the context is exited.
- Type
- Promise
(async) start()
- Description:
Start the context. This method is lazilly called when the client enters the context for the first time (cf. ${client.Context#enter}). If you know some some heavy and/or potentially long job has to be done when starting the context (e.g. call to a web service) it may be a good practice to call it explicitely.
This method should be implemented to perform operations that are valid for the whole lifetime of the context, regardless the client enters or exits the context.
- Source:
Example
import { Context } from '@soundworks/core/client.js';
class MyContext extends Context {
async start() {
await super.start();
await this.doSomeLongJob();
}
}
// Instantiate the context
const myContext = new Context(client);
// manually start the context to perform the long operation before the client
// enters the context.
await myContext.start();
(async) stop()
- Description:
Stop the context. This method is automatically called when
await client.stop()
is called. It should be used to cleanup context wise operations made instart()
(e.g. destroy the reusable audio graph).WARNING: this method should never be called manually.
- Source: