@rules_nodejs//nodejs:extensions.bzl
extensions for bzlmod
Module Extensions
nodeTag Classes
toolchain| Attribute | Type | Description | 
|---|---|---|
| name | name | Base name for generated repositories Default:  "nodejs" | 
| node_version | string | Version of the Node.js interpreter Default:  "20.19.5" | 
| node_version_from_nvmrc | label | The .nvmrc file containing the version of Node.js to use. If set then the version found in the .nvmrc file is used instead of the one specified by node_version. Default:  None | 
| include_headers | boolean | Set headers field in NodeInfo provided by this toolchain. This setting creates a dependency on a c++ toolchain. Default:  False | 
| node_urls | list of strings | List of URLs to use to download Node.js. Each entry is a template for downloading a node distribution. The  Default:  ["https://nodejs.org/dist/v{version}/{filename}"] | 
| node_repositories | dictionary: String → List of strings | Custom list of node repositories to use A dictionary mapping Node.js versions to sets of hosts and their corresponding (filename, strip_prefix, sha256) tuples. By default, if this attribute has no items, we'll use a list of all public Node.js releases. Default:  {} | 
@rules_nodejs//nodejs:providers.bzl
Public providers, aspects and helpers that are shipped in the built-in rules_nodejs repository.
Providers
UserBuildSettingInfoFields
| value | 
StampSettingInfoFields
| value | Whether stamping is enabled | 
@rules_nodejs//nodejs:repositories.bzl
Rules to be called from the users WORKSPACE
Functions & Macros
nodejs_repositoriesTo be run in user's WORKSPACE to install rules_nodejs dependencies.
This rule sets up node, npm, and npx. The versions of these tools can be specified in one of three ways
Simplest Usage
Specify no explicit versions. This will download and use the latest Node.js that was available when the
version of rules_nodejs you're using was released.
Forced version(s)
You can select the version of Node.js to download & use by specifying it when you call node_repositories,
using a value that matches a known version (see the default values)
Using a custom version
You can pass in a custom list of Node.js repositories and URLs for node_repositories to use.
Custom Node.js versions
To specify custom Node.js versions, use the node_repositories attribute
nodejs_repositories( node_repositories = { "10.10.0-darwin_amd64": ("node-v10.10.0-darwin-x64.tar.gz", "node-v10.10.0-darwin-x64", "00b7a8426e076e9bf9d12ba2d571312e833fe962c70afafd10ad3682fdeeaa5e"), "10.10.0-linux_amd64": ("node-v10.10.0-linux-x64.tar.xz", "node-v10.10.0-linux-x64", "686d2c7b7698097e67bcd68edc3d6b5d28d81f62436c7cf9e7779d134ec262a9"), "10.10.0-windows_amd64": ("node-v10.10.0-win-x64.zip", "node-v10.10.0-win-x64", "70c46e6451798be9d052b700ce5dadccb75cf917f6bf0d6ed54344c856830cfb"), }, )
These can be mapped to a custom download URL, using node_urls
nodejs_repositories( node_version = "10.10.0", node_repositories = {"10.10.0-darwin_amd64": ("node-v10.10.0-darwin-x64.tar.gz", "node-v10.10.0-darwin-x64", "00b7a8426e076e9bf9d12ba2d571312e833fe962c70afafd10ad3682fdeeaa5e")}, node_urls = ["https://mycorpproxy/mirror/node/v{version}/{filename}"], )
A Mac client will try to download node from https://mycorpproxy/mirror/node/v10.10.0/node-v10.10.0-darwin-x64.tar.gz
and expect that file to have sha256sum 00b7a8426e076e9bf9d12ba2d571312e833fe962c70afafd10ad3682fdeeaa5e
See the the repositories documentation for how to use the resulting repositories.
Using a custom node.js.
To avoid downloads, you can check in a vendored node.js binary or can build one from source.
See toolchains.
Parameters
| *name | Unique name for the repository rule | 
| node_download_auth | Auth to use for all url requests. Example: { "type": "basic", "login": "<UserName>", "password": "<Password>" } Default:  {} | 
| node_repositories | Custom list of node repositories to use A dictionary mapping Node.js versions to sets of hosts and their corresponding (filename, strip_prefix, sha256) tuples. By default, if this attribute has no items, we'll use a list of all public Node.js releases. Default:  {} | 
| node_urls | List of URLs to use to download Node.js. Each entry is a template for downloading a node distribution. The  Default:  ["https://nodejs.org/dist/v{version}/{filename}"] | 
| node_version | The specific version of Node.js to install Default:  "20.19.5" | 
| node_version_from_nvmrc | The .nvmrc file containing the version of Node.js to use. If set then the version found in the .nvmrc file is used instead of the one specified by node_version. Default:  None | 
| include_headers | Set headers field in NodeInfo provided by this toolchain. This setting creates a dependency on a c++ toolchain. Default:  False | 
| kwargs | Additional parameters | 
node_repositoriesDeprecated. Use nodejs_repositories instead.
Parameters
| kwargs | Parameters to forward to nodejs_repositories rule. | 
nodejs_register_toolchainsConvenience macro for users which does typical setup.
- create a repository for each built-in platform like "node16_linux_amd64" -
 this repository is lazily fetched when node is needed for that platform.
- create a convenience repository for the host platform like "node16_host"
- create a repository exposing toolchains for each platform like "node16_platforms"
- register a toolchain pointing at each platform
Users can avoid this macro and do these steps themselves, if they want more control.
Parameters
| name | base name for all created repos, like "node16" Default:  "nodejs" | 
| register | whether to call Bazel register_toolchains on the created toolchains. Default:  True | 
| kwargs | passed to each nodejs_repositories call | 
rules_nodejs_dependencies@rules_nodejs//nodejs:toolchain.bzl
This module implements the node toolchain rule.
Functions & Macros
nodejs_toolchainDefines a node toolchain for a platform.
You can use this to refer to a vendored nodejs binary in your repository,
or even to compile nodejs from sources using rules_foreign_cc or other rules.
First, in a BUILD.bazel file, create a nodejs_toolchain definition:
load("@rules_nodejs//nodejs:toolchain.bzl", "nodejs_toolchain") nodejs_toolchain( name = "toolchain", node = "//some/path/bin/node", )
Next, declare which execution platforms or target platforms the toolchain should be selected for
based on constraints.
toolchain( name = "my_nodejs", exec_compatible_with = [ "@platforms//os:linux", "@platforms//cpu:x86_64", ], toolchain = ":toolchain", toolchain_type = "@rules_nodejs//nodejs:toolchain_type", )
See https://bazel.build/extending/toolchains#toolchain-resolution for more information on toolchain
resolution.
Finally in your WORKSPACE, register it with register_toolchains("//:my_nodejs")
For usage see https://docs.bazel.build/versions/main/toolchains.html#defining-toolchains.
You can use the --toolchain_resolution_debug flag to bazel to help diagnose which toolchain is selected.
Parameters
| *name | Unique name for this target | 
| node | Node.js executable Default:  None | 
| node_path | Path to Node.js executable file This is typically an absolute path to a non-hermetic Node.js executable. Only one of  Default:  "" | 
| npm | Npm JavaScript entry point Default:  None | 
| npm_path | Path to npm JavaScript entry point. This is typically an absolute path to a non-hermetic npm installation. Only one of  Default:  "" | 
| npm_srcs | Additional source files required to run npm. Not necessary if specifying  Default:  [] | 
| headers | cc_library that contains the Node/v8 header files Default:  None | 
| kwargs | Additional parameters | 
node_toolchainDeprecated. Use nodejs_toolchain instead.
Parameters
| kwargs | Parameters to forward to nodejs_toolchain rule. | 
Providers
NodeInfoInformation about how to invoke Node.js and npm.
Fields
| node | Node.js executable If set, node_path will not be set. | 
| node_path | Path to Node.js executable; typically an absolute path to a non-hermetic Node.js. If set, node will not be set. | 
| npm | Npm JavaScript entry point File For backward compability, if set then npm_path will be set to the runfiles path of npm. | 
| npm_path | Path to npm JavaScript entry point; typically an absolute path to a non-hermetic Node.js. For backward compability, npm_path is set to the runfiles path of npm if npm is set. | 
| npm_sources | Additional source files required to run npm | 
| headers | Optional. 
 | 
| target_tool_path | (DEPRECATED) Path to Node.js executable for backward compatibility | 
| tool_files | (DEPRECATED) Alias for [node] for backward compatibility | 
| npm_files | (DEPRECATED) Alias for npm_sources.to_list() |