pulumi/sdk/nodejs
Thomas Gummerer 29f783d956
Prepare for pulumi 3.120.0 release (#16376)
It's Wednesday! :shipit: 

Tentative changelog:

##  (2024-06-12)


### Features

- [cli/import] Add flag --json to pulumi import which would serialize
the import diffs, operations, and overall output as JSON
  [#16342](https://github.com/pulumi/pulumi/pull/16342)

- [protobuf] Pass ProgramInfo to LanguageRuntime.About
  [#16311](https://github.com/pulumi/pulumi/pull/16311)

- [sdk/python] Support Poetry as Python toolchain
  [#16315](https://github.com/pulumi/pulumi/pull/16315)

- [sdk/python] Autoinstall dependencies using Poetry in
GetRequiredPlugins
  [#16315](https://github.com/pulumi/pulumi/pull/16315)


### Bug Fixes

- [cli/{config,new}] Fix non-interactive flag for 'new' and 'config env'
commands"
  [#16338](https://github.com/pulumi/pulumi/pull/16338)

- [programgen/go] Fix union type resolution in Go program generation
  [#16297](https://github.com/pulumi/pulumi/pull/16297)


### Miscellaneous

- [pkg] Refactor plugin.Provider to a `Method(context.Context,
MethodRequest) (MethodResponse, error)` style interface.
  [#16302](https://github.com/pulumi/pulumi/pull/16302)

- [programgen/nodejs] Sort dependencies in GenerateProject
  [#16341](https://github.com/pulumi/pulumi/pull/16341)
2024-06-12 09:09:43 +00:00
..
asset Apply autoformat 2023-04-28 18:27:10 -04:00
automation Add support for `--all` parameter of the `stack ls` command to the Automation API (#16266) 2024-06-03 15:53:43 +00:00
cmd Add explict provider test to conformance tests (#16362) 2024-06-11 14:56:08 +00:00
dist Fix typo in PP script 2019-08-06 17:35:52 -07:00
dynamic Allow dynamic providers to capture secrets 2023-06-29 15:28:31 -07:00
iterable Apply autoformat 2023-04-28 18:27:10 -04:00
log Move nodejs feature checks to startup (#14856) 2023-12-19 14:35:23 +00:00
npm Fix codepaths computation when working dir is nested relative to package.json (#15601) 2024-03-08 16:16:47 +00:00
proto Initial work for parameterized providers (#16281) 2024-06-10 17:28:47 +00:00
provider Cleanup so uses of `any` in the nodejs sdk (#15558) 2024-03-02 00:00:57 +00:00
queryable This commit safely replaces empty interfaces with type aliases. 2023-05-11 23:10:00 -04:00
runtime Flip stack transforms to non-experimental (#16282) 2024-05-30 18:01:33 +00:00
tests Add support for `--all` parameter of the `stack ls` command to the Automation API (#16266) 2024-06-03 15:53:43 +00:00
tests_with_mocks Add testing for async TS mocks 2023-06-01 14:13:04 +02:00
types Replace deprecated read-package-tree with @npmcli/arborist (#15503) 2024-02-26 18:40:28 +00:00
vendor Vendor TypeScript and ts-node (#15622) 2024-04-10 15:26:37 +00:00
.eslintrc.js Vendor TypeScript and ts-node (#15622) 2024-04-10 15:26:37 +00:00
.gitignore Vendor TypeScript and ts-node (#15622) 2024-04-10 15:26:37 +00:00
Makefile Vendor TypeScript and ts-node (#15622) 2024-04-10 15:26:37 +00:00
README.md fix some links 2023-05-19 19:39:26 -07:00
config.ts Add --secret to config set hints when needed 2023-06-22 17:25:30 +01:00
errors.ts Remove Useless Constructors. 2023-05-15 19:48:47 -04:00
index.ts Removing x namespace from go/python/nodejs automation packages (#6518) 2021-04-14 19:32:18 +01:00
invoke.ts [sdk/nodejs] Add pluginServerURL (#8698) 2022-01-10 15:54:41 -08:00
metadata.ts Make getOrganization total, default to 'organization' 2022-09-22 11:06:51 -07:00
output.ts Fix documentation comments in the NodeJS SDK (#16307) 2024-06-03 12:50:03 +00:00
package.json Prepare for pulumi 3.120.0 release (#16376) 2024-06-12 09:09:43 +00:00
resource.ts Fix documentation comments in the NodeJS SDK (#16307) 2024-06-03 12:50:03 +00:00
rome.json Vendor TypeScript and ts-node (#15622) 2024-04-10 15:26:37 +00:00
stackReference.ts Export automation.tag.TagMap type & @param tag fixes (#15774) 2024-03-25 14:33:15 +00:00
tsconfig.json Vendor TypeScript and ts-node (#15622) 2024-04-10 15:26:37 +00:00
tsutils.ts Vendor TypeScript and ts-node (#15622) 2024-04-10 15:26:37 +00:00
typescript-shim.ts Vendor TypeScript and ts-node (#15622) 2024-04-10 15:26:37 +00:00
utils.ts Fix documentation comments in the NodeJS SDK (#16307) 2024-06-03 12:50:03 +00:00
version.ts Prepare for pulumi 3.120.0 release (#16376) 2024-06-12 09:09:43 +00:00
yarn.lock Bump tar from 6.2.0 to 6.2.1 in /sdk/nodejs (#15901) 2024-04-25 20:54:30 +00:00

README.md

Pulumi Node.js SDK

The Pulumi Node.js SDK lets you write cloud programs in JavaScript.

Installation

Using npm:

$ npm install --save @pulumi/pulumi

Using yarn:

$ yarn add @pulumi/pulumi

This SDK is meant for use with the Pulumi CLI. Visit Pulumi's Download & Install to install the CLI.

Building and Testing

For anybody who wants to build from source, here is how you do it.

Prerequisites

This SDK uses Node.js and we support any of the Current, Active and Maintenance LTS versions. We support both NPM and Yarn for package management.

At the moment, we only support building on macOS and Linux, where standard GNU tools like make are available.

Make Targets

To build the SDK, simply run make from the root directory (where this README lives, at sdk/nodejs/ from the repo's root). This will build the code, run tests, and install the package and its supporting artifacts.

At the moment, for local development, we install everything into $HOME/.dev-pulumi. You will want this on your $PATH.

The tests will verify that everything works, but feel free to try running pulumi preview and/or pulumi up from the examples/minimal/ directory. Remember to run tsc first, since pulumi expects JavaScript, not TypeScript.