interface Scopethefrontside/effection
interface Scope
A programatic API to interact with an Effection scope from outside of an Operation.
Most often this is used to integrate external APIs with Effection by
capturing a Scope
from a running operation with useScope, and then
using it to call back into itself from a callback.
The following example calls into Effection to implement a proxy around a google search by using express.js.
Examples
Example 1
import { main, useScope, suspend } from "effection";
import { express } from "express";
await main(function*() {
let scope = yield* useScope();
express().get("/", (req, resp) => {
return scope.run(function*() {
let signal = yield* useAbortSignal();
let response = yield* fetch(`https://google.com?q=${req.params.q}`, { signal });
resp.send(yield* response.text());
});
});
yield* suspend();
});
Methods
- run<T>(operation: () => Operation<T>): Task<T>
Run an Operation within
Scope
.This is used to create concurrent tasks from outside of a running operation. To create concurrent tasks from within an already running operation, use Scope#spawn
- spawn<T>(operation: () => Operation<T>): Operation<Task<T>>
Spawn an Operation within
Scope
.This is used to create concurrent tasks from within a running operation. To create concurrent from outside of Effection, use Scope#run
- get<T>(context: Context<T>): T | undefined
Get a Context value from outside of an operation.
- set<T>(context: Context<T>, value: T): T
Set the value of a Context from outside of an operation
- expect<T>(context: Context<T>): T
Get a Context value from outside of an operation, and throw a
MissingContextError
if this context is not specified for this scope.- delete<T>(context: Context<T>): boolean
Remove a Context value from this scope.
- hasOwn<T>(context: Context<T>): boolean
Check if scope has its own unique value for
context
.