| 
									
										
										
										
											2016-11-10 12:25:26 -08:00
										 |  |  | ## Class: ClientRequest
 | 
					
						
							|  |  |  | 
 | 
					
						
							|  |  |  | > Make HTTP/HTTPS requests.
 | 
					
						
							|  |  |  | 
 | 
					
						
							| 
									
										
										
										
											2024-01-04 16:20:37 -05:00
										 |  |  | Process: [Main](../glossary.md#main-process), [Utility](../glossary.md#utility-process)<br /> | 
					
						
							| 
									
										
										
										
											2021-06-15 13:50:31 -07:00
										 |  |  | _This class is not exported from the `'electron'` module. It is only available as a return value of other methods in the Electron API._ | 
					
						
							| 
									
										
										
										
											2016-11-10 12:25:26 -08:00
										 |  |  | 
 | 
					
						
							|  |  |  | `ClientRequest` implements the [Writable Stream](https://nodejs.org/api/stream.html#stream_writable_streams) | 
					
						
							| 
									
										
										
										
											2019-07-22 08:20:43 -07:00
										 |  |  | interface and is therefore an [EventEmitter][event-emitter]. | 
					
						
							| 
									
										
										
										
											2016-11-10 12:25:26 -08:00
										 |  |  | 
 | 
					
						
							|  |  |  | ### `new ClientRequest(options)`
 | 
					
						
							|  |  |  | 
 | 
					
						
							| 
									
										
										
										
											2021-11-16 05:13:18 +01:00
										 |  |  | * `options` (Object | string) - If `options` is a string, it is interpreted as | 
					
						
							| 
									
										
										
										
											2016-11-10 12:25:26 -08:00
										 |  |  | the request URL. If it is an object, it is expected to fully specify an HTTP request via the | 
					
						
							|  |  |  | following properties: | 
					
						
							| 
									
										
										
										
											2021-11-16 05:13:18 +01:00
										 |  |  |   * `method` string (optional) - The HTTP request method. Defaults to the GET | 
					
						
							| 
									
										
										
										
											2020-09-29 09:03:33 -07:00
										 |  |  |     method. | 
					
						
							| 
									
										
										
										
											2021-11-16 05:13:18 +01:00
										 |  |  |   * `url` string (optional) - The request URL. Must be provided in the absolute | 
					
						
							| 
									
										
										
										
											2020-09-29 09:03:33 -07:00
										 |  |  |     form with the protocol scheme specified as http or https. | 
					
						
							| 
									
										
										
										
											2024-04-04 11:50:35 -07:00
										 |  |  |   * `headers` Record\<string, string | string[]\> (optional) - Headers to be sent | 
					
						
							| 
									
										
										
										
											2024-03-28 09:38:16 -07:00
										 |  |  |     with the request. | 
					
						
							| 
									
										
										
										
											2019-08-05 10:45:58 -07:00
										 |  |  |   * `session` Session (optional) - The [`Session`](session.md) instance with | 
					
						
							| 
									
										
										
										
											2020-09-29 09:03:33 -07:00
										 |  |  |     which the request is associated. | 
					
						
							| 
									
										
										
										
											2021-11-16 05:13:18 +01:00
										 |  |  |   * `partition` string (optional) - The name of the [`partition`](session.md) | 
					
						
							| 
									
										
										
										
											2020-09-29 09:03:33 -07:00
										 |  |  |     with which the request is associated. Defaults to the empty string. The | 
					
						
							|  |  |  |     `session` option supersedes `partition`. Thus if a `session` is explicitly | 
					
						
							|  |  |  |     specified, `partition` is ignored. | 
					
						
							| 
									
										
										
										
											2023-02-20 12:57:38 -08:00
										 |  |  |   * `credentials` string (optional) - Can be `include`, `omit` or | 
					
						
							|  |  |  |     `same-origin`. Whether to send | 
					
						
							|  |  |  |     [credentials](https://fetch.spec.whatwg.org/#credentials) with this | 
					
						
							| 
									
										
										
										
											2020-09-29 09:03:33 -07:00
										 |  |  |     request. If set to `include`, credentials from the session associated with | 
					
						
							|  |  |  |     the request will be used. If set to `omit`, credentials will not be sent | 
					
						
							|  |  |  |     with the request (and the `'login'` event will not be triggered in the | 
					
						
							| 
									
										
										
										
											2023-02-20 12:57:38 -08:00
										 |  |  |     event of a 401). If set to `same-origin`, `origin` must also be specified. | 
					
						
							|  |  |  |     This matches the behavior of the | 
					
						
							| 
									
										
										
										
											2020-09-29 09:03:33 -07:00
										 |  |  |     [fetch](https://fetch.spec.whatwg.org/#concept-request-credentials-mode) | 
					
						
							|  |  |  |     option of the same name. If this option is not specified, authentication | 
					
						
							|  |  |  |     data from the session will be sent, and cookies will not be sent (unless | 
					
						
							|  |  |  |     `useSessionCookies` is set). | 
					
						
							| 
									
										
										
										
											2021-11-16 05:13:18 +01:00
										 |  |  |   * `useSessionCookies` boolean (optional) - Whether to send cookies with this | 
					
						
							| 
									
										
										
										
											2020-09-29 09:03:33 -07:00
										 |  |  |     request from the provided session. If `credentials` is specified, this | 
					
						
							|  |  |  |     option has no effect. Default is `false`. | 
					
						
							| 
									
										
										
										
											2021-11-16 05:13:18 +01:00
										 |  |  |   * `protocol` string (optional) - Can be `http:` or `https:`. The protocol | 
					
						
							| 
									
										
										
										
											2020-09-29 09:03:33 -07:00
										 |  |  |     scheme in the form 'scheme:'. Defaults to 'http:'. | 
					
						
							| 
									
										
										
										
											2021-11-16 05:13:18 +01:00
										 |  |  |   * `host` string (optional) - The server host provided as a concatenation of | 
					
						
							| 
									
										
										
										
											2020-09-29 09:03:33 -07:00
										 |  |  |     the hostname and the port number 'hostname:port'. | 
					
						
							| 
									
										
										
										
											2021-11-16 05:13:18 +01:00
										 |  |  |   * `hostname` string (optional) - The server host name. | 
					
						
							| 
									
										
										
										
											2016-11-10 12:25:26 -08:00
										 |  |  |   * `port` Integer (optional) - The server's listening port number. | 
					
						
							| 
									
										
										
										
											2021-11-16 05:13:18 +01:00
										 |  |  |   * `path` string (optional) - The path part of the request URL. | 
					
						
							|  |  |  |   * `redirect` string (optional) - Can be `follow`, `error` or `manual`. The | 
					
						
							| 
									
										
										
										
											2020-09-29 09:03:33 -07:00
										 |  |  |     redirect mode for this request. When mode is `error`, any redirection will | 
					
						
							|  |  |  |     be aborted. When mode is `manual` the redirection will be cancelled unless | 
					
						
							|  |  |  |     [`request.followRedirect`](#requestfollowredirect) is invoked synchronously | 
					
						
							|  |  |  |     during the [`redirect`](#event-redirect) event.  Defaults to `follow`. | 
					
						
							| 
									
										
										
										
											2021-11-16 05:13:18 +01:00
										 |  |  |   * `origin` string (optional) - The origin URL of the request. | 
					
						
							| 
									
										
										
										
											2024-09-26 00:12:11 -07:00
										 |  |  |   * `referrerPolicy` string (optional) - can be "", `no-referrer`, | 
					
						
							| 
									
										
										
										
											2023-02-20 12:57:38 -08:00
										 |  |  |     `no-referrer-when-downgrade`, `origin`, `origin-when-cross-origin`, | 
					
						
							|  |  |  |     `unsafe-url`, `same-origin`, `strict-origin`, or | 
					
						
							|  |  |  |     `strict-origin-when-cross-origin`. Defaults to | 
					
						
							|  |  |  |     `strict-origin-when-cross-origin`. | 
					
						
							|  |  |  |   * `cache` string (optional) - can be `default`, `no-store`, `reload`, | 
					
						
							|  |  |  |     `no-cache`, `force-cache` or `only-if-cached`. | 
					
						
							| 
									
										
										
										
											2025-05-31 03:28:13 +08:00
										 |  |  |   * `priority` string (optional) - can be `throttled`, `idle`, `lowest`, | 
					
						
							|  |  |  |     `low`, `medium`, or `highest`. Defaults to `idle`. | 
					
						
							|  |  |  |   * `priorityIncremental` boolean (optional) - the incremental loading flag as part | 
					
						
							|  |  |  |     of HTTP extensible priorities (RFC 9218). Default is `true`. | 
					
						
							| 
									
										
										
										
											2016-11-10 12:25:26 -08:00
										 |  |  | 
 | 
					
						
							|  |  |  | `options` properties such as `protocol`, `host`, `hostname`, `port` and `path` | 
					
						
							|  |  |  | strictly follow the Node.js model as described in the | 
					
						
							|  |  |  | [URL](https://nodejs.org/api/url.html) module. | 
					
						
							|  |  |  | 
 | 
					
						
							|  |  |  | For instance, we could have created the same request to 'github.com' as follows: | 
					
						
							|  |  |  | 
 | 
					
						
							| 
									
										
										
										
											2023-11-20 23:50:08 -08:00
										 |  |  | ```js | 
					
						
							| 
									
										
										
										
											2016-11-10 12:25:26 -08:00
										 |  |  | const request = net.request({ | 
					
						
							|  |  |  |   method: 'GET', | 
					
						
							|  |  |  |   protocol: 'https:', | 
					
						
							|  |  |  |   hostname: 'github.com', | 
					
						
							|  |  |  |   port: 443, | 
					
						
							|  |  |  |   path: '/' | 
					
						
							|  |  |  | }) | 
					
						
							|  |  |  | ``` | 
					
						
							|  |  |  | 
 | 
					
						
							|  |  |  | ### Instance Events
 | 
					
						
							|  |  |  | 
 | 
					
						
							|  |  |  | #### Event: 'response'
 | 
					
						
							|  |  |  | 
 | 
					
						
							|  |  |  | Returns: | 
					
						
							|  |  |  | 
 | 
					
						
							| 
									
										
										
										
											2021-06-02 22:54:33 -07:00
										 |  |  | * `response` [IncomingMessage](incoming-message.md) - An object representing the HTTP response message. | 
					
						
							| 
									
										
										
										
											2016-11-10 12:25:26 -08:00
										 |  |  | 
 | 
					
						
							|  |  |  | #### Event: 'login'
 | 
					
						
							|  |  |  | 
 | 
					
						
							|  |  |  | Returns: | 
					
						
							|  |  |  | 
 | 
					
						
							|  |  |  | * `authInfo` Object | 
					
						
							| 
									
										
										
										
											2021-11-16 05:13:18 +01:00
										 |  |  |   * `isProxy` boolean | 
					
						
							|  |  |  |   * `scheme` string | 
					
						
							|  |  |  |   * `host` string | 
					
						
							| 
									
										
										
										
											2016-11-10 12:25:26 -08:00
										 |  |  |   * `port` Integer | 
					
						
							| 
									
										
										
										
											2021-11-16 05:13:18 +01:00
										 |  |  |   * `realm` string | 
					
						
							| 
									
										
										
										
											2016-11-10 12:25:26 -08:00
										 |  |  | * `callback` Function | 
					
						
							| 
									
										
										
										
											2021-11-16 05:13:18 +01:00
										 |  |  |   * `username` string (optional) | 
					
						
							|  |  |  |   * `password` string (optional) | 
					
						
							| 
									
										
										
										
											2016-11-10 12:25:26 -08:00
										 |  |  | 
 | 
					
						
							|  |  |  | Emitted when an authenticating proxy is asking for user credentials. | 
					
						
							|  |  |  | 
 | 
					
						
							|  |  |  | The `callback` function is expected to be called back with user credentials: | 
					
						
							|  |  |  | 
 | 
					
						
							| 
									
										
										
										
											2021-11-16 05:13:18 +01:00
										 |  |  | * `username` string | 
					
						
							|  |  |  | * `password` string | 
					
						
							| 
									
										
										
										
											2016-11-10 12:25:26 -08:00
										 |  |  | 
 | 
					
						
							| 
									
										
										
										
											2023-11-20 23:50:08 -08:00
										 |  |  | ```js @ts-type={request:Electron.ClientRequest} | 
					
						
							| 
									
										
										
										
											2016-11-10 12:25:26 -08:00
										 |  |  | request.on('login', (authInfo, callback) => { | 
					
						
							|  |  |  |   callback('username', 'password') | 
					
						
							|  |  |  | }) | 
					
						
							|  |  |  | ``` | 
					
						
							| 
									
										
										
										
											2020-11-05 14:12:43 -08:00
										 |  |  | 
 | 
					
						
							| 
									
										
										
										
											2016-11-10 12:25:26 -08:00
										 |  |  | Providing empty credentials will cancel the request and report an authentication | 
					
						
							|  |  |  | error on the response object: | 
					
						
							|  |  |  | 
 | 
					
						
							| 
									
										
										
										
											2023-11-20 23:50:08 -08:00
										 |  |  | ```js @ts-type={request:Electron.ClientRequest} | 
					
						
							| 
									
										
										
										
											2016-11-10 12:25:26 -08:00
										 |  |  | request.on('response', (response) => { | 
					
						
							| 
									
										
										
										
											2023-05-15 00:58:35 -07:00
										 |  |  |   console.log(`STATUS: ${response.statusCode}`) | 
					
						
							| 
									
										
										
										
											2016-11-10 12:25:26 -08:00
										 |  |  |   response.on('error', (error) => { | 
					
						
							|  |  |  |     console.log(`ERROR: ${JSON.stringify(error)}`) | 
					
						
							|  |  |  |   }) | 
					
						
							|  |  |  | }) | 
					
						
							|  |  |  | request.on('login', (authInfo, callback) => { | 
					
						
							|  |  |  |   callback() | 
					
						
							|  |  |  | }) | 
					
						
							|  |  |  | ``` | 
					
						
							|  |  |  | 
 | 
					
						
							|  |  |  | #### Event: 'finish'
 | 
					
						
							|  |  |  | 
 | 
					
						
							|  |  |  | Emitted just after the last chunk of the `request`'s data has been written into | 
					
						
							|  |  |  | the `request` object. | 
					
						
							|  |  |  | 
 | 
					
						
							|  |  |  | #### Event: 'abort'
 | 
					
						
							|  |  |  | 
 | 
					
						
							|  |  |  | Emitted when the `request` is aborted. The `abort` event will not be fired if | 
					
						
							|  |  |  | the `request` is already closed. | 
					
						
							|  |  |  | 
 | 
					
						
							|  |  |  | #### Event: 'error'
 | 
					
						
							|  |  |  | 
 | 
					
						
							|  |  |  | Returns: | 
					
						
							|  |  |  | 
 | 
					
						
							|  |  |  | * `error` Error - an error object providing some information about the failure. | 
					
						
							|  |  |  | 
 | 
					
						
							|  |  |  | Emitted when the `net` module fails to issue a network request. Typically when | 
					
						
							|  |  |  | the `request` object emits an `error` event, a `close` event will subsequently | 
					
						
							|  |  |  | follow and no response object will be provided. | 
					
						
							|  |  |  | 
 | 
					
						
							|  |  |  | #### Event: 'close'
 | 
					
						
							|  |  |  | 
 | 
					
						
							|  |  |  | Emitted as the last event in the HTTP request-response transaction. The `close` | 
					
						
							|  |  |  | event indicates that no more events will be emitted on either the `request` or | 
					
						
							|  |  |  | `response` objects. | 
					
						
							|  |  |  | 
 | 
					
						
							| 
									
										
										
										
											2017-03-25 12:37:34 +05:30
										 |  |  | #### Event: 'redirect'
 | 
					
						
							|  |  |  | 
 | 
					
						
							|  |  |  | Returns: | 
					
						
							|  |  |  | 
 | 
					
						
							|  |  |  | * `statusCode` Integer | 
					
						
							| 
									
										
										
										
											2021-11-16 05:13:18 +01:00
										 |  |  | * `method` string | 
					
						
							|  |  |  | * `redirectUrl` string | 
					
						
							| 
									
										
										
										
											2024-03-25 03:19:44 -07:00
										 |  |  | * `responseHeaders` Record\<string, string[]\> | 
					
						
							| 
									
										
										
										
											2017-03-25 12:37:34 +05:30
										 |  |  | 
 | 
					
						
							| 
									
										
										
										
											2019-11-26 17:01:13 -08:00
										 |  |  | Emitted when the server returns a redirect response (e.g. 301 Moved | 
					
						
							|  |  |  | Permanently). Calling [`request.followRedirect`](#requestfollowredirect) will | 
					
						
							|  |  |  | continue with the redirection.  If this event is handled, | 
					
						
							|  |  |  | [`request.followRedirect`](#requestfollowredirect) must be called | 
					
						
							|  |  |  | **synchronously**, otherwise the request will be cancelled. | 
					
						
							| 
									
										
										
										
											2017-03-25 12:37:34 +05:30
										 |  |  | 
 | 
					
						
							| 
									
										
										
										
											2016-11-10 12:25:26 -08:00
										 |  |  | ### Instance Properties
 | 
					
						
							|  |  |  | 
 | 
					
						
							|  |  |  | #### `request.chunkedEncoding`
 | 
					
						
							|  |  |  | 
 | 
					
						
							| 
									
										
										
										
											2021-11-16 05:13:18 +01:00
										 |  |  | A `boolean` specifying whether the request will use HTTP chunked transfer encoding | 
					
						
							| 
									
										
										
										
											2016-11-10 12:25:26 -08:00
										 |  |  | or not. Defaults to false. The property is readable and writable, however it can | 
					
						
							|  |  |  | be set only before the first write operation as the HTTP headers are not yet put | 
					
						
							|  |  |  | on the wire. Trying to set the `chunkedEncoding` property after the first write | 
					
						
							|  |  |  | will throw an error. | 
					
						
							|  |  |  | 
 | 
					
						
							|  |  |  | Using chunked encoding is strongly recommended if you need to send a large | 
					
						
							|  |  |  | request body as data will be streamed in small chunks instead of being | 
					
						
							|  |  |  | internally buffered inside Electron process memory. | 
					
						
							|  |  |  | 
 | 
					
						
							|  |  |  | ### Instance Methods
 | 
					
						
							|  |  |  | 
 | 
					
						
							|  |  |  | #### `request.setHeader(name, value)`
 | 
					
						
							|  |  |  | 
 | 
					
						
							| 
									
										
										
										
											2021-11-16 05:13:18 +01:00
										 |  |  | * `name` string - An extra HTTP header name. | 
					
						
							|  |  |  | * `value` string - An extra HTTP header value. | 
					
						
							| 
									
										
										
										
											2016-11-10 12:25:26 -08:00
										 |  |  | 
 | 
					
						
							| 
									
										
										
										
											2019-06-21 16:19:21 -05:00
										 |  |  | Adds an extra HTTP header. The header name will be issued as-is without | 
					
						
							| 
									
										
										
										
											2016-11-10 12:25:26 -08:00
										 |  |  | lowercasing. It can be called only before first write. Calling this method after | 
					
						
							| 
									
										
										
										
											2021-11-16 05:13:18 +01:00
										 |  |  | the first write will throw an error. If the passed value is not a `string`, its | 
					
						
							| 
									
										
										
										
											2017-03-30 13:24:40 -03:00
										 |  |  | `toString()` method will be called to obtain the final value. | 
					
						
							| 
									
										
										
										
											2016-11-10 12:25:26 -08:00
										 |  |  | 
 | 
					
						
							| 
									
										
										
										
											2020-08-25 04:29:58 -07:00
										 |  |  | Certain headers are restricted from being set by apps. These headers are | 
					
						
							|  |  |  | listed below. More information on restricted headers can be found in | 
					
						
							| 
									
										
										
										
											2022-03-17 05:45:55 -07:00
										 |  |  | [Chromium's header utils](https://source.chromium.org/chromium/chromium/src/+/main:services/network/public/cpp/header_util.cc;drc=1562cab3f1eda927938f8f4a5a91991fefde66d3;bpv=1;bpt=1;l=22). | 
					
						
							| 
									
										
										
										
											2020-08-25 04:29:58 -07:00
										 |  |  | 
 | 
					
						
							|  |  |  | * `Content-Length` | 
					
						
							|  |  |  | * `Host` | 
					
						
							|  |  |  | * `Trailer` or `Te` | 
					
						
							|  |  |  | * `Upgrade` | 
					
						
							|  |  |  | * `Cookie2` | 
					
						
							|  |  |  | * `Keep-Alive` | 
					
						
							|  |  |  | * `Transfer-Encoding` | 
					
						
							|  |  |  | 
 | 
					
						
							|  |  |  | Additionally, setting the `Connection` header to the value `upgrade` is also disallowed. | 
					
						
							|  |  |  | 
 | 
					
						
							| 
									
										
										
										
											2016-11-10 12:25:26 -08:00
										 |  |  | #### `request.getHeader(name)`
 | 
					
						
							|  |  |  | 
 | 
					
						
							| 
									
										
										
										
											2021-11-16 05:13:18 +01:00
										 |  |  | * `name` string - Specify an extra header name. | 
					
						
							| 
									
										
										
										
											2016-11-10 12:25:26 -08:00
										 |  |  | 
 | 
					
						
							| 
									
										
										
										
											2021-11-16 05:13:18 +01:00
										 |  |  | Returns `string` - The value of a previously set extra header name. | 
					
						
							| 
									
										
										
										
											2016-11-10 12:25:26 -08:00
										 |  |  | 
 | 
					
						
							|  |  |  | #### `request.removeHeader(name)`
 | 
					
						
							|  |  |  | 
 | 
					
						
							| 
									
										
										
										
											2021-11-16 05:13:18 +01:00
										 |  |  | * `name` string - Specify an extra header name. | 
					
						
							| 
									
										
										
										
											2016-11-10 12:25:26 -08:00
										 |  |  | 
 | 
					
						
							|  |  |  | Removes a previously set extra header name. This method can be called only | 
					
						
							|  |  |  | before first write. Trying to call it after the first write will throw an error. | 
					
						
							|  |  |  | 
 | 
					
						
							|  |  |  | #### `request.write(chunk[, encoding][, callback])`
 | 
					
						
							|  |  |  | 
 | 
					
						
							| 
									
										
										
										
											2021-11-16 05:13:18 +01:00
										 |  |  | * `chunk` (string | Buffer) - A chunk of the request body's data. If it is a | 
					
						
							| 
									
										
										
										
											2016-11-10 12:25:26 -08:00
										 |  |  | string, it is converted into a Buffer using the specified encoding. | 
					
						
							| 
									
										
										
										
											2021-11-16 05:13:18 +01:00
										 |  |  | * `encoding` string (optional) - Used to convert string chunks into Buffer | 
					
						
							| 
									
										
										
										
											2016-11-10 12:25:26 -08:00
										 |  |  | objects. Defaults to 'utf-8'. | 
					
						
							| 
									
										
										
										
											2017-07-24 10:29:03 +02:00
										 |  |  | * `callback` Function (optional) - Called after the write operation ends. | 
					
						
							| 
									
										
										
										
											2016-11-10 12:25:26 -08:00
										 |  |  | 
 | 
					
						
							|  |  |  | `callback` is essentially a dummy function introduced in the purpose of keeping | 
					
						
							|  |  |  | similarity with the Node.js API. It is called asynchronously in the next tick | 
					
						
							|  |  |  | after `chunk` content have been delivered to the Chromium networking layer. | 
					
						
							|  |  |  | Contrary to the Node.js implementation, it is not guaranteed that `chunk` | 
					
						
							|  |  |  | content have been flushed on the wire before `callback` is called. | 
					
						
							|  |  |  | 
 | 
					
						
							|  |  |  | Adds a chunk of data to the request body. The first write operation may cause | 
					
						
							|  |  |  | the request headers to be issued on the wire. After the first write operation, | 
					
						
							|  |  |  | it is not allowed to add or remove a custom header. | 
					
						
							|  |  |  | 
 | 
					
						
							|  |  |  | #### `request.end([chunk][, encoding][, callback])`
 | 
					
						
							|  |  |  | 
 | 
					
						
							| 
									
										
										
										
											2021-11-16 05:13:18 +01:00
										 |  |  | * `chunk` (string | Buffer) (optional) | 
					
						
							|  |  |  | * `encoding` string (optional) | 
					
						
							| 
									
										
										
										
											2016-11-10 12:25:26 -08:00
										 |  |  | * `callback` Function (optional) | 
					
						
							|  |  |  | 
 | 
					
						
							| 
									
										
										
										
											2023-03-27 10:00:55 -07:00
										 |  |  | Returns `this`. | 
					
						
							|  |  |  | 
 | 
					
						
							| 
									
										
										
										
											2016-11-10 12:25:26 -08:00
										 |  |  | Sends the last chunk of the request data. Subsequent write or end operations | 
					
						
							|  |  |  | will not be allowed. The `finish` event is emitted just after the end operation. | 
					
						
							|  |  |  | 
 | 
					
						
							|  |  |  | #### `request.abort()`
 | 
					
						
							|  |  |  | 
 | 
					
						
							|  |  |  | Cancels an ongoing HTTP transaction. If the request has already emitted the | 
					
						
							|  |  |  | `close` event, the abort operation will have no effect. Otherwise an ongoing | 
					
						
							|  |  |  | event will emit `abort` and `close` events. Additionally, if there is an ongoing | 
					
						
							|  |  |  | response object,it will emit the `aborted` event. | 
					
						
							| 
									
										
										
										
											2017-03-25 12:37:34 +05:30
										 |  |  | 
 | 
					
						
							|  |  |  | #### `request.followRedirect()`
 | 
					
						
							|  |  |  | 
 | 
					
						
							| 
									
										
										
										
											2019-11-26 17:01:13 -08:00
										 |  |  | Continues any pending redirection. Can only be called during a `'redirect'` | 
					
						
							|  |  |  | event. | 
					
						
							| 
									
										
										
										
											2018-07-28 00:15:48 +10:00
										 |  |  | 
 | 
					
						
							|  |  |  | #### `request.getUploadProgress()`
 | 
					
						
							|  |  |  | 
 | 
					
						
							|  |  |  | Returns `Object`: | 
					
						
							|  |  |  | 
 | 
					
						
							| 
									
										
										
										
											2021-11-16 05:13:18 +01:00
										 |  |  | * `active` boolean - Whether the request is currently active. If this is false | 
					
						
							| 
									
										
										
										
											2018-07-28 00:15:48 +10:00
										 |  |  | no other properties will be set | 
					
						
							| 
									
										
										
										
											2021-11-16 05:13:18 +01:00
										 |  |  | * `started` boolean - Whether the upload has started. If this is false both | 
					
						
							| 
									
										
										
										
											2018-07-28 00:15:48 +10:00
										 |  |  | `current` and `total` will be set to 0. | 
					
						
							|  |  |  | * `current` Integer - The number of bytes that have been uploaded so far | 
					
						
							|  |  |  | * `total` Integer - The number of bytes that will be uploaded this request | 
					
						
							|  |  |  | 
 | 
					
						
							|  |  |  | You can use this method in conjunction with `POST` requests to get the progress | 
					
						
							|  |  |  | of a file upload or other data transfer. | 
					
						
							| 
									
										
										
										
											2019-07-22 08:20:43 -07:00
										 |  |  | 
 | 
					
						
							|  |  |  | [event-emitter]: https://nodejs.org/api/events.html#events_class_eventemitter |