@webiny/pulumi-sdk 6.3.0-beta.4 → 6.4.0-beta.0

This diff represents the content of publicly available package versions that have been released to one of the supported registries. The information contained in this diff is provided for informational purposes only and reflects changes between package versions as they appear in their respective public registries.
package/Pulumi.js CHANGED
@@ -1,144 +1,115 @@
1
1
  import os from "os";
2
2
  import execa from "execa";
3
- import * as path from "path";
4
- import fs from "fs-extra";
3
+ import fs_extra from "fs-extra";
5
4
  import merge from "lodash/merge.js";
6
5
  import kebabCase from "lodash/kebabCase.js";
7
6
  import set from "lodash/set.js";
8
7
  import downloadBinaries from "./downloadBinaries.js";
9
- export const FLAG_NON_INTERACTIVE = "--non-interactive";
10
- export class PulumiError extends Error {}
11
- export class Pulumi {
12
- static async create(options = {}) {
13
- const pulumi = new Pulumi(options);
14
- // If not already installed, Pulumi binaries will be downloaded in this step.
15
- await pulumi.install();
16
- // No matter if it's a fresh installation or not, we make sure that Pulumi AWS plugin is installed.
17
- await pulumi.ensureAwsPluginIsInstalled();
18
- return pulumi;
19
- }
20
- constructor(options = {}) {
21
- this.options = options;
22
- this.pulumiDownloadFolder = path.join(options.pulumiFolder || process.cwd(), "pulumi-cli", os.platform());
23
- this.pulumiFolder = path.join(this.pulumiDownloadFolder, "pulumi");
24
- this.pulumiBinaryPath = path.join(this.pulumiFolder, "pulumi");
25
- }
26
- run(rawArgs) {
27
- const args = merge({}, this.options, rawArgs);
28
- if (!Array.isArray(args.command)) {
29
- args.command = [args.command];
30
- }
31
-
32
- // 1. Prepare Pulumi args.
33
- const finalArgs = [];
34
- for (const key in args.args) {
35
- const value = args.args[key];
36
- if (!value) {
37
- continue;
38
- }
39
- if (Array.isArray(value)) {
40
- for (let i = 0; i < value.length; i++) {
41
- finalArgs.push(`--${kebabCase(key)}`, value[i]);
42
- }
43
- continue;
44
- }
45
- if (typeof value === "boolean") {
46
- finalArgs.push(`--${kebabCase(key)}`);
47
- continue;
48
- }
49
- finalArgs.push(`--${kebabCase(key)}`, value);
50
- }
51
-
52
- // Prepare execa args.
53
- if (!args.execa) {
54
- args.execa = {};
55
- }
56
- set(args.execa, "env.PULUMI_SKIP_UPDATE_CHECK", "true");
57
- set(args.execa, "env.PULUMI_HOME", this.pulumiFolder);
58
- if (os.arch() === "arm64") {
59
- /**
60
- * This variable is an attempt to resolve this issue:
61
- * https://yaleman.org/post/2021/2021-01-01-apple-m1-terraform-and-golang/
62
- */
63
- set(args.execa, "env.GODEBUG", "asyncpreemptoff=1");
64
- }
65
-
66
- // Use ";" when on Windows. For Mac and Linux, use ":".
67
- const PATH_SEPARATOR = os.platform() === "win32" ? ";" : ":";
68
- const execaArgs = {
69
- ...args.execa,
70
- env: {
71
- ...(args.execa.env || {}),
72
- /**
73
- * Due to an issue with Pulumi https://github.com/pulumi/pulumi/issues/8374, and even though this
74
- * commit suggests it should already work like that https://github.com/pulumi/pulumi/commit/c878916901a997a9c0ffcbed23560e19e224a6f1,
75
- * we need to specify the exact location of our Pulumi binaries, using the PATH environment variable, so it can correctly resolve
76
- * plugins necessary for custom resources and dynamic providers to work.
77
- */
78
- PATH: this.pulumiFolder + PATH_SEPARATOR + process.env.PATH
79
- }
80
- };
81
-
82
- // We want to keep the "interactive" output format of the Pulumi command when `--preview` flag is passed in.
83
- const flags = args.command && args.command.includes("preview") ? [] : [FLAG_NON_INTERACTIVE];
84
- const pulumiProcess = execa(this.pulumiBinaryPath, [...args.command, ...finalArgs, ...flags], execaArgs);
85
-
86
- // We want to throw an instance of PulumiError when the Pulumi command fails.
87
- // Makes it easier to catch and handle Pulumi errors in the code.
88
- // Note: this code definitely looks funky, but it is because how `execa` works.
89
- const wrapped = pulumiProcess.then(result => result, err => {
90
- throw new PulumiError(err.stderr || err.stdout || err.message, {
91
- cause: err
92
- });
93
- });
94
- Object.assign(wrapped, pulumiProcess);
95
- return wrapped;
96
- }
97
- async install(rawArgs) {
98
- const args = merge({}, this.options, rawArgs);
99
- return await downloadBinaries(this.pulumiDownloadFolder, args.beforePulumiInstall, args.afterPulumiInstall);
100
- }
101
- async ensureAwsPluginIsInstalled() {
102
- let pulumiAwsVersion = "";
103
- const {
104
- stdout
105
- } = execa.sync("yarn", ["info", "@pulumi/aws", "-A", "-R", "--name-only", "--json"]);
106
- const match = stdout.match(/npm:(.*?)"/);
107
- if (match) {
108
- pulumiAwsVersion = match[1];
8
+ import * as __rspack_external_path from "path";
9
+ const FLAG_NON_INTERACTIVE = "--non-interactive";
10
+ class PulumiError extends Error {
11
+ }
12
+ class Pulumi {
13
+ static async create(options = {}) {
14
+ const pulumi = new Pulumi(options);
15
+ await pulumi.install();
16
+ await pulumi.ensureAwsPluginIsInstalled();
17
+ return pulumi;
109
18
  }
110
- if (!pulumiAwsVersion) {
111
- throw new PulumiError("Could not determine the version of @pulumi/aws package. Please ensure it is installed.");
19
+ constructor(options = {}){
20
+ this.options = options;
21
+ this.pulumiDownloadFolder = __rspack_external_path.join(options.pulumiFolder || process.cwd(), "pulumi-cli", os.platform());
22
+ this.pulumiFolder = __rspack_external_path.join(this.pulumiDownloadFolder, "pulumi");
23
+ this.pulumiBinaryPath = __rspack_external_path.join(this.pulumiFolder, "pulumi");
112
24
  }
113
- const pluginsDir = path.join(this.pulumiFolder, "plugins");
114
- // Pulumi names plugin directories with a "v" prefix (e.g. resource-aws-v7.25.0).
115
- const requiredPluginDir = `resource-aws-v${pulumiAwsVersion}`;
116
- const pluginExists = fs.pathExistsSync(path.join(pluginsDir, requiredPluginDir, "pulumi-resource-aws"));
117
- if (!pluginExists) {
118
- execa.sync(this.pulumiBinaryPath, ["plugin", "install", "resource", "aws", pulumiAwsVersion], {
119
- stdio: "inherit",
120
- env: {
121
- PULUMI_HOME: this.pulumiFolder,
122
- PULUMI_SKIP_UPDATE_CHECK: "true"
25
+ run(rawArgs) {
26
+ const args = merge({}, this.options, rawArgs);
27
+ if (!Array.isArray(args.command)) args.command = [
28
+ args.command
29
+ ];
30
+ const finalArgs = [];
31
+ for(const key in args.args){
32
+ const value = args.args[key];
33
+ if (value) {
34
+ if (Array.isArray(value)) {
35
+ for(let i = 0; i < value.length; i++)finalArgs.push(`--${kebabCase(key)}`, value[i]);
36
+ continue;
37
+ }
38
+ if ("boolean" == typeof value) {
39
+ finalArgs.push(`--${kebabCase(key)}`);
40
+ continue;
41
+ }
42
+ finalArgs.push(`--${kebabCase(key)}`, value);
43
+ }
123
44
  }
124
- });
45
+ if (!args.execa) args.execa = {};
46
+ set(args.execa, "env.PULUMI_SKIP_UPDATE_CHECK", "true");
47
+ set(args.execa, "env.PULUMI_HOME", this.pulumiFolder);
48
+ if ("arm64" === os.arch()) set(args.execa, "env.GODEBUG", "asyncpreemptoff=1");
49
+ const PATH_SEPARATOR = "win32" === os.platform() ? ";" : ":";
50
+ const execaArgs = {
51
+ ...args.execa,
52
+ env: {
53
+ ...args.execa.env || {},
54
+ PATH: this.pulumiFolder + PATH_SEPARATOR + process.env.PATH
55
+ }
56
+ };
57
+ const flags = args.command && args.command.includes("preview") ? [] : [
58
+ FLAG_NON_INTERACTIVE
59
+ ];
60
+ const pulumiProcess = execa(this.pulumiBinaryPath, [
61
+ ...args.command,
62
+ ...finalArgs,
63
+ ...flags
64
+ ], execaArgs);
65
+ const wrapped = pulumiProcess.then((result)=>result, (err)=>{
66
+ throw new PulumiError(err.stderr || err.stdout || err.message, {
67
+ cause: err
68
+ });
69
+ });
70
+ Object.assign(wrapped, pulumiProcess);
71
+ return wrapped;
125
72
  }
126
-
127
- // Remove stale resource-aws plugin versions to reclaim disk space.
128
- if (fs.pathExistsSync(pluginsDir)) {
129
- for (const entry of fs.readdirSync(pluginsDir)) {
130
- if (!entry.startsWith("resource-aws-") || entry === requiredPluginDir) {
131
- continue;
132
- }
133
- // Strip the trailing ".lock" suffix so both the directory and its
134
- // lock file are matched by the same prefix check.
135
- const baseName = entry.endsWith(".lock") ? entry.slice(0, -5) : entry;
136
- if (baseName !== requiredPluginDir) {
137
- fs.removeSync(path.join(pluginsDir, entry));
73
+ async install(rawArgs) {
74
+ const args = merge({}, this.options, rawArgs);
75
+ return await downloadBinaries(this.pulumiDownloadFolder, args.beforePulumiInstall, args.afterPulumiInstall);
76
+ }
77
+ async ensureAwsPluginIsInstalled() {
78
+ let pulumiAwsVersion = "";
79
+ const { stdout } = execa.sync("yarn", [
80
+ "info",
81
+ "@pulumi/aws",
82
+ "-A",
83
+ "-R",
84
+ "--name-only",
85
+ "--json"
86
+ ]);
87
+ const match = stdout.match(/npm:(.*?)"/);
88
+ if (match) pulumiAwsVersion = match[1];
89
+ if (!pulumiAwsVersion) throw new PulumiError("Could not determine the version of @pulumi/aws package. Please ensure it is installed.");
90
+ const pluginsDir = __rspack_external_path.join(this.pulumiFolder, "plugins");
91
+ const requiredPluginDir = `resource-aws-v${pulumiAwsVersion}`;
92
+ const pluginExists = fs_extra.pathExistsSync(__rspack_external_path.join(pluginsDir, requiredPluginDir, "pulumi-resource-aws"));
93
+ if (!pluginExists) execa.sync(this.pulumiBinaryPath, [
94
+ "plugin",
95
+ "install",
96
+ "resource",
97
+ "aws",
98
+ pulumiAwsVersion
99
+ ], {
100
+ stdio: "inherit",
101
+ env: {
102
+ PULUMI_HOME: this.pulumiFolder,
103
+ PULUMI_SKIP_UPDATE_CHECK: "true"
104
+ }
105
+ });
106
+ if (fs_extra.pathExistsSync(pluginsDir)) for (const entry of fs_extra.readdirSync(pluginsDir)){
107
+ if (!entry.startsWith("resource-aws-") || entry === requiredPluginDir) continue;
108
+ const baseName = entry.endsWith(".lock") ? entry.slice(0, -5) : entry;
109
+ if (baseName !== requiredPluginDir) fs_extra.removeSync(__rspack_external_path.join(pluginsDir, entry));
138
110
  }
139
- }
140
111
  }
141
- }
142
112
  }
113
+ export { FLAG_NON_INTERACTIVE, Pulumi, PulumiError };
143
114
 
144
115
  //# sourceMappingURL=Pulumi.js.map
package/Pulumi.js.map CHANGED
@@ -1 +1 @@
1
- {"version":3,"names":["os","execa","path","fs","merge","kebabCase","set","downloadBinaries","FLAG_NON_INTERACTIVE","PulumiError","Error","Pulumi","create","options","pulumi","install","ensureAwsPluginIsInstalled","constructor","pulumiDownloadFolder","join","pulumiFolder","process","cwd","platform","pulumiBinaryPath","run","rawArgs","args","Array","isArray","command","finalArgs","key","value","i","length","push","arch","PATH_SEPARATOR","execaArgs","env","PATH","flags","includes","pulumiProcess","wrapped","then","result","err","stderr","stdout","message","cause","Object","assign","beforePulumiInstall","afterPulumiInstall","pulumiAwsVersion","sync","match","pluginsDir","requiredPluginDir","pluginExists","pathExistsSync","stdio","PULUMI_HOME","PULUMI_SKIP_UPDATE_CHECK","entry","readdirSync","startsWith","baseName","endsWith","slice","removeSync"],"sources":["Pulumi.ts"],"sourcesContent":["import os from \"os\";\nimport execa, { ExecaChildProcess } from \"execa\";\nimport * as path from \"path\";\nimport fs from \"fs-extra\";\nimport merge from \"lodash/merge.js\";\nimport kebabCase from \"lodash/kebabCase.js\";\nimport set from \"lodash/set.js\";\nimport downloadBinaries from \"./downloadBinaries.js\";\n\ntype Command = string | string[];\n\nexport interface PulumiArgs {\n [key: string]: string | boolean | undefined | string[];\n}\n\nexport interface ExecaArgs {\n env?: {\n [key: string]: string | undefined;\n };\n\n [key: string]: any;\n}\n\nexport interface Options {\n args?: PulumiArgs;\n execa?: ExecaArgs;\n beforePulumiInstall?: () => any;\n afterPulumiInstall?: () => any;\n\n // A folder into which the Pulumi CLI, along with all of its meta data and config files, will be set up.\n // It's recommended this folder is not checked in into a code repository, since the Pulumi CLI can store\n // sensitive information here, for example - user's Pulumi Service credentials.\n pulumiFolder?: string;\n}\n\nexport interface RunArgs {\n command: Command;\n args?: PulumiArgs;\n execa?: ExecaArgs;\n beforePulumiInstall?: () => any;\n afterPulumiInstall?: () => any;\n}\n\nexport interface InstallArgs {\n beforePulumiInstall?: () => any;\n afterPulumiInstall?: () => any;\n}\n\nexport const FLAG_NON_INTERACTIVE = \"--non-interactive\";\n\nexport class PulumiError extends Error {}\n\nexport class Pulumi {\n options: Options;\n pulumiFolder: string;\n pulumiDownloadFolder: string;\n pulumiBinaryPath: string;\n\n static async create(options: Options = {}) {\n const pulumi = new Pulumi(options);\n // If not already installed, Pulumi binaries will be downloaded in this step.\n await pulumi.install();\n // No matter if it's a fresh installation or not, we make sure that Pulumi AWS plugin is installed.\n await pulumi.ensureAwsPluginIsInstalled();\n return pulumi;\n }\n\n private constructor(options: Options = {}) {\n this.options = options;\n\n this.pulumiDownloadFolder = path.join(\n options.pulumiFolder || process.cwd(),\n \"pulumi-cli\",\n os.platform()\n );\n\n this.pulumiFolder = path.join(this.pulumiDownloadFolder, \"pulumi\");\n this.pulumiBinaryPath = path.join(this.pulumiFolder, \"pulumi\");\n }\n\n run(rawArgs: RunArgs) {\n const args = merge({}, this.options, rawArgs);\n\n if (!Array.isArray(args.command)) {\n args.command = [args.command];\n }\n\n // 1. Prepare Pulumi args.\n const finalArgs = [];\n for (const key in args.args) {\n const value = args.args[key];\n if (!value) {\n continue;\n }\n\n if (Array.isArray(value)) {\n for (let i = 0; i < value.length; i++) {\n finalArgs.push(`--${kebabCase(key)}`, value[i]);\n }\n continue;\n }\n\n if (typeof value === \"boolean\") {\n finalArgs.push(`--${kebabCase(key)}`);\n continue;\n }\n\n finalArgs.push(`--${kebabCase(key)}`, value);\n }\n\n // Prepare execa args.\n if (!args.execa) {\n args.execa = {};\n }\n\n set(args.execa, \"env.PULUMI_SKIP_UPDATE_CHECK\", \"true\");\n set(args.execa, \"env.PULUMI_HOME\", this.pulumiFolder);\n\n if (os.arch() === \"arm64\") {\n /**\n * This variable is an attempt to resolve this issue:\n * https://yaleman.org/post/2021/2021-01-01-apple-m1-terraform-and-golang/\n */\n set(args.execa, \"env.GODEBUG\", \"asyncpreemptoff=1\");\n }\n\n // Use \";\" when on Windows. For Mac and Linux, use \":\".\n const PATH_SEPARATOR = os.platform() === \"win32\" ? \";\" : \":\";\n\n const execaArgs = {\n ...args.execa,\n env: {\n ...(args.execa.env || {}),\n /**\n * Due to an issue with Pulumi https://github.com/pulumi/pulumi/issues/8374, and even though this\n * commit suggests it should already work like that https://github.com/pulumi/pulumi/commit/c878916901a997a9c0ffcbed23560e19e224a6f1,\n * we need to specify the exact location of our Pulumi binaries, using the PATH environment variable, so it can correctly resolve\n * plugins necessary for custom resources and dynamic providers to work.\n */\n PATH: this.pulumiFolder + PATH_SEPARATOR + process.env.PATH\n }\n };\n\n // We want to keep the \"interactive\" output format of the Pulumi command when `--preview` flag is passed in.\n const flags =\n args.command && args.command.includes(\"preview\") ? [] : [FLAG_NON_INTERACTIVE];\n\n const pulumiProcess = execa(\n this.pulumiBinaryPath,\n [...args.command, ...finalArgs, ...flags],\n execaArgs\n );\n\n // We want to throw an instance of PulumiError when the Pulumi command fails.\n // Makes it easier to catch and handle Pulumi errors in the code.\n // Note: this code definitely looks funky, but it is because how `execa` works.\n const wrapped = pulumiProcess.then(\n result => result,\n err => {\n throw new PulumiError(err.stderr || err.stdout || err.message, { cause: err });\n }\n );\n\n Object.assign(wrapped, pulumiProcess);\n\n return wrapped as ExecaChildProcess<string>;\n }\n\n private async install(rawArgs?: InstallArgs): Promise<boolean> {\n const args = merge({}, this.options, rawArgs);\n\n return await downloadBinaries(\n this.pulumiDownloadFolder,\n args.beforePulumiInstall,\n args.afterPulumiInstall\n );\n }\n\n private async ensureAwsPluginIsInstalled() {\n let pulumiAwsVersion = \"\";\n const { stdout } = execa.sync(\"yarn\", [\n \"info\",\n \"@pulumi/aws\",\n \"-A\",\n \"-R\",\n \"--name-only\",\n \"--json\"\n ]);\n\n const match = stdout.match(/npm:(.*?)\"/);\n if (match) {\n pulumiAwsVersion = match[1];\n }\n\n if (!pulumiAwsVersion) {\n throw new PulumiError(\n \"Could not determine the version of @pulumi/aws package. Please ensure it is installed.\"\n );\n }\n\n const pluginsDir = path.join(this.pulumiFolder, \"plugins\");\n // Pulumi names plugin directories with a \"v\" prefix (e.g. resource-aws-v7.25.0).\n const requiredPluginDir = `resource-aws-v${pulumiAwsVersion}`;\n\n const pluginExists = fs.pathExistsSync(\n path.join(pluginsDir, requiredPluginDir, \"pulumi-resource-aws\")\n );\n\n if (!pluginExists) {\n execa.sync(\n this.pulumiBinaryPath,\n [\"plugin\", \"install\", \"resource\", \"aws\", pulumiAwsVersion],\n {\n stdio: \"inherit\",\n env: {\n PULUMI_HOME: this.pulumiFolder,\n PULUMI_SKIP_UPDATE_CHECK: \"true\"\n }\n }\n );\n }\n\n // Remove stale resource-aws plugin versions to reclaim disk space.\n if (fs.pathExistsSync(pluginsDir)) {\n for (const entry of fs.readdirSync(pluginsDir)) {\n if (!entry.startsWith(\"resource-aws-\") || entry === requiredPluginDir) {\n continue;\n }\n // Strip the trailing \".lock\" suffix so both the directory and its\n // lock file are matched by the same prefix check.\n const baseName = entry.endsWith(\".lock\") ? entry.slice(0, -5) : entry;\n if (baseName !== requiredPluginDir) {\n fs.removeSync(path.join(pluginsDir, entry));\n }\n }\n }\n }\n}\n"],"mappings":"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","ignoreList":[]}
1
+ {"version":3,"file":"Pulumi.js","sources":["../src/Pulumi.ts"],"sourcesContent":["import os from \"os\";\nimport execa, { ExecaChildProcess } from \"execa\";\nimport * as path from \"path\";\nimport fs from \"fs-extra\";\nimport merge from \"lodash/merge.js\";\nimport kebabCase from \"lodash/kebabCase.js\";\nimport set from \"lodash/set.js\";\nimport downloadBinaries from \"./downloadBinaries.js\";\n\ntype Command = string | string[];\n\nexport interface PulumiArgs {\n [key: string]: string | boolean | undefined | string[];\n}\n\nexport interface ExecaArgs {\n env?: {\n [key: string]: string | undefined;\n };\n\n [key: string]: any;\n}\n\nexport interface Options {\n args?: PulumiArgs;\n execa?: ExecaArgs;\n beforePulumiInstall?: () => any;\n afterPulumiInstall?: () => any;\n\n // A folder into which the Pulumi CLI, along with all of its meta data and config files, will be set up.\n // It's recommended this folder is not checked in into a code repository, since the Pulumi CLI can store\n // sensitive information here, for example - user's Pulumi Service credentials.\n pulumiFolder?: string;\n}\n\nexport interface RunArgs {\n command: Command;\n args?: PulumiArgs;\n execa?: ExecaArgs;\n beforePulumiInstall?: () => any;\n afterPulumiInstall?: () => any;\n}\n\nexport interface InstallArgs {\n beforePulumiInstall?: () => any;\n afterPulumiInstall?: () => any;\n}\n\nexport const FLAG_NON_INTERACTIVE = \"--non-interactive\";\n\nexport class PulumiError extends Error {}\n\nexport class Pulumi {\n options: Options;\n pulumiFolder: string;\n pulumiDownloadFolder: string;\n pulumiBinaryPath: string;\n\n static async create(options: Options = {}) {\n const pulumi = new Pulumi(options);\n // If not already installed, Pulumi binaries will be downloaded in this step.\n await pulumi.install();\n // No matter if it's a fresh installation or not, we make sure that Pulumi AWS plugin is installed.\n await pulumi.ensureAwsPluginIsInstalled();\n return pulumi;\n }\n\n private constructor(options: Options = {}) {\n this.options = options;\n\n this.pulumiDownloadFolder = path.join(\n options.pulumiFolder || process.cwd(),\n \"pulumi-cli\",\n os.platform()\n );\n\n this.pulumiFolder = path.join(this.pulumiDownloadFolder, \"pulumi\");\n this.pulumiBinaryPath = path.join(this.pulumiFolder, \"pulumi\");\n }\n\n run(rawArgs: RunArgs) {\n const args = merge({}, this.options, rawArgs);\n\n if (!Array.isArray(args.command)) {\n args.command = [args.command];\n }\n\n // 1. Prepare Pulumi args.\n const finalArgs = [];\n for (const key in args.args) {\n const value = args.args[key];\n if (!value) {\n continue;\n }\n\n if (Array.isArray(value)) {\n for (let i = 0; i < value.length; i++) {\n finalArgs.push(`--${kebabCase(key)}`, value[i]);\n }\n continue;\n }\n\n if (typeof value === \"boolean\") {\n finalArgs.push(`--${kebabCase(key)}`);\n continue;\n }\n\n finalArgs.push(`--${kebabCase(key)}`, value);\n }\n\n // Prepare execa args.\n if (!args.execa) {\n args.execa = {};\n }\n\n set(args.execa, \"env.PULUMI_SKIP_UPDATE_CHECK\", \"true\");\n set(args.execa, \"env.PULUMI_HOME\", this.pulumiFolder);\n\n if (os.arch() === \"arm64\") {\n /**\n * This variable is an attempt to resolve this issue:\n * https://yaleman.org/post/2021/2021-01-01-apple-m1-terraform-and-golang/\n */\n set(args.execa, \"env.GODEBUG\", \"asyncpreemptoff=1\");\n }\n\n // Use \";\" when on Windows. For Mac and Linux, use \":\".\n const PATH_SEPARATOR = os.platform() === \"win32\" ? \";\" : \":\";\n\n const execaArgs = {\n ...args.execa,\n env: {\n ...(args.execa.env || {}),\n /**\n * Due to an issue with Pulumi https://github.com/pulumi/pulumi/issues/8374, and even though this\n * commit suggests it should already work like that https://github.com/pulumi/pulumi/commit/c878916901a997a9c0ffcbed23560e19e224a6f1,\n * we need to specify the exact location of our Pulumi binaries, using the PATH environment variable, so it can correctly resolve\n * plugins necessary for custom resources and dynamic providers to work.\n */\n PATH: this.pulumiFolder + PATH_SEPARATOR + process.env.PATH\n }\n };\n\n // We want to keep the \"interactive\" output format of the Pulumi command when `--preview` flag is passed in.\n const flags =\n args.command && args.command.includes(\"preview\") ? [] : [FLAG_NON_INTERACTIVE];\n\n const pulumiProcess = execa(\n this.pulumiBinaryPath,\n [...args.command, ...finalArgs, ...flags],\n execaArgs\n );\n\n // We want to throw an instance of PulumiError when the Pulumi command fails.\n // Makes it easier to catch and handle Pulumi errors in the code.\n // Note: this code definitely looks funky, but it is because how `execa` works.\n const wrapped = pulumiProcess.then(\n result => result,\n err => {\n throw new PulumiError(err.stderr || err.stdout || err.message, { cause: err });\n }\n );\n\n Object.assign(wrapped, pulumiProcess);\n\n return wrapped as ExecaChildProcess<string>;\n }\n\n private async install(rawArgs?: InstallArgs): Promise<boolean> {\n const args = merge({}, this.options, rawArgs);\n\n return await downloadBinaries(\n this.pulumiDownloadFolder,\n args.beforePulumiInstall,\n args.afterPulumiInstall\n );\n }\n\n private async ensureAwsPluginIsInstalled() {\n let pulumiAwsVersion = \"\";\n const { stdout } = execa.sync(\"yarn\", [\n \"info\",\n \"@pulumi/aws\",\n \"-A\",\n \"-R\",\n \"--name-only\",\n \"--json\"\n ]);\n\n const match = stdout.match(/npm:(.*?)\"/);\n if (match) {\n pulumiAwsVersion = match[1];\n }\n\n if (!pulumiAwsVersion) {\n throw new PulumiError(\n \"Could not determine the version of @pulumi/aws package. Please ensure it is installed.\"\n );\n }\n\n const pluginsDir = path.join(this.pulumiFolder, \"plugins\");\n // Pulumi names plugin directories with a \"v\" prefix (e.g. resource-aws-v7.25.0).\n const requiredPluginDir = `resource-aws-v${pulumiAwsVersion}`;\n\n const pluginExists = fs.pathExistsSync(\n path.join(pluginsDir, requiredPluginDir, \"pulumi-resource-aws\")\n );\n\n if (!pluginExists) {\n execa.sync(\n this.pulumiBinaryPath,\n [\"plugin\", \"install\", \"resource\", \"aws\", pulumiAwsVersion],\n {\n stdio: \"inherit\",\n env: {\n PULUMI_HOME: this.pulumiFolder,\n PULUMI_SKIP_UPDATE_CHECK: \"true\"\n }\n }\n );\n }\n\n // Remove stale resource-aws plugin versions to reclaim disk space.\n if (fs.pathExistsSync(pluginsDir)) {\n for (const entry of fs.readdirSync(pluginsDir)) {\n if (!entry.startsWith(\"resource-aws-\") || entry === requiredPluginDir) {\n continue;\n }\n // Strip the trailing \".lock\" suffix so both the directory and its\n // lock file are matched by the same prefix check.\n const baseName = entry.endsWith(\".lock\") ? entry.slice(0, -5) : entry;\n if (baseName !== requiredPluginDir) {\n fs.removeSync(path.join(pluginsDir, entry));\n }\n }\n }\n }\n}\n"],"names":["FLAG_NON_INTERACTIVE","PulumiError","Error","Pulumi","options","pulumi","path","process","os","rawArgs","args","merge","Array","finalArgs","key","value","i","kebabCase","set","PATH_SEPARATOR","execaArgs","flags","pulumiProcess","execa","wrapped","result","err","Object","downloadBinaries","pulumiAwsVersion","stdout","match","pluginsDir","requiredPluginDir","pluginExists","fs","entry","baseName"],"mappings":";;;;;;;;AAgDO,MAAMA,uBAAuB;AAE7B,MAAMC,oBAAoBC;AAAO;AAEjC,MAAMC;IAMT,aAAa,OAAOC,UAAmB,CAAC,CAAC,EAAE;QACvC,MAAMC,SAAS,IAAIF,OAAOC;QAE1B,MAAMC,OAAO,OAAO;QAEpB,MAAMA,OAAO,0BAA0B;QACvC,OAAOA;IACX;IAEA,YAAoBD,UAAmB,CAAC,CAAC,CAAE;QACvC,IAAI,CAAC,OAAO,GAAGA;QAEf,IAAI,CAAC,oBAAoB,GAAGE,uBAAAA,IAAS,CACjCF,QAAQ,YAAY,IAAIG,QAAQ,GAAG,IACnC,cACAC,GAAG,QAAQ;QAGf,IAAI,CAAC,YAAY,GAAGF,uBAAAA,IAAS,CAAC,IAAI,CAAC,oBAAoB,EAAE;QACzD,IAAI,CAAC,gBAAgB,GAAGA,uBAAAA,IAAS,CAAC,IAAI,CAAC,YAAY,EAAE;IACzD;IAEA,IAAIG,OAAgB,EAAE;QAClB,MAAMC,OAAOC,MAAM,CAAC,GAAG,IAAI,CAAC,OAAO,EAAEF;QAErC,IAAI,CAACG,MAAM,OAAO,CAACF,KAAK,OAAO,GAC3BA,KAAK,OAAO,GAAG;YAACA,KAAK,OAAO;SAAC;QAIjC,MAAMG,YAAY,EAAE;QACpB,IAAK,MAAMC,OAAOJ,KAAK,IAAI,CAAE;YACzB,MAAMK,QAAQL,KAAK,IAAI,CAACI,IAAI;YAC5B,IAAKC;gBAIL,IAAIH,MAAM,OAAO,CAACG,QAAQ;oBACtB,IAAK,IAAIC,IAAI,GAAGA,IAAID,MAAM,MAAM,EAAEC,IAC9BH,UAAU,IAAI,CAAC,CAAC,EAAE,EAAEI,UAAUH,MAAM,EAAEC,KAAK,CAACC,EAAE;oBAElD;gBACJ;gBAEA,IAAI,AAAiB,aAAjB,OAAOD,OAAqB;oBAC5BF,UAAU,IAAI,CAAC,CAAC,EAAE,EAAEI,UAAUH,MAAM;oBACpC;gBACJ;gBAEAD,UAAU,IAAI,CAAC,CAAC,EAAE,EAAEI,UAAUH,MAAM,EAAEC;;QAC1C;QAGA,IAAI,CAACL,KAAK,KAAK,EACXA,KAAK,KAAK,GAAG,CAAC;QAGlBQ,IAAIR,KAAK,KAAK,EAAE,gCAAgC;QAChDQ,IAAIR,KAAK,KAAK,EAAE,mBAAmB,IAAI,CAAC,YAAY;QAEpD,IAAIF,AAAc,YAAdA,GAAG,IAAI,IAKPU,IAAIR,KAAK,KAAK,EAAE,eAAe;QAInC,MAAMS,iBAAiBX,AAAkB,YAAlBA,GAAG,QAAQ,KAAiB,MAAM;QAEzD,MAAMY,YAAY;YACd,GAAGV,KAAK,KAAK;YACb,KAAK;gBACD,GAAIA,KAAK,KAAK,CAAC,GAAG,IAAI,CAAC,CAAC;gBAOxB,MAAM,IAAI,CAAC,YAAY,GAAGS,iBAAiBZ,QAAQ,GAAG,CAAC,IAAI;YAC/D;QACJ;QAGA,MAAMc,QACFX,KAAK,OAAO,IAAIA,KAAK,OAAO,CAAC,QAAQ,CAAC,aAAa,EAAE,GAAG;YAACV;SAAqB;QAElF,MAAMsB,gBAAgBC,MAClB,IAAI,CAAC,gBAAgB,EACrB;eAAIb,KAAK,OAAO;eAAKG;eAAcQ;SAAM,EACzCD;QAMJ,MAAMI,UAAUF,cAAc,IAAI,CAC9BG,CAAAA,SAAUA,QACVC,CAAAA;YACI,MAAM,IAAIzB,YAAYyB,IAAI,MAAM,IAAIA,IAAI,MAAM,IAAIA,IAAI,OAAO,EAAE;gBAAE,OAAOA;YAAI;QAChF;QAGJC,OAAO,MAAM,CAACH,SAASF;QAEvB,OAAOE;IACX;IAEA,MAAc,QAAQf,OAAqB,EAAoB;QAC3D,MAAMC,OAAOC,MAAM,CAAC,GAAG,IAAI,CAAC,OAAO,EAAEF;QAErC,OAAO,MAAMmB,iBACT,IAAI,CAAC,oBAAoB,EACzBlB,KAAK,mBAAmB,EACxBA,KAAK,kBAAkB;IAE/B;IAEA,MAAc,6BAA6B;QACvC,IAAImB,mBAAmB;QACvB,MAAM,EAAEC,MAAM,EAAE,GAAGP,MAAM,IAAI,CAAC,QAAQ;YAClC;YACA;YACA;YACA;YACA;YACA;SACH;QAED,MAAMQ,QAAQD,OAAO,KAAK,CAAC;QAC3B,IAAIC,OACAF,mBAAmBE,KAAK,CAAC,EAAE;QAG/B,IAAI,CAACF,kBACD,MAAM,IAAI5B,YACN;QAIR,MAAM+B,aAAa1B,uBAAAA,IAAS,CAAC,IAAI,CAAC,YAAY,EAAE;QAEhD,MAAM2B,oBAAoB,CAAC,cAAc,EAAEJ,kBAAkB;QAE7D,MAAMK,eAAeC,SAAAA,cAAiB,CAClC7B,uBAAAA,IAAS,CAAC0B,YAAYC,mBAAmB;QAG7C,IAAI,CAACC,cACDX,MAAM,IAAI,CACN,IAAI,CAAC,gBAAgB,EACrB;YAAC;YAAU;YAAW;YAAY;YAAOM;SAAiB,EAC1D;YACI,OAAO;YACP,KAAK;gBACD,aAAa,IAAI,CAAC,YAAY;gBAC9B,0BAA0B;YAC9B;QACJ;QAKR,IAAIM,SAAAA,cAAiB,CAACH,aAClB,KAAK,MAAMI,SAASD,SAAAA,WAAc,CAACH,YAAa;YAC5C,IAAI,CAACI,MAAM,UAAU,CAAC,oBAAoBA,UAAUH,mBAChD;YAIJ,MAAMI,WAAWD,MAAM,QAAQ,CAAC,WAAWA,MAAM,KAAK,CAAC,GAAG,MAAMA;YAChE,IAAIC,aAAaJ,mBACbE,SAAAA,UAAa,CAAC7B,uBAAAA,IAAS,CAAC0B,YAAYI;QAE5C;IAER;AACJ"}
@@ -1,86 +1,78 @@
1
1
  import os from "os";
2
- import * as tar from "tar";
3
2
  import fs from "fs";
4
3
  import path from "path";
5
- // @ts-expect-error `tar` has no types.
6
4
  import decompress from "decompress";
7
5
  import semver from "semver";
8
6
  import { findUpSync } from "find-up";
9
7
  import { loadJsonFileSync } from "load-json-file";
10
8
  import { downloadFile } from "./downloadFile.js";
11
- // We need to sanitize the package version because, occasionally, we've noticed that the Pulumi version
12
- // can look like the following: "2.25.2+dirty". We want to ensure only "2.25.2" is returned.
13
- // @see https://github.com/pulumi/pulumi/issues/6847
14
- const getPulumiVersion = () => {
15
- const pkgJsonPath = findUpSync("node_modules/@pulumi/pulumi/package.json");
16
- const {
17
- version
18
- } = loadJsonFileSync(pkgJsonPath);
19
- return semver.clean(version);
9
+ import * as __rspack_external_tar from "tar";
10
+ const getPulumiVersion = ()=>{
11
+ const pkgJsonPath = findUpSync("node_modules/@pulumi/pulumi/package.json");
12
+ const { version } = loadJsonFileSync(pkgJsonPath);
13
+ return semver.clean(version);
20
14
  };
21
- export default async (downloadFolder, beforeInstall, afterInstall) => {
22
- if (fs.existsSync(downloadFolder)) {
23
- return false;
24
- }
25
- if (typeof beforeInstall === "function") {
26
- await beforeInstall();
27
- }
28
- const platform = os.platform();
29
- switch (platform) {
30
- case "darwin":
31
- await setupDarwin(downloadFolder);
32
- break;
33
- case "linux":
34
- await setupLinux(downloadFolder);
35
- break;
36
- case "win32":
37
- await setupWindows(downloadFolder);
38
- break;
39
- default:
40
- throw Error(`Cannot download Pulumi binaries - platform "${platform}" not supported. Supported ones are "darwin", "linux", and "win32"`);
41
- }
42
- if (typeof afterInstall === "function") {
43
- await afterInstall();
44
- }
45
- return true;
15
+ const downloadBinaries = async (downloadFolder, beforeInstall, afterInstall)=>{
16
+ if (fs.existsSync(downloadFolder)) return false;
17
+ if ("function" == typeof beforeInstall) await beforeInstall();
18
+ const platform = os.platform();
19
+ switch(platform){
20
+ case "darwin":
21
+ await setupDarwin(downloadFolder);
22
+ break;
23
+ case "linux":
24
+ await setupLinux(downloadFolder);
25
+ break;
26
+ case "win32":
27
+ await setupWindows(downloadFolder);
28
+ break;
29
+ default:
30
+ throw Error(`Cannot download Pulumi binaries - platform "${platform}" not supported. Supported ones are "darwin", "linux", and "win32"`);
31
+ }
32
+ if ("function" == typeof afterInstall) await afterInstall();
33
+ return true;
46
34
  };
47
- const SUPPORTED_ARCHITECTURES = ["x64", "arm64"];
35
+ const SUPPORTED_ARCHITECTURES = [
36
+ "x64",
37
+ "arm64"
38
+ ];
48
39
  async function setupDarwin(downloadFolder) {
49
- const version = getPulumiVersion();
50
- const arch = SUPPORTED_ARCHITECTURES.includes(process.arch) ? process.arch : "x64";
51
- const filename = `pulumi-v${version}-darwin-${arch}.tar.gz`;
52
- const downloadUrl = "https://get.pulumi.com/releases/sdk/" + filename;
53
- const absoluteFilename = path.join(downloadFolder, filename);
54
- await downloadFile(downloadUrl, absoluteFilename);
55
- await tar.extract({
56
- cwd: downloadFolder,
57
- file: absoluteFilename
58
- });
59
- fs.unlinkSync(path.join(downloadFolder, filename));
40
+ const version = getPulumiVersion();
41
+ const arch = SUPPORTED_ARCHITECTURES.includes(process.arch) ? process.arch : "x64";
42
+ const filename = `pulumi-v${version}-darwin-${arch}.tar.gz`;
43
+ const downloadUrl = "https://get.pulumi.com/releases/sdk/" + filename;
44
+ const absoluteFilename = path.join(downloadFolder, filename);
45
+ await downloadFile(downloadUrl, absoluteFilename);
46
+ await __rspack_external_tar.extract({
47
+ cwd: downloadFolder,
48
+ file: absoluteFilename
49
+ });
50
+ fs.unlinkSync(path.join(downloadFolder, filename));
60
51
  }
61
52
  async function setupWindows(downloadFolder) {
62
- const version = getPulumiVersion();
63
- const filename = `pulumi-v${version}-windows-x64.zip`;
64
- const downloadUrl = "https://get.pulumi.com/releases/sdk/" + filename;
65
- const absoluteFilename = path.join(downloadFolder, filename);
66
- await downloadFile(downloadUrl, absoluteFilename);
67
- const destination = path.join(downloadFolder, "pulumi");
68
- await decompress(absoluteFilename, destination, {
69
- strip: 2
70
- });
71
- fs.unlinkSync(path.join(downloadFolder, filename));
53
+ const version = getPulumiVersion();
54
+ const filename = `pulumi-v${version}-windows-x64.zip`;
55
+ const downloadUrl = "https://get.pulumi.com/releases/sdk/" + filename;
56
+ const absoluteFilename = path.join(downloadFolder, filename);
57
+ await downloadFile(downloadUrl, absoluteFilename);
58
+ const destination = path.join(downloadFolder, "pulumi");
59
+ await decompress(absoluteFilename, destination, {
60
+ strip: 2
61
+ });
62
+ fs.unlinkSync(path.join(downloadFolder, filename));
72
63
  }
73
64
  async function setupLinux(downloadFolder) {
74
- const version = getPulumiVersion();
75
- const filename = `pulumi-v${version}-linux-x64.tar.gz`;
76
- const downloadUrl = "https://get.pulumi.com/releases/sdk/" + filename;
77
- const absoluteFilename = path.join(downloadFolder, filename);
78
- await downloadFile(downloadUrl, absoluteFilename);
79
- await tar.extract({
80
- cwd: downloadFolder,
81
- file: absoluteFilename
82
- });
83
- fs.unlinkSync(path.join(downloadFolder, filename));
65
+ const version = getPulumiVersion();
66
+ const filename = `pulumi-v${version}-linux-x64.tar.gz`;
67
+ const downloadUrl = "https://get.pulumi.com/releases/sdk/" + filename;
68
+ const absoluteFilename = path.join(downloadFolder, filename);
69
+ await downloadFile(downloadUrl, absoluteFilename);
70
+ await __rspack_external_tar.extract({
71
+ cwd: downloadFolder,
72
+ file: absoluteFilename
73
+ });
74
+ fs.unlinkSync(path.join(downloadFolder, filename));
84
75
  }
76
+ export default downloadBinaries;
85
77
 
86
78
  //# sourceMappingURL=downloadBinaries.js.map
@@ -1 +1 @@
1
- {"version":3,"names":["os","tar","fs","path","decompress","semver","findUpSync","loadJsonFileSync","downloadFile","getPulumiVersion","pkgJsonPath","version","clean","downloadFolder","beforeInstall","afterInstall","existsSync","platform","setupDarwin","setupLinux","setupWindows","Error","SUPPORTED_ARCHITECTURES","arch","includes","process","filename","downloadUrl","absoluteFilename","join","extract","cwd","file","unlinkSync","destination","strip"],"sources":["downloadBinaries.ts"],"sourcesContent":["import os from \"os\";\nimport * as tar from \"tar\";\nimport fs from \"fs\";\nimport path from \"path\";\n// @ts-expect-error `tar` has no types.\nimport decompress from \"decompress\";\nimport semver from \"semver\";\nimport { findUpSync } from \"find-up\";\nimport { loadJsonFileSync } from \"load-json-file\";\nimport { downloadFile } from \"./downloadFile.js\";\nimport { PackageJson } from \"type-fest\";\n\n// We need to sanitize the package version because, occasionally, we've noticed that the Pulumi version\n// can look like the following: \"2.25.2+dirty\". We want to ensure only \"2.25.2\" is returned.\n// @see https://github.com/pulumi/pulumi/issues/6847\nconst getPulumiVersion = () => {\n const pkgJsonPath = findUpSync(\"node_modules/@pulumi/pulumi/package.json\");\n const { version } = loadJsonFileSync<PackageJson>(pkgJsonPath!);\n return semver.clean(version!);\n};\n\nexport default async (\n downloadFolder: string,\n beforeInstall?: () => void,\n afterInstall?: () => void\n) => {\n if (fs.existsSync(downloadFolder)) {\n return false;\n }\n\n if (typeof beforeInstall === \"function\") {\n await beforeInstall();\n }\n\n const platform = os.platform();\n switch (platform) {\n case \"darwin\":\n await setupDarwin(downloadFolder);\n break;\n case \"linux\":\n await setupLinux(downloadFolder);\n break;\n case \"win32\":\n await setupWindows(downloadFolder);\n break;\n default:\n throw Error(\n `Cannot download Pulumi binaries - platform \"${platform}\" not supported. Supported ones are \"darwin\", \"linux\", and \"win32\"`\n );\n }\n\n if (typeof afterInstall === \"function\") {\n await afterInstall();\n }\n\n return true;\n};\n\nconst SUPPORTED_ARCHITECTURES = [\"x64\", \"arm64\"];\n\nasync function setupDarwin(downloadFolder: string) {\n const version = getPulumiVersion();\n const arch = SUPPORTED_ARCHITECTURES.includes(process.arch) ? process.arch : \"x64\";\n\n const filename = `pulumi-v${version}-darwin-${arch}.tar.gz`;\n const downloadUrl = \"https://get.pulumi.com/releases/sdk/\" + filename;\n\n const absoluteFilename = path.join(downloadFolder, filename);\n await downloadFile(downloadUrl, absoluteFilename);\n\n await tar.extract({\n cwd: downloadFolder,\n file: absoluteFilename\n });\n\n fs.unlinkSync(path.join(downloadFolder, filename));\n}\n\nasync function setupWindows(downloadFolder: string) {\n const version = getPulumiVersion();\n const filename = `pulumi-v${version}-windows-x64.zip`;\n const downloadUrl = \"https://get.pulumi.com/releases/sdk/\" + filename;\n\n const absoluteFilename = path.join(downloadFolder, filename);\n await downloadFile(downloadUrl, absoluteFilename);\n\n const destination = path.join(downloadFolder, \"pulumi\");\n await decompress(absoluteFilename, destination, { strip: 2 });\n\n fs.unlinkSync(path.join(downloadFolder, filename));\n}\n\nasync function setupLinux(downloadFolder: string) {\n const version = getPulumiVersion();\n const filename = `pulumi-v${version}-linux-x64.tar.gz`;\n const downloadUrl = \"https://get.pulumi.com/releases/sdk/\" + filename;\n\n const absoluteFilename = path.join(downloadFolder, filename);\n await downloadFile(downloadUrl, absoluteFilename);\n\n await tar.extract({\n cwd: downloadFolder,\n file: absoluteFilename\n });\n\n fs.unlinkSync(path.join(downloadFolder, filename));\n}\n"],"mappings":"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","ignoreList":[]}
1
+ {"version":3,"file":"downloadBinaries.js","sources":["../src/downloadBinaries.ts"],"sourcesContent":["import os from \"os\";\nimport * as tar from \"tar\";\nimport fs from \"fs\";\nimport path from \"path\";\n// @ts-expect-error `tar` has no types.\nimport decompress from \"decompress\";\nimport semver from \"semver\";\nimport { findUpSync } from \"find-up\";\nimport { loadJsonFileSync } from \"load-json-file\";\nimport { downloadFile } from \"./downloadFile.js\";\nimport { PackageJson } from \"type-fest\";\n\n// We need to sanitize the package version because, occasionally, we've noticed that the Pulumi version\n// can look like the following: \"2.25.2+dirty\". We want to ensure only \"2.25.2\" is returned.\n// @see https://github.com/pulumi/pulumi/issues/6847\nconst getPulumiVersion = () => {\n const pkgJsonPath = findUpSync(\"node_modules/@pulumi/pulumi/package.json\");\n const { version } = loadJsonFileSync<PackageJson>(pkgJsonPath!);\n return semver.clean(version!);\n};\n\nexport default async (\n downloadFolder: string,\n beforeInstall?: () => void,\n afterInstall?: () => void\n) => {\n if (fs.existsSync(downloadFolder)) {\n return false;\n }\n\n if (typeof beforeInstall === \"function\") {\n await beforeInstall();\n }\n\n const platform = os.platform();\n switch (platform) {\n case \"darwin\":\n await setupDarwin(downloadFolder);\n break;\n case \"linux\":\n await setupLinux(downloadFolder);\n break;\n case \"win32\":\n await setupWindows(downloadFolder);\n break;\n default:\n throw Error(\n `Cannot download Pulumi binaries - platform \"${platform}\" not supported. Supported ones are \"darwin\", \"linux\", and \"win32\"`\n );\n }\n\n if (typeof afterInstall === \"function\") {\n await afterInstall();\n }\n\n return true;\n};\n\nconst SUPPORTED_ARCHITECTURES = [\"x64\", \"arm64\"];\n\nasync function setupDarwin(downloadFolder: string) {\n const version = getPulumiVersion();\n const arch = SUPPORTED_ARCHITECTURES.includes(process.arch) ? process.arch : \"x64\";\n\n const filename = `pulumi-v${version}-darwin-${arch}.tar.gz`;\n const downloadUrl = \"https://get.pulumi.com/releases/sdk/\" + filename;\n\n const absoluteFilename = path.join(downloadFolder, filename);\n await downloadFile(downloadUrl, absoluteFilename);\n\n await tar.extract({\n cwd: downloadFolder,\n file: absoluteFilename\n });\n\n fs.unlinkSync(path.join(downloadFolder, filename));\n}\n\nasync function setupWindows(downloadFolder: string) {\n const version = getPulumiVersion();\n const filename = `pulumi-v${version}-windows-x64.zip`;\n const downloadUrl = \"https://get.pulumi.com/releases/sdk/\" + filename;\n\n const absoluteFilename = path.join(downloadFolder, filename);\n await downloadFile(downloadUrl, absoluteFilename);\n\n const destination = path.join(downloadFolder, \"pulumi\");\n await decompress(absoluteFilename, destination, { strip: 2 });\n\n fs.unlinkSync(path.join(downloadFolder, filename));\n}\n\nasync function setupLinux(downloadFolder: string) {\n const version = getPulumiVersion();\n const filename = `pulumi-v${version}-linux-x64.tar.gz`;\n const downloadUrl = \"https://get.pulumi.com/releases/sdk/\" + filename;\n\n const absoluteFilename = path.join(downloadFolder, filename);\n await downloadFile(downloadUrl, absoluteFilename);\n\n await tar.extract({\n cwd: downloadFolder,\n file: absoluteFilename\n });\n\n fs.unlinkSync(path.join(downloadFolder, filename));\n}\n"],"names":["getPulumiVersion","pkgJsonPath","findUpSync","version","loadJsonFileSync","semver","downloadFolder","beforeInstall","afterInstall","fs","platform","os","setupDarwin","setupLinux","setupWindows","Error","SUPPORTED_ARCHITECTURES","arch","process","filename","downloadUrl","absoluteFilename","path","downloadFile","tar","destination","decompress"],"mappings":";;;;;;;;;AAeA,MAAMA,mBAAmB;IACrB,MAAMC,cAAcC,WAAW;IAC/B,MAAM,EAAEC,OAAO,EAAE,GAAGC,iBAA8BH;IAClD,OAAOI,OAAO,KAAK,CAACF;AACxB;AAEA,yBAAe,OACXG,gBACAC,eACAC;IAEA,IAAIC,GAAG,UAAU,CAACH,iBACd,OAAO;IAGX,IAAI,AAAyB,cAAzB,OAAOC,eACP,MAAMA;IAGV,MAAMG,WAAWC,GAAG,QAAQ;IAC5B,OAAQD;QACJ,KAAK;YACD,MAAME,YAAYN;YAClB;QACJ,KAAK;YACD,MAAMO,WAAWP;YACjB;QACJ,KAAK;YACD,MAAMQ,aAAaR;YACnB;QACJ;YACI,MAAMS,MACF,CAAC,4CAA4C,EAAEL,SAAS,kEAAkE,CAAC;IAEvI;IAEA,IAAI,AAAwB,cAAxB,OAAOF,cACP,MAAMA;IAGV,OAAO;AACX;AAEA,MAAMQ,0BAA0B;IAAC;IAAO;CAAQ;AAEhD,eAAeJ,YAAYN,cAAsB;IAC7C,MAAMH,UAAUH;IAChB,MAAMiB,OAAOD,wBAAwB,QAAQ,CAACE,QAAQ,IAAI,IAAIA,QAAQ,IAAI,GAAG;IAE7E,MAAMC,WAAW,CAAC,QAAQ,EAAEhB,QAAQ,QAAQ,EAAEc,KAAK,OAAO,CAAC;IAC3D,MAAMG,cAAc,yCAAyCD;IAE7D,MAAME,mBAAmBC,KAAK,IAAI,CAAChB,gBAAgBa;IACnD,MAAMI,aAAaH,aAAaC;IAEhC,MAAMG,sBAAAA,OAAW,CAAC;QACd,KAAKlB;QACL,MAAMe;IACV;IAEAZ,GAAG,UAAU,CAACa,KAAK,IAAI,CAAChB,gBAAgBa;AAC5C;AAEA,eAAeL,aAAaR,cAAsB;IAC9C,MAAMH,UAAUH;IAChB,MAAMmB,WAAW,CAAC,QAAQ,EAAEhB,QAAQ,gBAAgB,CAAC;IACrD,MAAMiB,cAAc,yCAAyCD;IAE7D,MAAME,mBAAmBC,KAAK,IAAI,CAAChB,gBAAgBa;IACnD,MAAMI,aAAaH,aAAaC;IAEhC,MAAMI,cAAcH,KAAK,IAAI,CAAChB,gBAAgB;IAC9C,MAAMoB,WAAWL,kBAAkBI,aAAa;QAAE,OAAO;IAAE;IAE3DhB,GAAG,UAAU,CAACa,KAAK,IAAI,CAAChB,gBAAgBa;AAC5C;AAEA,eAAeN,WAAWP,cAAsB;IAC5C,MAAMH,UAAUH;IAChB,MAAMmB,WAAW,CAAC,QAAQ,EAAEhB,QAAQ,iBAAiB,CAAC;IACtD,MAAMiB,cAAc,yCAAyCD;IAE7D,MAAME,mBAAmBC,KAAK,IAAI,CAAChB,gBAAgBa;IACnD,MAAMI,aAAaH,aAAaC;IAEhC,MAAMG,sBAAAA,OAAW,CAAC;QACd,KAAKlB;QACL,MAAMe;IACV;IAEAZ,GAAG,UAAU,CAACa,KAAK,IAAI,CAAChB,gBAAgBa;AAC5C"}
package/downloadFile.js CHANGED
@@ -1,23 +1,22 @@
1
1
  import { dirname } from "path";
2
- import fs from "fs-extra";
2
+ import fs_extra from "fs-extra";
3
3
  import { Readable } from "stream";
4
- export const downloadFile = async (url, file) => {
5
- const res = await fetch(url);
6
- if (!res.body) {
7
- throw new Error("Response body is null");
8
- }
9
- const nodeStream = Readable.fromWeb(res.body);
10
- await fs.ensureDir(dirname(file));
11
- await new Promise((resolve, reject) => {
12
- const fileStream = fs.createWriteStream(file);
13
- nodeStream.pipe(fileStream);
14
- nodeStream.on("error", err => {
15
- reject(err);
4
+ const downloadFile = async (url, file)=>{
5
+ const res = await fetch(url);
6
+ if (!res.body) throw new Error("Response body is null");
7
+ const nodeStream = Readable.fromWeb(res.body);
8
+ await fs_extra.ensureDir(dirname(file));
9
+ await new Promise((resolve, reject)=>{
10
+ const fileStream = fs_extra.createWriteStream(file);
11
+ nodeStream.pipe(fileStream);
12
+ nodeStream.on("error", (err)=>{
13
+ reject(err);
14
+ });
15
+ fileStream.on("finish", ()=>{
16
+ resolve();
17
+ });
16
18
  });
17
- fileStream.on("finish", () => {
18
- resolve();
19
- });
20
- });
21
19
  };
20
+ export { downloadFile };
22
21
 
23
22
  //# sourceMappingURL=downloadFile.js.map
@@ -1 +1 @@
1
- {"version":3,"names":["dirname","fs","Readable","downloadFile","url","file","res","fetch","body","Error","nodeStream","fromWeb","ensureDir","Promise","resolve","reject","fileStream","createWriteStream","pipe","on","err"],"sources":["downloadFile.ts"],"sourcesContent":["import { dirname } from \"path\";\nimport fs from \"fs-extra\";\nimport { Readable } from \"stream\";\nimport type { ReadableStream as NodeReadableStream } from \"stream/web\";\n\nexport const downloadFile = async (url: string, file: string) => {\n const res = await fetch(url);\n\n if (!res.body) {\n throw new Error(\"Response body is null\");\n }\n\n const nodeStream = Readable.fromWeb(res.body as NodeReadableStream);\n\n await fs.ensureDir(dirname(file));\n\n await new Promise<void>((resolve, reject) => {\n const fileStream = fs.createWriteStream(file);\n nodeStream.pipe(fileStream);\n nodeStream.on(\"error\", (err: Error) => {\n reject(err);\n });\n fileStream.on(\"finish\", () => {\n resolve();\n });\n });\n};\n"],"mappings":"AAAA,SAASA,OAAO,QAAQ,MAAM;AAC9B,OAAOC,EAAE,MAAM,UAAU;AACzB,SAASC,QAAQ,QAAQ,QAAQ;AAGjC,OAAO,MAAMC,YAAY,GAAG,MAAAA,CAAOC,GAAW,EAAEC,IAAY,KAAK;EAC7D,MAAMC,GAAG,GAAG,MAAMC,KAAK,CAACH,GAAG,CAAC;EAE5B,IAAI,CAACE,GAAG,CAACE,IAAI,EAAE;IACX,MAAM,IAAIC,KAAK,CAAC,uBAAuB,CAAC;EAC5C;EAEA,MAAMC,UAAU,GAAGR,QAAQ,CAACS,OAAO,CAACL,GAAG,CAACE,IAA0B,CAAC;EAEnE,MAAMP,EAAE,CAACW,SAAS,CAACZ,OAAO,CAACK,IAAI,CAAC,CAAC;EAEjC,MAAM,IAAIQ,OAAO,CAAO,CAACC,OAAO,EAAEC,MAAM,KAAK;IACzC,MAAMC,UAAU,GAAGf,EAAE,CAACgB,iBAAiB,CAACZ,IAAI,CAAC;IAC7CK,UAAU,CAACQ,IAAI,CAACF,UAAU,CAAC;IAC3BN,UAAU,CAACS,EAAE,CAAC,OAAO,EAAGC,GAAU,IAAK;MACnCL,MAAM,CAACK,GAAG,CAAC;IACf,CAAC,CAAC;IACFJ,UAAU,CAACG,EAAE,CAAC,QAAQ,EAAE,MAAM;MAC1BL,OAAO,CAAC,CAAC;IACb,CAAC,CAAC;EACN,CAAC,CAAC;AACN,CAAC","ignoreList":[]}
1
+ {"version":3,"file":"downloadFile.js","sources":["../src/downloadFile.ts"],"sourcesContent":["import { dirname } from \"path\";\nimport fs from \"fs-extra\";\nimport { Readable } from \"stream\";\nimport type { ReadableStream as NodeReadableStream } from \"stream/web\";\n\nexport const downloadFile = async (url: string, file: string) => {\n const res = await fetch(url);\n\n if (!res.body) {\n throw new Error(\"Response body is null\");\n }\n\n const nodeStream = Readable.fromWeb(res.body as NodeReadableStream);\n\n await fs.ensureDir(dirname(file));\n\n await new Promise<void>((resolve, reject) => {\n const fileStream = fs.createWriteStream(file);\n nodeStream.pipe(fileStream);\n nodeStream.on(\"error\", (err: Error) => {\n reject(err);\n });\n fileStream.on(\"finish\", () => {\n resolve();\n });\n });\n};\n"],"names":["downloadFile","url","file","res","fetch","Error","nodeStream","Readable","fs","dirname","Promise","resolve","reject","fileStream","err"],"mappings":";;;AAKO,MAAMA,eAAe,OAAOC,KAAaC;IAC5C,MAAMC,MAAM,MAAMC,MAAMH;IAExB,IAAI,CAACE,IAAI,IAAI,EACT,MAAM,IAAIE,MAAM;IAGpB,MAAMC,aAAaC,SAAS,OAAO,CAACJ,IAAI,IAAI;IAE5C,MAAMK,SAAAA,SAAY,CAACC,QAAQP;IAE3B,MAAM,IAAIQ,QAAc,CAACC,SAASC;QAC9B,MAAMC,aAAaL,SAAAA,iBAAoB,CAACN;QACxCI,WAAW,IAAI,CAACO;QAChBP,WAAW,EAAE,CAAC,SAAS,CAACQ;YACpBF,OAAOE;QACX;QACAD,WAAW,EAAE,CAAC,UAAU;YACpBF;QACJ;IACJ;AACJ"}
package/index.js CHANGED
@@ -1,3 +1 @@
1
1
  export * from "./Pulumi.js";
2
-
3
- //# sourceMappingURL=index.js.map
package/package.json CHANGED
@@ -1,6 +1,6 @@
1
1
  {
2
2
  "name": "@webiny/pulumi-sdk",
3
- "version": "6.3.0-beta.4",
3
+ "version": "6.4.0-beta.0",
4
4
  "type": "module",
5
5
  "exports": {
6
6
  ".": "./index.js",
@@ -18,20 +18,20 @@
18
18
  "directory": "dist"
19
19
  },
20
20
  "dependencies": {
21
- "@pulumi/aws": "^7.28.0",
22
- "@pulumi/pulumi": "^3.234.0",
21
+ "@pulumi/aws": "^7.29.0",
22
+ "@pulumi/pulumi": "^3.237.0",
23
23
  "decompress": "4.2.1",
24
24
  "execa": "5.1.1",
25
25
  "find-up": "8.0.0",
26
- "fs-extra": "11.3.4",
26
+ "fs-extra": "11.3.5",
27
27
  "load-json-file": "7.0.1",
28
28
  "lodash": "4.18.1",
29
- "semver": "7.7.4",
30
- "tar": "7.5.13"
29
+ "semver": "7.8.0",
30
+ "tar": "7.5.15"
31
31
  },
32
32
  "devDependencies": {
33
33
  "@types/lodash": "4.17.24",
34
- "@webiny/build-tools": "6.3.0-beta.4",
34
+ "@webiny/build-tools": "6.4.0-beta.0",
35
35
  "rimraf": "6.1.3",
36
36
  "type-fest": "5.6.0",
37
37
  "typescript": "6.0.3"
@@ -44,5 +44,5 @@
44
44
  ]
45
45
  }
46
46
  },
47
- "gitHead": "7cefe15431dbd65504e1f58147dc9e55bcbfa693"
47
+ "gitHead": "a545d7529828af07d08d49c3da1bcb967483b9ce"
48
48
  }
package/index.js.map DELETED
@@ -1 +0,0 @@
1
- {"version":3,"names":[],"sources":["index.ts"],"sourcesContent":["export * from \"./Pulumi.js\";\n"],"mappings":"AAAA","ignoreList":[]}