@akylas/nativescript-cli 8.8.2 → 8.8.3
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/lib/android-tools-info.js +9 -20
- package/lib/base-package-manager.js +47 -64
- package/lib/bun-package-manager.js +65 -88
- package/lib/color.js +2 -2
- package/lib/commands/add-platform.js +14 -30
- package/lib/commands/apple-login.js +18 -29
- package/lib/commands/appstore-list.js +34 -45
- package/lib/commands/appstore-upload.js +55 -68
- package/lib/commands/build.js +57 -86
- package/lib/commands/clean.js +161 -176
- package/lib/commands/command-base.js +14 -27
- package/lib/commands/config.js +51 -70
- package/lib/commands/create-project.js +210 -229
- package/lib/commands/debug.js +66 -88
- package/lib/commands/deploy.js +28 -44
- package/lib/commands/embedding/embed.js +33 -52
- package/lib/commands/extensibility/install-extension.js +5 -16
- package/lib/commands/extensibility/list-extensions.js +13 -24
- package/lib/commands/extensibility/uninstall-extension.js +4 -15
- package/lib/commands/fonts.js +30 -41
- package/lib/commands/generate-assets.js +13 -28
- package/lib/commands/generate-help.js +2 -13
- package/lib/commands/generate.js +17 -26
- package/lib/commands/info.js +2 -13
- package/lib/commands/install.js +34 -49
- package/lib/commands/list-platforms.js +14 -25
- package/lib/commands/migrate.js +15 -26
- package/lib/commands/native-add.js +23 -46
- package/lib/commands/platform-clean.js +19 -32
- package/lib/commands/plugin/add-plugin.js +12 -25
- package/lib/commands/plugin/build-plugin.js +34 -39
- package/lib/commands/plugin/create-plugin.js +110 -133
- package/lib/commands/plugin/list-plugins.js +22 -33
- package/lib/commands/plugin/remove-plugin.js +20 -33
- package/lib/commands/plugin/update-plugin.js +20 -33
- package/lib/commands/post-install.js +20 -33
- package/lib/commands/prepare.js +19 -35
- package/lib/commands/preview.js +49 -62
- package/lib/commands/remove-platform.js +7 -18
- package/lib/commands/resources/resources-update.js +13 -26
- package/lib/commands/run.js +55 -76
- package/lib/commands/start.js +6 -19
- package/lib/commands/test-init.js +123 -134
- package/lib/commands/test.js +66 -89
- package/lib/commands/typings.js +126 -142
- package/lib/commands/update-platform.js +22 -35
- package/lib/commands/update.js +30 -43
- package/lib/common/child-process.js +53 -72
- package/lib/common/codeGeneration/code-entity.js +1 -1
- package/lib/common/codeGeneration/code-printer.js +1 -1
- package/lib/common/command-params.js +7 -18
- package/lib/common/commands/analytics.js +27 -40
- package/lib/common/commands/autocompletion.js +39 -56
- package/lib/common/commands/device/device-log-stream.js +12 -23
- package/lib/common/commands/device/get-file.js +22 -33
- package/lib/common/commands/device/list-applications.js +12 -23
- package/lib/common/commands/device/list-devices.js +72 -87
- package/lib/common/commands/device/list-files.js +23 -34
- package/lib/common/commands/device/put-file.js +22 -33
- package/lib/common/commands/device/run-application.js +12 -25
- package/lib/common/commands/device/stop-application.js +11 -22
- package/lib/common/commands/device/uninstall-application.js +6 -17
- package/lib/common/commands/generate-messages.js +17 -28
- package/lib/common/commands/help.js +20 -33
- package/lib/common/commands/package-manager-get.js +6 -17
- package/lib/common/commands/package-manager-set.js +9 -20
- package/lib/common/commands/post-install.js +2 -13
- package/lib/common/commands/preuninstall.js +23 -38
- package/lib/common/commands/proxy/proxy-base.js +8 -19
- package/lib/common/commands/proxy/proxy-clear.js +4 -15
- package/lib/common/commands/proxy/proxy-get.js +3 -14
- package/lib/common/commands/proxy/proxy-set.js +87 -100
- package/lib/common/constants.js +11 -11
- package/lib/common/decorators.js +10 -22
- package/lib/common/dispatchers.js +79 -96
- package/lib/common/errors.js +89 -104
- package/lib/common/file-system.js +106 -127
- package/lib/common/header.js +1 -2
- package/lib/common/helpers.js +149 -178
- package/lib/common/host-info.js +37 -50
- package/lib/common/http-client.js +93 -108
- package/lib/common/logger/appenders/cli-appender.js +1 -2
- package/lib/common/logger/appenders/emit-appender.js +1 -2
- package/lib/common/logger/layouts/cli-layout.js +1 -2
- package/lib/common/logger/logger.js +1 -1
- package/lib/common/mobile/android/android-application-manager.js +121 -142
- package/lib/common/mobile/android/android-debug-bridge-result-handler.js +1 -1
- package/lib/common/mobile/android/android-debug-bridge.js +87 -112
- package/lib/common/mobile/android/android-device-file-system.js +98 -131
- package/lib/common/mobile/android/android-device-hash-service.js +50 -75
- package/lib/common/mobile/android/android-device.js +74 -91
- package/lib/common/mobile/android/android-emulator-services.js +105 -130
- package/lib/common/mobile/android/android-log-filter.js +1 -1
- package/lib/common/mobile/android/android-virtual-device-service.js +76 -97
- package/lib/common/mobile/android/device-android-debug-bridge.js +13 -29
- package/lib/common/mobile/android/genymotion/genymotion-service.js +91 -118
- package/lib/common/mobile/android/genymotion/virtualbox-service.js +64 -81
- package/lib/common/mobile/android/logcat-helper.js +108 -127
- package/lib/common/mobile/application-manager-base.js +84 -107
- package/lib/common/mobile/device-log-provider-base.js +7 -18
- package/lib/common/mobile/ios/device/ios-application-manager.js +79 -108
- package/lib/common/mobile/ios/device/ios-device-file-system.js +78 -105
- package/lib/common/mobile/ios/device/ios-device-operations.js +105 -142
- package/lib/common/mobile/ios/device/ios-device.js +20 -36
- package/lib/common/mobile/ios/ios-device-base.js +58 -81
- package/lib/common/mobile/ios/simulator/ios-emulator-services.js +63 -92
- package/lib/common/mobile/ios/simulator/ios-sim-resolver.js +1 -1
- package/lib/common/mobile/ios/simulator/ios-simulator-application-manager.js +60 -89
- package/lib/common/mobile/ios/simulator/ios-simulator-device.js +27 -43
- package/lib/common/mobile/ios/simulator/ios-simulator-file-system.js +37 -62
- package/lib/common/mobile/ios/simulator/ios-simulator-log-provider.js +24 -35
- package/lib/common/mobile/mobile-core/android-device-discovery.js +43 -62
- package/lib/common/mobile/mobile-core/android-emulator-discovery.js +21 -32
- package/lib/common/mobile/mobile-core/android-process-service.js +143 -182
- package/lib/common/mobile/mobile-core/device-discovery.js +2 -13
- package/lib/common/mobile/mobile-core/devices-service.js +385 -436
- package/lib/common/mobile/mobile-core/ios-device-discovery.js +24 -35
- package/lib/common/mobile/mobile-core/ios-simulator-discovery.js +47 -62
- package/lib/common/mobile/mobile-helper.js +15 -26
- package/lib/common/mobile/wp8/wp8-emulator-services.js +25 -52
- package/lib/common/opener.js +2 -2
- package/lib/common/plist-parser.js +2 -2
- package/lib/common/prompter.js +90 -105
- package/lib/common/queue.js +9 -20
- package/lib/common/services/auto-completion-service.js +39 -52
- package/lib/common/services/cancellation.js +17 -28
- package/lib/common/services/commands-service.js +146 -169
- package/lib/common/services/help-service.js +132 -157
- package/lib/common/services/hooks-service.js +93 -108
- package/lib/common/services/ios-notification-service.js +21 -34
- package/lib/common/services/json-file-settings-service.js +52 -71
- package/lib/common/services/lock-service.js +35 -52
- package/lib/common/services/message-contract-generator.js +35 -46
- package/lib/common/services/micro-templating-service.js +4 -15
- package/lib/common/services/net-service.js +90 -107
- package/lib/common/services/project-files-manager.js +10 -23
- package/lib/common/services/proxy-service.js +13 -24
- package/lib/common/services/qr.js +13 -24
- package/lib/common/services/settings-service.js +1 -1
- package/lib/common/services/xcode-select-service.js +20 -35
- package/lib/common/utils.js +2 -2
- package/lib/common/validators/project-name-validator.js +1 -1
- package/lib/common/validators/validation-result.js +1 -1
- package/lib/common/verify-node-version.js +2 -3
- package/lib/common/yok.js +23 -36
- package/lib/config.js +7 -58
- package/lib/constants.js +24 -24
- package/lib/controllers/build-controller.js +82 -99
- package/lib/controllers/debug-controller.js +107 -128
- package/lib/controllers/deploy-controller.js +17 -22
- package/lib/controllers/migrate-controller.js +722 -795
- package/lib/controllers/platform-controller.js +72 -87
- package/lib/controllers/prepare-controller.js +266 -299
- package/lib/controllers/run-controller.js +392 -406
- package/lib/controllers/update-controller-base.js +16 -29
- package/lib/controllers/update-controller.js +94 -119
- package/lib/data/prepare-data.js +4 -1
- package/lib/definitions/ios-debugger-port-service.d.ts +1 -1
- package/lib/definitions/livesync.d.ts +1 -1
- package/lib/detached-processes/cleanup-js-subprocess.js +3 -12
- package/lib/detached-processes/cleanup-process.js +16 -25
- package/lib/device-path-provider.js +23 -34
- package/lib/device-sockets/ios/app-debug-socket-proxy-factory.js +149 -164
- package/lib/device-sockets/ios/notification.js +1 -1
- package/lib/device-sockets/ios/socket-request-executor.js +24 -39
- package/lib/helpers/android-bundle-validator-helper.js +1 -1
- package/lib/helpers/deploy-command-helper.js +45 -49
- package/lib/helpers/key-command-helper.js +4 -13
- package/lib/helpers/livesync-command-helper.js +137 -152
- package/lib/helpers/network-connectivity-validator.js +6 -17
- package/lib/helpers/options-track-helper.js +6 -17
- package/lib/helpers/platform-command-helper.js +99 -120
- package/lib/key-commands/index.js +161 -211
- package/lib/nativescript-cli.js +5 -14
- package/lib/node-package-manager.js +81 -104
- package/lib/options.js +3 -12
- package/lib/package-installation-manager.js +130 -165
- package/lib/package-manager.js +63 -86
- package/lib/platform-command-param.js +4 -15
- package/lib/pnpm-package-manager.js +59 -78
- package/lib/project-data.js +1 -1
- package/lib/providers/project-files-provider.js +1 -1
- package/lib/services/analytics/analytics-broker-process.js +13 -22
- package/lib/services/analytics/analytics-broker.js +17 -30
- package/lib/services/analytics/analytics-service.js +161 -198
- package/lib/services/analytics/google-analytics-provider.js +41 -56
- package/lib/services/analytics-settings-service.js +15 -32
- package/lib/services/android/android-bundle-tool-service.js +43 -60
- package/lib/services/android/gradle-build-args-service.js +9 -20
- package/lib/services/android/gradle-build-service.js +34 -47
- package/lib/services/android/gradle-command-service.js +22 -35
- package/lib/services/android-device-debug-service.js +90 -117
- package/lib/services/android-plugin-build-service.js +230 -256
- package/lib/services/android-project-service.js +163 -199
- package/lib/services/android-resources-migration-service.js +51 -64
- package/lib/services/apple-portal/apple-portal-application-service.js +46 -63
- package/lib/services/apple-portal/apple-portal-session-service.js +171 -188
- package/lib/services/assets-generation/assets-generation-service.js +98 -115
- package/lib/services/build-artifacts-service.js +9 -20
- package/lib/services/build-info-file-service.js +20 -35
- package/lib/services/cleanup-service.js +47 -76
- package/lib/services/cocoapods-service.js +115 -136
- package/lib/services/device/device-install-app-service.js +73 -90
- package/lib/services/doctor-service.js +99 -118
- package/lib/services/extensibility-service.js +81 -100
- package/lib/services/files-hash-service.js +26 -43
- package/lib/services/hmr-status-service.js +1 -1
- package/lib/services/initialize-service.js +37 -50
- package/lib/services/ios/export-options-plist-service.js +38 -51
- package/lib/services/ios/ios-signing-service.js +161 -180
- package/lib/services/ios/spm-service.js +40 -53
- package/lib/services/ios/xcodebuild-args-service.js +77 -94
- package/lib/services/ios/xcodebuild-command-service.js +14 -25
- package/lib/services/ios/xcodebuild-service.js +50 -69
- package/lib/services/ios-debugger-port-service.js +23 -36
- package/lib/services/ios-device-debug-service.js +75 -102
- package/lib/services/ios-entitlements-service.js +31 -42
- package/lib/services/ios-extensions-service.js +18 -29
- package/lib/services/ios-project-service.js +405 -460
- package/lib/services/ios-provision-service.js +108 -129
- package/lib/services/ios-watch-app-service.js +21 -32
- package/lib/services/ip-service.js +38 -53
- package/lib/services/itmstransporter-service.js +129 -152
- package/lib/services/livesync/android-device-livesync-service-base.js +31 -48
- package/lib/services/livesync/android-device-livesync-service.js +120 -149
- package/lib/services/livesync/android-device-livesync-sockets-service.js +121 -152
- package/lib/services/livesync/android-livesync-service.js +14 -35
- package/lib/services/livesync/android-livesync-tool.js +89 -112
- package/lib/services/livesync/device-livesync-service-base.js +15 -28
- package/lib/services/livesync/ios-device-livesync-service.js +114 -143
- package/lib/services/livesync/ios-livesync-service.js +42 -58
- package/lib/services/livesync/platform-livesync-service-base.js +94 -119
- package/lib/services/log-parser-service.js +1 -1
- package/lib/services/log-source-map-service.js +30 -41
- package/lib/services/marking-mode-service.js +15 -28
- package/lib/services/npm-config-service.js +1 -1
- package/lib/services/pacote-service.js +49 -64
- package/lib/services/performance-service.js +1 -1
- package/lib/services/platform/add-platform-service.js +50 -71
- package/lib/services/platform/platform-validation-service.js +22 -33
- package/lib/services/platform/prepare-native-platform-service.js +49 -62
- package/lib/services/platform-environment-requirements.js +26 -37
- package/lib/services/plugins-service.js +122 -147
- package/lib/services/project-backup-service.js +1 -1
- package/lib/services/project-changes-service.js +124 -141
- package/lib/services/project-cleanup-service.js +64 -77
- package/lib/services/project-config-service.js +71 -80
- package/lib/services/project-data-service.js +101 -118
- package/lib/services/project-name-service.js +28 -43
- package/lib/services/project-service.js +84 -103
- package/lib/services/project-templates-service.js +52 -67
- package/lib/services/start-service.js +41 -59
- package/lib/services/temp-service.js +8 -21
- package/lib/services/terminal-spinner-service.js +13 -24
- package/lib/services/test-execution-service.js +59 -72
- package/lib/services/test-initialization-service.js +2 -2
- package/lib/services/timeline-profiler-service.js +1 -1
- package/lib/services/versions-service.js +119 -138
- package/lib/services/webpack/webpack-compiler-service.js +211 -231
- package/lib/services/xcconfig-service.js +8 -19
- package/lib/sys-info.js +45 -62
- package/lib/tools/node-modules/node-modules-builder.js +16 -27
- package/lib/yarn-package-manager.js +59 -78
- package/lib/yarn2-package-manager.js +60 -79
- package/package.json +57 -55
- package/vendor/aab-tool/bundletool.jar +0 -0
- package/lib/common/resources/platform-tools/android/darwin/NOTICE.txt +0 -3407
- package/lib/common/resources/platform-tools/android/darwin/adb +0 -0
- package/lib/common/resources/platform-tools/android/linux/NOTICE.txt +0 -4451
- package/lib/common/resources/platform-tools/android/linux/adb +0 -0
- package/lib/common/resources/platform-tools/android/win32/AdbWinApi.dll +0 -0
- package/lib/common/resources/platform-tools/android/win32/AdbWinUsbApi.dll +0 -0
- package/lib/common/resources/platform-tools/android/win32/NOTICE.txt +0 -4451
- package/lib/common/resources/platform-tools/android/win32/adb.exe +0 -0
- package/lib/common/resources/platform-tools/android/win32/fastboot.exe +0 -0
|
@@ -5,15 +5,6 @@ var __decorate = (this && this.__decorate) || function (decorators, target, key,
|
|
|
5
5
|
else for (var i = decorators.length - 1; i >= 0; i--) if (d = decorators[i]) r = (c < 3 ? d(r) : c > 3 ? d(target, key, r) : d(target, key)) || r;
|
|
6
6
|
return c > 3 && r && Object.defineProperty(target, key, r), r;
|
|
7
7
|
};
|
|
8
|
-
var __awaiter = (this && this.__awaiter) || function (thisArg, _arguments, P, generator) {
|
|
9
|
-
function adopt(value) { return value instanceof P ? value : new P(function (resolve) { resolve(value); }); }
|
|
10
|
-
return new (P || (P = Promise))(function (resolve, reject) {
|
|
11
|
-
function fulfilled(value) { try { step(generator.next(value)); } catch (e) { reject(e); } }
|
|
12
|
-
function rejected(value) { try { step(generator["throw"](value)); } catch (e) { reject(e); } }
|
|
13
|
-
function step(result) { result.done ? resolve(result.value) : adopt(result.value).then(fulfilled, rejected); }
|
|
14
|
-
step((generator = generator.apply(thisArg, _arguments || [])).next());
|
|
15
|
-
});
|
|
16
|
-
};
|
|
17
8
|
Object.defineProperty(exports, "__esModule", { value: true });
|
|
18
9
|
exports.ITMSTransporterService = void 0;
|
|
19
10
|
const path = require("path");
|
|
@@ -36,160 +27,146 @@ class ITMSTransporterService {
|
|
|
36
27
|
get $projectData() {
|
|
37
28
|
return this.$injector.resolve("projectData");
|
|
38
29
|
}
|
|
39
|
-
validate(appSpecificPassword) {
|
|
40
|
-
|
|
41
|
-
|
|
42
|
-
|
|
43
|
-
if (
|
|
44
|
-
|
|
45
|
-
this.$errors.fail("iTMS Transporter not found on this machine - make sure your Xcode installation is not damaged.");
|
|
46
|
-
}
|
|
47
|
-
}
|
|
48
|
-
else {
|
|
49
|
-
const altoolPath = yield this.getAltoolPath();
|
|
50
|
-
if (!this.$fs.exists(altoolPath)) {
|
|
51
|
-
this.$errors.fail("altool not found on this machine - make sure your Xcode installation is not damaged.");
|
|
52
|
-
}
|
|
53
|
-
if (!appSpecificPassword) {
|
|
54
|
-
this.$errors.fail("An app-specific password is required from xCode versions 14 and above, Use the --appleApplicationSpecificPassword to supply it.");
|
|
55
|
-
}
|
|
30
|
+
async validate(appSpecificPassword) {
|
|
31
|
+
const itmsTransporterPath = await this.getITMSTransporterPath();
|
|
32
|
+
const version = await this.$xcodeSelectService.getXcodeVersion();
|
|
33
|
+
if (+version.major < 14) {
|
|
34
|
+
if (!this.$fs.exists(itmsTransporterPath)) {
|
|
35
|
+
this.$errors.fail("iTMS Transporter not found on this machine - make sure your Xcode installation is not damaged.");
|
|
56
36
|
}
|
|
57
|
-
}
|
|
58
|
-
|
|
59
|
-
|
|
60
|
-
|
|
61
|
-
|
|
62
|
-
if (+version.major < 14) {
|
|
63
|
-
yield this.upload_iTMSTransporter(data);
|
|
37
|
+
}
|
|
38
|
+
else {
|
|
39
|
+
const altoolPath = await this.getAltoolPath();
|
|
40
|
+
if (!this.$fs.exists(altoolPath)) {
|
|
41
|
+
this.$errors.fail("altool not found on this machine - make sure your Xcode installation is not damaged.");
|
|
64
42
|
}
|
|
65
|
-
|
|
66
|
-
|
|
43
|
+
if (!appSpecificPassword) {
|
|
44
|
+
this.$errors.fail("An app-specific password is required from xCode versions 14 and above, Use the --appleApplicationSpecificPassword to supply it.");
|
|
67
45
|
}
|
|
46
|
+
}
|
|
47
|
+
}
|
|
48
|
+
async upload(data) {
|
|
49
|
+
const version = await this.$xcodeSelectService.getXcodeVersion();
|
|
50
|
+
if (+version.major < 14) {
|
|
51
|
+
await this.upload_iTMSTransporter(data);
|
|
52
|
+
}
|
|
53
|
+
else {
|
|
54
|
+
await this.upload_altool(data);
|
|
55
|
+
}
|
|
56
|
+
}
|
|
57
|
+
async upload_iTMSTransporter(data) {
|
|
58
|
+
const itmsTransporterPath = await this.getITMSTransporterPath();
|
|
59
|
+
const ipaFileName = "app.ipa";
|
|
60
|
+
const itmsDirectory = await this.$tempService.mkdirSync("itms-");
|
|
61
|
+
const innerDirectory = path.join(itmsDirectory, "mybundle.itmsp");
|
|
62
|
+
const ipaFileLocation = path.join(innerDirectory, ipaFileName);
|
|
63
|
+
const loggingLevel = data.verboseLogging
|
|
64
|
+
? constants_1.ITMSConstants.VerboseLoggingLevels.Verbose
|
|
65
|
+
: constants_1.ITMSConstants.VerboseLoggingLevels.Informational;
|
|
66
|
+
const bundleId = await this.getBundleIdentifier(data);
|
|
67
|
+
const application = await this.$applePortalApplicationService.getApplicationByBundleId(data.user, bundleId);
|
|
68
|
+
this.$fs.createDirectory(innerDirectory);
|
|
69
|
+
this.$fs.copyFile(data.ipaFilePath, ipaFileLocation);
|
|
70
|
+
const ipaFileHash = await this.$fs.getFileShasum(ipaFileLocation, {
|
|
71
|
+
algorithm: "md5",
|
|
68
72
|
});
|
|
73
|
+
const ipaFileSize = this.$fs.getFileSize(ipaFileLocation);
|
|
74
|
+
const metadata = this.getITMSMetadataXml(application.adamId, ipaFileName, ipaFileHash, ipaFileSize);
|
|
75
|
+
this.$fs.writeFile(path.join(innerDirectory, constants_1.ITMSConstants.ApplicationMetadataFile), metadata);
|
|
76
|
+
const password = data.user.isTwoFactorAuthenticationEnabled
|
|
77
|
+
? data.applicationSpecificPassword
|
|
78
|
+
: data.credentials.password;
|
|
79
|
+
await this.$childProcess.spawnFromEvent(itmsTransporterPath, [
|
|
80
|
+
"-m",
|
|
81
|
+
"upload",
|
|
82
|
+
"-f",
|
|
83
|
+
itmsDirectory,
|
|
84
|
+
"-u",
|
|
85
|
+
(0, helpers_1.quoteString)(data.credentials.username),
|
|
86
|
+
"-p",
|
|
87
|
+
(0, helpers_1.quoteString)(password),
|
|
88
|
+
"-v",
|
|
89
|
+
loggingLevel,
|
|
90
|
+
], "close", { stdio: "inherit" });
|
|
69
91
|
}
|
|
70
|
-
|
|
71
|
-
|
|
72
|
-
|
|
73
|
-
|
|
74
|
-
|
|
75
|
-
|
|
76
|
-
|
|
77
|
-
|
|
78
|
-
|
|
79
|
-
|
|
80
|
-
|
|
81
|
-
|
|
82
|
-
|
|
83
|
-
|
|
84
|
-
|
|
85
|
-
|
|
86
|
-
|
|
87
|
-
|
|
88
|
-
|
|
89
|
-
|
|
90
|
-
|
|
91
|
-
|
|
92
|
-
|
|
93
|
-
|
|
94
|
-
|
|
95
|
-
|
|
96
|
-
|
|
97
|
-
|
|
98
|
-
|
|
99
|
-
|
|
100
|
-
"-p",
|
|
101
|
-
(0, helpers_1.quoteString)(password),
|
|
102
|
-
"-v",
|
|
103
|
-
loggingLevel,
|
|
104
|
-
], "close", { stdio: "inherit" });
|
|
92
|
+
async upload_altool(data) {
|
|
93
|
+
const altoolPath = await this.getAltoolPath();
|
|
94
|
+
const ipaFileName = "app.ipa";
|
|
95
|
+
const itmsDirectory = await this.$tempService.mkdirSync("itms-");
|
|
96
|
+
const innerDirectory = path.join(itmsDirectory, "mybundle.itmsp");
|
|
97
|
+
const ipaFileLocation = path.join(innerDirectory, ipaFileName);
|
|
98
|
+
this.$fs.createDirectory(innerDirectory);
|
|
99
|
+
this.$fs.copyFile(data.ipaFilePath, ipaFileLocation);
|
|
100
|
+
const password = data.applicationSpecificPassword;
|
|
101
|
+
const args = [
|
|
102
|
+
"--upload-app",
|
|
103
|
+
"-t",
|
|
104
|
+
"ios",
|
|
105
|
+
"-f",
|
|
106
|
+
ipaFileLocation,
|
|
107
|
+
"-u",
|
|
108
|
+
data.credentials.username,
|
|
109
|
+
"-p",
|
|
110
|
+
password,
|
|
111
|
+
"-k 100000",
|
|
112
|
+
];
|
|
113
|
+
if (data.teamId) {
|
|
114
|
+
args.push("--asc-provider");
|
|
115
|
+
args.push(data.teamId);
|
|
116
|
+
}
|
|
117
|
+
if (data.verboseLogging) {
|
|
118
|
+
args.push("--verbose");
|
|
119
|
+
}
|
|
120
|
+
await this.$childProcess.spawnFromEvent(altoolPath, args, "close", {
|
|
121
|
+
stdio: "inherit",
|
|
105
122
|
});
|
|
106
123
|
}
|
|
107
|
-
|
|
108
|
-
|
|
109
|
-
|
|
110
|
-
|
|
111
|
-
|
|
112
|
-
|
|
113
|
-
const ipaFileLocation = path.join(innerDirectory, ipaFileName);
|
|
114
|
-
this.$fs.createDirectory(innerDirectory);
|
|
115
|
-
this.$fs.copyFile(data.ipaFilePath, ipaFileLocation);
|
|
116
|
-
const password = data.applicationSpecificPassword;
|
|
117
|
-
const args = [
|
|
118
|
-
"--upload-app",
|
|
119
|
-
"-t",
|
|
120
|
-
"ios",
|
|
121
|
-
"-f",
|
|
122
|
-
ipaFileLocation,
|
|
123
|
-
"-u",
|
|
124
|
-
data.credentials.username,
|
|
125
|
-
"-p",
|
|
126
|
-
password,
|
|
127
|
-
"-k 100000",
|
|
128
|
-
];
|
|
129
|
-
if (data.teamId) {
|
|
130
|
-
args.push("--asc-provider");
|
|
131
|
-
args.push(data.teamId);
|
|
124
|
+
async getBundleIdentifier(data) {
|
|
125
|
+
const { shouldExtractIpa, ipaFilePath } = data;
|
|
126
|
+
if (shouldExtractIpa) {
|
|
127
|
+
if (!this.$fs.exists(ipaFilePath) ||
|
|
128
|
+
path.extname(ipaFilePath) !== ".ipa") {
|
|
129
|
+
this.$errors.fail(`Cannot use specified ipa file ${ipaFilePath}. File either does not exist or is not an ipa file.`);
|
|
132
130
|
}
|
|
133
|
-
|
|
134
|
-
|
|
131
|
+
this.$logger.trace("--ipa set - extracting .ipa file to get app's bundle identifier");
|
|
132
|
+
const destinationDir = await this.$tempService.mkdirSync("ipa-");
|
|
133
|
+
await this.$fs.unzip(ipaFilePath, destinationDir);
|
|
134
|
+
const payloadDir = path.join(destinationDir, "Payload");
|
|
135
|
+
let allFiles = this.$fs.readDirectory(payloadDir);
|
|
136
|
+
this.$logger.trace("ITMSTransporter .ipa Payload files:");
|
|
137
|
+
allFiles.forEach((f) => this.$logger.trace(" - " + f));
|
|
138
|
+
allFiles = allFiles.filter((f) => path.extname(f).toLowerCase() === ".app");
|
|
139
|
+
if (allFiles.length > 1) {
|
|
140
|
+
this.$errors.fail("In the .ipa the ITMSTransporter is uploading there is more than one .app file. We don't know which one to upload.");
|
|
135
141
|
}
|
|
136
|
-
|
|
137
|
-
|
|
138
|
-
});
|
|
139
|
-
});
|
|
140
|
-
}
|
|
141
|
-
getBundleIdentifier(data) {
|
|
142
|
-
return __awaiter(this, void 0, void 0, function* () {
|
|
143
|
-
const { shouldExtractIpa, ipaFilePath } = data;
|
|
144
|
-
if (shouldExtractIpa) {
|
|
145
|
-
if (!this.$fs.exists(ipaFilePath) ||
|
|
146
|
-
path.extname(ipaFilePath) !== ".ipa") {
|
|
147
|
-
this.$errors.fail(`Cannot use specified ipa file ${ipaFilePath}. File either does not exist or is not an ipa file.`);
|
|
148
|
-
}
|
|
149
|
-
this.$logger.trace("--ipa set - extracting .ipa file to get app's bundle identifier");
|
|
150
|
-
const destinationDir = yield this.$tempService.mkdirSync("ipa-");
|
|
151
|
-
yield this.$fs.unzip(ipaFilePath, destinationDir);
|
|
152
|
-
const payloadDir = path.join(destinationDir, "Payload");
|
|
153
|
-
let allFiles = this.$fs.readDirectory(payloadDir);
|
|
154
|
-
this.$logger.trace("ITMSTransporter .ipa Payload files:");
|
|
155
|
-
allFiles.forEach((f) => this.$logger.trace(" - " + f));
|
|
156
|
-
allFiles = allFiles.filter((f) => path.extname(f).toLowerCase() === ".app");
|
|
157
|
-
if (allFiles.length > 1) {
|
|
158
|
-
this.$errors.fail("In the .ipa the ITMSTransporter is uploading there is more than one .app file. We don't know which one to upload.");
|
|
159
|
-
}
|
|
160
|
-
else if (allFiles.length <= 0) {
|
|
161
|
-
this.$errors.fail("In the .ipa the ITMSTransporter is uploading there must be at least one .app file.");
|
|
162
|
-
}
|
|
163
|
-
const appFile = path.join(payloadDir, allFiles[0]);
|
|
164
|
-
const plistObject = yield this.$plistParser.parseFile(path.join(appFile, constants_1.INFO_PLIST_FILE_NAME));
|
|
165
|
-
const bundleId = plistObject && plistObject.CFBundleIdentifier;
|
|
166
|
-
if (!bundleId) {
|
|
167
|
-
this.$errors.fail(`Unable to determine bundle identifier from ${ipaFilePath}.`);
|
|
168
|
-
}
|
|
169
|
-
this.$logger.trace(`bundle identifier determined to be ${bundleId}`);
|
|
170
|
-
return bundleId;
|
|
142
|
+
else if (allFiles.length <= 0) {
|
|
143
|
+
this.$errors.fail("In the .ipa the ITMSTransporter is uploading there must be at least one .app file.");
|
|
171
144
|
}
|
|
172
|
-
|
|
173
|
-
|
|
145
|
+
const appFile = path.join(payloadDir, allFiles[0]);
|
|
146
|
+
const plistObject = await this.$plistParser.parseFile(path.join(appFile, constants_1.INFO_PLIST_FILE_NAME));
|
|
147
|
+
const bundleId = plistObject && plistObject.CFBundleIdentifier;
|
|
148
|
+
if (!bundleId) {
|
|
149
|
+
this.$errors.fail(`Unable to determine bundle identifier from ${ipaFilePath}.`);
|
|
150
|
+
}
|
|
151
|
+
this.$logger.trace(`bundle identifier determined to be ${bundleId}`);
|
|
152
|
+
return bundleId;
|
|
153
|
+
}
|
|
154
|
+
return this.$projectData.projectIdentifiers.ios;
|
|
174
155
|
}
|
|
175
|
-
getAltoolPath() {
|
|
176
|
-
|
|
177
|
-
|
|
178
|
-
|
|
179
|
-
return itmsTransporterPath;
|
|
180
|
-
});
|
|
156
|
+
async getAltoolPath() {
|
|
157
|
+
const xcodePath = await this.$xcodeSelectService.getContentsDirectoryPath();
|
|
158
|
+
let itmsTransporterPath = path.join(xcodePath, "..", "Contents", "Developer", "usr", "bin", constants_1.ITMSConstants.altoolExecutableName);
|
|
159
|
+
return itmsTransporterPath;
|
|
181
160
|
}
|
|
182
|
-
getITMSTransporterPath() {
|
|
183
|
-
|
|
184
|
-
|
|
185
|
-
|
|
186
|
-
|
|
187
|
-
|
|
188
|
-
|
|
189
|
-
|
|
190
|
-
|
|
191
|
-
return itmsTransporterPath;
|
|
192
|
-
});
|
|
161
|
+
async getITMSTransporterPath() {
|
|
162
|
+
const xcodePath = await this.$xcodeSelectService.getContentsDirectoryPath();
|
|
163
|
+
let itmsTransporterPath = path.join(xcodePath, "..", "Contents", "SharedFrameworks", "ContentDeliveryServices.framework", "Versions", "A", "itms", "bin", constants_1.ITMSConstants.iTMSExecutableName);
|
|
164
|
+
const xcodeVersionData = await this.$xcodeSelectService.getXcodeVersion();
|
|
165
|
+
if (+xcodeVersionData.major < 11) {
|
|
166
|
+
const loaderAppContentsPath = path.join(xcodePath, "Applications", "Application Loader.app", "Contents");
|
|
167
|
+
itmsTransporterPath = path.join(loaderAppContentsPath, constants_1.ITMSConstants.iTMSDirectoryName, "bin", constants_1.ITMSConstants.iTMSExecutableName);
|
|
168
|
+
}
|
|
169
|
+
return itmsTransporterPath;
|
|
193
170
|
}
|
|
194
171
|
getITMSMetadataXml(appleId, ipaFileName, ipaFileHash, ipaFileSize) {
|
|
195
172
|
return `<?xml version="1.0" encoding="UTF-8"?>
|
|
@@ -206,11 +183,11 @@ class ITMSTransporterService {
|
|
|
206
183
|
</package>`;
|
|
207
184
|
}
|
|
208
185
|
}
|
|
186
|
+
exports.ITMSTransporterService = ITMSTransporterService;
|
|
209
187
|
__decorate([
|
|
210
188
|
(0, decorators_1.cache)()
|
|
211
189
|
], ITMSTransporterService.prototype, "getAltoolPath", null);
|
|
212
190
|
__decorate([
|
|
213
191
|
(0, decorators_1.cache)()
|
|
214
192
|
], ITMSTransporterService.prototype, "getITMSTransporterPath", null);
|
|
215
|
-
exports.ITMSTransporterService = ITMSTransporterService;
|
|
216
193
|
yok_1.injector.register("itmsTransporterService", ITMSTransporterService);
|
|
@@ -1,13 +1,4 @@
|
|
|
1
1
|
"use strict";
|
|
2
|
-
var __awaiter = (this && this.__awaiter) || function (thisArg, _arguments, P, generator) {
|
|
3
|
-
function adopt(value) { return value instanceof P ? value : new P(function (resolve) { resolve(value); }); }
|
|
4
|
-
return new (P || (P = Promise))(function (resolve, reject) {
|
|
5
|
-
function fulfilled(value) { try { step(generator.next(value)); } catch (e) { reject(e); } }
|
|
6
|
-
function rejected(value) { try { step(generator["throw"](value)); } catch (e) { reject(e); } }
|
|
7
|
-
function step(result) { result.done ? resolve(result.value) : adopt(result.value).then(fulfilled, rejected); }
|
|
8
|
-
step((generator = generator.apply(thisArg, _arguments || [])).next());
|
|
9
|
-
});
|
|
10
|
-
};
|
|
11
2
|
Object.defineProperty(exports, "__esModule", { value: true });
|
|
12
3
|
exports.AndroidDeviceLiveSyncServiceBase = void 0;
|
|
13
4
|
const device_livesync_service_base_1 = require("./device-livesync-service-base");
|
|
@@ -21,48 +12,40 @@ class AndroidDeviceLiveSyncServiceBase extends device_livesync_service_base_1.De
|
|
|
21
12
|
this.$logger = $logger;
|
|
22
13
|
this.device = device;
|
|
23
14
|
}
|
|
24
|
-
transferFiles(deviceAppData, localToDevicePaths, projectFilesPath, projectData, liveSyncDeviceDescriptor, options) {
|
|
25
|
-
|
|
26
|
-
|
|
27
|
-
|
|
28
|
-
|
|
29
|
-
|
|
30
|
-
return transferredFiles;
|
|
31
|
-
});
|
|
15
|
+
async transferFiles(deviceAppData, localToDevicePaths, projectFilesPath, projectData, liveSyncDeviceDescriptor, options) {
|
|
16
|
+
const deviceHashService = this.device.fileSystem.getDeviceHashService(deviceAppData.appIdentifier);
|
|
17
|
+
const currentHashes = await deviceHashService.generateHashesFromLocalToDevicePaths(localToDevicePaths);
|
|
18
|
+
const transferredFiles = await this.transferFilesCore(deviceAppData, localToDevicePaths, projectFilesPath, currentHashes, options);
|
|
19
|
+
await this.device.fileSystem.updateHashesOnDevice(currentHashes, deviceAppData.appIdentifier);
|
|
20
|
+
return transferredFiles;
|
|
32
21
|
}
|
|
33
|
-
transferFilesCore(deviceAppData, localToDevicePaths, projectFilesPath, currentHashes, options) {
|
|
34
|
-
|
|
35
|
-
|
|
36
|
-
|
|
37
|
-
|
|
38
|
-
|
|
39
|
-
|
|
40
|
-
|
|
41
|
-
|
|
42
|
-
|
|
43
|
-
|
|
44
|
-
|
|
45
|
-
return localToDevicePathsToTransfer;
|
|
46
|
-
});
|
|
22
|
+
async transferFilesCore(deviceAppData, localToDevicePaths, projectFilesPath, currentHashes, options) {
|
|
23
|
+
if (options.force && options.isFullSync) {
|
|
24
|
+
const hashFileDevicePath = this.device.fileSystem.getDeviceHashService(deviceAppData.appIdentifier).hashFileDevicePath;
|
|
25
|
+
await this.device.fileSystem.deleteFile(hashFileDevicePath, deviceAppData.appIdentifier);
|
|
26
|
+
this.$logger.trace("Before transfer directory on device ", localToDevicePaths);
|
|
27
|
+
await this.transferDirectoryOnDevice(deviceAppData, localToDevicePaths, projectFilesPath);
|
|
28
|
+
return localToDevicePaths;
|
|
29
|
+
}
|
|
30
|
+
const localToDevicePathsToTransfer = await this.getLocalToDevicePathsToTransfer(deviceAppData, localToDevicePaths, currentHashes, options);
|
|
31
|
+
this.$logger.trace("Files to transfer: ", localToDevicePathsToTransfer);
|
|
32
|
+
await this.transferFilesOnDevice(deviceAppData, localToDevicePathsToTransfer);
|
|
33
|
+
return localToDevicePathsToTransfer;
|
|
47
34
|
}
|
|
48
|
-
getLocalToDevicePathsToTransfer(deviceAppData, localToDevicePaths, currentHashes, options) {
|
|
49
|
-
|
|
50
|
-
|
|
51
|
-
|
|
52
|
-
|
|
53
|
-
|
|
54
|
-
return changedLocalToDevicePaths;
|
|
55
|
-
});
|
|
35
|
+
async getLocalToDevicePathsToTransfer(deviceAppData, localToDevicePaths, currentHashes, options) {
|
|
36
|
+
if (options.force || !options.isFullSync) {
|
|
37
|
+
return localToDevicePaths;
|
|
38
|
+
}
|
|
39
|
+
const changedLocalToDevicePaths = await this.getChangedLocalToDevicePaths(deviceAppData.appIdentifier, localToDevicePaths, currentHashes);
|
|
40
|
+
return changedLocalToDevicePaths;
|
|
56
41
|
}
|
|
57
|
-
getChangedLocalToDevicePaths(appIdentifier, localToDevicePaths, currentHashes) {
|
|
58
|
-
|
|
59
|
-
|
|
60
|
-
|
|
61
|
-
|
|
62
|
-
|
|
63
|
-
|
|
64
|
-
return changedLocalToDevicePaths;
|
|
65
|
-
});
|
|
42
|
+
async getChangedLocalToDevicePaths(appIdentifier, localToDevicePaths, currentHashes) {
|
|
43
|
+
const deviceHashService = this.device.fileSystem.getDeviceHashService(appIdentifier);
|
|
44
|
+
const oldHashes = (await deviceHashService.getShasumsFromDevice()) || {};
|
|
45
|
+
const changedHashes = deviceHashService.getChangedShasums(oldHashes, currentHashes);
|
|
46
|
+
const changedFiles = _.keys(changedHashes);
|
|
47
|
+
const changedLocalToDevicePaths = localToDevicePaths.filter((localToDevicePathData) => changedFiles.indexOf(localToDevicePathData.getLocalPath()) >= 0);
|
|
48
|
+
return changedLocalToDevicePaths;
|
|
66
49
|
}
|
|
67
50
|
}
|
|
68
51
|
exports.AndroidDeviceLiveSyncServiceBase = AndroidDeviceLiveSyncServiceBase;
|