pulumi/sdk/nodejs/vendor
Julien P fa2a196c27
Vendor TypeScript and ts-node ()
<!--- 
Thanks so much for your contribution! If this is your first time
contributing, please ensure that you have read the
[CONTRIBUTING](https://github.com/pulumi/pulumi/blob/master/CONTRIBUTING.md)
documentation.
-->

# Description

Fixes https://github.com/pulumi/pulumi/issues/15733

Historically these packages were direct dependencies of
`@pulumi/pulumi`. To decouple the node SDK from the precise version of
TypeScript, the packages are now declared as optional peer pependencies
of `@pulumi/pulumi` and customers can pick the versions they want.

The reason we mark the peer dependencies as *optional* is to prevent
package managers from automatically installing them. This avoids the
situation where the package manger would install a more recent version
of TypeScript without the user explictly opting in. Newer versions have
stricter type checks, and can thus stop existing programs from running
successfully.

When the peer dependencies are not present, we load the vendored
versions of the modules.

## Checklist

- [ ] I have run `make tidy` to update any new dependencies
- [ ] I have run `make lint` to verify my code passes the lint check
  - [ ] I have formatted my code using `gofumpt`

<!--- Please provide details if the checkbox below is to be left
unchecked. -->
- [ ] I have added tests that prove my fix is effective or that my
feature works
<!--- 
User-facing changes require a CHANGELOG entry.
-->
- [ ] I have run `make changelog` and committed the
`changelog/pending/<file>` documenting my change
<!--
If the change(s) in this PR is a modification of an existing call to the
Pulumi Cloud,
then the service should honor older versions of the CLI where this
change would not exist.
You must then bump the API version in
/pkg/backend/httpstate/client/api.go, as well as add
it to the service.
-->
- [ ] Yes, there are changes in this PR that warrants bumping the Pulumi
Cloud API version
<!-- @Pulumi employees: If yes, you must submit corresponding changes in
the service repo. -->
2024-04-10 15:26:37 +00:00
..
ts-node@7.0.1 Vendor TypeScript and ts-node () 2024-04-10 15:26:37 +00:00
typescript@3.8.3 Vendor TypeScript and ts-node () 2024-04-10 15:26:37 +00:00
README.md Vendor TypeScript and ts-node () 2024-04-10 15:26:37 +00:00

README.md

Vendor

This directory contains vendored versions of Typescript 3.8.3 and ts-node 7.0.1.

These are the default and minimum versions we support for these packages.

Historically these packages were direct dependencies of @pulumi/pulumi. To decouple the node SDK from the precise version of TypeScript, the packages are now declared as optional peer pependencies of @pulumi/pulumi and customers can pick the versions they want.

The reason we mark the peer dependencies as optional is to prevent package managers from automatically installing them. This avoids the situation where the package manger would install a more recent version of TypeScript without the user explictly opting in. Newer versions have stricter type checks, and can thus stop existing programs from running successfully.

When the peer dependencies are not present, we load the vendored versions of the modules.

TypeScript

To vendor typescript:

cd sdks/nodejs/vendor
curl -L -o typescript-3.8.3.tgz https://registry.npmjs.org/typescript/-/typescript-3.8.3.tgz
tar xvf typescript-3.8.3.tgz
rsync package/LICENSE.txt package/CopyrightNotice.txt package/ThirdPartyNoticeText.txt package/lib/typescript.js typescript@3.8.3/
rsync package/lib/*.d.ts typescript@3.8.3/
rm -rf package
rm typescript-3.8.3.tgz

ts-node

ts-node has its own dependencies that we need to include. Instead of copying another level of node_modules into our repository, we create a bundle using esbuild:

cd sdks/nodejs/vendor
curl -L -o ts-node-7.0.1.tgz https://registry.npmjs.org/ts-node/-/ts-node-7.0.1.tgz
tar xvf ts-node-7.0.1.tgz
cd package
npm install --omit=dev --no-package-lock --no-bin-links --ignore-scripts
cd ..
npx esbuild --bundle --platform=node --target=node18.0 --outdir=ts-node@7.0.1 --format=cjs package/dist/index.js
cp package/LICENSE ts-node@7.0.1
rm -rf package
rm ts-node-7.0.1.tgz