1# Deprecated APIs 2 3<!--introduced_in=v7.7.0--> 4 5<!-- type=misc --> 6 7Node.js APIs might be deprecated for any of the following reasons: 8 9* Use of the API is unsafe. 10* An improved alternative API is available. 11* Breaking changes to the API are expected in a future major release. 12 13Node.js uses three kinds of Deprecations: 14 15* Documentation-only 16* Runtime 17* End-of-Life 18 19A Documentation-only deprecation is one that is expressed only within the 20Node.js API docs. These generate no side-effects while running Node.js. 21Some Documentation-only deprecations trigger a runtime warning when launched 22with [`--pending-deprecation`][] flag (or its alternative, 23`NODE_PENDING_DEPRECATION=1` environment variable), similarly to Runtime 24deprecations below. Documentation-only deprecations that support that flag 25are explicitly labeled as such in the 26[list of Deprecated APIs](#list-of-deprecated-apis). 27 28A Runtime deprecation will, by default, generate a process warning that will 29be printed to `stderr` the first time the deprecated API is used. When the 30[`--throw-deprecation`][] command-line flag is used, a Runtime deprecation will 31cause an error to be thrown. 32 33An End-of-Life deprecation is used when functionality is or will soon be removed 34from Node.js. 35 36## Revoking deprecations 37 38Occasionally, the deprecation of an API might be reversed. In such situations, 39this document will be updated with information relevant to the decision. 40However, the deprecation identifier will not be modified. 41 42## List of deprecated APIs 43 44### DEP0001: `http.OutgoingMessage.prototype.flush` 45 46<!-- YAML 47changes: 48 - version: v14.0.0 49 pr-url: https://github.com/nodejs/node/pull/31164 50 description: End-of-Life. 51 - version: 52 - v6.12.0 53 - v4.8.6 54 pr-url: https://github.com/nodejs/node/pull/10116 55 description: A deprecation code has been assigned. 56 - version: v1.6.0 57 pr-url: https://github.com/nodejs/node/pull/1156 58 description: Runtime deprecation. 59--> 60 61Type: End-of-Life 62 63`OutgoingMessage.prototype.flush()` has been removed. Use 64`OutgoingMessage.prototype.flushHeaders()` instead. 65 66### DEP0002: `require('_linklist')` 67 68<!-- YAML 69changes: 70 - version: v8.0.0 71 pr-url: https://github.com/nodejs/node/pull/12113 72 description: End-of-Life. 73 - version: v6.12.0 74 pr-url: https://github.com/nodejs/node/pull/10116 75 description: A deprecation code has been assigned. 76 - version: v5.0.0 77 pr-url: https://github.com/nodejs/node/pull/3078 78 description: Runtime deprecation. 79--> 80 81Type: End-of-Life 82 83The `_linklist` module is deprecated. Please use a userland alternative. 84 85### DEP0003: `_writableState.buffer` 86 87<!-- YAML 88changes: 89 - version: v14.0.0 90 pr-url: https://github.com/nodejs/node/pull/31165 91 description: End-of-Life. 92 - version: 93 - v6.12.0 94 - v4.8.6 95 pr-url: https://github.com/nodejs/node/pull/10116 96 description: A deprecation code has been assigned. 97 - version: v0.11.15 98 pr-url: https://github.com/nodejs/node-v0.x-archive/pull/8826 99 description: Runtime deprecation. 100--> 101 102Type: End-of-Life 103 104The `_writableState.buffer` has been removed. Use `_writableState.getBuffer()` 105instead. 106 107### DEP0004: `CryptoStream.prototype.readyState` 108 109<!-- YAML 110changes: 111 - version: v10.0.0 112 pr-url: https://github.com/nodejs/node/pull/17882 113 description: End-of-Life. 114 - version: 115 - v6.12.0 116 - v4.8.6 117 pr-url: https://github.com/nodejs/node/pull/10116 118 description: A deprecation code has been assigned. 119 - version: v0.4.0 120 commit: 9c7f89bf56abd37a796fea621ad2e47dd33d2b82 121 description: Documentation-only deprecation. 122--> 123 124Type: End-of-Life 125 126The `CryptoStream.prototype.readyState` property was removed. 127 128### DEP0005: `Buffer()` constructor 129 130<!-- YAML 131changes: 132 - version: v10.0.0 133 pr-url: https://github.com/nodejs/node/pull/19524 134 description: Runtime deprecation. 135 - version: v6.12.0 136 pr-url: https://github.com/nodejs/node/pull/10116 137 description: A deprecation code has been assigned. 138 - version: v6.0.0 139 pr-url: https://github.com/nodejs/node/pull/4682 140 description: Documentation-only deprecation. 141--> 142 143Type: Runtime (supports [`--pending-deprecation`][]) 144 145The `Buffer()` function and `new Buffer()` constructor are deprecated due to 146API usability issues that can lead to accidental security issues. 147 148As an alternative, use one of the following methods of constructing `Buffer` 149objects: 150 151* [`Buffer.alloc(size[, fill[, encoding]])`][alloc]: Create a `Buffer` with 152 _initialized_ memory. 153* [`Buffer.allocUnsafe(size)`][alloc_unsafe_size]: Create a `Buffer` with 154 _uninitialized_ memory. 155* [`Buffer.allocUnsafeSlow(size)`][]: Create a `Buffer` with _uninitialized_ 156 memory. 157* [`Buffer.from(array)`][]: Create a `Buffer` with a copy of `array` 158* [`Buffer.from(arrayBuffer[, byteOffset[, length]])`][from_arraybuffer] - 159 Create a `Buffer` that wraps the given `arrayBuffer`. 160* [`Buffer.from(buffer)`][]: Create a `Buffer` that copies `buffer`. 161* [`Buffer.from(string[, encoding])`][from_string_encoding]: Create a `Buffer` 162 that copies `string`. 163 164Without `--pending-deprecation`, runtime warnings occur only for code not in 165`node_modules`. This means there will not be deprecation warnings for 166`Buffer()` usage in dependencies. With `--pending-deprecation`, a runtime 167warning results no matter where the `Buffer()` usage occurs. 168 169### DEP0006: `child_process` `options.customFds` 170 171<!-- YAML 172changes: 173 - version: v12.0.0 174 pr-url: https://github.com/nodejs/node/pull/25279 175 description: End-of-Life. 176 - version: 177 - v6.12.0 178 - v4.8.6 179 pr-url: https://github.com/nodejs/node/pull/10116 180 description: A deprecation code has been assigned. 181 - version: v0.11.14 182 description: Runtime deprecation. 183 - version: v0.5.10 184 description: Documentation-only deprecation. 185--> 186 187Type: End-of-Life 188 189Within the [`child_process`][] module's `spawn()`, `fork()`, and `exec()` 190methods, the `options.customFds` option is deprecated. The `options.stdio` 191option should be used instead. 192 193### DEP0007: Replace `cluster` `worker.suicide` with `worker.exitedAfterDisconnect` 194 195<!-- YAML 196changes: 197 - version: v9.0.0 198 pr-url: https://github.com/nodejs/node/pull/13702 199 description: End-of-Life. 200 - version: v7.0.0 201 pr-url: https://github.com/nodejs/node/pull/3747 202 description: Runtime deprecation. 203 - version: v6.12.0 204 pr-url: https://github.com/nodejs/node/pull/10116 205 description: A deprecation code has been assigned. 206 - version: v6.0.0 207 pr-url: https://github.com/nodejs/node/pull/3743 208 description: Documentation-only deprecation. 209--> 210 211Type: End-of-Life 212 213In an earlier version of the Node.js `cluster`, a boolean property with the name 214`suicide` was added to the `Worker` object. The intent of this property was to 215provide an indication of how and why the `Worker` instance exited. In Node.js 2166.0.0, the old property was deprecated and replaced with a new 217[`worker.exitedAfterDisconnect`][] property. The old property name did not 218precisely describe the actual semantics and was unnecessarily emotion-laden. 219 220### DEP0008: `require('node:constants')` 221 222<!-- YAML 223changes: 224 - version: v6.12.0 225 pr-url: https://github.com/nodejs/node/pull/10116 226 description: A deprecation code has been assigned. 227 - version: v6.3.0 228 pr-url: https://github.com/nodejs/node/pull/6534 229 description: Documentation-only deprecation. 230--> 231 232Type: Documentation-only 233 234The `node:constants` module is deprecated. When requiring access to constants 235relevant to specific Node.js builtin modules, developers should instead refer 236to the `constants` property exposed by the relevant module. For instance, 237`require('node:fs').constants` and `require('node:os').constants`. 238 239### DEP0009: `crypto.pbkdf2` without digest 240 241<!-- YAML 242changes: 243 - version: v14.0.0 244 pr-url: https://github.com/nodejs/node/pull/31166 245 description: End-of-Life (for `digest === null`). 246 - version: v11.0.0 247 pr-url: https://github.com/nodejs/node/pull/22861 248 description: Runtime deprecation (for `digest === null`). 249 - version: v8.0.0 250 pr-url: https://github.com/nodejs/node/pull/11305 251 description: End-of-Life (for `digest === undefined`). 252 - version: v6.12.0 253 pr-url: https://github.com/nodejs/node/pull/10116 254 description: A deprecation code has been assigned. 255 - version: v6.0.0 256 pr-url: https://github.com/nodejs/node/pull/4047 257 description: Runtime deprecation (for `digest === undefined`). 258--> 259 260Type: End-of-Life 261 262Use of the [`crypto.pbkdf2()`][] API without specifying a digest was deprecated 263in Node.js 6.0 because the method defaulted to using the non-recommended 264`'SHA1'` digest. Previously, a deprecation warning was printed. Starting in 265Node.js 8.0.0, calling `crypto.pbkdf2()` or `crypto.pbkdf2Sync()` with 266`digest` set to `undefined` will throw a `TypeError`. 267 268Beginning in Node.js v11.0.0, calling these functions with `digest` set to 269`null` would print a deprecation warning to align with the behavior when `digest` 270is `undefined`. 271 272Now, however, passing either `undefined` or `null` will throw a `TypeError`. 273 274### DEP0010: `crypto.createCredentials` 275 276<!-- YAML 277changes: 278 - version: v11.0.0 279 pr-url: https://github.com/nodejs/node/pull/21153 280 description: End-of-Life. 281 - version: 282 - v6.12.0 283 - v4.8.6 284 pr-url: https://github.com/nodejs/node/pull/10116 285 description: A deprecation code has been assigned. 286 - version: v0.11.13 287 pr-url: https://github.com/nodejs/node-v0.x-archive/pull/7265 288 description: Runtime deprecation. 289--> 290 291Type: End-of-Life 292 293The `crypto.createCredentials()` API was removed. Please use 294[`tls.createSecureContext()`][] instead. 295 296### DEP0011: `crypto.Credentials` 297 298<!-- YAML 299changes: 300 - version: v11.0.0 301 pr-url: https://github.com/nodejs/node/pull/21153 302 description: End-of-Life. 303 - version: 304 - v6.12.0 305 - v4.8.6 306 pr-url: https://github.com/nodejs/node/pull/10116 307 description: A deprecation code has been assigned. 308 - version: v0.11.13 309 pr-url: https://github.com/nodejs/node-v0.x-archive/pull/7265 310 description: Runtime deprecation. 311--> 312 313Type: End-of-Life 314 315The `crypto.Credentials` class was removed. Please use [`tls.SecureContext`][] 316instead. 317 318### DEP0012: `Domain.dispose` 319 320<!-- YAML 321changes: 322 - version: v9.0.0 323 pr-url: https://github.com/nodejs/node/pull/15412 324 description: End-of-Life. 325 - version: 326 - v6.12.0 327 - v4.8.6 328 pr-url: https://github.com/nodejs/node/pull/10116 329 description: A deprecation code has been assigned. 330 - version: v0.11.7 331 pr-url: https://github.com/nodejs/node-v0.x-archive/pull/5021 332 description: Runtime deprecation. 333--> 334 335Type: End-of-Life 336 337`Domain.dispose()` has been removed. Recover from failed I/O actions 338explicitly via error event handlers set on the domain instead. 339 340### DEP0013: `fs` asynchronous function without callback 341 342<!-- YAML 343changes: 344 - version: v10.0.0 345 pr-url: https://github.com/nodejs/node/pull/18668 346 description: End-of-Life. 347 - version: v7.0.0 348 pr-url: https://github.com/nodejs/node/pull/7897 349 description: Runtime deprecation. 350--> 351 352Type: End-of-Life 353 354Calling an asynchronous function without a callback throws a `TypeError` 355in Node.js 10.0.0 onwards. See <https://github.com/nodejs/node/pull/12562>. 356 357### DEP0014: `fs.read` legacy String interface 358 359<!-- YAML 360changes: 361 - version: v8.0.0 362 pr-url: https://github.com/nodejs/node/pull/9683 363 description: End-of-Life. 364 - version: 365 - v6.12.0 366 - v4.8.6 367 pr-url: https://github.com/nodejs/node/pull/10116 368 description: A deprecation code has been assigned. 369 - version: v6.0.0 370 pr-url: https://github.com/nodejs/node/pull/4525 371 description: Runtime deprecation. 372 - version: v0.1.96 373 commit: c93e0aaf062081db3ec40ac45b3e2c979d5759d6 374 description: Documentation-only deprecation. 375--> 376 377Type: End-of-Life 378 379The [`fs.read()`][] legacy `String` interface is deprecated. Use the `Buffer` 380API as mentioned in the documentation instead. 381 382### DEP0015: `fs.readSync` legacy String interface 383 384<!-- YAML 385changes: 386 - version: v8.0.0 387 pr-url: https://github.com/nodejs/node/pull/9683 388 description: End-of-Life. 389 - version: 390 - v6.12.0 391 - v4.8.6 392 pr-url: https://github.com/nodejs/node/pull/10116 393 description: A deprecation code has been assigned. 394 - version: v6.0.0 395 pr-url: https://github.com/nodejs/node/pull/4525 396 description: Runtime deprecation. 397 - version: v0.1.96 398 commit: c93e0aaf062081db3ec40ac45b3e2c979d5759d6 399 description: Documentation-only deprecation. 400--> 401 402Type: End-of-Life 403 404The [`fs.readSync()`][] legacy `String` interface is deprecated. Use the 405`Buffer` API as mentioned in the documentation instead. 406 407### DEP0016: `GLOBAL`/`root` 408 409<!-- YAML 410changes: 411 - version: v14.0.0 412 pr-url: https://github.com/nodejs/node/pull/31167 413 description: End-of-Life. 414 - version: v6.12.0 415 pr-url: https://github.com/nodejs/node/pull/10116 416 description: A deprecation code has been assigned. 417 - version: v6.0.0 418 pr-url: https://github.com/nodejs/node/pull/1838 419 description: Runtime deprecation. 420--> 421 422Type: End-of-Life 423 424The `GLOBAL` and `root` aliases for the `global` property were deprecated 425in Node.js 6.0.0 and have since been removed. 426 427### DEP0017: `Intl.v8BreakIterator` 428 429<!-- YAML 430changes: 431 - version: v9.0.0 432 pr-url: https://github.com/nodejs/node/pull/15238 433 description: End-of-Life. 434 - version: v7.0.0 435 pr-url: https://github.com/nodejs/node/pull/8908 436 description: Runtime deprecation. 437--> 438 439Type: End-of-Life 440 441`Intl.v8BreakIterator` was a non-standard extension and has been removed. 442See [`Intl.Segmenter`](https://github.com/tc39/proposal-intl-segmenter). 443 444### DEP0018: Unhandled promise rejections 445 446<!-- YAML 447changes: 448 - version: v15.0.0 449 pr-url: https://github.com/nodejs/node/pull/35316 450 description: End-of-Life. 451 - version: v7.0.0 452 pr-url: https://github.com/nodejs/node/pull/8217 453 description: Runtime deprecation. 454--> 455 456Type: End-of-Life 457 458Unhandled promise rejections are deprecated. By default, promise rejections 459that are not handled terminate the Node.js process with a non-zero exit 460code. To change the way Node.js treats unhandled rejections, use the 461[`--unhandled-rejections`][] command-line option. 462 463### DEP0019: `require('.')` resolved outside directory 464 465<!-- YAML 466changes: 467 - version: v12.0.0 468 pr-url: https://github.com/nodejs/node/pull/26973 469 description: Removed functionality. 470 - version: 471 - v6.12.0 472 - v4.8.6 473 pr-url: https://github.com/nodejs/node/pull/10116 474 description: A deprecation code has been assigned. 475 - version: v1.8.1 476 pr-url: https://github.com/nodejs/node/pull/1363 477 description: Runtime deprecation. 478--> 479 480Type: End-of-Life 481 482In certain cases, `require('.')` could resolve outside the package directory. 483This behavior has been removed. 484 485### DEP0020: `Server.connections` 486 487<!-- YAML 488changes: 489 - version: v15.0.0 490 pr-url: https://github.com/nodejs/node/pull/33647 491 description: Server.connections has been removed. 492 - version: 493 - v6.12.0 494 - v4.8.6 495 pr-url: https://github.com/nodejs/node/pull/10116 496 description: A deprecation code has been assigned. 497 - version: v0.9.7 498 pr-url: https://github.com/nodejs/node-v0.x-archive/pull/4595 499 description: Runtime deprecation. 500--> 501 502Type: End-of-Life 503 504The `Server.connections` property was deprecated in Node.js v0.9.7 and has 505been removed. Please use the [`Server.getConnections()`][] method instead. 506 507### DEP0021: `Server.listenFD` 508 509<!-- YAML 510changes: 511 - version: v12.0.0 512 pr-url: https://github.com/nodejs/node/pull/27127 513 description: End-of-Life. 514 - version: 515 - v6.12.0 516 - v4.8.6 517 pr-url: https://github.com/nodejs/node/pull/10116 518 description: A deprecation code has been assigned. 519 - version: v0.7.12 520 commit: 41421ff9da1288aa241a5e9dcf915b685ade1c23 521 description: Runtime deprecation. 522--> 523 524Type: End-of-Life 525 526The `Server.listenFD()` method was deprecated and removed. Please use 527[`Server.listen({fd: <number>})`][] instead. 528 529### DEP0022: `os.tmpDir()` 530 531<!-- YAML 532changes: 533 - version: v14.0.0 534 pr-url: https://github.com/nodejs/node/pull/31169 535 description: End-of-Life. 536 - version: v7.0.0 537 pr-url: https://github.com/nodejs/node/pull/6739 538 description: Runtime deprecation. 539--> 540 541Type: End-of-Life 542 543The `os.tmpDir()` API was deprecated in Node.js 7.0.0 and has since been 544removed. Please use [`os.tmpdir()`][] instead. 545 546### DEP0023: `os.getNetworkInterfaces()` 547 548<!-- YAML 549changes: 550 - version: v12.0.0 551 pr-url: https://github.com/nodejs/node/pull/25280 552 description: End-of-Life. 553 - version: 554 - v6.12.0 555 - v4.8.6 556 pr-url: https://github.com/nodejs/node/pull/10116 557 description: A deprecation code has been assigned. 558 - version: v0.6.0 559 commit: 37bb37d151fb6ee4696730e63ff28bb7a4924f97 560 description: Runtime deprecation. 561--> 562 563Type: End-of-Life 564 565The `os.getNetworkInterfaces()` method is deprecated. Please use the 566[`os.networkInterfaces()`][] method instead. 567 568### DEP0024: `REPLServer.prototype.convertToContext()` 569 570<!-- YAML 571changes: 572 - version: v9.0.0 573 pr-url: https://github.com/nodejs/node/pull/13434 574 description: End-of-Life. 575 - version: v7.0.0 576 pr-url: https://github.com/nodejs/node/pull/7829 577 description: Runtime deprecation. 578--> 579 580Type: End-of-Life 581 582The `REPLServer.prototype.convertToContext()` API has been removed. 583 584### DEP0025: `require('node:sys')` 585 586<!-- YAML 587changes: 588 - version: 589 - v6.12.0 590 - v4.8.6 591 pr-url: https://github.com/nodejs/node/pull/10116 592 description: A deprecation code has been assigned. 593 - version: v1.0.0 594 pr-url: https://github.com/nodejs/node/pull/317 595 description: Runtime deprecation. 596--> 597 598Type: Runtime 599 600The `node:sys` module is deprecated. Please use the [`util`][] module instead. 601 602### DEP0026: `util.print()` 603 604<!-- YAML 605changes: 606 - version: v12.0.0 607 pr-url: https://github.com/nodejs/node/pull/25377 608 description: End-of-Life. 609 - version: 610 - v6.12.0 611 - v4.8.6 612 pr-url: https://github.com/nodejs/node/pull/10116 613 description: A deprecation code has been assigned. 614 - version: v0.11.3 615 commit: 896b2aa7074fc886efd7dd0a397d694763cac7ce 616 description: Runtime deprecation. 617--> 618 619Type: End-of-Life 620 621`util.print()` has been removed. Please use [`console.log()`][] instead. 622 623### DEP0027: `util.puts()` 624 625<!-- YAML 626changes: 627 - version: v12.0.0 628 pr-url: https://github.com/nodejs/node/pull/25377 629 description: End-of-Life. 630 - version: 631 - v6.12.0 632 - v4.8.6 633 pr-url: https://github.com/nodejs/node/pull/10116 634 description: A deprecation code has been assigned. 635 - version: v0.11.3 636 commit: 896b2aa7074fc886efd7dd0a397d694763cac7ce 637 description: Runtime deprecation. 638--> 639 640Type: End-of-Life 641 642`util.puts()` has been removed. Please use [`console.log()`][] instead. 643 644### DEP0028: `util.debug()` 645 646<!-- YAML 647changes: 648 - version: v12.0.0 649 pr-url: https://github.com/nodejs/node/pull/25377 650 description: End-of-Life. 651 - version: 652 - v6.12.0 653 - v4.8.6 654 pr-url: https://github.com/nodejs/node/pull/10116 655 description: A deprecation code has been assigned. 656 - version: v0.11.3 657 commit: 896b2aa7074fc886efd7dd0a397d694763cac7ce 658 description: Runtime deprecation. 659--> 660 661Type: End-of-Life 662 663`util.debug()` has been removed. Please use [`console.error()`][] instead. 664 665### DEP0029: `util.error()` 666 667<!-- YAML 668changes: 669 - version: v12.0.0 670 pr-url: https://github.com/nodejs/node/pull/25377 671 description: End-of-Life. 672 - version: 673 - v6.12.0 674 - v4.8.6 675 pr-url: https://github.com/nodejs/node/pull/10116 676 description: A deprecation code has been assigned. 677 - version: v0.11.3 678 commit: 896b2aa7074fc886efd7dd0a397d694763cac7ce 679 description: Runtime deprecation. 680--> 681 682Type: End-of-Life 683 684`util.error()` has been removed. Please use [`console.error()`][] instead. 685 686### DEP0030: `SlowBuffer` 687 688<!-- YAML 689changes: 690 - version: v6.12.0 691 pr-url: https://github.com/nodejs/node/pull/10116 692 description: A deprecation code has been assigned. 693 - version: v6.0.0 694 pr-url: https://github.com/nodejs/node/pull/5833 695 description: Documentation-only deprecation. 696--> 697 698Type: Documentation-only 699 700The [`SlowBuffer`][] class is deprecated. Please use 701[`Buffer.allocUnsafeSlow(size)`][] instead. 702 703### DEP0031: `ecdh.setPublicKey()` 704 705<!-- YAML 706changes: 707 - version: v6.12.0 708 pr-url: https://github.com/nodejs/node/pull/10116 709 description: A deprecation code has been assigned. 710 - version: v5.2.0 711 pr-url: https://github.com/nodejs/node/pull/3511 712 description: Documentation-only deprecation. 713--> 714 715Type: Documentation-only 716 717The [`ecdh.setPublicKey()`][] method is now deprecated as its inclusion in the 718API is not useful. 719 720### DEP0032: `node:domain` module 721 722<!-- YAML 723changes: 724 - version: 725 - v6.12.0 726 - v4.8.6 727 pr-url: https://github.com/nodejs/node/pull/10116 728 description: A deprecation code has been assigned. 729 - version: v1.4.2 730 pr-url: https://github.com/nodejs/node/pull/943 731 description: Documentation-only deprecation. 732--> 733 734Type: Documentation-only 735 736The [`domain`][] module is deprecated and should not be used. 737 738### DEP0033: `EventEmitter.listenerCount()` 739 740<!-- YAML 741changes: 742 - version: 743 - v6.12.0 744 - v4.8.6 745 pr-url: https://github.com/nodejs/node/pull/10116 746 description: A deprecation code has been assigned. 747 - version: v3.2.0 748 pr-url: https://github.com/nodejs/node/pull/2349 749 description: Documentation-only deprecation. 750--> 751 752Type: Documentation-only 753 754The [`events.listenerCount(emitter, eventName)`][] API is 755deprecated. Please use [`emitter.listenerCount(eventName)`][] instead. 756 757### DEP0034: `fs.exists(path, callback)` 758 759<!-- YAML 760changes: 761 - version: 762 - v6.12.0 763 - v4.8.6 764 pr-url: https://github.com/nodejs/node/pull/10116 765 description: A deprecation code has been assigned. 766 - version: v1.0.0 767 pr-url: https://github.com/nodejs/node/pull/166 768 description: Documentation-only deprecation. 769--> 770 771Type: Documentation-only 772 773The [`fs.exists(path, callback)`][] API is deprecated. Please use 774[`fs.stat()`][] or [`fs.access()`][] instead. 775 776### DEP0035: `fs.lchmod(path, mode, callback)` 777 778<!-- YAML 779changes: 780 - version: 781 - v6.12.0 782 - v4.8.6 783 pr-url: https://github.com/nodejs/node/pull/10116 784 description: A deprecation code has been assigned. 785 - version: v0.4.7 786 description: Documentation-only deprecation. 787--> 788 789Type: Documentation-only 790 791The [`fs.lchmod(path, mode, callback)`][] API is deprecated. 792 793### DEP0036: `fs.lchmodSync(path, mode)` 794 795<!-- YAML 796changes: 797 - version: 798 - v6.12.0 799 - v4.8.6 800 pr-url: https://github.com/nodejs/node/pull/10116 801 description: A deprecation code has been assigned. 802 - version: v0.4.7 803 description: Documentation-only deprecation. 804--> 805 806Type: Documentation-only 807 808The [`fs.lchmodSync(path, mode)`][] API is deprecated. 809 810### DEP0037: `fs.lchown(path, uid, gid, callback)` 811 812<!-- YAML 813changes: 814 - version: v10.6.0 815 pr-url: https://github.com/nodejs/node/pull/21498 816 description: Deprecation revoked. 817 - version: 818 - v6.12.0 819 - v4.8.6 820 pr-url: https://github.com/nodejs/node/pull/10116 821 description: A deprecation code has been assigned. 822 - version: v0.4.7 823 description: Documentation-only deprecation. 824--> 825 826Type: Deprecation revoked 827 828The [`fs.lchown(path, uid, gid, callback)`][] API was deprecated. The 829deprecation was revoked because the requisite supporting APIs were added in 830libuv. 831 832### DEP0038: `fs.lchownSync(path, uid, gid)` 833 834<!-- YAML 835changes: 836 - version: v10.6.0 837 pr-url: https://github.com/nodejs/node/pull/21498 838 description: Deprecation revoked. 839 - version: 840 - v6.12.0 841 - v4.8.6 842 pr-url: https://github.com/nodejs/node/pull/10116 843 description: A deprecation code has been assigned. 844 - version: v0.4.7 845 description: Documentation-only deprecation. 846--> 847 848Type: Deprecation revoked 849 850The [`fs.lchownSync(path, uid, gid)`][] API was deprecated. The deprecation was 851revoked because the requisite supporting APIs were added in libuv. 852 853### DEP0039: `require.extensions` 854 855<!-- YAML 856changes: 857 - version: 858 - v6.12.0 859 - v4.8.6 860 pr-url: https://github.com/nodejs/node/pull/10116 861 description: A deprecation code has been assigned. 862 - version: v0.10.6 863 commit: 7bd8a5a2a60b75266f89f9a32877d55294a3881c 864 description: Documentation-only deprecation. 865--> 866 867Type: Documentation-only 868 869The [`require.extensions`][] property is deprecated. 870 871### DEP0040: `node:punycode` module 872 873<!-- YAML 874changes: 875 - version: v16.6.0 876 pr-url: https://github.com/nodejs/node/pull/38444 877 description: Added support for `--pending-deprecation`. 878 - version: v7.0.0 879 pr-url: https://github.com/nodejs/node/pull/7941 880 description: Documentation-only deprecation. 881--> 882 883Type: Documentation-only (supports [`--pending-deprecation`][]) 884 885The [`punycode`][] module is deprecated. Please use a userland alternative 886instead. 887 888### DEP0041: `NODE_REPL_HISTORY_FILE` environment variable 889 890<!-- YAML 891changes: 892 - version: v10.0.0 893 pr-url: https://github.com/nodejs/node/pull/13876 894 description: End-of-Life. 895 - version: 896 - v6.12.0 897 - v4.8.6 898 pr-url: https://github.com/nodejs/node/pull/10116 899 description: A deprecation code has been assigned. 900 - version: v3.0.0 901 pr-url: https://github.com/nodejs/node/pull/2224 902 description: Documentation-only deprecation. 903--> 904 905Type: End-of-Life 906 907The `NODE_REPL_HISTORY_FILE` environment variable was removed. Please use 908`NODE_REPL_HISTORY` instead. 909 910### DEP0042: `tls.CryptoStream` 911 912<!-- YAML 913changes: 914 - version: v10.0.0 915 pr-url: https://github.com/nodejs/node/pull/17882 916 description: End-of-Life. 917 - version: 918 - v6.12.0 919 - v4.8.6 920 pr-url: https://github.com/nodejs/node/pull/10116 921 description: A deprecation code has been assigned. 922 - version: v0.11.3 923 commit: af80e7bc6e6f33c582eb1f7d37c7f5bbe9f910f7 924 description: Documentation-only deprecation. 925--> 926 927Type: End-of-Life 928 929The [`tls.CryptoStream`][] class was removed. Please use 930[`tls.TLSSocket`][] instead. 931 932### DEP0043: `tls.SecurePair` 933 934<!-- YAML 935changes: 936 - version: v8.0.0 937 pr-url: https://github.com/nodejs/node/pull/11349 938 description: Runtime deprecation. 939 - version: v6.12.0 940 pr-url: https://github.com/nodejs/node/pull/10116 941 description: A deprecation code has been assigned. 942 - version: v6.0.0 943 pr-url: https://github.com/nodejs/node/pull/6063 944 description: Documentation-only deprecation. 945 - version: v0.11.15 946 pr-url: 947 - https://github.com/nodejs/node-v0.x-archive/pull/8695 948 - https://github.com/nodejs/node-v0.x-archive/pull/8700 949 description: Deprecation revoked. 950 - version: v0.11.3 951 commit: af80e7bc6e6f33c582eb1f7d37c7f5bbe9f910f7 952 description: Runtime deprecation. 953--> 954 955Type: Documentation-only 956 957The [`tls.SecurePair`][] class is deprecated. Please use 958[`tls.TLSSocket`][] instead. 959 960### DEP0044: `util.isArray()` 961 962<!-- YAML 963changes: 964 - version: 965 - v6.12.0 966 - v4.8.6 967 pr-url: https://github.com/nodejs/node/pull/10116 968 description: A deprecation code has been assigned. 969 - version: 970 - v4.0.0 971 - v3.3.1 972 pr-url: https://github.com/nodejs/node/pull/2447 973 description: Documentation-only deprecation. 974--> 975 976Type: Documentation-only 977 978The [`util.isArray()`][] API is deprecated. Please use `Array.isArray()` 979instead. 980 981### DEP0045: `util.isBoolean()` 982 983<!-- YAML 984changes: 985 - version: 986 - v6.12.0 987 - v4.8.6 988 pr-url: https://github.com/nodejs/node/pull/10116 989 description: A deprecation code has been assigned. 990 - version: 991 - v4.0.0 992 - v3.3.1 993 pr-url: https://github.com/nodejs/node/pull/2447 994 description: Documentation-only deprecation. 995--> 996 997Type: Documentation-only 998 999The [`util.isBoolean()`][] API is deprecated. 1000 1001### DEP0046: `util.isBuffer()` 1002 1003<!-- YAML 1004changes: 1005 - version: 1006 - v6.12.0 1007 - v4.8.6 1008 pr-url: https://github.com/nodejs/node/pull/10116 1009 description: A deprecation code has been assigned. 1010 - version: 1011 - v4.0.0 1012 - v3.3.1 1013 pr-url: https://github.com/nodejs/node/pull/2447 1014 description: Documentation-only deprecation. 1015--> 1016 1017Type: Documentation-only 1018 1019The [`util.isBuffer()`][] API is deprecated. Please use 1020[`Buffer.isBuffer()`][] instead. 1021 1022### DEP0047: `util.isDate()` 1023 1024<!-- YAML 1025changes: 1026 - version: 1027 - v6.12.0 1028 - v4.8.6 1029 pr-url: https://github.com/nodejs/node/pull/10116 1030 description: A deprecation code has been assigned. 1031 - version: 1032 - v4.0.0 1033 - v3.3.1 1034 pr-url: https://github.com/nodejs/node/pull/2447 1035 description: Documentation-only deprecation. 1036--> 1037 1038Type: Documentation-only 1039 1040The [`util.isDate()`][] API is deprecated. 1041 1042### DEP0048: `util.isError()` 1043 1044<!-- YAML 1045changes: 1046 - version: 1047 - v6.12.0 1048 - v4.8.6 1049 pr-url: https://github.com/nodejs/node/pull/10116 1050 description: A deprecation code has been assigned. 1051 - version: 1052 - v4.0.0 1053 - v3.3.1 1054 pr-url: https://github.com/nodejs/node/pull/2447 1055 description: Documentation-only deprecation. 1056--> 1057 1058Type: Documentation-only 1059 1060The [`util.isError()`][] API is deprecated. 1061 1062### DEP0049: `util.isFunction()` 1063 1064<!-- YAML 1065changes: 1066 - version: 1067 - v6.12.0 1068 - v4.8.6 1069 pr-url: https://github.com/nodejs/node/pull/10116 1070 description: A deprecation code has been assigned. 1071 - version: 1072 - v4.0.0 1073 - v3.3.1 1074 pr-url: https://github.com/nodejs/node/pull/2447 1075 description: Documentation-only deprecation. 1076--> 1077 1078Type: Documentation-only 1079 1080The [`util.isFunction()`][] API is deprecated. 1081 1082### DEP0050: `util.isNull()` 1083 1084<!-- YAML 1085changes: 1086 - version: 1087 - v6.12.0 1088 - v4.8.6 1089 pr-url: https://github.com/nodejs/node/pull/10116 1090 description: A deprecation code has been assigned. 1091 - version: 1092 - v4.0.0 1093 - v3.3.1 1094 pr-url: https://github.com/nodejs/node/pull/2447 1095 description: Documentation-only deprecation. 1096--> 1097 1098Type: Documentation-only 1099 1100The [`util.isNull()`][] API is deprecated. 1101 1102### DEP0051: `util.isNullOrUndefined()` 1103 1104<!-- YAML 1105changes: 1106 - version: 1107 - v6.12.0 1108 - v4.8.6 1109 pr-url: https://github.com/nodejs/node/pull/10116 1110 description: A deprecation code has been assigned. 1111 - version: 1112 - v4.0.0 1113 - v3.3.1 1114 pr-url: https://github.com/nodejs/node/pull/2447 1115 description: Documentation-only deprecation. 1116--> 1117 1118Type: Documentation-only 1119 1120The [`util.isNullOrUndefined()`][] API is deprecated. 1121 1122### DEP0052: `util.isNumber()` 1123 1124<!-- YAML 1125changes: 1126 - version: 1127 - v6.12.0 1128 - v4.8.6 1129 pr-url: https://github.com/nodejs/node/pull/10116 1130 description: A deprecation code has been assigned. 1131 - version: 1132 - v4.0.0 1133 - v3.3.1 1134 pr-url: https://github.com/nodejs/node/pull/2447 1135 description: Documentation-only deprecation. 1136--> 1137 1138Type: Documentation-only 1139 1140The [`util.isNumber()`][] API is deprecated. 1141 1142### DEP0053: `util.isObject()` 1143 1144<!-- YAML 1145changes: 1146 - version: 1147 - v6.12.0 1148 - v4.8.6 1149 pr-url: https://github.com/nodejs/node/pull/10116 1150 description: A deprecation code has been assigned. 1151 - version: 1152 - v4.0.0 1153 - v3.3.1 1154 pr-url: https://github.com/nodejs/node/pull/2447 1155 description: Documentation-only deprecation. 1156--> 1157 1158Type: Documentation-only 1159 1160The [`util.isObject()`][] API is deprecated. 1161 1162### DEP0054: `util.isPrimitive()` 1163 1164<!-- YAML 1165changes: 1166 - version: 1167 - v6.12.0 1168 - v4.8.6 1169 pr-url: https://github.com/nodejs/node/pull/10116 1170 description: A deprecation code has been assigned. 1171 - version: 1172 - v4.0.0 1173 - v3.3.1 1174 pr-url: https://github.com/nodejs/node/pull/2447 1175 description: Documentation-only deprecation. 1176--> 1177 1178Type: Documentation-only 1179 1180The [`util.isPrimitive()`][] API is deprecated. 1181 1182### DEP0055: `util.isRegExp()` 1183 1184<!-- YAML 1185changes: 1186 - version: 1187 - v6.12.0 1188 - v4.8.6 1189 pr-url: https://github.com/nodejs/node/pull/10116 1190 description: A deprecation code has been assigned. 1191 - version: 1192 - v4.0.0 1193 - v3.3.1 1194 pr-url: https://github.com/nodejs/node/pull/2447 1195 description: Documentation-only deprecation. 1196--> 1197 1198Type: Documentation-only 1199 1200The [`util.isRegExp()`][] API is deprecated. 1201 1202### DEP0056: `util.isString()` 1203 1204<!-- YAML 1205changes: 1206 - version: 1207 - v6.12.0 1208 - v4.8.6 1209 pr-url: https://github.com/nodejs/node/pull/10116 1210 description: A deprecation code has been assigned. 1211 - version: 1212 - v4.0.0 1213 - v3.3.1 1214 pr-url: https://github.com/nodejs/node/pull/2447 1215 description: Documentation-only deprecation. 1216--> 1217 1218Type: Documentation-only 1219 1220The [`util.isString()`][] API is deprecated. 1221 1222### DEP0057: `util.isSymbol()` 1223 1224<!-- YAML 1225changes: 1226 - version: 1227 - v6.12.0 1228 - v4.8.6 1229 pr-url: https://github.com/nodejs/node/pull/10116 1230 description: A deprecation code has been assigned. 1231 - version: 1232 - v4.0.0 1233 - v3.3.1 1234 pr-url: https://github.com/nodejs/node/pull/2447 1235 description: Documentation-only deprecation. 1236--> 1237 1238Type: Documentation-only 1239 1240The [`util.isSymbol()`][] API is deprecated. 1241 1242### DEP0058: `util.isUndefined()` 1243 1244<!-- YAML 1245changes: 1246 - version: 1247 - v6.12.0 1248 - v4.8.6 1249 pr-url: https://github.com/nodejs/node/pull/10116 1250 description: A deprecation code has been assigned. 1251 - version: 1252 - v4.0.0 1253 - v3.3.1 1254 pr-url: https://github.com/nodejs/node/pull/2447 1255 description: Documentation-only deprecation. 1256--> 1257 1258Type: Documentation-only 1259 1260The [`util.isUndefined()`][] API is deprecated. 1261 1262### DEP0059: `util.log()` 1263 1264<!-- YAML 1265changes: 1266 - version: v6.12.0 1267 pr-url: https://github.com/nodejs/node/pull/10116 1268 description: A deprecation code has been assigned. 1269 - version: v6.0.0 1270 pr-url: https://github.com/nodejs/node/pull/6161 1271 description: Documentation-only deprecation. 1272--> 1273 1274Type: Documentation-only 1275 1276The [`util.log()`][] API is deprecated. 1277 1278### DEP0060: `util._extend()` 1279 1280<!-- YAML 1281changes: 1282 - version: v6.12.0 1283 pr-url: https://github.com/nodejs/node/pull/10116 1284 description: A deprecation code has been assigned. 1285 - version: v6.0.0 1286 pr-url: https://github.com/nodejs/node/pull/4903 1287 description: Documentation-only deprecation. 1288--> 1289 1290Type: Documentation-only 1291 1292The [`util._extend()`][] API is deprecated. 1293 1294### DEP0061: `fs.SyncWriteStream` 1295 1296<!-- YAML 1297changes: 1298 - version: v11.0.0 1299 pr-url: https://github.com/nodejs/node/pull/20735 1300 description: End-of-Life. 1301 - version: v8.0.0 1302 pr-url: https://github.com/nodejs/node/pull/10467 1303 description: Runtime deprecation. 1304 - version: v7.0.0 1305 pr-url: https://github.com/nodejs/node/pull/6749 1306 description: Documentation-only deprecation. 1307--> 1308 1309Type: End-of-Life 1310 1311The `fs.SyncWriteStream` class was never intended to be a publicly accessible 1312API and has been removed. No alternative API is available. Please use a userland 1313alternative. 1314 1315### DEP0062: `node --debug` 1316 1317<!-- YAML 1318changes: 1319 - version: v12.0.0 1320 pr-url: https://github.com/nodejs/node/pull/25828 1321 description: End-of-Life. 1322 - version: v8.0.0 1323 pr-url: https://github.com/nodejs/node/pull/10970 1324 description: Runtime deprecation. 1325--> 1326 1327Type: End-of-Life 1328 1329`--debug` activates the legacy V8 debugger interface, which was removed as 1330of V8 5.8. It is replaced by Inspector which is activated with `--inspect` 1331instead. 1332 1333### DEP0063: `ServerResponse.prototype.writeHeader()` 1334 1335<!-- YAML 1336changes: 1337 - version: v8.0.0 1338 pr-url: https://github.com/nodejs/node/pull/11355 1339 description: Documentation-only deprecation. 1340--> 1341 1342Type: Documentation-only 1343 1344The `node:http` module `ServerResponse.prototype.writeHeader()` API is 1345deprecated. Please use `ServerResponse.prototype.writeHead()` instead. 1346 1347The `ServerResponse.prototype.writeHeader()` method was never documented as an 1348officially supported API. 1349 1350### DEP0064: `tls.createSecurePair()` 1351 1352<!-- YAML 1353changes: 1354 - version: v8.0.0 1355 pr-url: https://github.com/nodejs/node/pull/11349 1356 description: Runtime deprecation. 1357 - version: v6.12.0 1358 pr-url: https://github.com/nodejs/node/pull/10116 1359 description: A deprecation code has been assigned. 1360 - version: v6.0.0 1361 pr-url: https://github.com/nodejs/node/pull/6063 1362 description: Documentation-only deprecation. 1363 - version: v0.11.15 1364 pr-url: 1365 - https://github.com/nodejs/node-v0.x-archive/pull/8695 1366 - https://github.com/nodejs/node-v0.x-archive/pull/8700 1367 description: Deprecation revoked. 1368 - version: v0.11.3 1369 commit: af80e7bc6e6f33c582eb1f7d37c7f5bbe9f910f7 1370 description: Runtime deprecation. 1371--> 1372 1373Type: Runtime 1374 1375The `tls.createSecurePair()` API was deprecated in documentation in Node.js 13760.11.3. Users should use `tls.Socket` instead. 1377 1378### DEP0065: `repl.REPL_MODE_MAGIC` and `NODE_REPL_MODE=magic` 1379 1380<!-- YAML 1381changes: 1382 - version: v10.0.0 1383 pr-url: https://github.com/nodejs/node/pull/19187 1384 description: End-of-Life. 1385 - version: v8.0.0 1386 pr-url: https://github.com/nodejs/node/pull/11599 1387 description: Documentation-only deprecation. 1388--> 1389 1390Type: End-of-Life 1391 1392The `node:repl` module's `REPL_MODE_MAGIC` constant, used for `replMode` option, 1393has been removed. Its behavior has been functionally identical to that of 1394`REPL_MODE_SLOPPY` since Node.js 6.0.0, when V8 5.0 was imported. Please use 1395`REPL_MODE_SLOPPY` instead. 1396 1397The `NODE_REPL_MODE` environment variable is used to set the underlying 1398`replMode` of an interactive `node` session. Its value, `magic`, is also 1399removed. Please use `sloppy` instead. 1400 1401### DEP0066: `OutgoingMessage.prototype._headers, OutgoingMessage.prototype._headerNames` 1402 1403<!-- YAML 1404changes: 1405 - version: v12.0.0 1406 pr-url: https://github.com/nodejs/node/pull/24167 1407 description: Runtime deprecation. 1408 - version: v8.0.0 1409 pr-url: https://github.com/nodejs/node/pull/10941 1410 description: Documentation-only deprecation. 1411--> 1412 1413Type: Runtime 1414 1415The `node:http` module `OutgoingMessage.prototype._headers` and 1416`OutgoingMessage.prototype._headerNames` properties are deprecated. Use one of 1417the public methods (e.g. `OutgoingMessage.prototype.getHeader()`, 1418`OutgoingMessage.prototype.getHeaders()`, 1419`OutgoingMessage.prototype.getHeaderNames()`, 1420`OutgoingMessage.prototype.getRawHeaderNames()`, 1421`OutgoingMessage.prototype.hasHeader()`, 1422`OutgoingMessage.prototype.removeHeader()`, 1423`OutgoingMessage.prototype.setHeader()`) for working with outgoing headers. 1424 1425The `OutgoingMessage.prototype._headers` and 1426`OutgoingMessage.prototype._headerNames` properties were never documented as 1427officially supported properties. 1428 1429### DEP0067: `OutgoingMessage.prototype._renderHeaders` 1430 1431<!-- YAML 1432changes: 1433 - version: v8.0.0 1434 pr-url: https://github.com/nodejs/node/pull/10941 1435 description: Documentation-only deprecation. 1436--> 1437 1438Type: Documentation-only 1439 1440The `node:http` module `OutgoingMessage.prototype._renderHeaders()` API is 1441deprecated. 1442 1443The `OutgoingMessage.prototype._renderHeaders` property was never documented as 1444an officially supported API. 1445 1446### DEP0068: `node debug` 1447 1448<!-- YAML 1449changes: 1450 - version: v15.0.0 1451 pr-url: https://github.com/nodejs/node/pull/33648 1452 description: The legacy `node debug` command was removed. 1453 - version: v8.0.0 1454 pr-url: https://github.com/nodejs/node/pull/11441 1455 description: Runtime deprecation. 1456--> 1457 1458Type: End-of-Life 1459 1460`node debug` corresponds to the legacy CLI debugger which has been replaced with 1461a V8-inspector based CLI debugger available through `node inspect`. 1462 1463### DEP0069: `vm.runInDebugContext(string)` 1464 1465<!-- YAML 1466changes: 1467 - version: v10.0.0 1468 pr-url: https://github.com/nodejs/node/pull/13295 1469 description: End-of-Life. 1470 - version: v9.0.0 1471 pr-url: https://github.com/nodejs/node/pull/12815 1472 description: Runtime deprecation. 1473 - version: v8.0.0 1474 pr-url: https://github.com/nodejs/node/pull/12243 1475 description: Documentation-only deprecation. 1476--> 1477 1478Type: End-of-Life 1479 1480DebugContext has been removed in V8 and is not available in Node.js 10+. 1481 1482DebugContext was an experimental API. 1483 1484### DEP0070: `async_hooks.currentId()` 1485 1486<!-- YAML 1487changes: 1488 - version: v9.0.0 1489 pr-url: https://github.com/nodejs/node/pull/14414 1490 description: End-of-Life. 1491 - version: v8.2.0 1492 pr-url: https://github.com/nodejs/node/pull/13490 1493 description: Runtime deprecation. 1494--> 1495 1496Type: End-of-Life 1497 1498`async_hooks.currentId()` was renamed to `async_hooks.executionAsyncId()` for 1499clarity. 1500 1501This change was made while `async_hooks` was an experimental API. 1502 1503### DEP0071: `async_hooks.triggerId()` 1504 1505<!-- YAML 1506changes: 1507 - version: v9.0.0 1508 pr-url: https://github.com/nodejs/node/pull/14414 1509 description: End-of-Life. 1510 - version: v8.2.0 1511 pr-url: https://github.com/nodejs/node/pull/13490 1512 description: Runtime deprecation. 1513--> 1514 1515Type: End-of-Life 1516 1517`async_hooks.triggerId()` was renamed to `async_hooks.triggerAsyncId()` for 1518clarity. 1519 1520This change was made while `async_hooks` was an experimental API. 1521 1522### DEP0072: `async_hooks.AsyncResource.triggerId()` 1523 1524<!-- YAML 1525changes: 1526 - version: v9.0.0 1527 pr-url: https://github.com/nodejs/node/pull/14414 1528 description: End-of-Life. 1529 - version: v8.2.0 1530 pr-url: https://github.com/nodejs/node/pull/13490 1531 description: Runtime deprecation. 1532--> 1533 1534Type: End-of-Life 1535 1536`async_hooks.AsyncResource.triggerId()` was renamed to 1537`async_hooks.AsyncResource.triggerAsyncId()` for clarity. 1538 1539This change was made while `async_hooks` was an experimental API. 1540 1541### DEP0073: Several internal properties of `net.Server` 1542 1543<!-- YAML 1544changes: 1545 - version: v10.0.0 1546 pr-url: https://github.com/nodejs/node/pull/17141 1547 description: End-of-Life. 1548 - version: v9.0.0 1549 pr-url: https://github.com/nodejs/node/pull/14449 1550 description: Runtime deprecation. 1551--> 1552 1553Type: End-of-Life 1554 1555Accessing several internal, undocumented properties of `net.Server` instances 1556with inappropriate names is deprecated. 1557 1558As the original API was undocumented and not generally useful for non-internal 1559code, no replacement API is provided. 1560 1561### DEP0074: `REPLServer.bufferedCommand` 1562 1563<!-- YAML 1564changes: 1565 - version: v15.0.0 1566 pr-url: https://github.com/nodejs/node/pull/33286 1567 description: End-of-Life. 1568 - version: v9.0.0 1569 pr-url: https://github.com/nodejs/node/pull/13687 1570 description: Runtime deprecation. 1571--> 1572 1573Type: End-of-Life 1574 1575The `REPLServer.bufferedCommand` property was deprecated in favor of 1576[`REPLServer.clearBufferedCommand()`][]. 1577 1578### DEP0075: `REPLServer.parseREPLKeyword()` 1579 1580<!-- YAML 1581changes: 1582 - version: v15.0.0 1583 pr-url: https://github.com/nodejs/node/pull/33286 1584 description: End-of-Life. 1585 - version: v9.0.0 1586 pr-url: https://github.com/nodejs/node/pull/14223 1587 description: Runtime deprecation. 1588--> 1589 1590Type: End-of-Life 1591 1592`REPLServer.parseREPLKeyword()` was removed from userland visibility. 1593 1594### DEP0076: `tls.parseCertString()` 1595 1596<!-- YAML 1597changes: 1598 - version: v18.0.0 1599 pr-url: https://github.com/nodejs/node/pull/41479 1600 description: End-of-Life. 1601 - version: v9.0.0 1602 pr-url: https://github.com/nodejs/node/pull/14249 1603 description: Runtime deprecation. 1604 - version: v8.6.0 1605 pr-url: https://github.com/nodejs/node/pull/14245 1606 description: Documentation-only deprecation. 1607--> 1608 1609Type: End-of-Life 1610 1611`tls.parseCertString()` was a trivial parsing helper that was made public by 1612mistake. While it was supposed to parse certificate subject and issuer strings, 1613it never handled multi-value Relative Distinguished Names correctly. 1614 1615Earlier versions of this document suggested using `querystring.parse()` as an 1616alternative to `tls.parseCertString()`. However, `querystring.parse()` also does 1617not handle all certificate subjects correctly and should not be used. 1618 1619### DEP0077: `Module._debug()` 1620 1621<!-- YAML 1622changes: 1623 - version: v9.0.0 1624 pr-url: https://github.com/nodejs/node/pull/13948 1625 description: Runtime deprecation. 1626--> 1627 1628Type: Runtime 1629 1630`Module._debug()` is deprecated. 1631 1632The `Module._debug()` function was never documented as an officially 1633supported API. 1634 1635### DEP0078: `REPLServer.turnOffEditorMode()` 1636 1637<!-- YAML 1638changes: 1639 - version: v15.0.0 1640 pr-url: https://github.com/nodejs/node/pull/33286 1641 description: End-of-Life. 1642 - version: v9.0.0 1643 pr-url: https://github.com/nodejs/node/pull/15136 1644 description: Runtime deprecation. 1645--> 1646 1647Type: End-of-Life 1648 1649`REPLServer.turnOffEditorMode()` was removed from userland visibility. 1650 1651### DEP0079: Custom inspection function on objects via `.inspect()` 1652 1653<!-- YAML 1654changes: 1655 - version: v11.0.0 1656 pr-url: https://github.com/nodejs/node/pull/20722 1657 description: End-of-Life. 1658 - version: v10.0.0 1659 pr-url: https://github.com/nodejs/node/pull/16393 1660 description: Runtime deprecation. 1661 - version: v8.7.0 1662 pr-url: https://github.com/nodejs/node/pull/15631 1663 description: Documentation-only deprecation. 1664--> 1665 1666Type: End-of-Life 1667 1668Using a property named `inspect` on an object to specify a custom inspection 1669function for [`util.inspect()`][] is deprecated. Use [`util.inspect.custom`][] 1670instead. For backward compatibility with Node.js prior to version 6.4.0, both 1671can be specified. 1672 1673### DEP0080: `path._makeLong()` 1674 1675<!-- YAML 1676changes: 1677 - version: v9.0.0 1678 pr-url: https://github.com/nodejs/node/pull/14956 1679 description: Documentation-only deprecation. 1680--> 1681 1682Type: Documentation-only 1683 1684The internal `path._makeLong()` was not intended for public use. However, 1685userland modules have found it useful. The internal API is deprecated 1686and replaced with an identical, public `path.toNamespacedPath()` method. 1687 1688### DEP0081: `fs.truncate()` using a file descriptor 1689 1690<!-- YAML 1691changes: 1692 - version: v9.0.0 1693 pr-url: https://github.com/nodejs/node/pull/15990 1694 description: Runtime deprecation. 1695--> 1696 1697Type: Runtime 1698 1699`fs.truncate()` `fs.truncateSync()` usage with a file descriptor is 1700deprecated. Please use `fs.ftruncate()` or `fs.ftruncateSync()` to work with 1701file descriptors. 1702 1703### DEP0082: `REPLServer.prototype.memory()` 1704 1705<!-- YAML 1706changes: 1707 - version: v15.0.0 1708 pr-url: https://github.com/nodejs/node/pull/33286 1709 description: End-of-Life. 1710 - version: v9.0.0 1711 pr-url: https://github.com/nodejs/node/pull/16242 1712 description: Runtime deprecation. 1713--> 1714 1715Type: End-of-Life 1716 1717`REPLServer.prototype.memory()` is only necessary for the internal mechanics of 1718the `REPLServer` itself. Do not use this function. 1719 1720### DEP0083: Disabling ECDH by setting `ecdhCurve` to `false` 1721 1722<!-- YAML 1723changes: 1724 - version: v10.0.0 1725 pr-url: https://github.com/nodejs/node/pull/19794 1726 description: End-of-Life. 1727 - version: v9.2.0 1728 pr-url: https://github.com/nodejs/node/pull/16130 1729 description: Runtime deprecation. 1730--> 1731 1732Type: End-of-Life. 1733 1734The `ecdhCurve` option to `tls.createSecureContext()` and `tls.TLSSocket` could 1735be set to `false` to disable ECDH entirely on the server only. This mode was 1736deprecated in preparation for migrating to OpenSSL 1.1.0 and consistency with 1737the client and is now unsupported. Use the `ciphers` parameter instead. 1738 1739### DEP0084: requiring bundled internal dependencies 1740 1741<!-- YAML 1742changes: 1743 - version: v12.0.0 1744 pr-url: https://github.com/nodejs/node/pull/25138 1745 description: This functionality has been removed. 1746 - version: v10.0.0 1747 pr-url: https://github.com/nodejs/node/pull/16392 1748 description: Runtime deprecation. 1749--> 1750 1751Type: End-of-Life 1752 1753Since Node.js versions 4.4.0 and 5.2.0, several modules only intended for 1754internal usage were mistakenly exposed to user code through `require()`. These 1755modules were: 1756 1757* `v8/tools/codemap` 1758* `v8/tools/consarray` 1759* `v8/tools/csvparser` 1760* `v8/tools/logreader` 1761* `v8/tools/profile_view` 1762* `v8/tools/profile` 1763* `v8/tools/SourceMap` 1764* `v8/tools/splaytree` 1765* `v8/tools/tickprocessor-driver` 1766* `v8/tools/tickprocessor` 1767* `node-inspect/lib/_inspect` (from 7.6.0) 1768* `node-inspect/lib/internal/inspect_client` (from 7.6.0) 1769* `node-inspect/lib/internal/inspect_repl` (from 7.6.0) 1770 1771The `v8/*` modules do not have any exports, and if not imported in a specific 1772order would in fact throw errors. As such there are virtually no legitimate use 1773cases for importing them through `require()`. 1774 1775On the other hand, `node-inspect` can be installed locally through a package 1776manager, as it is published on the npm registry under the same name. No source 1777code modification is necessary if that is done. 1778 1779### DEP0085: AsyncHooks sensitive API 1780 1781<!-- YAML 1782changes: 1783 - version: v10.0.0 1784 pr-url: https://github.com/nodejs/node/pull/17147 1785 description: End-of-Life. 1786 - version: 1787 - v9.4.0 1788 - v8.10.0 1789 pr-url: https://github.com/nodejs/node/pull/16972 1790 description: Runtime deprecation. 1791--> 1792 1793Type: End-of-Life 1794 1795The AsyncHooks sensitive API was never documented and had various minor issues. 1796Use the `AsyncResource` API instead. See 1797<https://github.com/nodejs/node/issues/15572>. 1798 1799### DEP0086: Remove `runInAsyncIdScope` 1800 1801<!-- YAML 1802changes: 1803 - version: v10.0.0 1804 pr-url: https://github.com/nodejs/node/pull/17147 1805 description: End-of-Life. 1806 - version: 1807 - v9.4.0 1808 - v8.10.0 1809 pr-url: https://github.com/nodejs/node/pull/16972 1810 description: Runtime deprecation. 1811--> 1812 1813Type: End-of-Life 1814 1815`runInAsyncIdScope` doesn't emit the `'before'` or `'after'` event and can thus 1816cause a lot of issues. See <https://github.com/nodejs/node/issues/14328>. 1817 1818<!-- md-lint skip-deprecation DEP0087 --> 1819 1820<!-- md-lint skip-deprecation DEP0088 --> 1821 1822### DEP0089: `require('node:assert')` 1823 1824<!-- YAML 1825changes: 1826 - version: v12.8.0 1827 pr-url: https://github.com/nodejs/node/pull/28892 1828 description: Deprecation revoked. 1829 - version: 1830 - v9.9.0 1831 - v8.13.0 1832 pr-url: https://github.com/nodejs/node/pull/17002 1833 description: Documentation-only deprecation. 1834--> 1835 1836Type: Deprecation revoked 1837 1838Importing assert directly was not recommended as the exposed functions use 1839loose equality checks. The deprecation was revoked because use of the 1840`node:assert` module is not discouraged, and the deprecation caused developer 1841confusion. 1842 1843### DEP0090: Invalid GCM authentication tag lengths 1844 1845<!-- YAML 1846changes: 1847 - version: v11.0.0 1848 pr-url: https://github.com/nodejs/node/pull/17825 1849 description: End-of-Life. 1850 - version: v10.0.0 1851 pr-url: https://github.com/nodejs/node/pull/18017 1852 description: Runtime deprecation. 1853--> 1854 1855Type: End-of-Life 1856 1857Node.js used to support all GCM authentication tag lengths which are accepted by 1858OpenSSL when calling [`decipher.setAuthTag()`][]. Beginning with Node.js 1859v11.0.0, only authentication tag lengths of 128, 120, 112, 104, 96, 64, and 32 1860bits are allowed. Authentication tags of other lengths are invalid per 1861[NIST SP 800-38D][]. 1862 1863### DEP0091: `crypto.DEFAULT_ENCODING` 1864 1865<!-- YAML 1866changes: 1867 - version: v10.0.0 1868 pr-url: https://github.com/nodejs/node/pull/18333 1869 description: Runtime deprecation. 1870--> 1871 1872Type: Runtime 1873 1874The [`crypto.DEFAULT_ENCODING`][] property is deprecated. 1875 1876### DEP0092: Top-level `this` bound to `module.exports` 1877 1878<!-- YAML 1879changes: 1880 - version: v10.0.0 1881 pr-url: https://github.com/nodejs/node/pull/16878 1882 description: Documentation-only deprecation. 1883--> 1884 1885Type: Documentation-only 1886 1887Assigning properties to the top-level `this` as an alternative 1888to `module.exports` is deprecated. Developers should use `exports` 1889or `module.exports` instead. 1890 1891### DEP0093: `crypto.fips` is deprecated and replaced 1892 1893<!-- YAML 1894changes: 1895 - version: v10.0.0 1896 pr-url: https://github.com/nodejs/node/pull/18335 1897 description: Documentation-only deprecation. 1898--> 1899 1900Type: Documentation-only 1901 1902The [`crypto.fips`][] property is deprecated. Please use `crypto.setFips()` 1903and `crypto.getFips()` instead. 1904 1905### DEP0094: Using `assert.fail()` with more than one argument 1906 1907<!-- YAML 1908changes: 1909 - version: v10.0.0 1910 pr-url: https://github.com/nodejs/node/pull/18418 1911 description: Runtime deprecation. 1912--> 1913 1914Type: Runtime 1915 1916Using `assert.fail()` with more than one argument is deprecated. Use 1917`assert.fail()` with only one argument or use a different `node:assert` module 1918method. 1919 1920### DEP0095: `timers.enroll()` 1921 1922<!-- YAML 1923changes: 1924 - version: v10.0.0 1925 pr-url: https://github.com/nodejs/node/pull/18066 1926 description: Runtime deprecation. 1927--> 1928 1929Type: Runtime 1930 1931`timers.enroll()` is deprecated. Please use the publicly documented 1932[`setTimeout()`][] or [`setInterval()`][] instead. 1933 1934### DEP0096: `timers.unenroll()` 1935 1936<!-- YAML 1937changes: 1938 - version: v10.0.0 1939 pr-url: https://github.com/nodejs/node/pull/18066 1940 description: Runtime deprecation. 1941--> 1942 1943Type: Runtime 1944 1945`timers.unenroll()` is deprecated. Please use the publicly documented 1946[`clearTimeout()`][] or [`clearInterval()`][] instead. 1947 1948### DEP0097: `MakeCallback` with `domain` property 1949 1950<!-- YAML 1951changes: 1952 - version: v10.0.0 1953 pr-url: https://github.com/nodejs/node/pull/17417 1954 description: Runtime deprecation. 1955--> 1956 1957Type: Runtime 1958 1959Users of `MakeCallback` that add the `domain` property to carry context, 1960should start using the `async_context` variant of `MakeCallback` or 1961`CallbackScope`, or the high-level `AsyncResource` class. 1962 1963### DEP0098: AsyncHooks embedder `AsyncResource.emitBefore` and `AsyncResource.emitAfter` APIs 1964 1965<!-- YAML 1966changes: 1967 - version: v12.0.0 1968 pr-url: https://github.com/nodejs/node/pull/26530 1969 description: End-of-Life. 1970 - version: 1971 - v10.0.0 1972 - v9.6.0 1973 - v8.12.0 1974 pr-url: https://github.com/nodejs/node/pull/18632 1975 description: Runtime deprecation. 1976--> 1977 1978Type: End-of-Life 1979 1980The embedded API provided by AsyncHooks exposes `.emitBefore()` and 1981`.emitAfter()` methods which are very easy to use incorrectly which can lead 1982to unrecoverable errors. 1983 1984Use [`asyncResource.runInAsyncScope()`][] API instead which provides a much 1985safer, and more convenient, alternative. See 1986<https://github.com/nodejs/node/pull/18513>. 1987 1988### DEP0099: Async context-unaware `node::MakeCallback` C++ APIs 1989 1990<!-- YAML 1991changes: 1992 - version: v10.0.0 1993 pr-url: https://github.com/nodejs/node/pull/18632 1994 description: Compile-time deprecation. 1995--> 1996 1997Type: Compile-time 1998 1999Certain versions of `node::MakeCallback` APIs available to native addons are 2000deprecated. Please use the versions of the API that accept an `async_context` 2001parameter. 2002 2003### DEP0100: `process.assert()` 2004 2005<!-- YAML 2006changes: 2007 - version: v10.0.0 2008 pr-url: https://github.com/nodejs/node/pull/18666 2009 description: Runtime deprecation. 2010 - version: v0.3.7 2011 description: Documentation-only deprecation. 2012--> 2013 2014Type: Runtime 2015 2016`process.assert()` is deprecated. Please use the [`assert`][] module instead. 2017 2018This was never a documented feature. 2019 2020### DEP0101: `--with-lttng` 2021 2022<!-- YAML 2023changes: 2024 - version: v10.0.0 2025 pr-url: https://github.com/nodejs/node/pull/18982 2026 description: End-of-Life. 2027--> 2028 2029Type: End-of-Life 2030 2031The `--with-lttng` compile-time option has been removed. 2032 2033### DEP0102: Using `noAssert` in `Buffer#(read|write)` operations 2034 2035<!-- YAML 2036changes: 2037 - version: v10.0.0 2038 pr-url: https://github.com/nodejs/node/pull/18395 2039 description: End-of-Life. 2040--> 2041 2042Type: End-of-Life 2043 2044Using the `noAssert` argument has no functionality anymore. All input is 2045verified regardless of the value of `noAssert`. Skipping the verification 2046could lead to hard-to-find errors and crashes. 2047 2048### DEP0103: `process.binding('util').is[...]` typechecks 2049 2050<!-- YAML 2051changes: 2052 - version: v10.9.0 2053 pr-url: https://github.com/nodejs/node/pull/22004 2054 description: Superseded by [DEP0111](#DEP0111). 2055 - version: v10.0.0 2056 pr-url: https://github.com/nodejs/node/pull/18415 2057 description: Documentation-only deprecation. 2058--> 2059 2060Type: Documentation-only (supports [`--pending-deprecation`][]) 2061 2062Using `process.binding()` in general should be avoided. The type checking 2063methods in particular can be replaced by using [`util.types`][]. 2064 2065This deprecation has been superseded by the deprecation of the 2066`process.binding()` API ([DEP0111](#DEP0111)). 2067 2068### DEP0104: `process.env` string coercion 2069 2070<!-- YAML 2071changes: 2072 - version: v10.0.0 2073 pr-url: https://github.com/nodejs/node/pull/18990 2074 description: Documentation-only deprecation. 2075--> 2076 2077Type: Documentation-only (supports [`--pending-deprecation`][]) 2078 2079When assigning a non-string property to [`process.env`][], the assigned value is 2080implicitly converted to a string. This behavior is deprecated if the assigned 2081value is not a string, boolean, or number. In the future, such assignment might 2082result in a thrown error. Please convert the property to a string before 2083assigning it to `process.env`. 2084 2085### DEP0105: `decipher.finaltol` 2086 2087<!-- YAML 2088changes: 2089 - version: v11.0.0 2090 pr-url: https://github.com/nodejs/node/pull/19941 2091 description: End-of-Life. 2092 - version: v10.0.0 2093 pr-url: https://github.com/nodejs/node/pull/19353 2094 description: Runtime deprecation. 2095--> 2096 2097Type: End-of-Life 2098 2099`decipher.finaltol()` has never been documented and was an alias for 2100[`decipher.final()`][]. This API has been removed, and it is recommended to use 2101[`decipher.final()`][] instead. 2102 2103### DEP0106: `crypto.createCipher` and `crypto.createDecipher` 2104 2105<!-- YAML 2106changes: 2107 - version: v11.0.0 2108 pr-url: https://github.com/nodejs/node/pull/22089 2109 description: Runtime deprecation. 2110 - version: v10.0.0 2111 pr-url: https://github.com/nodejs/node/pull/19343 2112 description: Documentation-only deprecation. 2113--> 2114 2115Type: Runtime 2116 2117Using [`crypto.createCipher()`][] and [`crypto.createDecipher()`][] must be 2118avoided as they use a weak key derivation function (MD5 with no salt) and static 2119initialization vectors. It is recommended to derive a key using 2120[`crypto.pbkdf2()`][] or [`crypto.scrypt()`][] with random salts and to use 2121[`crypto.createCipheriv()`][] and [`crypto.createDecipheriv()`][] to obtain the 2122[`Cipher`][] and [`Decipher`][] objects respectively. 2123 2124### DEP0107: `tls.convertNPNProtocols()` 2125 2126<!-- YAML 2127changes: 2128 - version: v11.0.0 2129 pr-url: https://github.com/nodejs/node/pull/20736 2130 description: End-of-Life. 2131 - version: v10.0.0 2132 pr-url: https://github.com/nodejs/node/pull/19403 2133 description: Runtime deprecation. 2134--> 2135 2136Type: End-of-Life 2137 2138This was an undocumented helper function not intended for use outside Node.js 2139core and obsoleted by the removal of NPN (Next Protocol Negotiation) support. 2140 2141### DEP0108: `zlib.bytesRead` 2142 2143<!-- YAML 2144changes: 2145 - version: v11.0.0 2146 pr-url: https://github.com/nodejs/node/pull/23308 2147 description: Runtime deprecation. 2148 - version: v10.0.0 2149 pr-url: https://github.com/nodejs/node/pull/19414 2150 description: Documentation-only deprecation. 2151--> 2152 2153Type: Runtime 2154 2155Deprecated alias for [`zlib.bytesWritten`][]. This original name was chosen 2156because it also made sense to interpret the value as the number of bytes 2157read by the engine, but is inconsistent with other streams in Node.js that 2158expose values under these names. 2159 2160### DEP0109: `http`, `https`, and `tls` support for invalid URLs 2161 2162<!-- YAML 2163changes: 2164 - version: v16.0.0 2165 pr-url: https://github.com/nodejs/node/pull/36853 2166 description: End-of-Life. 2167 - version: v11.0.0 2168 pr-url: https://github.com/nodejs/node/pull/20270 2169 description: Runtime deprecation. 2170--> 2171 2172Type: End-of-Life 2173 2174Some previously supported (but strictly invalid) URLs were accepted through the 2175[`http.request()`][], [`http.get()`][], [`https.request()`][], 2176[`https.get()`][], and [`tls.checkServerIdentity()`][] APIs because those were 2177accepted by the legacy `url.parse()` API. The mentioned APIs now use the WHATWG 2178URL parser that requires strictly valid URLs. Passing an invalid URL is 2179deprecated and support will be removed in the future. 2180 2181### DEP0110: `vm.Script` cached data 2182 2183<!-- YAML 2184changes: 2185 - version: v10.6.0 2186 pr-url: https://github.com/nodejs/node/pull/20300 2187 description: Documentation-only deprecation. 2188--> 2189 2190Type: Documentation-only 2191 2192The `produceCachedData` option is deprecated. Use 2193[`script.createCachedData()`][] instead. 2194 2195### DEP0111: `process.binding()` 2196 2197<!-- YAML 2198changes: 2199 - version: v11.12.0 2200 pr-url: https://github.com/nodejs/node/pull/26500 2201 description: Added support for `--pending-deprecation`. 2202 - version: v10.9.0 2203 pr-url: https://github.com/nodejs/node/pull/22004 2204 description: Documentation-only deprecation. 2205--> 2206 2207Type: Documentation-only (supports [`--pending-deprecation`][]) 2208 2209`process.binding()` is for use by Node.js internal code only. 2210 2211While `process.binding()` has not reached End-of-Life status in general, it is 2212unavailable when [policies][] are enabled. 2213 2214### DEP0112: `dgram` private APIs 2215 2216<!-- YAML 2217changes: 2218 - version: v11.0.0 2219 pr-url: https://github.com/nodejs/node/pull/22011 2220 description: Runtime deprecation. 2221--> 2222 2223Type: Runtime 2224 2225The `node:dgram` module previously contained several APIs that were never meant 2226to accessed outside of Node.js core: `Socket.prototype._handle`, 2227`Socket.prototype._receiving`, `Socket.prototype._bindState`, 2228`Socket.prototype._queue`, `Socket.prototype._reuseAddr`, 2229`Socket.prototype._healthCheck()`, `Socket.prototype._stopReceiving()`, and 2230`dgram._createSocketHandle()`. 2231 2232### DEP0113: `Cipher.setAuthTag()`, `Decipher.getAuthTag()` 2233 2234<!-- YAML 2235changes: 2236 - version: v12.0.0 2237 pr-url: https://github.com/nodejs/node/pull/26249 2238 description: End-of-Life. 2239 - version: v11.0.0 2240 pr-url: https://github.com/nodejs/node/pull/22126 2241 description: Runtime deprecation. 2242--> 2243 2244Type: End-of-Life 2245 2246`Cipher.setAuthTag()` and `Decipher.getAuthTag()` are no longer available. They 2247were never documented and would throw when called. 2248 2249### DEP0114: `crypto._toBuf()` 2250 2251<!-- YAML 2252changes: 2253 - version: v12.0.0 2254 pr-url: https://github.com/nodejs/node/pull/25338 2255 description: End-of-Life. 2256 - version: v11.0.0 2257 pr-url: https://github.com/nodejs/node/pull/22501 2258 description: Runtime deprecation. 2259--> 2260 2261Type: End-of-Life 2262 2263The `crypto._toBuf()` function was not designed to be used by modules outside 2264of Node.js core and was removed. 2265 2266<!--lint disable nodejs-yaml-comments --> 2267 2268### DEP0115: `crypto.prng()`, `crypto.pseudoRandomBytes()`, `crypto.rng()` 2269 2270<!-- YAML 2271changes: 2272 - version: v11.0.0 2273 pr-url: 2274 - https://github.com/nodejs/node/pull/22519 2275 - https://github.com/nodejs/node/pull/23017 2276 description: Added documentation-only deprecation 2277 with `--pending-deprecation` support. 2278--> 2279 2280Type: Documentation-only (supports [`--pending-deprecation`][]) 2281 2282<!--lint enable nodejs-yaml-comments --> 2283 2284In recent versions of Node.js, there is no difference between 2285[`crypto.randomBytes()`][] and `crypto.pseudoRandomBytes()`. The latter is 2286deprecated along with the undocumented aliases `crypto.prng()` and 2287`crypto.rng()` in favor of [`crypto.randomBytes()`][] and might be removed in a 2288future release. 2289 2290### DEP0116: Legacy URL API 2291 2292<!-- YAML 2293changes: 2294 - version: v18.13.0 2295 pr-url: https://github.com/nodejs/node/pull/44919 2296 description: \`url.parse()` is deprecated again in DEP0169. 2297 - version: 2298 - v15.13.0 2299 - v14.17.0 2300 pr-url: https://github.com/nodejs/node/pull/37784 2301 description: Deprecation revoked. Status changed to "Legacy". 2302 - version: v11.0.0 2303 pr-url: https://github.com/nodejs/node/pull/22715 2304 description: Documentation-only deprecation. 2305--> 2306 2307Type: Deprecation revoked 2308 2309The [legacy URL API][] is deprecated. This includes [`url.format()`][], 2310[`url.parse()`][], [`url.resolve()`][], and the [legacy `urlObject`][]. Please 2311use the [WHATWG URL API][] instead. 2312 2313### DEP0117: Native crypto handles 2314 2315<!-- YAML 2316changes: 2317 - version: v12.0.0 2318 pr-url: https://github.com/nodejs/node/pull/27011 2319 description: End-of-Life. 2320 - version: v11.0.0 2321 pr-url: https://github.com/nodejs/node/pull/22747 2322 description: Runtime deprecation. 2323--> 2324 2325Type: End-of-Life 2326 2327Previous versions of Node.js exposed handles to internal native objects through 2328the `_handle` property of the `Cipher`, `Decipher`, `DiffieHellman`, 2329`DiffieHellmanGroup`, `ECDH`, `Hash`, `Hmac`, `Sign`, and `Verify` classes. 2330The `_handle` property has been removed because improper use of the native 2331object can lead to crashing the application. 2332 2333### DEP0118: `dns.lookup()` support for a falsy host name 2334 2335<!-- YAML 2336changes: 2337 - version: v11.0.0 2338 pr-url: https://github.com/nodejs/node/pull/23173 2339 description: Runtime deprecation. 2340--> 2341 2342Type: Runtime 2343 2344Previous versions of Node.js supported `dns.lookup()` with a falsy host name 2345like `dns.lookup(false)` due to backward compatibility. 2346This behavior is undocumented and is thought to be unused in real world apps. 2347It will become an error in future versions of Node.js. 2348 2349### DEP0119: `process.binding('uv').errname()` private API 2350 2351<!-- YAML 2352changes: 2353 - version: v11.0.0 2354 pr-url: https://github.com/nodejs/node/pull/23597 2355 description: Documentation-only deprecation. 2356--> 2357 2358Type: Documentation-only (supports [`--pending-deprecation`][]) 2359 2360`process.binding('uv').errname()` is deprecated. Please use 2361[`util.getSystemErrorName()`][] instead. 2362 2363### DEP0120: Windows Performance Counter support 2364 2365<!-- YAML 2366changes: 2367 - version: v12.0.0 2368 pr-url: https://github.com/nodejs/node/pull/24862 2369 description: End-of-Life. 2370 - version: v11.0.0 2371 pr-url: https://github.com/nodejs/node/pull/22485 2372 description: Runtime deprecation. 2373--> 2374 2375Type: End-of-Life 2376 2377Windows Performance Counter support has been removed from Node.js. The 2378undocumented `COUNTER_NET_SERVER_CONNECTION()`, 2379`COUNTER_NET_SERVER_CONNECTION_CLOSE()`, `COUNTER_HTTP_SERVER_REQUEST()`, 2380`COUNTER_HTTP_SERVER_RESPONSE()`, `COUNTER_HTTP_CLIENT_REQUEST()`, and 2381`COUNTER_HTTP_CLIENT_RESPONSE()` functions have been deprecated. 2382 2383### DEP0121: `net._setSimultaneousAccepts()` 2384 2385<!-- YAML 2386changes: 2387 - version: v12.0.0 2388 pr-url: https://github.com/nodejs/node/pull/23760 2389 description: Runtime deprecation. 2390--> 2391 2392Type: Runtime 2393 2394The undocumented `net._setSimultaneousAccepts()` function was originally 2395intended for debugging and performance tuning when using the 2396`node:child_process` and `node:cluster` modules on Windows. The function is not 2397generally useful and is being removed. See discussion here: 2398<https://github.com/nodejs/node/issues/18391> 2399 2400### DEP0122: `tls` `Server.prototype.setOptions()` 2401 2402<!-- YAML 2403changes: 2404 - version: v12.0.0 2405 pr-url: https://github.com/nodejs/node/pull/23820 2406 description: Runtime deprecation. 2407--> 2408 2409Type: Runtime 2410 2411Please use `Server.prototype.setSecureContext()` instead. 2412 2413### DEP0123: setting the TLS ServerName to an IP address 2414 2415<!-- YAML 2416changes: 2417 - version: v12.0.0 2418 pr-url: https://github.com/nodejs/node/pull/23329 2419 description: Runtime deprecation. 2420--> 2421 2422Type: Runtime 2423 2424Setting the TLS ServerName to an IP address is not permitted by 2425[RFC 6066][]. This will be ignored in a future version. 2426 2427### DEP0124: using `REPLServer.rli` 2428 2429<!-- YAML 2430changes: 2431 - version: v15.0.0 2432 pr-url: https://github.com/nodejs/node/pull/33286 2433 description: End-of-Life. 2434 - version: v12.0.0 2435 pr-url: https://github.com/nodejs/node/pull/26260 2436 description: Runtime deprecation. 2437--> 2438 2439Type: End-of-Life 2440 2441This property is a reference to the instance itself. 2442 2443### DEP0125: `require('node:_stream_wrap')` 2444 2445<!-- YAML 2446changes: 2447 - version: v12.0.0 2448 pr-url: https://github.com/nodejs/node/pull/26245 2449 description: Runtime deprecation. 2450--> 2451 2452Type: Runtime 2453 2454The `node:_stream_wrap` module is deprecated. 2455 2456### DEP0126: `timers.active()` 2457 2458<!-- YAML 2459changes: 2460 - version: v11.14.0 2461 pr-url: https://github.com/nodejs/node/pull/26760 2462 description: Runtime deprecation. 2463--> 2464 2465Type: Runtime 2466 2467The previously undocumented `timers.active()` is deprecated. 2468Please use the publicly documented [`timeout.refresh()`][] instead. 2469If re-referencing the timeout is necessary, [`timeout.ref()`][] can be used 2470with no performance impact since Node.js 10. 2471 2472### DEP0127: `timers._unrefActive()` 2473 2474<!-- YAML 2475changes: 2476 - version: v11.14.0 2477 pr-url: https://github.com/nodejs/node/pull/26760 2478 description: Runtime deprecation. 2479--> 2480 2481Type: Runtime 2482 2483The previously undocumented and "private" `timers._unrefActive()` is deprecated. 2484Please use the publicly documented [`timeout.refresh()`][] instead. 2485If unreferencing the timeout is necessary, [`timeout.unref()`][] can be used 2486with no performance impact since Node.js 10. 2487 2488### DEP0128: modules with an invalid `main` entry and an `index.js` file 2489 2490<!-- YAML 2491changes: 2492 - version: v16.0.0 2493 pr-url: https://github.com/nodejs/node/pull/37204 2494 description: Runtime deprecation. 2495 - version: v12.0.0 2496 pr-url: https://github.com/nodejs/node/pull/26823 2497 description: Documentation-only. 2498--> 2499 2500Type: Runtime 2501 2502Modules that have an invalid `main` entry (e.g., `./does-not-exist.js`) and 2503also have an `index.js` file in the top level directory will resolve the 2504`index.js` file. That is deprecated and is going to throw an error in future 2505Node.js versions. 2506 2507### DEP0129: `ChildProcess._channel` 2508 2509<!-- YAML 2510changes: 2511 - version: v13.0.0 2512 pr-url: https://github.com/nodejs/node/pull/27949 2513 description: Runtime deprecation. 2514 - version: v11.14.0 2515 pr-url: https://github.com/nodejs/node/pull/26982 2516 description: Documentation-only. 2517--> 2518 2519Type: Runtime 2520 2521The `_channel` property of child process objects returned by `spawn()` and 2522similar functions is not intended for public use. Use `ChildProcess.channel` 2523instead. 2524 2525### DEP0130: `Module.createRequireFromPath()` 2526 2527<!-- YAML 2528changes: 2529 - version: v16.0.0 2530 pr-url: https://github.com/nodejs/node/pull/37201 2531 description: End-of-life. 2532 - version: v13.0.0 2533 pr-url: https://github.com/nodejs/node/pull/27951 2534 description: Runtime deprecation. 2535 - version: v12.2.0 2536 pr-url: https://github.com/nodejs/node/pull/27405 2537 description: Documentation-only. 2538--> 2539 2540Type: End-of-Life 2541 2542Use [`module.createRequire()`][] instead. 2543 2544### DEP0131: Legacy HTTP parser 2545 2546<!-- YAML 2547changes: 2548 - version: v13.0.0 2549 pr-url: https://github.com/nodejs/node/pull/29589 2550 description: This feature has been removed. 2551 - version: v12.22.0 2552 pr-url: https://github.com/nodejs/node/pull/37603 2553 description: Runtime deprecation. 2554 - version: v12.3.0 2555 pr-url: https://github.com/nodejs/node/pull/27498 2556 description: Documentation-only. 2557--> 2558 2559Type: End-of-Life 2560 2561The legacy HTTP parser, used by default in versions of Node.js prior to 12.0.0, 2562is deprecated and has been removed in v13.0.0. Prior to v13.0.0, the 2563`--http-parser=legacy` command-line flag could be used to revert to using the 2564legacy parser. 2565 2566### DEP0132: `worker.terminate()` with callback 2567 2568<!-- YAML 2569changes: 2570 - version: v12.5.0 2571 pr-url: https://github.com/nodejs/node/pull/28021 2572 description: Runtime deprecation. 2573--> 2574 2575Type: Runtime 2576 2577Passing a callback to [`worker.terminate()`][] is deprecated. Use the returned 2578`Promise` instead, or a listener to the worker's `'exit'` event. 2579 2580### DEP0133: `http` `connection` 2581 2582<!-- YAML 2583changes: 2584 - version: v12.12.0 2585 pr-url: https://github.com/nodejs/node/pull/29015 2586 description: Documentation-only deprecation. 2587--> 2588 2589Type: Documentation-only 2590 2591Prefer [`response.socket`][] over [`response.connection`][] and 2592[`request.socket`][] over [`request.connection`][]. 2593 2594### DEP0134: `process._tickCallback` 2595 2596<!-- YAML 2597changes: 2598 - version: v12.12.0 2599 pr-url: https://github.com/nodejs/node/pull/29781 2600 description: Documentation-only deprecation. 2601--> 2602 2603Type: Documentation-only (supports [`--pending-deprecation`][]) 2604 2605The `process._tickCallback` property was never documented as 2606an officially supported API. 2607 2608### DEP0135: `WriteStream.open()` and `ReadStream.open()` are internal 2609 2610<!-- YAML 2611changes: 2612 - version: v13.0.0 2613 pr-url: https://github.com/nodejs/node/pull/29061 2614 description: Runtime deprecation. 2615--> 2616 2617Type: Runtime 2618 2619[`WriteStream.open()`][] and [`ReadStream.open()`][] are undocumented internal 2620APIs that do not make sense to use in userland. File streams should always be 2621opened through their corresponding factory methods [`fs.createWriteStream()`][] 2622and [`fs.createReadStream()`][]) or by passing a file descriptor in options. 2623 2624### DEP0136: `http` `finished` 2625 2626<!-- YAML 2627changes: 2628 - version: 2629 - v13.4.0 2630 - v12.16.0 2631 pr-url: https://github.com/nodejs/node/pull/28679 2632 description: Documentation-only deprecation. 2633--> 2634 2635Type: Documentation-only 2636 2637[`response.finished`][] indicates whether [`response.end()`][] has been 2638called, not whether `'finish'` has been emitted and the underlying data 2639is flushed. 2640 2641Use [`response.writableFinished`][] or [`response.writableEnded`][] 2642accordingly instead to avoid the ambiguity. 2643 2644To maintain existing behavior `response.finished` should be replaced with 2645`response.writableEnded`. 2646 2647### DEP0137: Closing fs.FileHandle on garbage collection 2648 2649<!-- YAML 2650changes: 2651 - version: v14.0.0 2652 pr-url: https://github.com/nodejs/node/pull/28396 2653 description: Runtime deprecation. 2654--> 2655 2656Type: Runtime 2657 2658Allowing a [`fs.FileHandle`][] object to be closed on garbage collection is 2659deprecated. In the future, doing so might result in a thrown error that will 2660terminate the process. 2661 2662Please ensure that all `fs.FileHandle` objects are explicitly closed using 2663`FileHandle.prototype.close()` when the `fs.FileHandle` is no longer needed: 2664 2665```js 2666const fsPromises = require('node:fs').promises; 2667async function openAndClose() { 2668 let filehandle; 2669 try { 2670 filehandle = await fsPromises.open('thefile.txt', 'r'); 2671 } finally { 2672 if (filehandle !== undefined) 2673 await filehandle.close(); 2674 } 2675} 2676``` 2677 2678### DEP0138: `process.mainModule` 2679 2680<!-- YAML 2681changes: 2682 - version: v14.0.0 2683 pr-url: https://github.com/nodejs/node/pull/32232 2684 description: Documentation-only deprecation. 2685--> 2686 2687Type: Documentation-only 2688 2689[`process.mainModule`][] is a CommonJS-only feature while `process` global 2690object is shared with non-CommonJS environment. Its use within ECMAScript 2691modules is unsupported. 2692 2693It is deprecated in favor of [`require.main`][], because it serves the same 2694purpose and is only available on CommonJS environment. 2695 2696### DEP0139: `process.umask()` with no arguments 2697 2698<!-- YAML 2699changes: 2700 - version: 2701 - v14.0.0 2702 - v12.19.0 2703 pr-url: https://github.com/nodejs/node/pull/32499 2704 description: Documentation-only deprecation. 2705--> 2706 2707Type: Documentation-only 2708 2709Calling `process.umask()` with no argument causes the process-wide umask to be 2710written twice. This introduces a race condition between threads, and is a 2711potential security vulnerability. There is no safe, cross-platform alternative 2712API. 2713 2714### DEP0140: Use `request.destroy()` instead of `request.abort()` 2715 2716<!-- YAML 2717changes: 2718 - version: 2719 - v14.1.0 2720 - v13.14.0 2721 pr-url: https://github.com/nodejs/node/pull/32807 2722 description: Documentation-only deprecation. 2723--> 2724 2725Type: Documentation-only 2726 2727Use [`request.destroy()`][] instead of [`request.abort()`][]. 2728 2729### DEP0141: `repl.inputStream` and `repl.outputStream` 2730 2731<!-- YAML 2732changes: 2733 - version: v14.3.0 2734 pr-url: https://github.com/nodejs/node/pull/33294 2735 description: Documentation-only (supports [`--pending-deprecation`][]). 2736--> 2737 2738Type: Documentation-only (supports [`--pending-deprecation`][]) 2739 2740The `node:repl` module exported the input and output stream twice. Use `.input` 2741instead of `.inputStream` and `.output` instead of `.outputStream`. 2742 2743### DEP0142: `repl._builtinLibs` 2744 2745<!-- YAML 2746changes: 2747 - version: v14.3.0 2748 pr-url: https://github.com/nodejs/node/pull/33294 2749 description: Documentation-only (supports [`--pending-deprecation`][]). 2750--> 2751 2752Type: Documentation-only 2753 2754The `node:repl` module exports a `_builtinLibs` property that contains an array 2755of built-in modules. It was incomplete so far and instead it's better to rely 2756upon `require('node:module').builtinModules`. 2757 2758### DEP0143: `Transform._transformState` 2759 2760<!-- YAML 2761changes: 2762 - version: v14.5.0 2763 pr-url: https://github.com/nodejs/node/pull/33126 2764 description: Runtime deprecation. 2765--> 2766 2767Type: Runtime 2768`Transform._transformState` will be removed in future versions where it is 2769no longer required due to simplification of the implementation. 2770 2771### DEP0144: `module.parent` 2772 2773<!-- YAML 2774changes: 2775 - version: 2776 - v14.6.0 2777 - v12.19.0 2778 pr-url: https://github.com/nodejs/node/pull/32217 2779 description: Documentation-only deprecation. 2780--> 2781 2782Type: Documentation-only (supports [`--pending-deprecation`][]) 2783 2784A CommonJS module can access the first module that required it using 2785`module.parent`. This feature is deprecated because it does not work 2786consistently in the presence of ECMAScript modules and because it gives an 2787inaccurate representation of the CommonJS module graph. 2788 2789Some modules use it to check if they are the entry point of the current process. 2790Instead, it is recommended to compare `require.main` and `module`: 2791 2792```js 2793if (require.main === module) { 2794 // Code section that will run only if current file is the entry point. 2795} 2796``` 2797 2798When looking for the CommonJS modules that have required the current one, 2799`require.cache` and `module.children` can be used: 2800 2801```js 2802const moduleParents = Object.values(require.cache) 2803 .filter((m) => m.children.includes(module)); 2804``` 2805 2806### DEP0145: `socket.bufferSize` 2807 2808<!-- YAML 2809changes: 2810 - version: v14.6.0 2811 pr-url: https://github.com/nodejs/node/pull/34088 2812 description: Documentation-only deprecation. 2813--> 2814 2815Type: Documentation-only 2816 2817[`socket.bufferSize`][] is just an alias for [`writable.writableLength`][]. 2818 2819### DEP0146: `new crypto.Certificate()` 2820 2821<!-- YAML 2822changes: 2823 - version: v14.9.0 2824 pr-url: https://github.com/nodejs/node/pull/34697 2825 description: Documentation-only deprecation. 2826--> 2827 2828Type: Documentation-only 2829 2830The [`crypto.Certificate()` constructor][] is deprecated. Use 2831[static methods of `crypto.Certificate()`][] instead. 2832 2833### DEP0147: `fs.rmdir(path, { recursive: true })` 2834 2835<!-- YAML 2836changes: 2837 - version: v16.0.0 2838 pr-url: https://github.com/nodejs/node/pull/37302 2839 description: Runtime deprecation. 2840 - version: v15.0.0 2841 pr-url: https://github.com/nodejs/node/pull/35562 2842 description: Runtime deprecation for permissive behavior. 2843 - version: v14.14.0 2844 pr-url: https://github.com/nodejs/node/pull/35579 2845 description: Documentation-only deprecation. 2846--> 2847 2848Type: Runtime 2849 2850In future versions of Node.js, `recursive` option will be ignored for 2851`fs.rmdir`, `fs.rmdirSync`, and `fs.promises.rmdir`. 2852 2853Use `fs.rm(path, { recursive: true, force: true })`, 2854`fs.rmSync(path, { recursive: true, force: true })` or 2855`fs.promises.rm(path, { recursive: true, force: true })` instead. 2856 2857### DEP0148: Folder mappings in `"exports"` (trailing `"/"`) 2858 2859<!-- YAML 2860changes: 2861 - version: v17.0.0 2862 pr-url: https://github.com/nodejs/node/pull/40121 2863 description: End-of-Life. 2864 - version: v16.0.0 2865 pr-url: https://github.com/nodejs/node/pull/37215 2866 description: Runtime deprecation. 2867 - version: v15.1.0 2868 pr-url: https://github.com/nodejs/node/pull/35747 2869 description: Runtime deprecation for self-referencing imports. 2870 - version: v14.13.0 2871 pr-url: https://github.com/nodejs/node/pull/34718 2872 description: Documentation-only deprecation. 2873--> 2874 2875Type: Runtime 2876 2877Using a trailing `"/"` to define subpath folder mappings in the 2878[subpath exports][] or [subpath imports][] fields is deprecated. Use 2879[subpath patterns][] instead. 2880 2881### DEP0149: `http.IncomingMessage#connection` 2882 2883<!-- YAML 2884changes: 2885 - version: v16.0.0 2886 pr-url: https://github.com/nodejs/node/pull/33768 2887 description: Documentation-only deprecation. 2888 --> 2889 2890Type: Documentation-only. 2891 2892Prefer [`message.socket`][] over [`message.connection`][]. 2893 2894### DEP0150: Changing the value of `process.config` 2895 2896<!-- YAML 2897changes: 2898 - version: v19.0.0 2899 pr-url: https://github.com/nodejs/node/pull/43627 2900 description: End-of-Life. 2901 - version: v16.0.0 2902 pr-url: https://github.com/nodejs/node/pull/36902 2903 description: Runtime deprecation. 2904--> 2905 2906Type: End-of-Life 2907 2908The `process.config` property provides access to Node.js compile-time settings. 2909However, the property is mutable and therefore subject to tampering. The ability 2910to change the value will be removed in a future version of Node.js. 2911 2912### DEP0151: Main index lookup and extension searching 2913 2914<!-- YAML 2915changes: 2916 - version: v16.0.0 2917 pr-url: https://github.com/nodejs/node/pull/37206 2918 description: Runtime deprecation. 2919 - version: 2920 - v15.8.0 2921 - v14.18.0 2922 pr-url: https://github.com/nodejs/node/pull/36918 2923 description: Documentation-only deprecation 2924 with `--pending-deprecation` support. 2925--> 2926 2927Type: Runtime 2928 2929Previously, `index.js` and extension searching lookups would apply to 2930`import 'pkg'` main entry point resolution, even when resolving ES modules. 2931 2932With this deprecation, all ES module main entry point resolutions require 2933an explicit [`"exports"` or `"main"` entry][] with the exact file extension. 2934 2935### DEP0152: Extension PerformanceEntry properties 2936 2937<!-- YAML 2938changes: 2939 - version: v16.0.0 2940 pr-url: https://github.com/nodejs/node/pull/37136 2941 description: Runtime deprecation. 2942--> 2943 2944Type: Runtime 2945 2946The `'gc'`, `'http2'`, and `'http'` {PerformanceEntry} object types have 2947additional properties assigned to them that provide additional information. 2948These properties are now available within the standard `detail` property 2949of the `PerformanceEntry` object. The existing accessors have been 2950deprecated and should no longer be used. 2951 2952### DEP0153: `dns.lookup` and `dnsPromises.lookup` options type coercion 2953 2954<!-- YAML 2955changes: 2956 - version: v18.0.0 2957 pr-url: https://github.com/nodejs/node/pull/41431 2958 description: End-of-Life. 2959 - version: v17.0.0 2960 pr-url: https://github.com/nodejs/node/pull/39793 2961 description: Runtime deprecation. 2962 - version: v16.8.0 2963 pr-url: https://github.com/nodejs/node/pull/38906 2964 description: Documentation-only deprecation. 2965--> 2966 2967Type: End-of-Life 2968 2969Using a non-nullish non-integer value for `family` option, a non-nullish 2970non-number value for `hints` option, a non-nullish non-boolean value for `all` 2971option, or a non-nullish non-boolean value for `verbatim` option in 2972[`dns.lookup()`][] and [`dnsPromises.lookup()`][] throws an 2973`ERR_INVALID_ARG_TYPE` error. 2974 2975### DEP0154: RSA-PSS generate key pair options 2976 2977<!-- YAML 2978changes: 2979 - version: v16.10.0 2980 pr-url: https://github.com/nodejs/node/pull/39927 2981 description: Documentation-only deprecation. 2982--> 2983 2984Type: Documentation-only (supports [`--pending-deprecation`][]) 2985 2986The `'hash'` and `'mgf1Hash'` options are replaced with `'hashAlgorithm'` 2987and `'mgf1HashAlgorithm'`. 2988 2989### DEP0155: Trailing slashes in pattern specifier resolutions 2990 2991<!-- YAML 2992changes: 2993 - version: v17.0.0 2994 pr-url: https://github.com/nodejs/node/pull/40117 2995 description: Runtime deprecation. 2996 - version: v16.10.0 2997 pr-url: https://github.com/nodejs/node/pull/40039 2998 description: Documentation-only deprecation 2999 with `--pending-deprecation` support. 3000--> 3001 3002Type: Runtime 3003 3004The remapping of specifiers ending in `"/"` like `import 'pkg/x/'` is deprecated 3005for package `"exports"` and `"imports"` pattern resolutions. 3006 3007### DEP0156: `.aborted` property and `'abort'`, `'aborted'` event in `http` 3008 3009<!-- YAML 3010changes: 3011 - version: 3012 - v17.0.0 3013 - v16.12.0 3014 pr-url: https://github.com/nodejs/node/pull/36670 3015 description: Documentation-only deprecation. 3016--> 3017 3018Type: Documentation-only 3019 3020Move to {Stream} API instead, as the [`http.ClientRequest`][], 3021[`http.ServerResponse`][], and [`http.IncomingMessage`][] are all stream-based. 3022Check `stream.destroyed` instead of the `.aborted` property, and listen for 3023`'close'` instead of `'abort'`, `'aborted'` event. 3024 3025The `.aborted` property and `'abort'` event are only useful for detecting 3026`.abort()` calls. For closing a request early, use the Stream 3027`.destroy([error])` then check the `.destroyed` property and `'close'` event 3028should have the same effect. The receiving end should also check the 3029[`readable.readableEnded`][] value on [`http.IncomingMessage`][] to get whether 3030it was an aborted or graceful destroy. 3031 3032### DEP0157: Thenable support in streams 3033 3034<!-- YAML 3035changes: 3036 - version: v18.0.0 3037 pr-url: https://github.com/nodejs/node/pull/40773 3038 description: End-of-life. 3039 - version: 3040 - v17.2.0 3041 - v16.14.0 3042 pr-url: https://github.com/nodejs/node/pull/40860 3043 description: Documentation-only deprecation. 3044--> 3045 3046Type: End-of-Life 3047 3048An undocumented feature of Node.js streams was to support thenables in 3049implementation methods. This is now deprecated, use callbacks instead and avoid 3050use of async function for streams implementation methods. 3051 3052This feature caused users to encounter unexpected problems where the user 3053implements the function in callback style but uses e.g. an async method which 3054would cause an error since mixing promise and callback semantics is not valid. 3055 3056```js 3057const w = new Writable({ 3058 async final(callback) { 3059 await someOp(); 3060 callback(); 3061 }, 3062}); 3063``` 3064 3065### DEP0158: `buffer.slice(start, end)` 3066 3067<!-- YAML 3068changes: 3069 - version: 3070 - v17.5.0 3071 - v16.15.0 3072 pr-url: https://github.com/nodejs/node/pull/41596 3073 description: Documentation-only deprecation. 3074--> 3075 3076Type: Documentation-only 3077 3078This method was deprecated because it is not compatible with 3079`Uint8Array.prototype.slice()`, which is a superclass of `Buffer`. 3080 3081Use [`buffer.subarray`][] which does the same thing instead. 3082 3083### DEP0159: `ERR_INVALID_CALLBACK` 3084 3085<!-- YAML 3086changes: 3087 - version: v18.0.0 3088 pr-url: https://github.com/nodejs/node/pull/41678 3089 description: End-of-Life. 3090--> 3091 3092Type: End-of-Life 3093 3094This error code was removed due to adding more confusion to 3095the errors used for value type validation. 3096 3097### DEP0160: `process.on('multipleResolves', handler)` 3098 3099<!-- YAML 3100changes: 3101 - version: v18.0.0 3102 pr-url: https://github.com/nodejs/node/pull/41896 3103 description: Runtime deprecation. 3104 - version: 3105 - v17.6.0 3106 - v16.15.0 3107 pr-url: https://github.com/nodejs/node/pull/41872 3108 description: Documentation-only deprecation. 3109--> 3110 3111Type: Runtime. 3112 3113This event was deprecated because it did not work with V8 promise combinators 3114which diminished its usefulness. 3115 3116### DEP0161: `process._getActiveRequests()` and `process._getActiveHandles()` 3117 3118<!-- YAML 3119changes: 3120 - version: 3121 - v17.6.0 3122 - v16.15.0 3123 pr-url: https://github.com/nodejs/node/pull/41587 3124 description: Documentation-only deprecation. 3125--> 3126 3127Type: Documentation-only 3128 3129The `process._getActiveHandles()` and `process._getActiveRequests()` 3130functions are not intended for public use and can be removed in future 3131releases. 3132 3133Use [`process.getActiveResourcesInfo()`][] to get a list of types of active 3134resources and not the actual references. 3135 3136### DEP0162: `fs.write()`, `fs.writeFileSync()` coercion to string 3137 3138<!-- YAML 3139changes: 3140 - version: v19.0.0 3141 pr-url: https://github.com/nodejs/node/pull/42796 3142 description: End-of-Life. 3143 - version: v18.0.0 3144 pr-url: https://github.com/nodejs/node/pull/42607 3145 description: Runtime deprecation. 3146 - version: 3147 - v17.8.0 3148 - v16.15.0 3149 pr-url: https://github.com/nodejs/node/pull/42149 3150 description: Documentation-only deprecation. 3151--> 3152 3153Type: End-of-Life 3154 3155Implicit coercion of objects with own `toString` property, passed as second 3156parameter in [`fs.write()`][], [`fs.writeFile()`][], [`fs.appendFile()`][], 3157[`fs.writeFileSync()`][], and [`fs.appendFileSync()`][] is deprecated. 3158Convert them to primitive strings. 3159 3160### DEP0163: `channel.subscribe(onMessage)`, `channel.unsubscribe(onMessage)` 3161 3162<!-- YAML 3163changes: 3164 - version: 3165 - v18.7.0 3166 - v16.17.0 3167 pr-url: https://github.com/nodejs/node/pull/42714 3168 description: Documentation-only deprecation. 3169--> 3170 3171Type: Documentation-only 3172 3173These methods were deprecated because they can be used in a way which does not 3174hold the channel reference alive long enough to receive the events. 3175 3176Use [`diagnostics_channel.subscribe(name, onMessage)`][] or 3177[`diagnostics_channel.unsubscribe(name, onMessage)`][] which does the same 3178thing instead. 3179 3180### DEP0164: `process.exit(code)`, `process.exitCode` coercion to integer 3181 3182<!-- YAML 3183changes: 3184 - version: v18.10.0 3185 pr-url: https://github.com/nodejs/node/pull/44714 3186 description: Documentation-only deprecation of `process.exitCode` integer 3187 coercion. 3188 - version: 3189 - v18.7.0 3190 - v16.17.0 3191 pr-url: https://github.com/nodejs/node/pull/43738 3192 description: Documentation-only deprecation of `process.exit(code)` integer 3193 coercion. 3194--> 3195 3196Type: Documentation-only 3197 3198Values other than `undefined`, `null`, integer numbers, and integer strings 3199(e.g., `'1'`) are deprecated as value for the `code` parameter in 3200[`process.exit()`][] and as value to assign to [`process.exitCode`][]. 3201 3202### DEP0165: `--trace-atomics-wait` 3203 3204<!-- YAML 3205changes: 3206 - version: v18.8.0 3207 pr-url: https://github.com/nodejs/node/pull/44093 3208 description: Documentation-only deprecation. 3209--> 3210 3211Type: Documentation-only 3212 3213The [`--trace-atomics-wait`][] flag is deprecated. 3214 3215### DEP0166: Double slashes in imports and exports targets 3216 3217<!-- YAML 3218changes: 3219 - version: v19.0.0 3220 pr-url: https://github.com/nodejs/node/pull/44495 3221 description: Runtime deprecation. 3222 - version: v18.10.0 3223 pr-url: https://github.com/nodejs/node/pull/44477 3224 description: Documentation-only deprecation 3225 with `--pending-deprecation` support. 3226--> 3227 3228Type: Runtime 3229 3230Package imports and exports targets mapping into paths including a double slash 3231(of _"/"_ or _"\\"_) are deprecated and will fail with a resolution validation 3232error in a future release. This same deprecation also applies to pattern matches 3233starting or ending in a slash. 3234 3235### DEP0167: Weak `DiffieHellmanGroup` instances (`modp1`, `modp2`, `modp5`) 3236 3237<!-- YAML 3238changes: 3239 - version: v18.10.0 3240 pr-url: https://github.com/nodejs/node/pull/44588 3241 description: Documentation-only deprecation. 3242--> 3243 3244Type: Documentation-only 3245 3246The well-known MODP groups `modp1`, `modp2`, and `modp5` are deprecated because 3247they are not secure against practical attacks. See [RFC 8247 Section 2.4][] for 3248details. 3249 3250These groups might be removed in future versions of Node.js. Applications that 3251rely on these groups should evaluate using stronger MODP groups instead. 3252 3253### DEP0168: Unhandled exception in Node-API callbacks 3254 3255<!-- YAML 3256changes: 3257 - version: 3258 - v18.3.0 3259 - v16.17.0 3260 pr-url: https://github.com/nodejs/node/pull/36510 3261 description: Runtime deprecation. 3262--> 3263 3264Type: Runtime 3265 3266The implicit suppression of uncaught exceptions in Node-API callbacks is now 3267deprecated. 3268 3269Set the flag [`--force-node-api-uncaught-exceptions-policy`][] to force Node.js 3270to emit an [`'uncaughtException'`][] event if the exception is not handled in 3271Node-API callbacks. 3272 3273### DEP0169: Insecure url.parse() 3274 3275<!-- YAML 3276changes: 3277 - version: v18.17.0 3278 pr-url: https://github.com/nodejs/node/pull/47203 3279 description: Added support for `--pending-deprecation`. 3280 - version: 3281 - v18.13.0 3282 pr-url: https://github.com/nodejs/node/pull/44919 3283 description: Documentation-only deprecation. 3284--> 3285 3286Type: Documentation-only (supports [`--pending-deprecation`][]) 3287 3288[`url.parse()`][] behavior is not standardized and prone to errors that 3289have security implications. Use the [WHATWG URL API][] instead. CVEs are not 3290issued for `url.parse()` vulnerabilities. 3291 3292### DEP0170: Invalid port when using `url.parse()` 3293 3294<!-- YAML 3295changes: 3296 - version: 3297 - v18.13.0 3298 pr-url: https://github.com/nodejs/node/pull/45576 3299 description: Documentation-only deprecation. 3300--> 3301 3302Type: Documentation-only 3303 3304[`url.parse()`][] accepts URLs with ports that are not numbers. This behavior 3305might result in host name spoofing with unexpected input. These URLs will throw 3306an error in future versions of Node.js, as the [WHATWG URL API][] does already. 3307 3308### DEP0171: Setters for `http.IncomingMessage` headers and trailers 3309 3310<!-- YAML 3311changes: 3312 - version: 3313 - v18.13.0 3314 pr-url: https://github.com/nodejs/node/pull/45697 3315 description: Documentation-only deprecation. 3316--> 3317 3318Type: Documentation-only 3319 3320In a future version of Node.js, [`message.headers`][], 3321[`message.headersDistinct`][], [`message.trailers`][], and 3322[`message.trailersDistinct`][] will be read-only. 3323 3324[NIST SP 800-38D]: https://nvlpubs.nist.gov/nistpubs/Legacy/SP/nistspecialpublication800-38d.pdf 3325[RFC 6066]: https://tools.ietf.org/html/rfc6066#section-3 3326[RFC 8247 Section 2.4]: https://www.rfc-editor.org/rfc/rfc8247#section-2.4 3327[WHATWG URL API]: url.md#the-whatwg-url-api 3328[`"exports"` or `"main"` entry]: packages.md#main-entry-point-export 3329[`'uncaughtException'`]: process.md#event-uncaughtexception 3330[`--force-node-api-uncaught-exceptions-policy`]: cli.md#--force-node-api-uncaught-exceptions-policy 3331[`--pending-deprecation`]: cli.md#--pending-deprecation 3332[`--throw-deprecation`]: cli.md#--throw-deprecation 3333[`--trace-atomics-wait`]: cli.md#--trace-atomics-wait 3334[`--unhandled-rejections`]: cli.md#--unhandled-rejectionsmode 3335[`Buffer.allocUnsafeSlow(size)`]: buffer.md#static-method-bufferallocunsafeslowsize 3336[`Buffer.from(array)`]: buffer.md#static-method-bufferfromarray 3337[`Buffer.from(buffer)`]: buffer.md#static-method-bufferfrombuffer 3338[`Buffer.isBuffer()`]: buffer.md#static-method-bufferisbufferobj 3339[`Cipher`]: crypto.md#class-cipher 3340[`Decipher`]: crypto.md#class-decipher 3341[`REPLServer.clearBufferedCommand()`]: repl.md#replserverclearbufferedcommand 3342[`ReadStream.open()`]: fs.md#class-fsreadstream 3343[`Server.getConnections()`]: net.md#servergetconnectionscallback 3344[`Server.listen({fd: <number>})`]: net.md#serverlistenhandle-backlog-callback 3345[`SlowBuffer`]: buffer.md#class-slowbuffer 3346[`WriteStream.open()`]: fs.md#class-fswritestream 3347[`assert`]: assert.md 3348[`asyncResource.runInAsyncScope()`]: async_context.md#asyncresourceruninasyncscopefn-thisarg-args 3349[`buffer.subarray`]: buffer.md#bufsubarraystart-end 3350[`child_process`]: child_process.md 3351[`clearInterval()`]: timers.md#clearintervaltimeout 3352[`clearTimeout()`]: timers.md#cleartimeouttimeout 3353[`console.error()`]: console.md#consoleerrordata-args 3354[`console.log()`]: console.md#consolelogdata-args 3355[`crypto.Certificate()` constructor]: crypto.md#legacy-api 3356[`crypto.DEFAULT_ENCODING`]: crypto.md#cryptodefault_encoding 3357[`crypto.createCipher()`]: crypto.md#cryptocreatecipheralgorithm-password-options 3358[`crypto.createCipheriv()`]: crypto.md#cryptocreatecipherivalgorithm-key-iv-options 3359[`crypto.createDecipher()`]: crypto.md#cryptocreatedecipheralgorithm-password-options 3360[`crypto.createDecipheriv()`]: crypto.md#cryptocreatedecipherivalgorithm-key-iv-options 3361[`crypto.fips`]: crypto.md#cryptofips 3362[`crypto.pbkdf2()`]: crypto.md#cryptopbkdf2password-salt-iterations-keylen-digest-callback 3363[`crypto.randomBytes()`]: crypto.md#cryptorandombytessize-callback 3364[`crypto.scrypt()`]: crypto.md#cryptoscryptpassword-salt-keylen-options-callback 3365[`decipher.final()`]: crypto.md#decipherfinaloutputencoding 3366[`decipher.setAuthTag()`]: crypto.md#deciphersetauthtagbuffer-encoding 3367[`diagnostics_channel.subscribe(name, onMessage)`]: diagnostics_channel.md#diagnostics_channelsubscribename-onmessage 3368[`diagnostics_channel.unsubscribe(name, onMessage)`]: diagnostics_channel.md#diagnostics_channelunsubscribename-onmessage 3369[`dns.lookup()`]: dns.md#dnslookuphostname-options-callback 3370[`dnsPromises.lookup()`]: dns.md#dnspromiseslookuphostname-options 3371[`domain`]: domain.md 3372[`ecdh.setPublicKey()`]: crypto.md#ecdhsetpublickeypublickey-encoding 3373[`emitter.listenerCount(eventName)`]: events.md#emitterlistenercounteventname-listener 3374[`events.listenerCount(emitter, eventName)`]: events.md#eventslistenercountemitter-eventname 3375[`fs.FileHandle`]: fs.md#class-filehandle 3376[`fs.access()`]: fs.md#fsaccesspath-mode-callback 3377[`fs.appendFile()`]: fs.md#fsappendfilepath-data-options-callback 3378[`fs.appendFileSync()`]: fs.md#fsappendfilesyncpath-data-options 3379[`fs.createReadStream()`]: fs.md#fscreatereadstreampath-options 3380[`fs.createWriteStream()`]: fs.md#fscreatewritestreampath-options 3381[`fs.exists(path, callback)`]: fs.md#fsexistspath-callback 3382[`fs.lchmod(path, mode, callback)`]: fs.md#fslchmodpath-mode-callback 3383[`fs.lchmodSync(path, mode)`]: fs.md#fslchmodsyncpath-mode 3384[`fs.lchown(path, uid, gid, callback)`]: fs.md#fslchownpath-uid-gid-callback 3385[`fs.lchownSync(path, uid, gid)`]: fs.md#fslchownsyncpath-uid-gid 3386[`fs.read()`]: fs.md#fsreadfd-buffer-offset-length-position-callback 3387[`fs.readSync()`]: fs.md#fsreadsyncfd-buffer-offset-length-position 3388[`fs.stat()`]: fs.md#fsstatpath-options-callback 3389[`fs.write()`]: fs.md#fswritefd-buffer-offset-length-position-callback 3390[`fs.writeFile()`]: fs.md#fswritefilefile-data-options-callback 3391[`fs.writeFileSync()`]: fs.md#fswritefilesyncfile-data-options 3392[`http.ClientRequest`]: http.md#class-httpclientrequest 3393[`http.IncomingMessage`]: http.md#class-httpincomingmessage 3394[`http.ServerResponse`]: http.md#class-httpserverresponse 3395[`http.get()`]: http.md#httpgetoptions-callback 3396[`http.request()`]: http.md#httprequestoptions-callback 3397[`https.get()`]: https.md#httpsgetoptions-callback 3398[`https.request()`]: https.md#httpsrequestoptions-callback 3399[`message.connection`]: http.md#messageconnection 3400[`message.headersDistinct`]: http.md#messageheadersdistinct 3401[`message.headers`]: http.md#messageheaders 3402[`message.socket`]: http.md#messagesocket 3403[`message.trailersDistinct`]: http.md#messagetrailersdistinct 3404[`message.trailers`]: http.md#messagetrailers 3405[`module.createRequire()`]: module.md#modulecreaterequirefilename 3406[`os.networkInterfaces()`]: os.md#osnetworkinterfaces 3407[`os.tmpdir()`]: os.md#ostmpdir 3408[`process.env`]: process.md#processenv 3409[`process.exit()`]: process.md#processexitcode 3410[`process.exitCode`]: process.md#processexitcode_1 3411[`process.getActiveResourcesInfo()`]: process.md#processgetactiveresourcesinfo 3412[`process.mainModule`]: process.md#processmainmodule 3413[`punycode`]: punycode.md 3414[`readable.readableEnded`]: stream.md#readablereadableended 3415[`request.abort()`]: http.md#requestabort 3416[`request.connection`]: http.md#requestconnection 3417[`request.destroy()`]: http.md#requestdestroyerror 3418[`request.socket`]: http.md#requestsocket 3419[`require.extensions`]: modules.md#requireextensions 3420[`require.main`]: modules.md#accessing-the-main-module 3421[`response.connection`]: http.md#responseconnection 3422[`response.end()`]: http.md#responseenddata-encoding-callback 3423[`response.finished`]: http.md#responsefinished 3424[`response.socket`]: http.md#responsesocket 3425[`response.writableEnded`]: http.md#responsewritableended 3426[`response.writableFinished`]: http.md#responsewritablefinished 3427[`script.createCachedData()`]: vm.md#scriptcreatecacheddata 3428[`setInterval()`]: timers.md#setintervalcallback-delay-args 3429[`setTimeout()`]: timers.md#settimeoutcallback-delay-args 3430[`socket.bufferSize`]: net.md#socketbuffersize 3431[`timeout.ref()`]: timers.md#timeoutref 3432[`timeout.refresh()`]: timers.md#timeoutrefresh 3433[`timeout.unref()`]: timers.md#timeoutunref 3434[`tls.CryptoStream`]: tls.md#class-tlscryptostream 3435[`tls.SecureContext`]: tls.md#tlscreatesecurecontextoptions 3436[`tls.SecurePair`]: tls.md#class-tlssecurepair 3437[`tls.TLSSocket`]: tls.md#class-tlstlssocket 3438[`tls.checkServerIdentity()`]: tls.md#tlscheckserveridentityhostname-cert 3439[`tls.createSecureContext()`]: tls.md#tlscreatesecurecontextoptions 3440[`url.format()`]: url.md#urlformaturlobject 3441[`url.parse()`]: url.md#urlparseurlstring-parsequerystring-slashesdenotehost 3442[`url.resolve()`]: url.md#urlresolvefrom-to 3443[`util._extend()`]: util.md#util_extendtarget-source 3444[`util.getSystemErrorName()`]: util.md#utilgetsystemerrornameerr 3445[`util.inspect()`]: util.md#utilinspectobject-options 3446[`util.inspect.custom`]: util.md#utilinspectcustom 3447[`util.isArray()`]: util.md#utilisarrayobject 3448[`util.isBoolean()`]: util.md#utilisbooleanobject 3449[`util.isBuffer()`]: util.md#utilisbufferobject 3450[`util.isDate()`]: util.md#utilisdateobject 3451[`util.isError()`]: util.md#utiliserrorobject 3452[`util.isFunction()`]: util.md#utilisfunctionobject 3453[`util.isNull()`]: util.md#utilisnullobject 3454[`util.isNullOrUndefined()`]: util.md#utilisnullorundefinedobject 3455[`util.isNumber()`]: util.md#utilisnumberobject 3456[`util.isObject()`]: util.md#utilisobjectobject 3457[`util.isPrimitive()`]: util.md#utilisprimitiveobject 3458[`util.isRegExp()`]: util.md#utilisregexpobject 3459[`util.isString()`]: util.md#utilisstringobject 3460[`util.isSymbol()`]: util.md#utilissymbolobject 3461[`util.isUndefined()`]: util.md#utilisundefinedobject 3462[`util.log()`]: util.md#utillogstring 3463[`util.types`]: util.md#utiltypes 3464[`util`]: util.md 3465[`worker.exitedAfterDisconnect`]: cluster.md#workerexitedafterdisconnect 3466[`worker.terminate()`]: worker_threads.md#workerterminate 3467[`writable.writableLength`]: stream.md#writablewritablelength 3468[`zlib.bytesWritten`]: zlib.md#zlibbyteswritten 3469[alloc]: buffer.md#static-method-bufferallocsize-fill-encoding 3470[alloc_unsafe_size]: buffer.md#static-method-bufferallocunsafesize 3471[from_arraybuffer]: buffer.md#static-method-bufferfromarraybuffer-byteoffset-length 3472[from_string_encoding]: buffer.md#static-method-bufferfromstring-encoding 3473[legacy URL API]: url.md#legacy-url-api 3474[legacy `urlObject`]: url.md#legacy-urlobject 3475[policies]: permissions.md#policies 3476[static methods of `crypto.Certificate()`]: crypto.md#class-certificate 3477[subpath exports]: packages.md#subpath-exports 3478[subpath imports]: packages.md#subpath-imports 3479[subpath patterns]: packages.md#subpath-patterns 3480