@sentry/wizard 3.1.0 → 3.2.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/CHANGELOG.md +15 -0
- package/bin.ts +5 -1
- package/dist/bin.js +6 -1
- package/dist/bin.js.map +1 -1
- package/dist/lib/Constants.d.ts +2 -1
- package/dist/lib/Constants.js +5 -0
- package/dist/lib/Constants.js.map +1 -1
- package/dist/lib/Helper/File.js +25 -2
- package/dist/lib/Helper/File.js.map +1 -1
- package/dist/lib/Helper/Git.d.ts +7 -0
- package/dist/lib/Helper/Git.js +94 -0
- package/dist/lib/Helper/Git.js.map +1 -0
- package/dist/lib/Helper/Logging.d.ts +1 -0
- package/dist/lib/Helper/Logging.js +9 -2
- package/dist/lib/Helper/Logging.js.map +1 -1
- package/dist/lib/Helper/MergeConfig.js +24 -1
- package/dist/lib/Helper/MergeConfig.js.map +1 -1
- package/dist/lib/Helper/Package.d.ts +9 -0
- package/dist/lib/Helper/Package.js +39 -2
- package/dist/lib/Helper/Package.js.map +1 -1
- package/dist/lib/Helper/PackageManager.d.ts +1 -1
- package/dist/lib/Helper/PackageManager.js +32 -11
- package/dist/lib/Helper/PackageManager.js.map +1 -1
- package/dist/lib/Helper/SentryCli.d.ts +11 -0
- package/dist/lib/Helper/SentryCli.js +141 -2
- package/dist/lib/Helper/SentryCli.js.map +1 -1
- package/dist/lib/Helper/Wizard.js +24 -1
- package/dist/lib/Helper/Wizard.js.map +1 -1
- package/dist/lib/Helper/__tests__/MergeConfig.js +25 -2
- package/dist/lib/Helper/__tests__/MergeConfig.js.map +1 -1
- package/dist/lib/Setup.js +25 -2
- package/dist/lib/Setup.js.map +1 -1
- package/dist/lib/Steps/ChooseIntegration.js +28 -1
- package/dist/lib/Steps/ChooseIntegration.js.map +1 -1
- package/dist/lib/Steps/Initial.js +25 -2
- package/dist/lib/Steps/Initial.js.map +1 -1
- package/dist/lib/Steps/Integrations/BaseIntegration.js +24 -1
- package/dist/lib/Steps/Integrations/BaseIntegration.js.map +1 -1
- package/dist/lib/Steps/Integrations/Cordova.js +25 -2
- package/dist/lib/Steps/Integrations/Cordova.js.map +1 -1
- package/dist/lib/Steps/Integrations/Electron.js +26 -3
- package/dist/lib/Steps/Integrations/Electron.js.map +1 -1
- package/dist/lib/Steps/Integrations/MobileProject.js +24 -1
- package/dist/lib/Steps/Integrations/MobileProject.js.map +1 -1
- package/dist/lib/Steps/Integrations/NextJs.d.ts +5 -11
- package/dist/lib/Steps/Integrations/NextJs.js +14 -343
- package/dist/lib/Steps/Integrations/NextJs.js.map +1 -1
- package/dist/lib/Steps/Integrations/ReactNative.d.ts +1 -0
- package/dist/lib/Steps/Integrations/ReactNative.js +67 -6
- package/dist/lib/Steps/Integrations/ReactNative.js.map +1 -1
- package/dist/lib/Steps/Integrations/SvelteKit.d.ts +13 -0
- package/dist/lib/Steps/Integrations/SvelteKit.js +95 -0
- package/dist/lib/Steps/Integrations/SvelteKit.js.map +1 -0
- package/dist/lib/Steps/Integrations/__tests__/ReactNative.js +28 -5
- package/dist/lib/Steps/Integrations/__tests__/ReactNative.js.map +1 -1
- package/dist/lib/Steps/PromptForParameters.js +24 -1
- package/dist/lib/Steps/PromptForParameters.js.map +1 -1
- package/dist/lib/Steps/SentryProjectSelector.js +25 -1
- package/dist/lib/Steps/SentryProjectSelector.js.map +1 -1
- package/dist/lib/__tests__/Setup.js +24 -1
- package/dist/lib/__tests__/Setup.js.map +1 -1
- package/dist/src/{nextjs-wizard.js → nextjs/nextjs-wizard.js} +113 -108
- package/dist/src/nextjs/nextjs-wizard.js.map +1 -0
- package/dist/src/sveltekit/sdk-example.d.ts +10 -0
- package/dist/src/sveltekit/sdk-example.js +106 -0
- package/dist/src/sveltekit/sdk-example.js.map +1 -0
- package/dist/src/sveltekit/sdk-setup.d.ts +13 -0
- package/dist/src/sveltekit/sdk-setup.js +451 -0
- package/dist/src/sveltekit/sdk-setup.js.map +1 -0
- package/dist/src/sveltekit/sentry-cli-setup.d.ts +2 -0
- package/dist/src/sveltekit/sentry-cli-setup.js +71 -0
- package/dist/src/sveltekit/sentry-cli-setup.js.map +1 -0
- package/dist/src/sveltekit/sveltekit-wizard.d.ts +5 -0
- package/dist/src/sveltekit/sveltekit-wizard.js +147 -0
- package/dist/src/sveltekit/sveltekit-wizard.js.map +1 -0
- package/dist/src/templates/nextjs-templates.js +2 -2
- package/dist/src/templates/nextjs-templates.js.map +1 -1
- package/dist/src/templates/sveltekit-templates.d.ts +12 -0
- package/dist/src/templates/sveltekit-templates.js +26 -0
- package/dist/src/templates/sveltekit-templates.js.map +1 -0
- package/dist/src/{clack-utils.d.ts → utils/clack-utils.d.ts} +7 -0
- package/dist/src/{clack-utils.js → utils/clack-utils.js} +127 -42
- package/dist/src/utils/clack-utils.js.map +1 -0
- package/lib/Constants.ts +5 -0
- package/lib/Helper/Git.ts +39 -0
- package/lib/Helper/Logging.ts +4 -0
- package/lib/Helper/Package.ts +17 -0
- package/lib/Helper/PackageManager.ts +4 -9
- package/lib/Helper/SentryCli.ts +74 -0
- package/lib/Steps/ChooseIntegration.ts +4 -0
- package/lib/Steps/Integrations/NextJs.ts +7 -397
- package/lib/Steps/Integrations/ReactNative.ts +49 -3
- package/lib/Steps/Integrations/SvelteKit.ts +29 -0
- package/lib/Steps/SentryProjectSelector.ts +1 -0
- package/package.json +1 -1
- package/src/{nextjs-wizard.ts → nextjs/nextjs-wizard.ts} +13 -44
- package/src/sveltekit/sdk-example.ts +56 -0
- package/src/sveltekit/sdk-setup.ts +430 -0
- package/src/sveltekit/sentry-cli-setup.ts +27 -0
- package/src/sveltekit/sveltekit-wizard.ts +116 -0
- package/src/templates/nextjs-templates.ts +2 -2
- package/src/templates/sveltekit-templates.ts +172 -0
- package/src/{clack-utils.ts → utils/clack-utils.ts} +73 -11
- package/dist/src/clack-utils.js.map +0 -1
- package/dist/src/nextjs-wizard.js.map +0 -1
- /package/dist/src/{nextjs-wizard.d.ts → nextjs/nextjs-wizard.d.ts} +0 -0
package/CHANGELOG.md
CHANGED
|
@@ -1,5 +1,20 @@
|
|
|
1
1
|
# Changelog
|
|
2
2
|
|
|
3
|
+
## 3.2.0
|
|
4
|
+
|
|
5
|
+
- feat(sveltekit): Add support for SvelteKit SDK Setup (#251)
|
|
6
|
+
|
|
7
|
+
Set up the Sentry SvelteKit SDK in your app with one command:
|
|
8
|
+
|
|
9
|
+
```sh
|
|
10
|
+
npx @sentry/wizard -i sveltekit
|
|
11
|
+
```
|
|
12
|
+
|
|
13
|
+
- feat(rn): Add code snippet to send the first Sentry Error ([#263](https://github.com/getsentry/sentry-wizard/pull/263))
|
|
14
|
+
- fix(rn): Show loader when installing dependencies (#264)
|
|
15
|
+
- ref(nextjs): Clean up minor things (#258)
|
|
16
|
+
- ref(nextjs): Replace old Next.js wizard (#262)
|
|
17
|
+
|
|
3
18
|
## 3.1.0
|
|
4
19
|
|
|
5
20
|
- ref: Rewrite Next.js wizard (#256)
|
package/bin.ts
CHANGED
|
@@ -1,7 +1,8 @@
|
|
|
1
1
|
#!/usr/bin/env node
|
|
2
2
|
import { DEFAULT_URL, Integration, Platform } from './lib/Constants';
|
|
3
3
|
import { run } from './lib/Setup';
|
|
4
|
-
import { runNextjsWizard } from './src/nextjs-wizard';
|
|
4
|
+
import { runNextjsWizard } from './src/nextjs/nextjs-wizard';
|
|
5
|
+
import { runSvelteKitWizard } from './src/sveltekit/sveltekit-wizard';
|
|
5
6
|
export * from './lib/Setup';
|
|
6
7
|
|
|
7
8
|
// eslint-disable-next-line @typescript-eslint/no-unsafe-assignment, @typescript-eslint/no-unsafe-member-access, @typescript-eslint/no-unsafe-call
|
|
@@ -58,6 +59,9 @@ const argv = require('yargs')
|
|
|
58
59
|
if (argv.i === 'nextjs') {
|
|
59
60
|
// eslint-disable-next-line no-console
|
|
60
61
|
runNextjsWizard({ promoCode: argv['promo-code'] }).catch(console.error);
|
|
62
|
+
} else if (argv.i === 'sveltekit') {
|
|
63
|
+
// eslint-disable-next-line no-console
|
|
64
|
+
runSvelteKitWizard({ promoCode: argv['promo-code'] }).catch(console.error);
|
|
61
65
|
} else {
|
|
62
66
|
// eslint-disable-next-line @typescript-eslint/no-floating-promises
|
|
63
67
|
run(argv);
|
package/dist/bin.js
CHANGED
|
@@ -17,7 +17,8 @@ var __exportStar = (this && this.__exportStar) || function(m, exports) {
|
|
|
17
17
|
Object.defineProperty(exports, "__esModule", { value: true });
|
|
18
18
|
var Constants_1 = require("./lib/Constants");
|
|
19
19
|
var Setup_1 = require("./lib/Setup");
|
|
20
|
-
var nextjs_wizard_1 = require("./src/nextjs-wizard");
|
|
20
|
+
var nextjs_wizard_1 = require("./src/nextjs/nextjs-wizard");
|
|
21
|
+
var sveltekit_wizard_1 = require("./src/sveltekit/sveltekit-wizard");
|
|
21
22
|
__exportStar(require("./lib/Setup"), exports);
|
|
22
23
|
// eslint-disable-next-line @typescript-eslint/no-unsafe-assignment, @typescript-eslint/no-unsafe-member-access, @typescript-eslint/no-unsafe-call
|
|
23
24
|
var argv = require('yargs')
|
|
@@ -71,6 +72,10 @@ if (argv.i === 'nextjs') {
|
|
|
71
72
|
// eslint-disable-next-line no-console
|
|
72
73
|
(0, nextjs_wizard_1.runNextjsWizard)({ promoCode: argv['promo-code'] }).catch(console.error);
|
|
73
74
|
}
|
|
75
|
+
else if (argv.i === 'sveltekit') {
|
|
76
|
+
// eslint-disable-next-line no-console
|
|
77
|
+
(0, sveltekit_wizard_1.runSvelteKitWizard)({ promoCode: argv['promo-code'] }).catch(console.error);
|
|
78
|
+
}
|
|
74
79
|
else {
|
|
75
80
|
// eslint-disable-next-line @typescript-eslint/no-floating-promises
|
|
76
81
|
(0, Setup_1.run)(argv);
|
package/dist/bin.js.map
CHANGED
|
@@ -1 +1 @@
|
|
|
1
|
-
{"version":3,"file":"bin.js","sourceRoot":"","sources":["../bin.ts"],"names":[],"mappings":";;;;;;;;;;;;;;;;;AACA,6CAAqE;AACrE,qCAAkC;AAClC,
|
|
1
|
+
{"version":3,"file":"bin.js","sourceRoot":"","sources":["../bin.ts"],"names":[],"mappings":";;;;;;;;;;;;;;;;;AACA,6CAAqE;AACrE,qCAAkC;AAClC,4DAA6D;AAC7D,qEAAsE;AACtE,8CAA4B;AAE5B,kJAAkJ;AAClJ,IAAM,IAAI,GAAG,OAAO,CAAC,OAAO,CAAC;KAC1B,MAAM,CAAC,OAAO,EAAE;IACf,OAAO,EAAE,KAAK;IACd,QAAQ,EAAE,kDAAkD;IAC5D,IAAI,EAAE,SAAS;CAChB,CAAC;KACD,MAAM,CAAC,WAAW,EAAE;IACnB,OAAO,EAAE,KAAK;IACd,QAAQ,EAAE,4DAA4D;IACtE,IAAI,EAAE,SAAS;CAChB,CAAC;KACD,MAAM,CAAC,cAAc,EAAE;IACtB,OAAO,EAAE,KAAK;IACd,QAAQ,EACN,qEAAqE;IACvE,IAAI,EAAE,SAAS;CAChB,CAAC;KACD,MAAM,CAAC,OAAO,EAAE;IACf,OAAO,EAAE,KAAK;IACd,QAAQ,EACN,8EAA8E;IAChF,IAAI,EAAE,SAAS;CAChB,CAAC;KACD,MAAM,CAAC,GAAG,EAAE;IACX,KAAK,EAAE,aAAa;IACpB,OAAO,EAAE,MAAM,CAAC,IAAI,CAAC,uBAAW,CAAC;IACjC,QAAQ,EAAE,iEAAiE;CAC5E,CAAC;KACD,MAAM,CAAC,GAAG,EAAE;IACX,KAAK,EAAE,UAAU;IACjB,OAAO,EAAE,MAAM,CAAC,IAAI,CAAC,oBAAQ,CAAC;IAC9B,QAAQ,EAAE,iDAAiD;IAC3D,IAAI,EAAE,OAAO;CACd,CAAC;KACD,MAAM,CAAC,GAAG,EAAE;IACX,KAAK,EAAE,KAAK;IACZ,OAAO,EAAE,uBAAW;IACpB,QAAQ,EAAE,6DAA6D;CACxE,CAAC;KACD,MAAM,CAAC,GAAG,EAAE;IACX,KAAK,EAAE,QAAQ;IACf,OAAO,EAAE,KAAK;IACd,QAAQ,EAAE,0CAA0C;IACpD,IAAI,EAAE,SAAS;CAChB,CAAC;KACD,MAAM,CAAC,YAAY,EAAE;IACpB,KAAK,EAAE,YAAY;IACnB,QAAQ,EAAE,iDAAiD;CAC5D,CAAC,CAAC,IAAI,CAAC;AAEV,IAAI,IAAI,CAAC,CAAC,KAAK,QAAQ,EAAE;IACvB,sCAAsC;IACtC,IAAA,+BAAe,EAAC,EAAE,SAAS,EAAE,IAAI,CAAC,YAAY,CAAC,EAAE,CAAC,CAAC,KAAK,CAAC,OAAO,CAAC,KAAK,CAAC,CAAC;CACzE;KAAM,IAAI,IAAI,CAAC,CAAC,KAAK,WAAW,EAAE;IACjC,sCAAsC;IACtC,IAAA,qCAAkB,EAAC,EAAE,SAAS,EAAE,IAAI,CAAC,YAAY,CAAC,EAAE,CAAC,CAAC,KAAK,CAAC,OAAO,CAAC,KAAK,CAAC,CAAC;CAC5E;KAAM;IACL,mEAAmE;IACnE,IAAA,WAAG,EAAC,IAAI,CAAC,CAAC;CACX","sourcesContent":["#!/usr/bin/env node\nimport { DEFAULT_URL, Integration, Platform } from './lib/Constants';\nimport { run } from './lib/Setup';\nimport { runNextjsWizard } from './src/nextjs/nextjs-wizard';\nimport { runSvelteKitWizard } from './src/sveltekit/sveltekit-wizard';\nexport * from './lib/Setup';\n\n// eslint-disable-next-line @typescript-eslint/no-unsafe-assignment, @typescript-eslint/no-unsafe-member-access, @typescript-eslint/no-unsafe-call\nconst argv = require('yargs')\n .option('debug', {\n default: false,\n describe: 'Enable verbose logging\\nenv: SENTRY_WIZARD_DEBUG',\n type: 'boolean',\n })\n .option('uninstall', {\n default: false,\n describe: 'Revert project setup process\\nenv: SENTRY_WIZARD_UNINSTALL',\n type: 'boolean',\n })\n .option('skip-connect', {\n default: false,\n describe:\n 'Skips the connection to the server\\nenv: SENTRY_WIZARD_SKIP_CONNECT',\n type: 'boolean',\n })\n .option('quiet', {\n default: false,\n describe:\n 'Do not fallback to prompting user asking questions\\nenv: SENTRY_WIZARD_QUIET',\n type: 'boolean',\n })\n .option('i', {\n alias: 'integration',\n choices: Object.keys(Integration),\n describe: 'Choose the integration to setup\\nenv: SENTRY_WIZARD_INTEGRATION',\n })\n .option('p', {\n alias: 'platform',\n choices: Object.keys(Platform),\n describe: 'Choose platform(s)\\nenv: SENTRY_WIZARD_PLATFORM',\n type: 'array',\n })\n .option('u', {\n alias: 'url',\n default: DEFAULT_URL,\n describe: 'The url to your Sentry installation\\nenv: SENTRY_WIZARD_URL',\n })\n .option('s', {\n alias: 'signup',\n default: false,\n describe: 'Redirect to signup page if not logged in',\n type: 'boolean',\n })\n .option('promo-code', {\n alias: 'promo-code',\n describe: 'A promo code that will be applied during signup',\n }).argv;\n\nif (argv.i === 'nextjs') {\n // eslint-disable-next-line no-console\n runNextjsWizard({ promoCode: argv['promo-code'] }).catch(console.error);\n} else if (argv.i === 'sveltekit') {\n // eslint-disable-next-line no-console\n runSvelteKitWizard({ promoCode: argv['promo-code'] }).catch(console.error);\n} else {\n // eslint-disable-next-line @typescript-eslint/no-floating-promises\n run(argv);\n}\n"]}
|
package/dist/lib/Constants.d.ts
CHANGED
package/dist/lib/Constants.js
CHANGED
|
@@ -8,6 +8,7 @@ var Integration;
|
|
|
8
8
|
Integration["cordova"] = "cordova";
|
|
9
9
|
Integration["electron"] = "electron";
|
|
10
10
|
Integration["nextjs"] = "nextjs";
|
|
11
|
+
Integration["sveltekit"] = "sveltekit";
|
|
11
12
|
})(Integration = exports.Integration || (exports.Integration = {}));
|
|
12
13
|
/** Key value should be the same here */
|
|
13
14
|
var Platform;
|
|
@@ -42,6 +43,8 @@ function getIntegrationDescription(type) {
|
|
|
42
43
|
return 'Electron';
|
|
43
44
|
case Integration.nextjs:
|
|
44
45
|
return 'Next.js';
|
|
46
|
+
case Integration.sveltekit:
|
|
47
|
+
return 'SvelteKit';
|
|
45
48
|
default:
|
|
46
49
|
return 'React Native';
|
|
47
50
|
}
|
|
@@ -57,6 +60,8 @@ function mapIntegrationToPlatform(type) {
|
|
|
57
60
|
return 'javascript-electron';
|
|
58
61
|
case Integration.nextjs:
|
|
59
62
|
return 'javascript-nextjs';
|
|
63
|
+
case Integration.sveltekit:
|
|
64
|
+
return 'javascript-sveltekit';
|
|
60
65
|
default:
|
|
61
66
|
throw new Error("Unknown integration ".concat(type));
|
|
62
67
|
}
|
|
@@ -1 +1 @@
|
|
|
1
|
-
{"version":3,"file":"Constants.js","sourceRoot":"","sources":["../../lib/Constants.ts"],"names":[],"mappings":";;;AAAA,wCAAwC;AACxC,IAAY,
|
|
1
|
+
{"version":3,"file":"Constants.js","sourceRoot":"","sources":["../../lib/Constants.ts"],"names":[],"mappings":";;;AAAA,wCAAwC;AACxC,IAAY,WAMX;AAND,WAAY,WAAW;IACrB,0CAA2B,CAAA;IAC3B,kCAAmB,CAAA;IACnB,oCAAqB,CAAA;IACrB,gCAAiB,CAAA;IACjB,sCAAuB,CAAA;AACzB,CAAC,EANW,WAAW,GAAX,mBAAW,KAAX,mBAAW,QAMtB;AAED,wCAAwC;AACxC,IAAY,QAGX;AAHD,WAAY,QAAQ;IAClB,uBAAW,CAAA;IACX,+BAAmB,CAAA;AACrB,CAAC,EAHW,QAAQ,GAAR,gBAAQ,KAAR,gBAAQ,QAGnB;AAED,SAAgB,kBAAkB;IAChC,OAAO,MAAM,CAAC,IAAI,CAAC,QAAQ,CAAC,CAAC,GAAG,CAAC,UAAC,QAAgB,IAAK,OAAA,CAAC;QACtD,OAAO,EAAE,IAAI;QACb,IAAI,EAAE,sBAAsB,CAAC,QAAQ,CAAC;QACtC,KAAK,EAAE,QAAQ;KAChB,CAAC,EAJqD,CAIrD,CAAC,CAAC;AACN,CAAC;AAND,gDAMC;AAED,SAAgB,sBAAsB,CAAC,IAAY;IACjD,QAAQ,IAAI,EAAE;QACZ,KAAK,QAAQ,CAAC,GAAG;YACf,OAAO,KAAK,CAAC;QACf;YACE,OAAO,SAAS,CAAC;KACpB;AACH,CAAC;AAPD,wDAOC;AAED,SAAgB,yBAAyB,CAAC,IAAY;IACpD,QAAQ,IAAI,EAAE;QACZ,KAAK,WAAW,CAAC,WAAW;YAC1B,OAAO,cAAc,CAAC;QACxB,KAAK,WAAW,CAAC,OAAO;YACtB,OAAO,SAAS,CAAC;QACnB,KAAK,WAAW,CAAC,QAAQ;YACvB,OAAO,UAAU,CAAC;QACpB,KAAK,WAAW,CAAC,MAAM;YACrB,OAAO,SAAS,CAAC;QACnB,KAAK,WAAW,CAAC,SAAS;YACxB,OAAO,WAAW,CAAC;QACrB;YACE,OAAO,cAAc,CAAC;KACzB;AACH,CAAC;AAfD,8DAeC;AAED,SAAgB,wBAAwB,CAAC,IAAY;IACnD,QAAQ,IAAI,EAAE;QACZ,KAAK,WAAW,CAAC,WAAW;YAC1B,OAAO,cAAc,CAAC;QACxB,KAAK,WAAW,CAAC,OAAO;YACtB,OAAO,SAAS,CAAC;QACnB,KAAK,WAAW,CAAC,QAAQ;YACvB,OAAO,qBAAqB,CAAC;QAC/B,KAAK,WAAW,CAAC,MAAM;YACrB,OAAO,mBAAmB,CAAC;QAC7B,KAAK,WAAW,CAAC,SAAS;YACxB,OAAO,sBAAsB,CAAC;QAChC;YACE,MAAM,IAAI,KAAK,CAAC,8BAAuB,IAAI,CAAE,CAAC,CAAC;KAClD;AACH,CAAC;AAfD,4DAeC;AAED,SAAgB,qBAAqB;IACnC,OAAO,MAAM,CAAC,IAAI,CAAC,WAAW,CAAC,CAAC,GAAG,CAAC,UAAC,IAAY,IAAK,OAAA,CAAC;QACrD,IAAI,EAAE,yBAAyB,CAAC,IAAI,CAAC;QACrC,KAAK,EAAE,IAAI;KACZ,CAAC,EAHoD,CAGpD,CAAC,CAAC;AACN,CAAC;AALD,sDAKC;AAcY,QAAA,WAAW,GAAG,oBAAoB,CAAC","sourcesContent":["/** Key value should be the same here */\nexport enum Integration {\n reactNative = 'reactNative',\n cordova = 'cordova',\n electron = 'electron',\n nextjs = 'nextjs',\n sveltekit = 'sveltekit',\n}\n\n/** Key value should be the same here */\nexport enum Platform {\n ios = 'ios',\n android = 'android',\n}\n\nexport function getPlatformChoices(): any[] {\n return Object.keys(Platform).map((platform: string) => ({\n checked: true,\n name: getPlatformDescription(platform),\n value: platform,\n }));\n}\n\nexport function getPlatformDescription(type: string): string {\n switch (type) {\n case Platform.ios:\n return 'iOS';\n default:\n return 'Android';\n }\n}\n\nexport function getIntegrationDescription(type: string): string {\n switch (type) {\n case Integration.reactNative:\n return 'React Native';\n case Integration.cordova:\n return 'Cordova';\n case Integration.electron:\n return 'Electron';\n case Integration.nextjs:\n return 'Next.js';\n case Integration.sveltekit:\n return 'SvelteKit';\n default:\n return 'React Native';\n }\n}\n\nexport function mapIntegrationToPlatform(type: string): string {\n switch (type) {\n case Integration.reactNative:\n return 'react-native';\n case Integration.cordova:\n return 'cordova';\n case Integration.electron:\n return 'javascript-electron';\n case Integration.nextjs:\n return 'javascript-nextjs';\n case Integration.sveltekit:\n return 'javascript-sveltekit';\n default:\n throw new Error(`Unknown integration ${type}`);\n }\n}\n\nexport function getIntegrationChoices(): any[] {\n return Object.keys(Integration).map((type: string) => ({\n name: getIntegrationDescription(type),\n value: type,\n }));\n}\n\nexport interface Args {\n url: string;\n debug: boolean;\n uninstall: boolean;\n integration: Integration;\n platform: Platform[];\n skipConnect: boolean;\n quiet: boolean;\n signup: boolean;\n promoCode?: string;\n}\n\nexport const DEFAULT_URL = 'https://sentry.io/';\n"]}
|
package/dist/lib/Helper/File.js
CHANGED
|
@@ -1,4 +1,27 @@
|
|
|
1
1
|
"use strict";
|
|
2
|
+
var __createBinding = (this && this.__createBinding) || (Object.create ? (function(o, m, k, k2) {
|
|
3
|
+
if (k2 === undefined) k2 = k;
|
|
4
|
+
var desc = Object.getOwnPropertyDescriptor(m, k);
|
|
5
|
+
if (!desc || ("get" in desc ? !m.__esModule : desc.writable || desc.configurable)) {
|
|
6
|
+
desc = { enumerable: true, get: function() { return m[k]; } };
|
|
7
|
+
}
|
|
8
|
+
Object.defineProperty(o, k2, desc);
|
|
9
|
+
}) : (function(o, m, k, k2) {
|
|
10
|
+
if (k2 === undefined) k2 = k;
|
|
11
|
+
o[k2] = m[k];
|
|
12
|
+
}));
|
|
13
|
+
var __setModuleDefault = (this && this.__setModuleDefault) || (Object.create ? (function(o, v) {
|
|
14
|
+
Object.defineProperty(o, "default", { enumerable: true, value: v });
|
|
15
|
+
}) : function(o, v) {
|
|
16
|
+
o["default"] = v;
|
|
17
|
+
});
|
|
18
|
+
var __importStar = (this && this.__importStar) || function (mod) {
|
|
19
|
+
if (mod && mod.__esModule) return mod;
|
|
20
|
+
var result = {};
|
|
21
|
+
if (mod != null) for (var k in mod) if (k !== "default" && Object.prototype.hasOwnProperty.call(mod, k)) __createBinding(result, mod, k);
|
|
22
|
+
__setModuleDefault(result, mod);
|
|
23
|
+
return result;
|
|
24
|
+
};
|
|
2
25
|
var __spreadArray = (this && this.__spreadArray) || function (to, from, pack) {
|
|
3
26
|
if (pack || arguments.length === 2) for (var i = 0, l = from.length, ar; i < l; i++) {
|
|
4
27
|
if (ar || !(i in from)) {
|
|
@@ -10,8 +33,8 @@ var __spreadArray = (this && this.__spreadArray) || function (to, from, pack) {
|
|
|
10
33
|
};
|
|
11
34
|
Object.defineProperty(exports, "__esModule", { value: true });
|
|
12
35
|
exports.matchesContent = exports.exists = exports.matchFiles = exports.patchMatchingFile = void 0;
|
|
13
|
-
var fs = require("fs");
|
|
14
|
-
var glob = require("glob");
|
|
36
|
+
var fs = __importStar(require("fs"));
|
|
37
|
+
var glob = __importStar(require("glob"));
|
|
15
38
|
var IGNORE_PATTERN = ['node_modules/**', 'ios/Pods/**', '**/Pods/**'];
|
|
16
39
|
function patchMatchingFile(globPattern, func) {
|
|
17
40
|
var args = [];
|
|
@@ -1 +1 @@
|
|
|
1
|
-
{"version":3,"file":"File.js","sourceRoot":"","sources":["../../../lib/Helper/File.ts"],"names":[],"mappings":"
|
|
1
|
+
{"version":3,"file":"File.js","sourceRoot":"","sources":["../../../lib/Helper/File.ts"],"names":[],"mappings":";;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;AAAA,qCAAyB;AACzB,yCAA6B;AAE7B,IAAM,cAAc,GAAG,CAAC,iBAAiB,EAAE,aAAa,EAAE,YAAY,CAAC,CAAC;AAExE,SAAgB,iBAAiB,CAC/B,WAAmB,EACnB,IAAS;IACT,cAAc;SAAd,UAAc,EAAd,qBAAc,EAAd,IAAc;QAAd,6BAAc;;IAEd,IAAM,OAAO,GAAG,IAAI,CAAC,IAAI,CAAC,WAAW,EAAE;QACrC,MAAM,EAAE,cAAc;KACvB,CAAC,CAAC;IACH,IAAI,EAAE,GAAG,OAAO,CAAC,OAAO,EAAE,CAAC;IAC3B,OAAO,CAAC,OAAO,CAAC,UAAC,KAAa;QAC5B,IAAM,QAAQ,GAAG,EAAE,CAAC,YAAY,CAAC,KAAK,EAAE;YACtC,QAAQ,EAAE,OAAO;SAClB,CAAC,CAAC;QACH,EAAE,GAAG,EAAE;aACJ,IAAI,CAAC,cAAM,OAAA,IAAI,8BAAC,QAAQ,EAAE,KAAK,GAAK,IAAI,WAA7B,CAA8B,CAAC;aAC1C,IAAI,CAAC,UAAC,WAAW;YAChB,IACE,WAAW,KAAK,IAAI;gBACpB,WAAW,KAAK,SAAS;gBACzB,QAAQ,KAAK,WAAW,EACxB;gBACA,EAAE,CAAC,aAAa,CAAC,KAAK,EAAE,WAAW,CAAC,CAAC;aACtC;QACH,CAAC,CAAC,CAAC;IACP,CAAC,CAAC,CAAC;IACH,OAAO,EAAE,CAAC;AACZ,CAAC;AA1BD,8CA0BC;AAED,SAAgB,UAAU,CAAC,WAAmB;IAC5C,OAAO,IAAI,CAAC,IAAI,CAAC,WAAW,EAAE;QAC5B,MAAM,EAAE,cAAc;KACvB,CAAC,CAAC;AACL,CAAC;AAJD,gCAIC;AAED,SAAgB,MAAM,CAAC,WAAmB;IACxC,IAAM,OAAO,GAAG,IAAI,CAAC,IAAI,CAAC,WAAW,EAAE;QACrC,MAAM,EAAE,cAAc;KACvB,CAAC,CAAC;IACH,IAAI,OAAO,CAAC,MAAM,KAAK,CAAC,EAAE;QACxB,OAAO,KAAK,CAAC;KACd;IACD,OAAO,OAAO,CAAC,MAAM,CAAC,UAAC,IAAa,EAAE,KAAa;QACjD,OAAO,IAAI,IAAI,EAAE,CAAC,UAAU,CAAC,KAAK,CAAC,CAAC;IACtC,CAAC,EAAE,IAAI,CAAC,CAAC;AACX,CAAC;AAVD,wBAUC;AAED,SAAgB,cAAc,CAC5B,WAAmB,EACnB,cAAsB;IAEtB,IAAM,OAAO,GAAG,IAAI,CAAC,IAAI,CAAC,WAAW,EAAE;QACrC,MAAM,EAAE,cAAc;KACvB,CAAC,CAAC;IACH,IAAI,OAAO,CAAC,MAAM,KAAK,CAAC,EAAE;QACxB,OAAO,KAAK,CAAC;KACd;IACD,OAAO,OAAO,CAAC,MAAM,CAAC,UAAC,IAAa,EAAE,KAAa;QACjD,OAAO,CAAC,CAAC,CAAC,IAAI,IAAI,EAAE,CAAC,YAAY,CAAC,KAAK,CAAC,CAAC,QAAQ,EAAE,CAAC,KAAK,CAAC,cAAc,CAAC,CAAC,CAAC;IAC7E,CAAC,EAAE,IAAI,CAAC,CAAC;AACX,CAAC;AAbD,wCAaC","sourcesContent":["import * as fs from 'fs';\nimport * as glob from 'glob';\n\nconst IGNORE_PATTERN = ['node_modules/**', 'ios/Pods/**', '**/Pods/**'];\n\nexport function patchMatchingFile(\n globPattern: string,\n func: any,\n ...args: any[]\n): Promise<void> {\n const matches = glob.sync(globPattern, {\n ignore: IGNORE_PATTERN,\n });\n let rv = Promise.resolve();\n matches.forEach((match: string) => {\n const contents = fs.readFileSync(match, {\n encoding: 'utf-8',\n });\n rv = rv\n .then(() => func(contents, match, ...args))\n .then((newContents) => {\n if (\n newContents !== null &&\n newContents !== undefined &&\n contents !== newContents\n ) {\n fs.writeFileSync(match, newContents);\n }\n });\n });\n return rv;\n}\n\nexport function matchFiles(globPattern: string): string[] {\n return glob.sync(globPattern, {\n ignore: IGNORE_PATTERN,\n });\n}\n\nexport function exists(globPattern: string): boolean {\n const matches = glob.sync(globPattern, {\n ignore: IGNORE_PATTERN,\n });\n if (matches.length === 0) {\n return false;\n }\n return matches.reduce((prev: boolean, match: string) => {\n return prev && fs.existsSync(match);\n }, true);\n}\n\nexport function matchesContent(\n globPattern: string,\n contentPattern: RegExp,\n): boolean {\n const matches = glob.sync(globPattern, {\n ignore: IGNORE_PATTERN,\n });\n if (matches.length === 0) {\n return false;\n }\n return matches.reduce((prev: boolean, match: string) => {\n return !!(prev && fs.readFileSync(match).toString().match(contentPattern));\n }, true);\n}\n"]}
|
|
@@ -0,0 +1,7 @@
|
|
|
1
|
+
/**
|
|
2
|
+
* Adds the given file to the .gitignore file.
|
|
3
|
+
*
|
|
4
|
+
* @param filepath the file(path) to add to the .gitignore file
|
|
5
|
+
* @param errorMsg the error message to display if the file couldn't be added
|
|
6
|
+
*/
|
|
7
|
+
export declare function addToGitignore(filepath: string, errorMsg: string): Promise<void>;
|
|
@@ -0,0 +1,94 @@
|
|
|
1
|
+
"use strict";
|
|
2
|
+
var __createBinding = (this && this.__createBinding) || (Object.create ? (function(o, m, k, k2) {
|
|
3
|
+
if (k2 === undefined) k2 = k;
|
|
4
|
+
var desc = Object.getOwnPropertyDescriptor(m, k);
|
|
5
|
+
if (!desc || ("get" in desc ? !m.__esModule : desc.writable || desc.configurable)) {
|
|
6
|
+
desc = { enumerable: true, get: function() { return m[k]; } };
|
|
7
|
+
}
|
|
8
|
+
Object.defineProperty(o, k2, desc);
|
|
9
|
+
}) : (function(o, m, k, k2) {
|
|
10
|
+
if (k2 === undefined) k2 = k;
|
|
11
|
+
o[k2] = m[k];
|
|
12
|
+
}));
|
|
13
|
+
var __setModuleDefault = (this && this.__setModuleDefault) || (Object.create ? (function(o, v) {
|
|
14
|
+
Object.defineProperty(o, "default", { enumerable: true, value: v });
|
|
15
|
+
}) : function(o, v) {
|
|
16
|
+
o["default"] = v;
|
|
17
|
+
});
|
|
18
|
+
var __importStar = (this && this.__importStar) || function (mod) {
|
|
19
|
+
if (mod && mod.__esModule) return mod;
|
|
20
|
+
var result = {};
|
|
21
|
+
if (mod != null) for (var k in mod) if (k !== "default" && Object.prototype.hasOwnProperty.call(mod, k)) __createBinding(result, mod, k);
|
|
22
|
+
__setModuleDefault(result, mod);
|
|
23
|
+
return result;
|
|
24
|
+
};
|
|
25
|
+
var __awaiter = (this && this.__awaiter) || function (thisArg, _arguments, P, generator) {
|
|
26
|
+
function adopt(value) { return value instanceof P ? value : new P(function (resolve) { resolve(value); }); }
|
|
27
|
+
return new (P || (P = Promise))(function (resolve, reject) {
|
|
28
|
+
function fulfilled(value) { try { step(generator.next(value)); } catch (e) { reject(e); } }
|
|
29
|
+
function rejected(value) { try { step(generator["throw"](value)); } catch (e) { reject(e); } }
|
|
30
|
+
function step(result) { result.done ? resolve(result.value) : adopt(result.value).then(fulfilled, rejected); }
|
|
31
|
+
step((generator = generator.apply(thisArg, _arguments || [])).next());
|
|
32
|
+
});
|
|
33
|
+
};
|
|
34
|
+
var __generator = (this && this.__generator) || function (thisArg, body) {
|
|
35
|
+
var _ = { label: 0, sent: function() { if (t[0] & 1) throw t[1]; return t[1]; }, trys: [], ops: [] }, f, y, t, g;
|
|
36
|
+
return g = { next: verb(0), "throw": verb(1), "return": verb(2) }, typeof Symbol === "function" && (g[Symbol.iterator] = function() { return this; }), g;
|
|
37
|
+
function verb(n) { return function (v) { return step([n, v]); }; }
|
|
38
|
+
function step(op) {
|
|
39
|
+
if (f) throw new TypeError("Generator is already executing.");
|
|
40
|
+
while (g && (g = 0, op[0] && (_ = 0)), _) try {
|
|
41
|
+
if (f = 1, y && (t = op[0] & 2 ? y["return"] : op[0] ? y["throw"] || ((t = y["return"]) && t.call(y), 0) : y.next) && !(t = t.call(y, op[1])).done) return t;
|
|
42
|
+
if (y = 0, t) op = [op[0] & 2, t.value];
|
|
43
|
+
switch (op[0]) {
|
|
44
|
+
case 0: case 1: t = op; break;
|
|
45
|
+
case 4: _.label++; return { value: op[1], done: false };
|
|
46
|
+
case 5: _.label++; y = op[1]; op = [0]; continue;
|
|
47
|
+
case 7: op = _.ops.pop(); _.trys.pop(); continue;
|
|
48
|
+
default:
|
|
49
|
+
if (!(t = _.trys, t = t.length > 0 && t[t.length - 1]) && (op[0] === 6 || op[0] === 2)) { _ = 0; continue; }
|
|
50
|
+
if (op[0] === 3 && (!t || (op[1] > t[0] && op[1] < t[3]))) { _.label = op[1]; break; }
|
|
51
|
+
if (op[0] === 6 && _.label < t[1]) { _.label = t[1]; t = op; break; }
|
|
52
|
+
if (t && _.label < t[2]) { _.label = t[2]; _.ops.push(op); break; }
|
|
53
|
+
if (t[2]) _.ops.pop();
|
|
54
|
+
_.trys.pop(); continue;
|
|
55
|
+
}
|
|
56
|
+
op = body.call(thisArg, _);
|
|
57
|
+
} catch (e) { op = [6, e]; y = 0; } finally { f = t = 0; }
|
|
58
|
+
if (op[0] & 5) throw op[1]; return { value: op[0] ? op[1] : void 0, done: true };
|
|
59
|
+
}
|
|
60
|
+
};
|
|
61
|
+
Object.defineProperty(exports, "__esModule", { value: true });
|
|
62
|
+
exports.addToGitignore = void 0;
|
|
63
|
+
var fs = __importStar(require("fs"));
|
|
64
|
+
var Logging_1 = require("./Logging");
|
|
65
|
+
var GITIGNORE_FILENAME = '.gitignore';
|
|
66
|
+
/**
|
|
67
|
+
* Adds the given file to the .gitignore file.
|
|
68
|
+
*
|
|
69
|
+
* @param filepath the file(path) to add to the .gitignore file
|
|
70
|
+
* @param errorMsg the error message to display if the file couldn't be added
|
|
71
|
+
*/
|
|
72
|
+
function addToGitignore(filepath, errorMsg) {
|
|
73
|
+
return __awaiter(this, void 0, void 0, function () {
|
|
74
|
+
var _a;
|
|
75
|
+
return __generator(this, function (_b) {
|
|
76
|
+
switch (_b.label) {
|
|
77
|
+
case 0:
|
|
78
|
+
_b.trys.push([0, 2, , 3]);
|
|
79
|
+
return [4 /*yield*/, fs.promises.appendFile(GITIGNORE_FILENAME, "\n# Sentry\n".concat(filepath, "\n"))];
|
|
80
|
+
case 1:
|
|
81
|
+
_b.sent();
|
|
82
|
+
(0, Logging_1.green)("\u2713 ".concat(filepath, " added to ").concat(GITIGNORE_FILENAME));
|
|
83
|
+
return [3 /*break*/, 3];
|
|
84
|
+
case 2:
|
|
85
|
+
_a = _b.sent();
|
|
86
|
+
(0, Logging_1.red)(errorMsg);
|
|
87
|
+
return [3 /*break*/, 3];
|
|
88
|
+
case 3: return [2 /*return*/];
|
|
89
|
+
}
|
|
90
|
+
});
|
|
91
|
+
});
|
|
92
|
+
}
|
|
93
|
+
exports.addToGitignore = addToGitignore;
|
|
94
|
+
//# sourceMappingURL=Git.js.map
|
|
@@ -0,0 +1 @@
|
|
|
1
|
+
{"version":3,"file":"Git.js","sourceRoot":"","sources":["../../../lib/Helper/Git.ts"],"names":[],"mappings":";;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;AAAA,qCAAyB;AAEzB,qCAAuC;AAEvC,IAAM,kBAAkB,GAAG,YAAY,CAAC;AAExC;;;;;GAKG;AACH,SAAsB,cAAc,CAClC,QAAgB,EAChB,QAAgB;;;;;;;oBAgBd,qBAAM,EAAE,CAAC,QAAQ,CAAC,UAAU,CAC1B,kBAAkB,EAClB,sBAAe,QAAQ,OAAI,CAC5B,EAAA;;oBAHD,SAGC,CAAC;oBACF,IAAA,eAAK,EAAC,iBAAK,QAAQ,uBAAa,kBAAkB,CAAE,CAAC,CAAC;;;;oBAEtD,IAAA,aAAG,EAAC,QAAQ,CAAC,CAAC;;;;;;CAEjB;AA1BD,wCA0BC","sourcesContent":["import * as fs from 'fs';\n\nimport { green, red } from './Logging';\n\nconst GITIGNORE_FILENAME = '.gitignore';\n\n/**\n * Adds the given file to the .gitignore file.\n *\n * @param filepath the file(path) to add to the .gitignore file\n * @param errorMsg the error message to display if the file couldn't be added\n */\nexport async function addToGitignore(\n filepath: string,\n errorMsg: string,\n): Promise<void> {\n /**\n * Don't check whether the given file is ignored because:\n * 1. It's tricky to check it without git.\n * 2. Git might not be installed or accessible.\n * 3. It's convenient to use a module to interact with git, but it would\n * increase the size x2 approximately. Docs say to run the Wizard without\n * installing it, and duplicating the size would slow the set-up down.\n * 4. The Wizard is meant to be run once.\n * 5. A message is logged informing users it's been added to the gitignore.\n * 6. It will be added to the gitignore as many times as it runs - not a big\n * deal.\n * 7. It's straightforward to remove it from the gitignore.\n */\n try {\n await fs.promises.appendFile(\n GITIGNORE_FILENAME,\n `\\n# Sentry\\n${filepath}\\n`,\n );\n green(`✓ ${filepath} added to ${GITIGNORE_FILENAME}`);\n } catch {\n red(errorMsg);\n }\n}\n"]}
|
|
@@ -4,4 +4,5 @@ export declare function green(msg: string): void;
|
|
|
4
4
|
export declare function red(msg: string): void;
|
|
5
5
|
export declare function dim(msg: string): void;
|
|
6
6
|
export declare function yellow(msg: string): void;
|
|
7
|
+
export declare function cyan(msg: string): void;
|
|
7
8
|
export declare function debug(msg: any): void;
|
|
@@ -1,7 +1,10 @@
|
|
|
1
1
|
"use strict";
|
|
2
|
+
var __importDefault = (this && this.__importDefault) || function (mod) {
|
|
3
|
+
return (mod && mod.__esModule) ? mod : { "default": mod };
|
|
4
|
+
};
|
|
2
5
|
Object.defineProperty(exports, "__esModule", { value: true });
|
|
3
|
-
exports.debug = exports.yellow = exports.dim = exports.red = exports.green = exports.nl = exports.l = void 0;
|
|
4
|
-
var chalk_1 = require("chalk");
|
|
6
|
+
exports.debug = exports.cyan = exports.yellow = exports.dim = exports.red = exports.green = exports.nl = exports.l = void 0;
|
|
7
|
+
var chalk_1 = __importDefault(require("chalk"));
|
|
5
8
|
function prepareMessage(msg) {
|
|
6
9
|
if (typeof msg === 'string') {
|
|
7
10
|
return msg;
|
|
@@ -36,6 +39,10 @@ function yellow(msg) {
|
|
|
36
39
|
return l(chalk_1.default.yellow(prepareMessage(msg)));
|
|
37
40
|
}
|
|
38
41
|
exports.yellow = yellow;
|
|
42
|
+
function cyan(msg) {
|
|
43
|
+
return l(chalk_1.default.cyan(prepareMessage(msg)));
|
|
44
|
+
}
|
|
45
|
+
exports.cyan = cyan;
|
|
39
46
|
function debug(msg) {
|
|
40
47
|
return l(chalk_1.default.italic.yellow(prepareMessage(msg)));
|
|
41
48
|
}
|
|
@@ -1 +1 @@
|
|
|
1
|
-
{"version":3,"file":"Logging.js","sourceRoot":"","sources":["../../../lib/Helper/Logging.ts"],"names":[],"mappings":"
|
|
1
|
+
{"version":3,"file":"Logging.js","sourceRoot":"","sources":["../../../lib/Helper/Logging.ts"],"names":[],"mappings":";;;;;;AAAA,gDAA0B;AAE1B,SAAS,cAAc,CAAC,GAAY;IAClC,IAAI,OAAO,GAAG,KAAK,QAAQ,EAAE;QAC3B,OAAO,GAAG,CAAC;KACZ;IACD,IAAI,GAAG,YAAY,KAAK,EAAE;QACxB,OAAO,UAAG,GAAG,CAAC,KAAK,IAAI,EAAE,CAAE,CAAC;KAC7B;IACD,OAAO,IAAI,CAAC,SAAS,CAAC,GAAG,EAAE,IAAI,EAAE,IAAI,CAAC,CAAC;AACzC,CAAC;AAED,SAAgB,CAAC,CAAC,GAAW;IAC3B,sCAAsC;IACtC,OAAO,CAAC,GAAG,CAAC,GAAG,CAAC,CAAC;AACnB,CAAC;AAHD,cAGC;AAED,SAAgB,EAAE;IAChB,OAAO,CAAC,CAAC,EAAE,CAAC,CAAC;AACf,CAAC;AAFD,gBAEC;AAED,SAAgB,KAAK,CAAC,GAAW;IAC/B,OAAO,CAAC,CAAC,eAAK,CAAC,KAAK,CAAC,cAAc,CAAC,GAAG,CAAC,CAAC,CAAC,CAAC;AAC7C,CAAC;AAFD,sBAEC;AAED,SAAgB,GAAG,CAAC,GAAW;IAC7B,OAAO,CAAC,CAAC,eAAK,CAAC,GAAG,CAAC,cAAc,CAAC,GAAG,CAAC,CAAC,CAAC,CAAC;AAC3C,CAAC;AAFD,kBAEC;AAED,SAAgB,GAAG,CAAC,GAAW;IAC7B,OAAO,CAAC,CAAC,eAAK,CAAC,GAAG,CAAC,cAAc,CAAC,GAAG,CAAC,CAAC,CAAC,CAAC;AAC3C,CAAC;AAFD,kBAEC;AAED,SAAgB,MAAM,CAAC,GAAW;IAChC,OAAO,CAAC,CAAC,eAAK,CAAC,MAAM,CAAC,cAAc,CAAC,GAAG,CAAC,CAAC,CAAC,CAAC;AAC9C,CAAC;AAFD,wBAEC;AAED,SAAgB,IAAI,CAAC,GAAW;IAC9B,OAAO,CAAC,CAAC,eAAK,CAAC,IAAI,CAAC,cAAc,CAAC,GAAG,CAAC,CAAC,CAAC,CAAC;AAC5C,CAAC;AAFD,oBAEC;AAED,SAAgB,KAAK,CAAC,GAAQ;IAC5B,OAAO,CAAC,CAAC,eAAK,CAAC,MAAM,CAAC,MAAM,CAAC,cAAc,CAAC,GAAG,CAAC,CAAC,CAAC,CAAC;AACrD,CAAC;AAFD,sBAEC","sourcesContent":["import Chalk from 'chalk';\n\nfunction prepareMessage(msg: unknown): string {\n if (typeof msg === 'string') {\n return msg;\n }\n if (msg instanceof Error) {\n return `${msg.stack || ''}`;\n }\n return JSON.stringify(msg, null, '\\t');\n}\n\nexport function l(msg: string): void {\n // eslint-disable-next-line no-console\n console.log(msg);\n}\n\nexport function nl(): void {\n return l('');\n}\n\nexport function green(msg: string): void {\n return l(Chalk.green(prepareMessage(msg)));\n}\n\nexport function red(msg: string): void {\n return l(Chalk.red(prepareMessage(msg)));\n}\n\nexport function dim(msg: string): void {\n return l(Chalk.dim(prepareMessage(msg)));\n}\n\nexport function yellow(msg: string): void {\n return l(Chalk.yellow(prepareMessage(msg)));\n}\n\nexport function cyan(msg: string): void {\n return l(Chalk.cyan(prepareMessage(msg)));\n}\n\nexport function debug(msg: any): void {\n return l(Chalk.italic.yellow(prepareMessage(msg)));\n}\n"]}
|
|
@@ -1,7 +1,30 @@
|
|
|
1
1
|
"use strict";
|
|
2
|
+
var __createBinding = (this && this.__createBinding) || (Object.create ? (function(o, m, k, k2) {
|
|
3
|
+
if (k2 === undefined) k2 = k;
|
|
4
|
+
var desc = Object.getOwnPropertyDescriptor(m, k);
|
|
5
|
+
if (!desc || ("get" in desc ? !m.__esModule : desc.writable || desc.configurable)) {
|
|
6
|
+
desc = { enumerable: true, get: function() { return m[k]; } };
|
|
7
|
+
}
|
|
8
|
+
Object.defineProperty(o, k2, desc);
|
|
9
|
+
}) : (function(o, m, k, k2) {
|
|
10
|
+
if (k2 === undefined) k2 = k;
|
|
11
|
+
o[k2] = m[k];
|
|
12
|
+
}));
|
|
13
|
+
var __setModuleDefault = (this && this.__setModuleDefault) || (Object.create ? (function(o, v) {
|
|
14
|
+
Object.defineProperty(o, "default", { enumerable: true, value: v });
|
|
15
|
+
}) : function(o, v) {
|
|
16
|
+
o["default"] = v;
|
|
17
|
+
});
|
|
18
|
+
var __importStar = (this && this.__importStar) || function (mod) {
|
|
19
|
+
if (mod && mod.__esModule) return mod;
|
|
20
|
+
var result = {};
|
|
21
|
+
if (mod != null) for (var k in mod) if (k !== "default" && Object.prototype.hasOwnProperty.call(mod, k)) __createBinding(result, mod, k);
|
|
22
|
+
__setModuleDefault(result, mod);
|
|
23
|
+
return result;
|
|
24
|
+
};
|
|
2
25
|
Object.defineProperty(exports, "__esModule", { value: true });
|
|
3
26
|
exports.mergeConfigFile = void 0;
|
|
4
|
-
var fs = require("fs");
|
|
27
|
+
var fs = __importStar(require("fs"));
|
|
5
28
|
// merges the config files
|
|
6
29
|
function mergeConfigFile(sourcePath, templatePath) {
|
|
7
30
|
try {
|
|
@@ -1 +1 @@
|
|
|
1
|
-
{"version":3,"file":"MergeConfig.js","sourceRoot":"","sources":["../../../lib/Helper/MergeConfig.ts"],"names":[],"mappings":"
|
|
1
|
+
{"version":3,"file":"MergeConfig.js","sourceRoot":"","sources":["../../../lib/Helper/MergeConfig.ts"],"names":[],"mappings":";;;;;;;;;;;;;;;;;;;;;;;;;;AAAA,qCAAyB;AAEzB,0BAA0B;AAC1B,SAAgB,eAAe,CAC7B,UAAkB,EAClB,YAAoB;IAEpB,IAAI;QACF,IAAM,YAAY,GAAG,EAAE,CAAC,YAAY,CAAC,YAAY,EAAE,MAAM,CAAC,CAAC;QAC3D,IAAM,UAAU,GAAG,EAAE,CAAC,YAAY,CAAC,UAAU,EAAE,MAAM,CAAC,CAAC;QACvD,IAAM,OAAO,GAAG,YAAY,CAAC,OAAO,CAAC,oBAAoB,EAAE,UAAU,CAAC,CAAC;QACvE,8DAA8D;QAC9D,QAAQ,CAAC,OAAO,CAAC,CAAC,CAAC,wCAAwC;QAC3D,EAAE,CAAC,aAAa,CAAC,UAAU,EAAE,OAAO,CAAC,CAAC;QACtC,OAAO,IAAI,CAAC;KACb;IAAC,OAAO,KAAK,EAAE;QACd,OAAO,KAAK,CAAC;KACd;AACH,CAAC;AAfD,0CAeC","sourcesContent":["import * as fs from 'fs';\n\n// merges the config files\nexport function mergeConfigFile(\n sourcePath: string,\n templatePath: string,\n): boolean {\n try {\n const templateFile = fs.readFileSync(templatePath, 'utf8');\n const sourceFile = fs.readFileSync(sourcePath, 'utf8');\n const newText = templateFile.replace('// ORIGINAL CONFIG', sourceFile);\n // eslint-disable-next-line @typescript-eslint/no-implied-eval\n Function(newText); // check if the file is valid javascript\n fs.writeFileSync(sourcePath, newText);\n return true;\n } catch (error) {\n return false;\n }\n}\n"]}
|
|
@@ -1 +1,10 @@
|
|
|
1
1
|
export declare function checkPackageVersion(appPackage: unknown, packageName: string, acceptableVersions: string, canBeLatest: boolean): boolean;
|
|
2
|
+
/**
|
|
3
|
+
* Determines if the passed `package.json` object has the passed package installed.
|
|
4
|
+
*
|
|
5
|
+
* @param appPackage The `package.json` object
|
|
6
|
+
* @param packageName The name of the package to check for
|
|
7
|
+
*
|
|
8
|
+
* @returns `true` if the package is installed, `false` otherwise
|
|
9
|
+
*/
|
|
10
|
+
export declare function hasPackageInstalled(appPackage: Record<string, any>, packageName: string): boolean;
|
|
@@ -1,7 +1,30 @@
|
|
|
1
1
|
"use strict";
|
|
2
|
+
var __createBinding = (this && this.__createBinding) || (Object.create ? (function(o, m, k, k2) {
|
|
3
|
+
if (k2 === undefined) k2 = k;
|
|
4
|
+
var desc = Object.getOwnPropertyDescriptor(m, k);
|
|
5
|
+
if (!desc || ("get" in desc ? !m.__esModule : desc.writable || desc.configurable)) {
|
|
6
|
+
desc = { enumerable: true, get: function() { return m[k]; } };
|
|
7
|
+
}
|
|
8
|
+
Object.defineProperty(o, k2, desc);
|
|
9
|
+
}) : (function(o, m, k, k2) {
|
|
10
|
+
if (k2 === undefined) k2 = k;
|
|
11
|
+
o[k2] = m[k];
|
|
12
|
+
}));
|
|
13
|
+
var __setModuleDefault = (this && this.__setModuleDefault) || (Object.create ? (function(o, v) {
|
|
14
|
+
Object.defineProperty(o, "default", { enumerable: true, value: v });
|
|
15
|
+
}) : function(o, v) {
|
|
16
|
+
o["default"] = v;
|
|
17
|
+
});
|
|
18
|
+
var __importStar = (this && this.__importStar) || function (mod) {
|
|
19
|
+
if (mod && mod.__esModule) return mod;
|
|
20
|
+
var result = {};
|
|
21
|
+
if (mod != null) for (var k in mod) if (k !== "default" && Object.prototype.hasOwnProperty.call(mod, k)) __createBinding(result, mod, k);
|
|
22
|
+
__setModuleDefault(result, mod);
|
|
23
|
+
return result;
|
|
24
|
+
};
|
|
2
25
|
Object.defineProperty(exports, "__esModule", { value: true });
|
|
3
|
-
exports.checkPackageVersion = void 0;
|
|
4
|
-
var _ = require("lodash");
|
|
26
|
+
exports.hasPackageInstalled = exports.checkPackageVersion = void 0;
|
|
27
|
+
var _ = __importStar(require("lodash"));
|
|
5
28
|
var semver_1 = require("semver");
|
|
6
29
|
var Logging_1 = require("./Logging");
|
|
7
30
|
function checkPackageVersion(appPackage, packageName, acceptableVersions, canBeLatest) {
|
|
@@ -43,4 +66,18 @@ function fulfillsVersionRange(version, acceptableVersions, canBeLatest) {
|
|
|
43
66
|
? (0, semver_1.subset)(cleanedUserVersion, acceptableVersions)
|
|
44
67
|
: (0, semver_1.satisfies)(cleanedUserVersion, acceptableVersions)));
|
|
45
68
|
}
|
|
69
|
+
/**
|
|
70
|
+
* Determines if the passed `package.json` object has the passed package installed.
|
|
71
|
+
*
|
|
72
|
+
* @param appPackage The `package.json` object
|
|
73
|
+
* @param packageName The name of the package to check for
|
|
74
|
+
*
|
|
75
|
+
* @returns `true` if the package is installed, `false` otherwise
|
|
76
|
+
*/
|
|
77
|
+
function hasPackageInstalled(appPackage, packageName) {
|
|
78
|
+
var depsVersion = appPackage.dependencies[packageName];
|
|
79
|
+
var devDepsVersion = appPackage.devDependencies[packageName];
|
|
80
|
+
return !!depsVersion || !!devDepsVersion;
|
|
81
|
+
}
|
|
82
|
+
exports.hasPackageInstalled = hasPackageInstalled;
|
|
46
83
|
//# sourceMappingURL=Package.js.map
|
|
@@ -1 +1 @@
|
|
|
1
|
-
{"version":3,"file":"Package.js","sourceRoot":"","sources":["../../../lib/Helper/Package.ts"],"names":[],"mappings":"
|
|
1
|
+
{"version":3,"file":"Package.js","sourceRoot":"","sources":["../../../lib/Helper/Package.ts"],"names":[],"mappings":";;;;;;;;;;;;;;;;;;;;;;;;;;AAAA,wCAA4B;AAC5B,iCAA8D;AAE9D,qCAAuC;AAEvC,SAAgB,mBAAmB,CACjC,UAAmB,EACnB,WAAmB,EACnB,kBAA0B,EAC1B,WAAoB;IAEpB,IAAM,WAAW,GAAG,CAAC,CAAC,GAAG,CAAC,UAAU,EAAE,CAAC,cAAc,EAAE,WAAW,CAAC,CAAC,CAAC;IACrE,IAAM,cAAc,GAAG,CAAC,CAAC,GAAG,CAAC,UAAU,EAAE,CAAC,iBAAiB,EAAE,WAAW,CAAC,CAAC,CAAC;IAE3E,IAAI,CAAC,WAAW,IAAI,CAAC,cAAc,EAAE;QACnC,IAAA,aAAG,EAAC,iBAAK,WAAW,iCAA8B,CAAC,CAAC;QACpD,IAAA,aAAG,EAAC,oCAAoC,CAAC,CAAC;QAC1C,OAAO,KAAK,CAAC;KACd;SAAM,IACL,CAAC,oBAAoB,CAAC,WAAW,EAAE,kBAAkB,EAAE,WAAW,CAAC;QACnE,CAAC,oBAAoB,CAAC,cAAc,EAAE,kBAAkB,EAAE,WAAW,CAAC,EACtE;QACA,IAAA,aAAG,EACD,6DAAoD,WAAW,uDAA8C,kBAAkB,QAAK,CACrI,CAAC;QACF,OAAO,KAAK,CAAC;KACd;SAAM;QACL,IAAA,eAAK,EACH,0CAA+B,WAAW,sCAAsC,CACjF,CAAC;QACF,OAAO,IAAI,CAAC;KACb;AACH,CAAC;AA3BD,kDA2BC;AAED,SAAS,oBAAoB,CAC3B,OAAe,EACf,kBAA0B,EAC1B,WAAoB;IAEpB,IAAI,OAAO,KAAK,QAAQ,EAAE;QACxB,OAAO,WAAW,CAAC;KACpB;IAED,IAAI,kBAAkB,EAAE,OAAO,CAAC;IAEhC,IAAI,IAAA,cAAK,EAAC,OAAO,CAAC,EAAE;QAClB,kBAAkB,GAAG,IAAA,cAAK,EAAC,OAAO,CAAC,CAAC;QACpC,OAAO,GAAG,KAAK,CAAC;KACjB;SAAM,IAAI,IAAA,mBAAU,EAAC,OAAO,CAAC,EAAE;QAC9B,kBAAkB,GAAG,IAAA,mBAAU,EAAC,OAAO,CAAC,CAAC;QACzC,OAAO,GAAG,IAAI,CAAC;KAChB;IAED,OAAO;IACL,yGAAyG;IACzG,CAAC,CAAC,kBAAkB;QACpB,CAAC,OAAO;YACN,CAAC,CAAC,IAAA,eAAM,EAAC,kBAAkB,EAAE,kBAAkB,CAAC;YAChD,CAAC,CAAC,IAAA,kBAAS,EAAC,kBAAkB,EAAE,kBAAkB,CAAC,CAAC,CACvD,CAAC;AACJ,CAAC;AAED;;;;;;;GAOG;AACH,SAAgB,mBAAmB,CACjC,UAA+B,EAC/B,WAAmB;IAEnB,IAAM,WAAW,GAAG,UAAU,CAAC,YAAY,CAAC,WAAW,CAAC,CAAC;IACzD,IAAM,cAAc,GAAG,UAAU,CAAC,eAAe,CAAC,WAAW,CAAC,CAAC;IAC/D,OAAO,CAAC,CAAC,WAAW,IAAI,CAAC,CAAC,cAAc,CAAC;AAC3C,CAAC;AAPD,kDAOC","sourcesContent":["import * as _ from 'lodash';\nimport { satisfies, subset, valid, validRange } from 'semver';\n\nimport { green, red } from './Logging';\n\nexport function checkPackageVersion(\n appPackage: unknown,\n packageName: string,\n acceptableVersions: string,\n canBeLatest: boolean,\n): boolean {\n const depsVersion = _.get(appPackage, ['dependencies', packageName]);\n const devDepsVersion = _.get(appPackage, ['devDependencies', packageName]);\n\n if (!depsVersion && !devDepsVersion) {\n red(`✗ ${packageName} isn't in your dependencies.`);\n red(' Please install it with yarn/npm.');\n return false;\n } else if (\n !fulfillsVersionRange(depsVersion, acceptableVersions, canBeLatest) &&\n !fulfillsVersionRange(devDepsVersion, acceptableVersions, canBeLatest)\n ) {\n red(\n `✗ Your \\`package.json\\` specifies a version of \\`${packageName}\\` outside of the compatible version range ${acceptableVersions}.\\n`,\n );\n return false;\n } else {\n green(\n `✓ A compatible version of \\`${packageName}\\` is specified in \\`package.json\\`.`,\n );\n return true;\n }\n}\n\nfunction fulfillsVersionRange(\n version: string,\n acceptableVersions: string,\n canBeLatest: boolean,\n): boolean {\n if (version === 'latest') {\n return canBeLatest;\n }\n\n let cleanedUserVersion, isRange;\n\n if (valid(version)) {\n cleanedUserVersion = valid(version);\n isRange = false;\n } else if (validRange(version)) {\n cleanedUserVersion = validRange(version);\n isRange = true;\n }\n\n return (\n // If the given version is a bogus format, this will still be undefined and we'll automatically reject it\n !!cleanedUserVersion &&\n (isRange\n ? subset(cleanedUserVersion, acceptableVersions)\n : satisfies(cleanedUserVersion, acceptableVersions))\n );\n}\n\n/**\n * Determines if the passed `package.json` object has the passed package installed.\n *\n * @param appPackage The `package.json` object\n * @param packageName The name of the package to check for\n *\n * @returns `true` if the package is installed, `false` otherwise\n */\nexport function hasPackageInstalled(\n appPackage: Record<string, any>,\n packageName: string,\n): boolean {\n const depsVersion = appPackage.dependencies[packageName];\n const devDepsVersion = appPackage.devDependencies[packageName];\n return !!depsVersion || !!devDepsVersion;\n}\n"]}
|
|
@@ -1,4 +1,27 @@
|
|
|
1
1
|
"use strict";
|
|
2
|
+
var __createBinding = (this && this.__createBinding) || (Object.create ? (function(o, m, k, k2) {
|
|
3
|
+
if (k2 === undefined) k2 = k;
|
|
4
|
+
var desc = Object.getOwnPropertyDescriptor(m, k);
|
|
5
|
+
if (!desc || ("get" in desc ? !m.__esModule : desc.writable || desc.configurable)) {
|
|
6
|
+
desc = { enumerable: true, get: function() { return m[k]; } };
|
|
7
|
+
}
|
|
8
|
+
Object.defineProperty(o, k2, desc);
|
|
9
|
+
}) : (function(o, m, k, k2) {
|
|
10
|
+
if (k2 === undefined) k2 = k;
|
|
11
|
+
o[k2] = m[k];
|
|
12
|
+
}));
|
|
13
|
+
var __setModuleDefault = (this && this.__setModuleDefault) || (Object.create ? (function(o, v) {
|
|
14
|
+
Object.defineProperty(o, "default", { enumerable: true, value: v });
|
|
15
|
+
}) : function(o, v) {
|
|
16
|
+
o["default"] = v;
|
|
17
|
+
});
|
|
18
|
+
var __importStar = (this && this.__importStar) || function (mod) {
|
|
19
|
+
if (mod && mod.__esModule) return mod;
|
|
20
|
+
var result = {};
|
|
21
|
+
if (mod != null) for (var k in mod) if (k !== "default" && Object.prototype.hasOwnProperty.call(mod, k)) __createBinding(result, mod, k);
|
|
22
|
+
__setModuleDefault(result, mod);
|
|
23
|
+
return result;
|
|
24
|
+
};
|
|
2
25
|
var __awaiter = (this && this.__awaiter) || function (thisArg, _arguments, P, generator) {
|
|
3
26
|
function adopt(value) { return value instanceof P ? value : new P(function (resolve) { resolve(value); }); }
|
|
4
27
|
return new (P || (P = Promise))(function (resolve, reject) {
|
|
@@ -36,14 +59,13 @@ var __generator = (this && this.__generator) || function (thisArg, body) {
|
|
|
36
59
|
}
|
|
37
60
|
};
|
|
38
61
|
Object.defineProperty(exports, "__esModule", { value: true });
|
|
39
|
-
exports.Pnpm = exports.Yarn = exports.Npm = exports.
|
|
62
|
+
exports.Pnpm = exports.Yarn = exports.Npm = exports.getPackageManagerChoice = void 0;
|
|
40
63
|
/* eslint-disable @typescript-eslint/typedef */
|
|
41
64
|
var child_process_1 = require("child_process");
|
|
42
|
-
var fs = require("fs");
|
|
43
|
-
var path = require("path");
|
|
65
|
+
var fs = __importStar(require("fs"));
|
|
66
|
+
var path = __importStar(require("path"));
|
|
44
67
|
var util_1 = require("util");
|
|
45
|
-
|
|
46
|
-
function getPackageMangerChoice() {
|
|
68
|
+
function getPackageManagerChoice() {
|
|
47
69
|
if (fs.existsSync(path.join(process.cwd(), Yarn.LOCK_FILE))) {
|
|
48
70
|
return new Yarn();
|
|
49
71
|
}
|
|
@@ -55,7 +77,7 @@ function getPackageMangerChoice() {
|
|
|
55
77
|
}
|
|
56
78
|
return null;
|
|
57
79
|
}
|
|
58
|
-
exports.
|
|
80
|
+
exports.getPackageManagerChoice = getPackageManagerChoice;
|
|
59
81
|
var Npm = exports.Npm = /** @class */ (function () {
|
|
60
82
|
function Npm() {
|
|
61
83
|
}
|
|
@@ -63,7 +85,7 @@ var Npm = exports.Npm = /** @class */ (function () {
|
|
|
63
85
|
return __awaiter(this, void 0, void 0, function () {
|
|
64
86
|
return __generator(this, function (_a) {
|
|
65
87
|
switch (_a.label) {
|
|
66
|
-
case 0: return [4 /*yield*/, installPackage(Npm.INSTALL_COMMAND, packageName
|
|
88
|
+
case 0: return [4 /*yield*/, installPackage(Npm.INSTALL_COMMAND, packageName)];
|
|
67
89
|
case 1:
|
|
68
90
|
_a.sent();
|
|
69
91
|
return [2 /*return*/];
|
|
@@ -83,7 +105,7 @@ var Yarn = exports.Yarn = /** @class */ (function () {
|
|
|
83
105
|
return __awaiter(this, void 0, void 0, function () {
|
|
84
106
|
return __generator(this, function (_a) {
|
|
85
107
|
switch (_a.label) {
|
|
86
|
-
case 0: return [4 /*yield*/, installPackage(Yarn.INSTALL_COMMAND, packageName
|
|
108
|
+
case 0: return [4 /*yield*/, installPackage(Yarn.INSTALL_COMMAND, packageName)];
|
|
87
109
|
case 1:
|
|
88
110
|
_a.sent();
|
|
89
111
|
return [2 /*return*/];
|
|
@@ -103,7 +125,7 @@ var Pnpm = exports.Pnpm = /** @class */ (function () {
|
|
|
103
125
|
return __awaiter(this, void 0, void 0, function () {
|
|
104
126
|
return __generator(this, function (_a) {
|
|
105
127
|
switch (_a.label) {
|
|
106
|
-
case 0: return [4 /*yield*/, installPackage(Pnpm.INSTALL_COMMAND, packageName
|
|
128
|
+
case 0: return [4 /*yield*/, installPackage(Pnpm.INSTALL_COMMAND, packageName)];
|
|
107
129
|
case 1:
|
|
108
130
|
_a.sent();
|
|
109
131
|
return [2 /*return*/];
|
|
@@ -116,14 +138,13 @@ var Pnpm = exports.Pnpm = /** @class */ (function () {
|
|
|
116
138
|
Pnpm.INSTALL_COMMAND = 'pnpm add';
|
|
117
139
|
return Pnpm;
|
|
118
140
|
}());
|
|
119
|
-
function installPackage(command, packageName
|
|
141
|
+
function installPackage(command, packageName) {
|
|
120
142
|
return __awaiter(this, void 0, void 0, function () {
|
|
121
143
|
return __generator(this, function (_a) {
|
|
122
144
|
switch (_a.label) {
|
|
123
145
|
case 0: return [4 /*yield*/, (0, util_1.promisify)(child_process_1.exec)("".concat(command, " ").concat(packageName))];
|
|
124
146
|
case 1:
|
|
125
147
|
_a.sent();
|
|
126
|
-
(0, Logging_1.green)("\u2713 Added `".concat(packageName, "` using `").concat(label, "`."));
|
|
127
148
|
return [2 /*return*/];
|
|
128
149
|
}
|
|
129
150
|
});
|
|
@@ -1 +1 @@
|
|
|
1
|
-
{"version":3,"file":"PackageManager.js","sourceRoot":"","sources":["../../../lib/Helper/PackageManager.ts"],"names":[],"mappings":"
|
|
1
|
+
{"version":3,"file":"PackageManager.js","sourceRoot":"","sources":["../../../lib/Helper/PackageManager.ts"],"names":[],"mappings":";;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;AAAA,+CAA+C;AAC/C,+CAAqC;AACrC,qCAAyB;AACzB,yCAA6B;AAC7B,6BAAiC;AAEjC,SAAgB,uBAAuB;IACrC,IAAI,EAAE,CAAC,UAAU,CAAC,IAAI,CAAC,IAAI,CAAC,OAAO,CAAC,GAAG,EAAE,EAAE,IAAI,CAAC,SAAS,CAAC,CAAC,EAAE;QAC3D,OAAO,IAAI,IAAI,EAAE,CAAC;KACnB;IACD,IAAI,EAAE,CAAC,UAAU,CAAC,IAAI,CAAC,IAAI,CAAC,OAAO,CAAC,GAAG,EAAE,EAAE,IAAI,CAAC,SAAS,CAAC,CAAC,EAAE;QAC3D,OAAO,IAAI,IAAI,EAAE,CAAC;KACnB;IACD,IAAI,EAAE,CAAC,UAAU,CAAC,IAAI,CAAC,IAAI,CAAC,OAAO,CAAC,GAAG,EAAE,EAAE,GAAG,CAAC,SAAS,CAAC,CAAC,EAAE;QAC1D,OAAO,IAAI,GAAG,EAAE,CAAC;KAClB;IACD,OAAO,IAAI,CAAC;AACd,CAAC;AAXD,0DAWC;AAMD;IAAA;IAQA,CAAC;IAHc,4BAAc,GAA3B,UAA4B,WAAmB;;;;4BAC7C,qBAAM,cAAc,CAAC,GAAG,CAAC,eAAe,EAAE,WAAW,CAAC,EAAA;;wBAAtD,SAAsD,CAAC;;;;;KACxD;IANa,aAAS,GAAG,mBAAmB,CAAC;IAChC,SAAK,GAAG,KAAK,CAAC;IACd,mBAAe,GAAG,aAAa,CAAC;IAKhD,UAAC;CAAA,AARD,IAQC;AAED;IAAA;IAQA,CAAC;IAHc,6BAAc,GAA3B,UAA4B,WAAmB;;;;4BAC7C,qBAAM,cAAc,CAAC,IAAI,CAAC,eAAe,EAAE,WAAW,CAAC,EAAA;;wBAAvD,SAAuD,CAAC;;;;;KACzD;IANa,cAAS,GAAG,WAAW,CAAC;IACxB,UAAK,GAAG,MAAM,CAAC;IACf,oBAAe,GAAG,UAAU,CAAC;IAK7C,WAAC;CAAA,AARD,IAQC;AAED;IAAA;IAQA,CAAC;IAHc,6BAAc,GAA3B,UAA4B,WAAmB;;;;4BAC7C,qBAAM,cAAc,CAAC,IAAI,CAAC,eAAe,EAAE,WAAW,CAAC,EAAA;;wBAAvD,SAAuD,CAAC;;;;;KACzD;IANa,cAAS,GAAG,gBAAgB,CAAC;IAC7B,UAAK,GAAG,MAAM,CAAC;IACf,oBAAe,GAAG,UAAU,CAAC;IAK7C,WAAC;CAAA,AARD,IAQC;AAED,SAAe,cAAc,CAC3B,OAAe,EACf,WAAmB;;;;wBAEnB,qBAAM,IAAA,gBAAS,EAAC,oBAAI,CAAC,CAAC,UAAG,OAAO,cAAI,WAAW,CAAE,CAAC,EAAA;;oBAAlD,SAAkD,CAAC;;;;;CACpD","sourcesContent":["/* eslint-disable @typescript-eslint/typedef */\nimport { exec } from 'child_process';\nimport * as fs from 'fs';\nimport * as path from 'path';\nimport { promisify } from 'util';\n\nexport function getPackageManagerChoice(): PackageManager | null {\n if (fs.existsSync(path.join(process.cwd(), Yarn.LOCK_FILE))) {\n return new Yarn();\n }\n if (fs.existsSync(path.join(process.cwd(), Pnpm.LOCK_FILE))) {\n return new Pnpm();\n }\n if (fs.existsSync(path.join(process.cwd(), Npm.LOCK_FILE))) {\n return new Npm();\n }\n return null;\n}\n\nexport interface PackageManager {\n installPackage(packageName: string): Promise<void>;\n}\n\nexport class Npm implements PackageManager {\n public static LOCK_FILE = 'package-lock.json';\n public static LABEL = 'npm';\n public static INSTALL_COMMAND = 'npm install';\n\n public async installPackage(packageName: string): Promise<void> {\n await installPackage(Npm.INSTALL_COMMAND, packageName);\n }\n}\n\nexport class Yarn implements PackageManager {\n public static LOCK_FILE = 'yarn.lock';\n public static LABEL = 'yarn';\n public static INSTALL_COMMAND = 'yarn add';\n\n public async installPackage(packageName: string): Promise<void> {\n await installPackage(Yarn.INSTALL_COMMAND, packageName);\n }\n}\n\nexport class Pnpm implements PackageManager {\n public static LOCK_FILE = 'pnpm-lock.yaml';\n public static LABEL = 'pnpm';\n public static INSTALL_COMMAND = 'pnpm add';\n\n public async installPackage(packageName: string): Promise<void> {\n await installPackage(Pnpm.INSTALL_COMMAND, packageName);\n }\n}\n\nasync function installPackage(\n command: string,\n packageName: string,\n): Promise<void> {\n await promisify(exec)(`${command} ${packageName}`);\n}\n"]}
|
|
@@ -13,5 +13,16 @@ export declare class SentryCli {
|
|
|
13
13
|
/** Create the contents of a `sentry.properties` file */
|
|
14
14
|
dumpProperties(props: SentryCliProps): string;
|
|
15
15
|
dumpConfig(config: SentryCliConfig): string;
|
|
16
|
+
/**
|
|
17
|
+
* Creates `.sentryclirc` and `sentry.properties` files with the CLI properties
|
|
18
|
+
* obtained from the user answers (or from logging into Sentry).
|
|
19
|
+
* The `.sentryclirc` only contains the auth token and will be added to the
|
|
20
|
+
* user's `.gitignore` file. The properties file contains the rest of the
|
|
21
|
+
* properties (org, project, etc.).
|
|
22
|
+
*
|
|
23
|
+
* @param sentryCli instance of the Sentry CLI
|
|
24
|
+
* @param cliProps the properties to write to the files
|
|
25
|
+
*/
|
|
26
|
+
createSentryCliConfig(cliProps: SentryCliProps): Promise<void>;
|
|
16
27
|
}
|
|
17
28
|
export {};
|