|
| 1 | +# Deferred Promise |
| 2 | + |
| 3 | +The `DeferredPromise` class is a Promise-compatible abstraction that defers resolving/rejecting promises to another closure. This class is primarily useful when one part of your system establishes as promise but another part of your system fulfills it. |
| 4 | + |
| 5 | +> This class is conceptually inspired by the [`createDeferredPromise()`](https://github.com/nodejs/node/blob/696fd4b14fc34cc2d01497a3abd9bb441b89be50/lib/internal/util.js#L468-L477) internal utility in Node.js. Unlike the Node.js implementation, however, `DeferredProimse` _extends_ a native `Promise`, allowing the consumer to handle deferred promises like regular promises (no `.promise` instance nesting). |
| 6 | +
|
| 7 | +## Getting started |
| 8 | + |
| 9 | +```sh |
| 10 | +npm install deferred-promise |
| 11 | +``` |
| 12 | + |
| 13 | +## Documentation |
| 14 | + |
| 15 | +- [**Class: `DeferredPromise`**](#class-deferredpromise) |
| 16 | + - [`new DeferredPromise()`](#new-defferedpromise) |
| 17 | + - [`deferredPromise.state`](#deferredpromisestate) |
| 18 | + - [`deferredProimse.result`](#deferredpromiseresult) |
| 19 | + - [`deferredPromise.resolve()`](#deferredpromiseresolve) |
| 20 | + - [`deferredPromies.reject()`](#deferredpromisereject) |
| 21 | + |
| 22 | +## Class: `DeferredPromise` |
| 23 | + |
| 24 | +### `new DefferedPromise()` |
| 25 | + |
| 26 | +Creates a new instance of a deferred promise. |
| 27 | + |
| 28 | +```js |
| 29 | +import { DeferredPromise } from 'deferred-promise' |
| 30 | + |
| 31 | +const promise = new DeferredPromise() |
| 32 | +``` |
| 33 | + |
| 34 | +Unlike the regular `Promise`, a deferred promise does not accept the callback function. Instead, you should use [`.resolve()`](#deferredpromiseresolve) and [`.reject()`](#deferredpromisereject) to resolve and reject the promise respectively. |
| 35 | + |
| 36 | +A deferred promise is fully compatible with the native `Promise`, which means you can pass it to the consumers that await a regular `Promise` as well. |
| 37 | + |
| 38 | +### `deferredPromise.state` |
| 39 | + |
| 40 | +- `<"pending" | "resolved" | "rejected">` **Default:** `"pending"` |
| 41 | + |
| 42 | +```js |
| 43 | +const promise = new DeferredPromise() |
| 44 | +console.log(promise.state) // "pending" |
| 45 | + |
| 46 | +promise.resolve() |
| 47 | +console.log(promise.state) // "resolved" |
| 48 | +``` |
| 49 | + |
| 50 | +### `deferredPromise.result` |
| 51 | + |
| 52 | +Returns the value that has resolved the promise. If no value has been provided to the `.resolve()` call, `undefined` is returned instead. |
| 53 | + |
| 54 | +```js |
| 55 | +const promise = new DeferredPromise() |
| 56 | +promise.resolve('John') |
| 57 | + |
| 58 | +console.log(promise.result) // "John" |
| 59 | +``` |
| 60 | + |
| 61 | +### `deferredPromise.rejectionReason` |
| 62 | + |
| 63 | +Returns the reason that has rejected the promise. If no reason has been provided to the `.reject()` call, `undefined` is returned instead. |
| 64 | + |
| 65 | +```js |
| 66 | +const promise = new DeferredPromise() |
| 67 | +promise.reject(new Error('Internal Server Error')) |
| 68 | + |
| 69 | +console.log(promise.rejectionReason) // Error |
| 70 | +``` |
| 71 | + |
| 72 | +### `deferredPromise.resolve()` |
| 73 | + |
| 74 | +Resolves the deferred promise with a given value. |
| 75 | + |
| 76 | +```js |
| 77 | +function startServer() { |
| 78 | + const serverReady = new DeferredPromise() |
| 79 | + |
| 80 | + new http.Server().listen(() => { |
| 81 | + // Resolve the deferred promise with the server address |
| 82 | + // once the server is ready. |
| 83 | + serverReady.resolve('http://localhost:8080') |
| 84 | + }) |
| 85 | + |
| 86 | + // Return the deferred promise to the consumer. |
| 87 | + return serverReady |
| 88 | +} |
| 89 | + |
| 90 | +startServer().then((address) => { |
| 91 | + console.log('Server is running at "%s"', address) |
| 92 | +}) |
| 93 | +``` |
| 94 | + |
| 95 | +### `deferredPromise.reject()` |
| 96 | + |
| 97 | +Rejects the deferred promise with a given reason. |
| 98 | + |
| 99 | +```js |
| 100 | +function createBroadcast() { |
| 101 | + const runtimePromise = new DeferredPromise() |
| 102 | + |
| 103 | + receiver.on('error', (error) => { |
| 104 | + // Reject the deferred promise in response |
| 105 | + // to the incoming "error" event. |
| 106 | + runtimePromise.reject(error) |
| 107 | + }) |
| 108 | + |
| 109 | + // This deferred promise will be pending forever |
| 110 | + // unless the broadcast channel receives the |
| 111 | + // "error" event that rejects it. |
| 112 | + return runtimePromise |
| 113 | +} |
| 114 | +``` |
0 commit comments