@effectionx/timebox
TypeScript icon, indicating that this package has built-in type declarations

0.1.1 • Public • Published

Timebox

Constrain any operation to complete within a certain time.


Very often you want to put a limit on how long an operation may run such as a fetch() of an external resource, or handling a web request. To do this, you can use the timebox() function. It will encapsulate the operation and either return its result, or a otherwise a "timeout" object indicating that it did not complete in the required time.

import { timebox } from "@effectionx/timebox";
import { handleRequest } from "./handle-request";

// a theoretical request handler
export function* handler(request) {
  // do not let the handler run for more than 10 seconds
  let result = yield* timebox(10000, () => handleRequest(request));
  if (result.timeout) {
    return new Response(504, "Gateway Timeout");
  } else {
    return result.value;
  }
}

Readme

Keywords

none

Package Sidebar

Install

npm i @effectionx/timebox

Weekly Downloads

2

Version

0.1.1

License

MIT

Unpacked Size

9.81 kB

Total Files

10

Last publish

Collaborators

  • frontsidejack