2018-11-02 12:24:54 +08:00
|
|
|
|
# Security
|
|
|
|
|
|
2020-07-27 12:54:58 +08:00
|
|
|
|
## Reporting a bug in Node.js
|
2018-11-02 12:24:54 +08:00
|
|
|
|
|
2019-09-24 07:03:26 +08:00
|
|
|
|
Report security bugs in Node.js via [HackerOne](https://hackerone.com/nodejs).
|
2018-11-02 12:24:54 +08:00
|
|
|
|
|
2024-05-29 01:40:22 +08:00
|
|
|
|
Normally, your report will be acknowledged within 5 days, and you'll receive
|
2022-11-02 00:02:21 +08:00
|
|
|
|
a more detailed response to your report within 10 days indicating the
|
|
|
|
|
next steps in handling your submission. These timelines may extend when
|
|
|
|
|
our triage volunteers are away on holiday, particularly at the end of the
|
|
|
|
|
year.
|
2018-11-02 12:24:54 +08:00
|
|
|
|
|
2019-09-24 07:03:26 +08:00
|
|
|
|
After the initial reply to your report, the security team will endeavor to keep
|
|
|
|
|
you informed of the progress being made towards a fix and full announcement,
|
|
|
|
|
and may ask for additional information or guidance surrounding the reported
|
2020-04-17 20:45:50 +08:00
|
|
|
|
issue.
|
2018-11-02 12:24:54 +08:00
|
|
|
|
|
2020-07-27 12:54:58 +08:00
|
|
|
|
### Node.js bug bounty program
|
2018-11-02 12:24:54 +08:00
|
|
|
|
|
2019-09-24 07:03:26 +08:00
|
|
|
|
The Node.js project engages in an official bug bounty program for security
|
|
|
|
|
researchers and responsible public disclosures. The program is managed through
|
|
|
|
|
the HackerOne platform. See <https://hackerone.com/nodejs> for further details.
|
2018-11-02 12:24:54 +08:00
|
|
|
|
|
2024-05-29 01:40:22 +08:00
|
|
|
|
## Reporting a bug in a third-party module
|
2018-11-02 12:24:54 +08:00
|
|
|
|
|
2024-05-29 01:40:22 +08:00
|
|
|
|
Security bugs in third-party modules should be reported to their respective
|
2022-03-01 12:40:12 +08:00
|
|
|
|
maintainers.
|
2019-09-24 07:03:26 +08:00
|
|
|
|
|
2020-07-27 12:54:58 +08:00
|
|
|
|
## Disclosure policy
|
2019-09-24 07:03:26 +08:00
|
|
|
|
|
|
|
|
|
Here is the security disclosure policy for Node.js
|
|
|
|
|
|
|
|
|
|
* The security report is received and is assigned a primary handler. This
|
2023-04-03 17:28:10 +08:00
|
|
|
|
person will coordinate the fix and release process. The problem is validated
|
|
|
|
|
against all supported Node.js versions. Once confirmed, a list of all affected
|
|
|
|
|
versions is determined. Code is audited to find any potential similar
|
|
|
|
|
problems. Fixes are prepared for all supported releases.
|
|
|
|
|
These fixes are not committed to the public repository but rather held locally
|
|
|
|
|
pending the announcement.
|
2019-09-24 07:03:26 +08:00
|
|
|
|
|
|
|
|
|
* A suggested embargo date for this vulnerability is chosen and a CVE (Common
|
|
|
|
|
Vulnerabilities and Exposures (CVE®)) is requested for the vulnerability.
|
|
|
|
|
|
2024-05-29 01:40:22 +08:00
|
|
|
|
* On the embargo date, a copy of the announcement is sent to the Node.js
|
|
|
|
|
security mailing list. The changes are pushed to the public repository and new
|
|
|
|
|
builds are deployed to nodejs.org. Within 6 hours of the mailing list being
|
2019-09-24 07:03:26 +08:00
|
|
|
|
notified, a copy of the advisory will be published on the Node.js blog.
|
|
|
|
|
|
2024-05-29 01:40:22 +08:00
|
|
|
|
* Typically, the embargo date will be set 72 hours from the time the CVE is
|
2019-09-24 07:03:26 +08:00
|
|
|
|
issued. However, this may vary depending on the severity of the bug or
|
|
|
|
|
difficulty in applying a fix.
|
|
|
|
|
|
2024-05-29 01:40:22 +08:00
|
|
|
|
* This process can take some time, especially when we need to coordinate with
|
|
|
|
|
maintainers of other projects. We will try to handle the bug as quickly as
|
|
|
|
|
possible; however, we must follow the release process above to ensure that we
|
|
|
|
|
handle disclosure consistently.
|
2019-09-24 07:03:26 +08:00
|
|
|
|
|
2022-11-21 19:13:47 +08:00
|
|
|
|
## The Node.js threat model
|
|
|
|
|
|
|
|
|
|
In the Node.js threat model, there are trusted elements such as the
|
|
|
|
|
underlying operating system. Vulnerabilities that require the compromise
|
|
|
|
|
of these trusted elements are outside the scope of the Node.js threat
|
|
|
|
|
model.
|
|
|
|
|
|
|
|
|
|
For a vulnerability to be eligible for a bug bounty, it must be a
|
|
|
|
|
vulnerability in the context of the Node.js threat model. In other
|
|
|
|
|
words, it cannot assume that a trusted element (such as the operating
|
|
|
|
|
system) has been compromised.
|
|
|
|
|
|
|
|
|
|
Being able to cause the following through control of the elements that Node.js
|
|
|
|
|
does not trust is considered a vulnerability:
|
|
|
|
|
|
|
|
|
|
* Disclosure or loss of integrity or confidentiality of data protected through
|
|
|
|
|
the correct use of Node.js APIs.
|
|
|
|
|
* The unavailability of the runtime, including the unbounded degradation of its
|
|
|
|
|
performance.
|
|
|
|
|
|
|
|
|
|
If Node.js loads configuration files or runs code by default (without a
|
|
|
|
|
specific request from the user), and this is not documented, it is considered a
|
|
|
|
|
vulnerability.
|
|
|
|
|
Vulnerabilities related to this case may be fixed by a documentation update.
|
|
|
|
|
|
|
|
|
|
**Node.js does NOT trust**:
|
|
|
|
|
|
2024-12-23 19:33:18 +08:00
|
|
|
|
* Data received from the remote end of inbound network connections
|
|
|
|
|
that are accepted through the use of Node.js APIs and
|
|
|
|
|
which is transformed/validated by Node.js before being passed
|
|
|
|
|
to the application. This includes:
|
|
|
|
|
* HTTP APIs (all flavors) server APIs.
|
|
|
|
|
* The data received from the remote end of outbound network connections
|
|
|
|
|
that are created through the use of Node.js APIs and
|
|
|
|
|
which is transformed/validated by Node.js before being passed
|
|
|
|
|
to the application EXCEPT with respect to payload length. Node.js trusts
|
|
|
|
|
that applications make connections/requests which will avoid payload
|
|
|
|
|
sizes that will result in a Denial of Service.
|
|
|
|
|
* HTTP APIs (all flavors) client APIs.
|
|
|
|
|
* DNS APIs.
|
|
|
|
|
* Consumers of data protected through the use of Node.js APIs (for example,
|
|
|
|
|
people who have access to data encrypted through the Node.js crypto APIs).
|
|
|
|
|
* The file content or other I/O that is opened for reading or writing by the
|
|
|
|
|
use of Node.js APIs (ex: stdin, stdout, stderr).
|
2022-11-21 19:13:47 +08:00
|
|
|
|
|
|
|
|
|
In other words, if the data passing through Node.js to/from the application
|
|
|
|
|
can trigger actions other than those documented for the APIs, there is likely
|
|
|
|
|
a security vulnerability. Examples of unwanted actions are polluting globals,
|
|
|
|
|
causing an unrecoverable crash, or any other unexpected side effects that can
|
|
|
|
|
lead to a loss of confidentiality, integrity, or availability.
|
|
|
|
|
|
2024-05-29 01:40:22 +08:00
|
|
|
|
**Node.js trusts everything else**. Examples include:
|
2022-11-21 19:13:47 +08:00
|
|
|
|
|
2024-12-23 19:33:18 +08:00
|
|
|
|
* The developers and infrastructure that runs it.
|
|
|
|
|
* The operating system that Node.js is running under and its configuration,
|
|
|
|
|
along with anything under control of the operating system.
|
|
|
|
|
* The code it is asked to run, including JavaScript, WASM and native code, even
|
|
|
|
|
if said code is dynamically loaded, e.g., all dependencies installed from the
|
|
|
|
|
npm registry.
|
|
|
|
|
The code run inherits all the privileges of the execution user.
|
|
|
|
|
* Inputs provided to it by the code it is asked to run, as it is the
|
|
|
|
|
responsibility of the application to perform the required input validations,
|
|
|
|
|
e.g. the input to `JSON.parse()`.
|
|
|
|
|
* Any connection used for inspector (debugger protocol) regardless of being
|
|
|
|
|
opened by command line options or Node.js APIs, and regardless of the remote
|
|
|
|
|
end being on the local machine or remote.
|
|
|
|
|
* The file system when requiring a module.
|
|
|
|
|
See <https://nodejs.org/api/modules.html#all-together>.
|
|
|
|
|
* The `node:wasi` module does not currently provide the comprehensive file
|
|
|
|
|
system security properties provided by some WASI runtimes.
|
2022-11-21 19:13:47 +08:00
|
|
|
|
|
|
|
|
|
Any unexpected behavior from the data manipulation from Node.js Internal
|
2023-04-23 14:00:17 +08:00
|
|
|
|
functions may be considered a vulnerability if they are exploitable via
|
2023-03-30 20:40:57 +08:00
|
|
|
|
untrusted resources.
|
2022-11-21 19:13:47 +08:00
|
|
|
|
|
|
|
|
|
In addition to addressing vulnerabilities based on the above, the project works
|
|
|
|
|
to avoid APIs and internal implementations that make it "easy" for application
|
|
|
|
|
code to use the APIs incorrectly in a way that results in vulnerabilities within
|
|
|
|
|
the application code itself. While we don’t consider those vulnerabilities in
|
2024-05-29 01:40:22 +08:00
|
|
|
|
Node.js itself and will not necessarily issue a CVE, we do want them to be
|
2022-11-21 19:13:47 +08:00
|
|
|
|
reported privately to Node.js first.
|
|
|
|
|
We often choose to work to improve our APIs based on those reports and issue
|
|
|
|
|
fixes either in regular or security releases depending on how much of a risk to
|
|
|
|
|
the community they pose.
|
|
|
|
|
|
2023-01-07 17:04:37 +08:00
|
|
|
|
### Examples of vulnerabilities
|
2022-11-21 19:13:47 +08:00
|
|
|
|
|
|
|
|
|
#### Improper Certificate Validation (CWE-295)
|
|
|
|
|
|
|
|
|
|
* Node.js provides APIs to validate handling of Subject Alternative Names (SANs)
|
2023-04-23 14:00:17 +08:00
|
|
|
|
in certificates used to connect to a TLS/SSL endpoint. If certificates can be
|
2022-11-21 19:13:47 +08:00
|
|
|
|
crafted which result in incorrect validation by the Node.js APIs that is
|
|
|
|
|
considered a vulnerability.
|
|
|
|
|
|
|
|
|
|
#### Inconsistent Interpretation of HTTP Requests (CWE-444)
|
|
|
|
|
|
|
|
|
|
* Node.js provides APIs to accept http connections. Those APIs parse the
|
|
|
|
|
headers received for a connection and pass them on to the application.
|
|
|
|
|
Bugs in parsing those headers which can result in request smuggling are
|
|
|
|
|
considered vulnerabilities.
|
|
|
|
|
|
|
|
|
|
#### Missing Cryptographic Step (CWE-325)
|
|
|
|
|
|
|
|
|
|
* Node.js provides APIs to encrypt data. Bugs that would allow an attacker
|
2022-11-21 22:25:43 +08:00
|
|
|
|
to get the original data without requiring the decryption key are
|
2022-11-21 19:13:47 +08:00
|
|
|
|
considered vulnerabilities.
|
|
|
|
|
|
|
|
|
|
#### External Control of System or Configuration Setting (CWE-15)
|
|
|
|
|
|
|
|
|
|
* If Node.js automatically loads a configuration file which is not documented
|
|
|
|
|
and modification of that configuration can affect the confidentiality of
|
|
|
|
|
data protected using the Node.js APIs this is considered a vulnerability.
|
|
|
|
|
|
2023-01-07 17:04:37 +08:00
|
|
|
|
### Examples of non-vulnerabilities
|
2022-11-21 19:13:47 +08:00
|
|
|
|
|
|
|
|
|
#### Malicious Third-Party Modules (CWE-1357)
|
|
|
|
|
|
2024-05-29 01:40:22 +08:00
|
|
|
|
* Code is trusted by Node.js. Therefore any scenario that requires a malicious
|
2022-11-21 19:13:47 +08:00
|
|
|
|
third-party module cannot result in a vulnerability in Node.js.
|
|
|
|
|
|
|
|
|
|
#### Prototype Pollution Attacks (CWE-1321)
|
|
|
|
|
|
|
|
|
|
* Node.js trusts the inputs provided to it by application code.
|
2024-05-29 01:40:22 +08:00
|
|
|
|
It is up to the application to sanitize appropriately. Therefore any scenario
|
2022-11-21 19:13:47 +08:00
|
|
|
|
that requires control over user input is not considered a vulnerability.
|
|
|
|
|
|
|
|
|
|
#### Uncontrolled Search Path Element (CWE-427)
|
|
|
|
|
|
|
|
|
|
* Node.js trusts the file system in the environment accessible to it.
|
|
|
|
|
Therefore, it is not a vulnerability if it accesses/loads files from any path
|
|
|
|
|
that is accessible to it.
|
|
|
|
|
|
|
|
|
|
#### External Control of System or Configuration Setting (CWE-15)
|
|
|
|
|
|
|
|
|
|
* If Node.js automatically loads a configuration file which is documented
|
|
|
|
|
no scenario that requires modification of that configuration file is
|
|
|
|
|
considered a vulnerability.
|
|
|
|
|
|
2023-01-27 02:22:51 +08:00
|
|
|
|
#### Uncontrolled Resource Consumption (CWE-400) on outbound connections
|
|
|
|
|
|
|
|
|
|
* If Node.js is asked to connect to a remote site and return an
|
|
|
|
|
artifact, it is not considered a vulnerability if the size of
|
2023-03-28 21:31:20 +08:00
|
|
|
|
that artifact is large enough to impact performance or
|
2023-01-27 02:22:51 +08:00
|
|
|
|
cause the runtime to run out of resources.
|
|
|
|
|
|
2024-03-02 07:02:41 +08:00
|
|
|
|
#### Vulnerabilities affecting software downloaded by Corepack
|
|
|
|
|
|
|
|
|
|
* Corepack defaults to downloading the latest version of the software requested
|
|
|
|
|
by the user, or a specific version requested by the user. For this reason,
|
2024-05-29 01:40:22 +08:00
|
|
|
|
Node.js releases won't be affected by such vulnerabilities. Users are
|
|
|
|
|
responsible for keeping the software they use through Corepack up-to-date.
|
2024-03-02 07:02:41 +08:00
|
|
|
|
|
2023-07-21 21:51:55 +08:00
|
|
|
|
## Assessing experimental features reports
|
|
|
|
|
|
|
|
|
|
Experimental features are eligible to reports as any other stable feature of
|
|
|
|
|
Node.js. They will also be susceptible to receiving the same severity score
|
|
|
|
|
as any other stable feature.
|
|
|
|
|
|
2020-07-27 12:54:58 +08:00
|
|
|
|
## Receiving security updates
|
2019-09-24 07:03:26 +08:00
|
|
|
|
|
|
|
|
|
Security notifications will be distributed via the following methods.
|
|
|
|
|
|
|
|
|
|
* <https://groups.google.com/group/nodejs-sec>
|
2024-12-12 01:04:36 +08:00
|
|
|
|
* <https://nodejs.org/en/blog/vulnerability>
|
2019-09-24 07:03:26 +08:00
|
|
|
|
|
2020-07-27 12:54:58 +08:00
|
|
|
|
## Comments on this policy
|
2019-09-24 07:03:26 +08:00
|
|
|
|
|
2024-09-04 00:38:27 +08:00
|
|
|
|
If you have suggestions on how this process could be improved, please visit
|
|
|
|
|
the [nodejs/security-wg](https://github.com/nodejs/security-wg)
|
|
|
|
|
repository.
|