@akylas/nativescript-cli 8.7.2
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/LICENSE +201 -0
- package/README.md +385 -0
- package/bin/nativescript +3 -0
- package/bin/nativescript.js +3 -0
- package/bin/ns +3 -0
- package/bin/nsc +3 -0
- package/bin/nsc.js +3 -0
- package/bin/tns +12 -0
- package/bin/tns.cmd +1 -0
- package/config/config.json +8 -0
- package/config/test-dependencies.json +58 -0
- package/config/test-deps-versions-generated.json +1 -0
- package/docs/build-jekyll-md.sh +7 -0
- package/docs/helpers/favicon.ico +0 -0
- package/docs/helpers/logo.png +0 -0
- package/docs/man_pages/cloud/cloud-setup.md +29 -0
- package/docs/man_pages/device/device-android.md +32 -0
- package/docs/man_pages/device/device-ios.md +40 -0
- package/docs/man_pages/device/device-list-applications.md +37 -0
- package/docs/man_pages/device/device-log.md +37 -0
- package/docs/man_pages/device/device-run.md +55 -0
- package/docs/man_pages/device/device.md +46 -0
- package/docs/man_pages/env-configuration/setup.md +22 -0
- package/docs/man_pages/general/autocomplete-disable.md +37 -0
- package/docs/man_pages/general/autocomplete-enable.md +37 -0
- package/docs/man_pages/general/autocomplete-status.md +35 -0
- package/docs/man_pages/general/autocomplete.md +46 -0
- package/docs/man_pages/general/clean.md +22 -0
- package/docs/man_pages/general/doctor.md +33 -0
- package/docs/man_pages/general/error-reporting.md +41 -0
- package/docs/man_pages/general/extension-install.md +45 -0
- package/docs/man_pages/general/extension-uninstall.md +41 -0
- package/docs/man_pages/general/extension.md +35 -0
- package/docs/man_pages/general/help.md +39 -0
- package/docs/man_pages/general/info.md +33 -0
- package/docs/man_pages/general/migrate.md +79 -0
- package/docs/man_pages/general/package-manager-get.md +26 -0
- package/docs/man_pages/general/package-manager-set.md +29 -0
- package/docs/man_pages/general/package-manager.md +25 -0
- package/docs/man_pages/general/proxy-clear.md +26 -0
- package/docs/man_pages/general/proxy-set.md +45 -0
- package/docs/man_pages/general/proxy.md +31 -0
- package/docs/man_pages/general/update.md +40 -0
- package/docs/man_pages/general/usage-reporting.md +41 -0
- package/docs/man_pages/index.html +3 -0
- package/docs/man_pages/lib-management/plugin-add.md +42 -0
- package/docs/man_pages/lib-management/plugin-build.md +32 -0
- package/docs/man_pages/lib-management/plugin-create.md +48 -0
- package/docs/man_pages/lib-management/plugin-install.md +42 -0
- package/docs/man_pages/lib-management/plugin-remove.md +31 -0
- package/docs/man_pages/lib-management/plugin-update.md +41 -0
- package/docs/man_pages/lib-management/plugin.md +39 -0
- package/docs/man_pages/project/configuration/generate.md +36 -0
- package/docs/man_pages/project/configuration/install.md +43 -0
- package/docs/man_pages/project/configuration/open-android.md +27 -0
- package/docs/man_pages/project/configuration/open-ios.md +31 -0
- package/docs/man_pages/project/configuration/open.md +36 -0
- package/docs/man_pages/project/configuration/platform-add.md +46 -0
- package/docs/man_pages/project/configuration/platform-clean.md +41 -0
- package/docs/man_pages/project/configuration/platform-remove.md +41 -0
- package/docs/man_pages/project/configuration/platform-update.md +45 -0
- package/docs/man_pages/project/configuration/platform.md +29 -0
- package/docs/man_pages/project/configuration/prepare.md +49 -0
- package/docs/man_pages/project/configuration/resources/resources-generate-icons.md +39 -0
- package/docs/man_pages/project/configuration/resources/resources-generate-splashes.md +39 -0
- package/docs/man_pages/project/configuration/resources/resources-update.md +35 -0
- package/docs/man_pages/project/configuration/resources/resources.md +14 -0
- package/docs/man_pages/project/creation/create.md +64 -0
- package/docs/man_pages/project/testing/build-android.md +62 -0
- package/docs/man_pages/project/testing/build-ios.md +65 -0
- package/docs/man_pages/project/testing/build.md +66 -0
- package/docs/man_pages/project/testing/debug-android.md +64 -0
- package/docs/man_pages/project/testing/debug-ios.md +65 -0
- package/docs/man_pages/project/testing/debug.md +67 -0
- package/docs/man_pages/project/testing/deploy.md +72 -0
- package/docs/man_pages/project/testing/dev-test-android.md +31 -0
- package/docs/man_pages/project/testing/dev-test-ios.md +36 -0
- package/docs/man_pages/project/testing/preview.md +35 -0
- package/docs/man_pages/project/testing/run-android.md +79 -0
- package/docs/man_pages/project/testing/run-ios.md +83 -0
- package/docs/man_pages/project/testing/run.md +92 -0
- package/docs/man_pages/project/testing/test-android.md +46 -0
- package/docs/man_pages/project/testing/test-init.md +34 -0
- package/docs/man_pages/project/testing/test-ios.md +48 -0
- package/docs/man_pages/project/testing/test.md +48 -0
- package/docs/man_pages/project/testing/typings.md +52 -0
- package/docs/man_pages/publishing/apple-login.md +35 -0
- package/docs/man_pages/publishing/appstore-upload.md +52 -0
- package/docs/man_pages/publishing/appstore.md +42 -0
- package/docs/man_pages/publishing/publish-ios.md +55 -0
- package/docs/man_pages/publishing/publish.md +38 -0
- package/docs/man_pages/start.md +81 -0
- package/lib/.d.ts +494 -0
- package/lib/android-tools-info.js +135 -0
- package/lib/base-package-manager.js +129 -0
- package/lib/bash-scripts/terminateProcess.sh +12 -0
- package/lib/bootstrap.js +203 -0
- package/lib/bun-package-manager.js +135 -0
- package/lib/color.js +10 -0
- package/lib/commands/add-platform.js +49 -0
- package/lib/commands/apple-login.js +52 -0
- package/lib/commands/appstore-list.js +75 -0
- package/lib/commands/appstore-upload.js +106 -0
- package/lib/commands/build.js +161 -0
- package/lib/commands/clean.js +253 -0
- package/lib/commands/command-base.js +46 -0
- package/lib/commands/config.js +135 -0
- package/lib/commands/create-project.js +431 -0
- package/lib/commands/debug.js +191 -0
- package/lib/commands/deploy.js +78 -0
- package/lib/commands/extensibility/install-extension.js +33 -0
- package/lib/commands/extensibility/list-extensions.js +40 -0
- package/lib/commands/extensibility/uninstall-extension.js +32 -0
- package/lib/commands/fonts.js +64 -0
- package/lib/commands/generate-assets.js +71 -0
- package/lib/commands/generate-help.js +26 -0
- package/lib/commands/generate.js +78 -0
- package/lib/commands/info.js +26 -0
- package/lib/commands/install.js +80 -0
- package/lib/commands/list-platforms.js +45 -0
- package/lib/commands/migrate.js +44 -0
- package/lib/commands/platform-clean.js +54 -0
- package/lib/commands/plugin/add-plugin.js +43 -0
- package/lib/commands/plugin/build-plugin.js +70 -0
- package/lib/commands/plugin/create-plugin.js +175 -0
- package/lib/commands/plugin/list-plugins.js +54 -0
- package/lib/commands/plugin/remove-plugin.js +52 -0
- package/lib/commands/plugin/update-plugin.js +52 -0
- package/lib/commands/post-install.js +57 -0
- package/lib/commands/prepare.js +63 -0
- package/lib/commands/preview.js +93 -0
- package/lib/commands/remove-platform.js +40 -0
- package/lib/commands/resources/resources-update.js +45 -0
- package/lib/commands/run.js +177 -0
- package/lib/commands/setup.js +15 -0
- package/lib/commands/start.js +33 -0
- package/lib/commands/test-init.js +167 -0
- package/lib/commands/test.js +146 -0
- package/lib/commands/typings.js +180 -0
- package/lib/commands/update-platform.js +57 -0
- package/lib/commands/update.js +70 -0
- package/lib/common/LICENSE +201 -0
- package/lib/common/README.md +1084 -0
- package/lib/common/bin/common-lib.js +5 -0
- package/lib/common/bootstrap.js +97 -0
- package/lib/common/child-process.js +217 -0
- package/lib/common/codeGeneration/code-entity.js +47 -0
- package/lib/common/codeGeneration/code-generation.d.ts +47 -0
- package/lib/common/codeGeneration/code-printer.js +48 -0
- package/lib/common/command-params.js +45 -0
- package/lib/common/commands/analytics.js +81 -0
- package/lib/common/commands/autocompletion.js +110 -0
- package/lib/common/commands/device/device-log-stream.js +44 -0
- package/lib/common/commands/device/get-file.js +54 -0
- package/lib/common/commands/device/list-applications.js +42 -0
- package/lib/common/commands/device/list-devices.js +150 -0
- package/lib/common/commands/device/list-files.js +55 -0
- package/lib/common/commands/device/put-file.js +55 -0
- package/lib/common/commands/device/run-application.js +46 -0
- package/lib/common/commands/device/stop-application.js +42 -0
- package/lib/common/commands/device/uninstall-application.js +33 -0
- package/lib/common/commands/doctor.js +54 -0
- package/lib/common/commands/generate-messages.js +45 -0
- package/lib/common/commands/help.js +51 -0
- package/lib/common/commands/package-manager-get.js +32 -0
- package/lib/common/commands/package-manager-set.js +37 -0
- package/lib/common/commands/post-install.js +27 -0
- package/lib/common/commands/preuninstall.js +61 -0
- package/lib/common/commands/proxy/proxy-base.js +34 -0
- package/lib/common/commands/proxy/proxy-clear.js +32 -0
- package/lib/common/commands/proxy/proxy-get.js +31 -0
- package/lib/common/commands/proxy/proxy-set.js +150 -0
- package/lib/common/common-lib.js +5 -0
- package/lib/common/constants.js +122 -0
- package/lib/common/declarations.d.ts +1713 -0
- package/lib/common/decorators.js +201 -0
- package/lib/common/definitions/cli-global.d.ts +22 -0
- package/lib/common/definitions/commands-service.d.ts +27 -0
- package/lib/common/definitions/commands.d.ts +51 -0
- package/lib/common/definitions/config.d.ts +33 -0
- package/lib/common/definitions/extensibility.d.ts +147 -0
- package/lib/common/definitions/google-analytics.d.ts +109 -0
- package/lib/common/definitions/json-file-settings-service.d.ts +24 -0
- package/lib/common/definitions/key-commands.d.ts +62 -0
- package/lib/common/definitions/logger.d.ts +41 -0
- package/lib/common/definitions/mobile.d.ts +1499 -0
- package/lib/common/definitions/validator.d.ts +8 -0
- package/lib/common/definitions/yok.d.ts +56 -0
- package/lib/common/dispatchers.js +151 -0
- package/lib/common/docs/helpers/basic-extensions-page.html +15 -0
- package/lib/common/docs/helpers/basic-page.html +14 -0
- package/lib/common/docs/helpers/styles.css +365 -0
- package/lib/common/doctor.d.ts +6 -0
- package/lib/common/errors.js +206 -0
- package/lib/common/file-system.js +441 -0
- package/lib/common/header.js +30 -0
- package/lib/common/helpers.js +658 -0
- package/lib/common/host-info.js +133 -0
- package/lib/common/http-client.js +173 -0
- package/lib/common/logger/appenders/cli-appender.js +24 -0
- package/lib/common/logger/appenders/emit-appender.js +30 -0
- package/lib/common/logger/layouts/cli-layout.js +33 -0
- package/lib/common/logger/logger.js +199 -0
- package/lib/common/messages/messages.interface.d.ts +10 -0
- package/lib/common/messages/messages.js +15 -0
- package/lib/common/mobile/android/android-application-manager.js +228 -0
- package/lib/common/mobile/android/android-debug-bridge-result-handler.js +332 -0
- package/lib/common/mobile/android/android-debug-bridge.js +167 -0
- package/lib/common/mobile/android/android-device-file-system.js +176 -0
- package/lib/common/mobile/android/android-device-hash-service.js +133 -0
- package/lib/common/mobile/android/android-device.js +164 -0
- package/lib/common/mobile/android/android-emulator-services.js +205 -0
- package/lib/common/mobile/android/android-ini-file-parser.js +77 -0
- package/lib/common/mobile/android/android-log-filter.js +42 -0
- package/lib/common/mobile/android/android-virtual-device-service.js +360 -0
- package/lib/common/mobile/android/device-android-debug-bridge.js +48 -0
- package/lib/common/mobile/android/genymotion/genymotion-service.js +211 -0
- package/lib/common/mobile/android/genymotion/virtualbox-service.js +121 -0
- package/lib/common/mobile/android/logcat-helper.js +165 -0
- package/lib/common/mobile/application-manager-base.js +136 -0
- package/lib/common/mobile/device-emitter.js +61 -0
- package/lib/common/mobile/device-log-emitter.js +40 -0
- package/lib/common/mobile/device-log-provider-base.js +76 -0
- package/lib/common/mobile/device-log-provider.js +126 -0
- package/lib/common/mobile/device-platforms-constants.js +22 -0
- package/lib/common/mobile/emulator-helper.js +84 -0
- package/lib/common/mobile/ios/device/ios-application-manager.js +159 -0
- package/lib/common/mobile/ios/device/ios-device-file-system.js +133 -0
- package/lib/common/mobile/ios/device/ios-device-operations.js +234 -0
- package/lib/common/mobile/ios/device/ios-device.js +153 -0
- package/lib/common/mobile/ios/ios-device-base.js +108 -0
- package/lib/common/mobile/ios/ios-device-product-name-mapper.js +65 -0
- package/lib/common/mobile/ios/ios-log-filter.js +24 -0
- package/lib/common/mobile/ios/simulator/ios-emulator-services.js +139 -0
- package/lib/common/mobile/ios/simulator/ios-sim-resolver.js +23 -0
- package/lib/common/mobile/ios/simulator/ios-simulator-application-manager.js +147 -0
- package/lib/common/mobile/ios/simulator/ios-simulator-device.js +106 -0
- package/lib/common/mobile/ios/simulator/ios-simulator-file-system.js +81 -0
- package/lib/common/mobile/ios/simulator/ios-simulator-log-provider.js +69 -0
- package/lib/common/mobile/local-to-device-path-data-factory.js +37 -0
- package/lib/common/mobile/log-filter.js +51 -0
- package/lib/common/mobile/logging-levels.js +12 -0
- package/lib/common/mobile/mobile-core/android-device-discovery.js +91 -0
- package/lib/common/mobile/mobile-core/android-emulator-discovery.js +65 -0
- package/lib/common/mobile/mobile-core/android-process-service.js +259 -0
- package/lib/common/mobile/mobile-core/device-discovery.js +64 -0
- package/lib/common/mobile/mobile-core/devices-service.js +854 -0
- package/lib/common/mobile/mobile-core/ios-device-discovery.js +63 -0
- package/lib/common/mobile/mobile-core/ios-simulator-discovery.js +109 -0
- package/lib/common/mobile/mobile-helper.js +102 -0
- package/lib/common/mobile/wp8/wp8-emulator-services.js +82 -0
- package/lib/common/old.npmignore +12 -0
- package/lib/common/opener.js +16 -0
- package/lib/common/os-info.js +21 -0
- package/lib/common/plist-parser.js +24 -0
- package/lib/common/project-helper.js +70 -0
- package/lib/common/prompter.js +191 -0
- package/lib/common/queue.js +37 -0
- package/lib/common/resource-loader.js +25 -0
- package/lib/common/resources/messages/errorMessages.json +7 -0
- package/lib/common/resources/platform-tools/android/darwin/NOTICE.txt +3407 -0
- package/lib/common/resources/platform-tools/android/darwin/adb +0 -0
- package/lib/common/resources/platform-tools/android/linux/NOTICE.txt +4451 -0
- 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 +4451 -0
- package/lib/common/resources/platform-tools/android/win32/adb.exe +0 -0
- package/lib/common/resources/platform-tools/android/win32/fastboot.exe +0 -0
- package/lib/common/resources/platform-tools/unzip/win32/unzip.exe +0 -0
- package/lib/common/services/analytics/google-analytics-custom-dimensions.d.ts +16 -0
- package/lib/common/services/auto-completion-service.js +265 -0
- package/lib/common/services/cancellation.js +67 -0
- package/lib/common/services/commands-service.js +268 -0
- package/lib/common/services/help-service.js +252 -0
- package/lib/common/services/hooks-service.js +318 -0
- package/lib/common/services/ios-notification-service.js +49 -0
- package/lib/common/services/json-file-settings-service.js +133 -0
- package/lib/common/services/lock-service.js +129 -0
- package/lib/common/services/message-contract-generator.js +83 -0
- package/lib/common/services/messages-service.js +77 -0
- package/lib/common/services/micro-templating-service.js +49 -0
- package/lib/common/services/net-service.js +137 -0
- package/lib/common/services/project-files-manager.js +100 -0
- package/lib/common/services/project-files-provider-base.js +54 -0
- package/lib/common/services/proxy-service.js +64 -0
- package/lib/common/services/qr.js +39 -0
- package/lib/common/services/settings-service.js +42 -0
- package/lib/common/services/xcode-select-service.js +62 -0
- package/lib/common/utils.js +31 -0
- package/lib/common/validators/project-name-validator.js +88 -0
- package/lib/common/validators/validation-result.js +16 -0
- package/lib/common/vendor/License.txt +4 -0
- package/lib/common/vendor/jaro-winkler_distance.js +111 -0
- package/lib/common/verify-node-version.js +78 -0
- package/lib/common/yok.js +426 -0
- package/lib/config.js +137 -0
- package/lib/constants-provider.js +12 -0
- package/lib/constants.js +350 -0
- package/lib/controllers/build-controller.js +133 -0
- package/lib/controllers/debug-controller.js +235 -0
- package/lib/controllers/deploy-controller.js +38 -0
- package/lib/controllers/migrate-controller.js +1114 -0
- package/lib/controllers/platform-controller.js +127 -0
- package/lib/controllers/prepare-controller.js +353 -0
- package/lib/controllers/run-controller.js +525 -0
- package/lib/controllers/update-controller-base.js +84 -0
- package/lib/controllers/update-controller.js +188 -0
- package/lib/data/build-data.js +44 -0
- package/lib/data/controller-data-base.js +11 -0
- package/lib/data/debug-data.js +6 -0
- package/lib/data/platform-data.js +13 -0
- package/lib/data/prepare-data.js +46 -0
- package/lib/data/run-data.js +11 -0
- package/lib/declarations.d.ts +1256 -0
- package/lib/definitions/android-bundle-tool-service.d.ts +17 -0
- package/lib/definitions/android-plugin-migrator.d.ts +52 -0
- package/lib/definitions/build.d.ts +92 -0
- package/lib/definitions/cleanup-service.d.ts +79 -0
- package/lib/definitions/data.d.ts +7 -0
- package/lib/definitions/debug.d.ts +166 -0
- package/lib/definitions/deploy.d.ts +3 -0
- package/lib/definitions/file-log-service.d.ts +19 -0
- package/lib/definitions/files-hash-service.d.ts +35 -0
- package/lib/definitions/gradle.d.ts +33 -0
- package/lib/definitions/hmr-status-service.d.ts +5 -0
- package/lib/definitions/initialize-service.d.ts +11 -0
- package/lib/definitions/ios-debugger-port-service.d.ts +29 -0
- package/lib/definitions/ios.d.ts +97 -0
- package/lib/definitions/ip-service.d.ts +10 -0
- package/lib/definitions/livesync-global.d.ts +7 -0
- package/lib/definitions/livesync.d.ts +601 -0
- package/lib/definitions/lock-service.d.ts +43 -0
- package/lib/definitions/log-parser-service.d.ts +14 -0
- package/lib/definitions/marking-mode-service.d.ts +11 -0
- package/lib/definitions/metadata-filtering-service.d.ts +48 -0
- package/lib/definitions/migrate.d.ts +46 -0
- package/lib/definitions/nativescript-dev-xcode.d.ts +87 -0
- package/lib/definitions/pacote-service.d.ts +50 -0
- package/lib/definitions/platform.d.ts +146 -0
- package/lib/definitions/plugins.d.ts +75 -0
- package/lib/definitions/prepare.d.ts +51 -0
- package/lib/definitions/project-changes.d.ts +34 -0
- package/lib/definitions/project.d.ts +858 -0
- package/lib/definitions/prompter.d.ts +27 -0
- package/lib/definitions/qr-code.d.ts +3 -0
- package/lib/definitions/require.d.ts +11 -0
- package/lib/definitions/run.d.ts +45 -0
- package/lib/definitions/start-service.d.ts +15 -0
- package/lib/definitions/subscription-service.d.ts +11 -0
- package/lib/definitions/system-warnings.d.ts +4 -0
- package/lib/definitions/temp-service.d.ts +9 -0
- package/lib/definitions/terminal-spinner-service.d.ts +12 -0
- package/lib/definitions/update.d.ts +16 -0
- package/lib/definitions/xcode.d.ts +12 -0
- package/lib/detached-processes/cleanup-js-subprocess.js +62 -0
- package/lib/detached-processes/cleanup-process-definitions.d.ts +70 -0
- package/lib/detached-processes/cleanup-process.js +281 -0
- package/lib/detached-processes/detached-process-enums.d.ts +70 -0
- package/lib/detached-processes/file-log-service.js +20 -0
- package/lib/device-path-provider.js +60 -0
- package/lib/device-sockets/ios/app-debug-socket-proxy-factory.js +217 -0
- package/lib/device-sockets/ios/notification.js +30 -0
- package/lib/device-sockets/ios/socket-request-executor.js +56 -0
- package/lib/helpers/android-bundle-validator-helper.js +52 -0
- package/lib/helpers/deploy-command-helper.js +70 -0
- package/lib/helpers/key-command-helper.js +124 -0
- package/lib/helpers/livesync-command-helper.js +220 -0
- package/lib/helpers/network-connectivity-validator.js +47 -0
- package/lib/helpers/options-track-helper.js +88 -0
- package/lib/helpers/package-path-helper.js +6 -0
- package/lib/helpers/platform-command-helper.js +192 -0
- package/lib/helpers/version-validator-helper.js +25 -0
- package/lib/key-commands/bootstrap.js +21 -0
- package/lib/key-commands/index.js +456 -0
- package/lib/nativescript-cli-lib-bootstrap.js +8 -0
- package/lib/nativescript-cli-lib.js +5 -0
- package/lib/nativescript-cli.js +55 -0
- package/lib/node/pbxproj-dom-xcode.js +5 -0
- package/lib/node/xcode.js +7 -0
- package/lib/node-package-manager.js +156 -0
- package/lib/options.js +393 -0
- package/lib/package-installation-manager.js +221 -0
- package/lib/package-manager.js +184 -0
- package/lib/platform-command-param.js +29 -0
- package/lib/pnpm-package-manager.js +136 -0
- package/lib/project-data.js +237 -0
- package/lib/providers/project-files-provider.js +46 -0
- package/lib/resolvers/livesync-service-resolver.js +22 -0
- package/lib/services/analytics/analytics-broker-process.js +77 -0
- package/lib/services/analytics/analytics-broker.js +53 -0
- package/lib/services/analytics/analytics-service.js +366 -0
- package/lib/services/analytics/analytics.d.ts +55 -0
- package/lib/services/analytics/google-analytics-cross-client-custom-dimensions.d.ts +6 -0
- package/lib/services/analytics/google-analytics-provider.js +152 -0
- package/lib/services/analytics-settings-service.js +104 -0
- package/lib/services/android/android-bundle-tool-service.js +81 -0
- package/lib/services/android/gradle-build-args-service.js +87 -0
- package/lib/services/android/gradle-build-service.js +68 -0
- package/lib/services/android/gradle-command-service.js +49 -0
- package/lib/services/android-device-debug-service.js +173 -0
- package/lib/services/android-plugin-build-service.js +527 -0
- package/lib/services/android-project-service.js +600 -0
- package/lib/services/android-resources-migration-service.js +104 -0
- package/lib/services/apple-portal/apple-portal-application-service.js +82 -0
- package/lib/services/apple-portal/apple-portal-cookie-service.js +53 -0
- package/lib/services/apple-portal/apple-portal-session-service.js +277 -0
- package/lib/services/apple-portal/definitions.d.ts +87 -0
- package/lib/services/assets-generation/assets-generation-service.js +178 -0
- package/lib/services/build-artifacts-service.js +113 -0
- package/lib/services/build-data-service.js +20 -0
- package/lib/services/build-info-file-service.js +79 -0
- package/lib/services/cleanup-service.js +194 -0
- package/lib/services/cocoapods-platform-manager.js +137 -0
- package/lib/services/cocoapods-service.js +354 -0
- package/lib/services/debug-data-service.js +21 -0
- package/lib/services/debug-service-base.js +44 -0
- package/lib/services/device/device-install-app-service.js +118 -0
- package/lib/services/doctor-service.js +294 -0
- package/lib/services/extensibility-service.js +220 -0
- package/lib/services/files-hash-service.js +79 -0
- package/lib/services/hmr-status-service.js +128 -0
- package/lib/services/info-service.js +14 -0
- package/lib/services/initialize-service.js +70 -0
- package/lib/services/ios/export-options-plist-service.js +131 -0
- package/lib/services/ios/ios-signing-service.js +265 -0
- package/lib/services/ios/spm-service.js +78 -0
- package/lib/services/ios/xcodebuild-args-service.js +163 -0
- package/lib/services/ios/xcodebuild-command-service.js +40 -0
- package/lib/services/ios/xcodebuild-service.js +93 -0
- package/lib/services/ios-debugger-port-service.js +140 -0
- package/lib/services/ios-device-debug-service.js +167 -0
- package/lib/services/ios-entitlements-service.js +78 -0
- package/lib/services/ios-extensions-service.js +63 -0
- package/lib/services/ios-log-filter.js +70 -0
- package/lib/services/ios-native-target-service.js +108 -0
- package/lib/services/ios-project-service.js +851 -0
- package/lib/services/ios-provision-service.js +173 -0
- package/lib/services/ios-watch-app-service.js +76 -0
- package/lib/services/ip-service.js +78 -0
- package/lib/services/itmstransporter-service.js +216 -0
- package/lib/services/karma-execution.js +16 -0
- package/lib/services/livesync/android-device-livesync-service-base.js +68 -0
- package/lib/services/livesync/android-device-livesync-service.js +203 -0
- package/lib/services/livesync/android-device-livesync-sockets-service.js +198 -0
- package/lib/services/livesync/android-livesync-service.js +76 -0
- package/lib/services/livesync/android-livesync-tool.js +427 -0
- package/lib/services/livesync/android-livesync-tool.md +211 -0
- package/lib/services/livesync/device-livesync-service-base.js +69 -0
- package/lib/services/livesync/ios-device-livesync-service.js +218 -0
- package/lib/services/livesync/ios-livesync-service.js +95 -0
- package/lib/services/livesync/livesync-socket.js +14 -0
- package/lib/services/livesync/platform-livesync-service-base.js +180 -0
- package/lib/services/livesync-process-data-service.js +43 -0
- package/lib/services/log-parser-service.js +52 -0
- package/lib/services/log-source-map-service.js +235 -0
- package/lib/services/marking-mode-service.js +56 -0
- package/lib/services/metadata-filtering-service.js +105 -0
- package/lib/services/npm-config-service.js +39 -0
- package/lib/services/pacote-service.js +109 -0
- package/lib/services/performance-service.js +92 -0
- package/lib/services/platform/add-platform-service.js +119 -0
- package/lib/services/platform/platform-validation-service.js +85 -0
- package/lib/services/platform/prepare-native-platform-service.js +87 -0
- package/lib/services/platform-environment-requirements.js +87 -0
- package/lib/services/platform-project-service-base.js +32 -0
- package/lib/services/platforms-data-service.js +31 -0
- package/lib/services/plugins-service.js +477 -0
- package/lib/services/prepare-data-service.js +21 -0
- package/lib/services/project-backup-service.js +114 -0
- package/lib/services/project-changes-service.js +274 -0
- package/lib/services/project-cleanup-service.js +102 -0
- package/lib/services/project-config-service.js +335 -0
- package/lib/services/project-data-service.js +478 -0
- package/lib/services/project-name-service.js +67 -0
- package/lib/services/project-service.js +204 -0
- package/lib/services/project-templates-service.js +114 -0
- package/lib/services/qr-code-terminal-service.js +20 -0
- package/lib/services/require-service.js +11 -0
- package/lib/services/start-service.js +116 -0
- package/lib/services/temp-service.js +36 -0
- package/lib/services/terminal-spinner-service.js +38 -0
- package/lib/services/test-execution-service.js +154 -0
- package/lib/services/test-initialization-service.js +54 -0
- package/lib/services/timeline-profiler-service.js +108 -0
- package/lib/services/user-settings-service.js +34 -0
- package/lib/services/versions-service.js +196 -0
- package/lib/services/watch-ignore-list-service.js +20 -0
- package/lib/services/webpack/webpack-compiler-service.js +405 -0
- package/lib/services/webpack/webpack.d.ts +227 -0
- package/lib/services/xcconfig-service.js +76 -0
- package/lib/services/xcproj-service.js +11 -0
- package/lib/shared-event-bus.js +7 -0
- package/lib/sys-info.js +120 -0
- package/lib/tools/config-manipulation/config-transformer.js +201 -0
- package/lib/tools/node-modules/node-modules-builder.js +42 -0
- package/lib/tools/node-modules/node-modules-dependencies-builder.js +100 -0
- package/lib/yarn-package-manager.js +134 -0
- package/lib/yarn2-package-manager.js +143 -0
- package/package.json +192 -0
- package/postinstall.js +10 -0
- package/preuninstall.js +14 -0
- package/resources/assets/image-definitions.json +655 -0
- package/resources/test/example.jasmine.js +6 -0
- package/resources/test/example.jasmine.ts +6 -0
- package/resources/test/example.mocha.js +9 -0
- package/resources/test/example.mocha.ts +9 -0
- package/resources/test/example.qunit.js +7 -0
- package/resources/test/example.qunit.ts +7 -0
- package/resources/test/karma.conf.js +93 -0
- package/resources/test/test-main.js +9 -0
- package/resources/test/test-main.ts +11 -0
- package/resources/test/tsconfig.spec.json +9 -0
- package/setup/mac-startup-shell-script.sh +2 -0
- package/vendor/aab-tool/LICENSE +202 -0
- package/vendor/aab-tool/README.txt +1 -0
- package/vendor/aab-tool/bundletool.jar +0 -0
- package/vendor/gradle-app/app/build.gradle +1054 -0
- package/vendor/gradle-app/app/gradle-helpers/AnalyticsCollector.gradle +48 -0
- package/vendor/gradle-app/app/gradle-helpers/BuildToolTask.gradle +50 -0
- package/vendor/gradle-app/app/gradle-helpers/CustomExecutionLogger.gradle +52 -0
- package/vendor/gradle-app/build.gradle +170 -0
- package/vendor/gradle-app/settings.gradle +78 -0
- package/vendor/gradle-plugin/LICENSE +995 -0
- package/vendor/gradle-plugin/build.gradle +363 -0
- package/vendor/gradle-plugin/gradle/wrapper/gradle-wrapper.jar +0 -0
- package/vendor/gradle-plugin/gradle/wrapper/gradle-wrapper.properties +6 -0
- package/vendor/gradle-plugin/gradle.properties +6 -0
- package/vendor/gradle-plugin/gradlew +172 -0
- package/vendor/gradle-plugin/gradlew.bat +84 -0
- package/vendor/gradle-plugin/settings.gradle +45 -0
|
@@ -0,0 +1,366 @@
|
|
|
1
|
+
"use strict";
|
|
2
|
+
var __decorate = (this && this.__decorate) || function (decorators, target, key, desc) {
|
|
3
|
+
var c = arguments.length, r = c < 3 ? target : desc === null ? desc = Object.getOwnPropertyDescriptor(target, key) : desc, d;
|
|
4
|
+
if (typeof Reflect === "object" && typeof Reflect.decorate === "function") r = Reflect.decorate(decorators, target, key, desc);
|
|
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
|
+
return c > 3 && r && Object.defineProperty(target, key, r), r;
|
|
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
|
+
Object.defineProperty(exports, "__esModule", { value: true });
|
|
18
|
+
exports.AnalyticsService = void 0;
|
|
19
|
+
const path = require("path");
|
|
20
|
+
const _ = require("lodash");
|
|
21
|
+
const decorators_1 = require("../../common/decorators");
|
|
22
|
+
const helpers_1 = require("../../common/helpers");
|
|
23
|
+
const constants_1 = require("../../common/constants");
|
|
24
|
+
const yok_1 = require("../../common/yok");
|
|
25
|
+
class AnalyticsService {
|
|
26
|
+
constructor($logger, $options, $staticConfig, $prompter, $userSettingsService, $analyticsSettingsService, $childProcess, $projectDataService, $mobileHelper, $projectHelper) {
|
|
27
|
+
this.$logger = $logger;
|
|
28
|
+
this.$options = $options;
|
|
29
|
+
this.$staticConfig = $staticConfig;
|
|
30
|
+
this.$prompter = $prompter;
|
|
31
|
+
this.$userSettingsService = $userSettingsService;
|
|
32
|
+
this.$analyticsSettingsService = $analyticsSettingsService;
|
|
33
|
+
this.$childProcess = $childProcess;
|
|
34
|
+
this.$projectDataService = $projectDataService;
|
|
35
|
+
this.$mobileHelper = $mobileHelper;
|
|
36
|
+
this.$projectHelper = $projectHelper;
|
|
37
|
+
this.shouldDisposeInstance = true;
|
|
38
|
+
this.analyticsStatuses = {};
|
|
39
|
+
}
|
|
40
|
+
setShouldDispose(shouldDispose) {
|
|
41
|
+
this.shouldDisposeInstance = shouldDispose;
|
|
42
|
+
}
|
|
43
|
+
checkConsent() {
|
|
44
|
+
return __awaiter(this, void 0, void 0, function* () {
|
|
45
|
+
if (yield this.$analyticsSettingsService.canDoRequest()) {
|
|
46
|
+
const initialTrackFeatureUsageStatus = yield this.getStatus(this.$staticConfig.TRACK_FEATURE_USAGE_SETTING_NAME);
|
|
47
|
+
let trackFeatureUsage = initialTrackFeatureUsageStatus === "enabled";
|
|
48
|
+
if ((yield this.isNotConfirmed(this.$staticConfig.TRACK_FEATURE_USAGE_SETTING_NAME)) &&
|
|
49
|
+
(0, helpers_1.isInteractive)()) {
|
|
50
|
+
const message = `Do you want to help us improve ${this.$analyticsSettingsService.getClientName()} by automatically sending anonymous usage statistics? We will not use this information to identify or contact you.`;
|
|
51
|
+
trackFeatureUsage = yield this.$prompter.confirm(message, () => false);
|
|
52
|
+
yield this.setStatus(this.$staticConfig.TRACK_FEATURE_USAGE_SETTING_NAME, trackFeatureUsage);
|
|
53
|
+
yield this.trackAcceptFeatureUsage({
|
|
54
|
+
acceptTrackFeatureUsage: trackFeatureUsage,
|
|
55
|
+
});
|
|
56
|
+
}
|
|
57
|
+
const isErrorReportingUnset = yield this.isNotConfirmed(this.$staticConfig.ERROR_REPORT_SETTING_NAME);
|
|
58
|
+
const isUsageReportingConfirmed = !(yield this.isNotConfirmed(this.$staticConfig.TRACK_FEATURE_USAGE_SETTING_NAME));
|
|
59
|
+
if (isErrorReportingUnset && isUsageReportingConfirmed) {
|
|
60
|
+
yield this.setStatus(this.$staticConfig.ERROR_REPORT_SETTING_NAME, trackFeatureUsage);
|
|
61
|
+
}
|
|
62
|
+
}
|
|
63
|
+
});
|
|
64
|
+
}
|
|
65
|
+
setStatus(settingName, enabled) {
|
|
66
|
+
return __awaiter(this, void 0, void 0, function* () {
|
|
67
|
+
this.analyticsStatuses[settingName] = enabled
|
|
68
|
+
? "enabled"
|
|
69
|
+
: "disabled";
|
|
70
|
+
yield this.$userSettingsService.saveSetting(settingName, enabled.toString());
|
|
71
|
+
});
|
|
72
|
+
}
|
|
73
|
+
isEnabled(settingName) {
|
|
74
|
+
return __awaiter(this, void 0, void 0, function* () {
|
|
75
|
+
const analyticsStatus = yield this.getStatus(settingName);
|
|
76
|
+
return analyticsStatus === "enabled";
|
|
77
|
+
});
|
|
78
|
+
}
|
|
79
|
+
getStatusMessage(settingName, jsonFormat, readableSettingName) {
|
|
80
|
+
if (jsonFormat) {
|
|
81
|
+
return this.getJsonStatusMessage(settingName);
|
|
82
|
+
}
|
|
83
|
+
return this.getHumanReadableStatusMessage(settingName, readableSettingName);
|
|
84
|
+
}
|
|
85
|
+
trackAcceptFeatureUsage(settings) {
|
|
86
|
+
return __awaiter(this, void 0, void 0, function* () {
|
|
87
|
+
const acceptTracking = !!(settings && settings.acceptTrackFeatureUsage);
|
|
88
|
+
const googleAnalyticsEventData = {
|
|
89
|
+
googleAnalyticsDataType: "event",
|
|
90
|
+
action: "Accept Tracking",
|
|
91
|
+
label: acceptTracking.toString(),
|
|
92
|
+
};
|
|
93
|
+
yield this.forcefullyTrackInGoogleAnalytics(googleAnalyticsEventData);
|
|
94
|
+
});
|
|
95
|
+
}
|
|
96
|
+
trackInGoogleAnalytics(gaSettings) {
|
|
97
|
+
return __awaiter(this, void 0, void 0, function* () {
|
|
98
|
+
yield this.initAnalyticsStatuses();
|
|
99
|
+
if (!this.$staticConfig.disableAnalytics &&
|
|
100
|
+
this.analyticsStatuses[this.$staticConfig.TRACK_FEATURE_USAGE_SETTING_NAME] === "enabled") {
|
|
101
|
+
return this.forcefullyTrackInGoogleAnalytics(gaSettings);
|
|
102
|
+
}
|
|
103
|
+
});
|
|
104
|
+
}
|
|
105
|
+
trackEventActionInGoogleAnalytics(data) {
|
|
106
|
+
return __awaiter(this, void 0, void 0, function* () {
|
|
107
|
+
const device = data.device;
|
|
108
|
+
const platform = device ? device.deviceInfo.platform : data.platform;
|
|
109
|
+
const normalizedPlatform = platform
|
|
110
|
+
? this.$mobileHelper.normalizePlatformName(platform)
|
|
111
|
+
: platform;
|
|
112
|
+
const isForDevice = device ? !device.isEmulator : data.isForDevice;
|
|
113
|
+
let label = "";
|
|
114
|
+
label = this.addDataToLabel(label, normalizedPlatform);
|
|
115
|
+
if (isForDevice !== null && isForDevice !== undefined) {
|
|
116
|
+
const deviceType = isForDevice
|
|
117
|
+
? constants_1.DeviceTypes.Device
|
|
118
|
+
: this.$mobileHelper.isAndroidPlatform(platform)
|
|
119
|
+
? constants_1.DeviceTypes.Emulator
|
|
120
|
+
: constants_1.DeviceTypes.Simulator;
|
|
121
|
+
label = this.addDataToLabel(label, deviceType);
|
|
122
|
+
}
|
|
123
|
+
if (device) {
|
|
124
|
+
label = this.addDataToLabel(label, device.deviceInfo.version);
|
|
125
|
+
}
|
|
126
|
+
if (data.additionalData) {
|
|
127
|
+
label = this.addDataToLabel(label, data.additionalData);
|
|
128
|
+
}
|
|
129
|
+
const customDimensions = {};
|
|
130
|
+
this.setProjectRelatedCustomDimensions(customDimensions, data.projectDir);
|
|
131
|
+
const googleAnalyticsEventData = {
|
|
132
|
+
googleAnalyticsDataType: "event",
|
|
133
|
+
action: data.action,
|
|
134
|
+
label,
|
|
135
|
+
customDimensions,
|
|
136
|
+
value: data.value,
|
|
137
|
+
};
|
|
138
|
+
yield this.trackInGoogleAnalytics(googleAnalyticsEventData);
|
|
139
|
+
});
|
|
140
|
+
}
|
|
141
|
+
finishTracking() {
|
|
142
|
+
return __awaiter(this, void 0, void 0, function* () {
|
|
143
|
+
return new Promise((resolve, reject) => {
|
|
144
|
+
if (this.brokerProcess && this.brokerProcess.connected) {
|
|
145
|
+
let timer;
|
|
146
|
+
const handler = (data) => {
|
|
147
|
+
if (data === "ProcessFinishedTasks") {
|
|
148
|
+
this.brokerProcess.removeListener("message", handler);
|
|
149
|
+
clearTimeout(timer);
|
|
150
|
+
resolve();
|
|
151
|
+
}
|
|
152
|
+
};
|
|
153
|
+
timer = setTimeout(() => {
|
|
154
|
+
this.brokerProcess.removeListener("message", handler);
|
|
155
|
+
resolve();
|
|
156
|
+
}, 3000);
|
|
157
|
+
this.brokerProcess.on("message", handler);
|
|
158
|
+
const msg = { type: "FinishTracking" };
|
|
159
|
+
this.brokerProcess.send(msg, (err) => this.$logger.trace(`Error while sending ${JSON.stringify(msg)}`));
|
|
160
|
+
}
|
|
161
|
+
else {
|
|
162
|
+
resolve();
|
|
163
|
+
}
|
|
164
|
+
});
|
|
165
|
+
});
|
|
166
|
+
}
|
|
167
|
+
forcefullyTrackInGoogleAnalytics(gaSettings) {
|
|
168
|
+
gaSettings.customDimensions = gaSettings.customDimensions || {};
|
|
169
|
+
gaSettings.customDimensions["cd5"] =
|
|
170
|
+
this.$options.analyticsClient ||
|
|
171
|
+
((0, helpers_1.isInteractive)() ? "CLI" : "Unknown");
|
|
172
|
+
this.setProjectRelatedCustomDimensions(gaSettings.customDimensions);
|
|
173
|
+
const googleAnalyticsData = _.merge({
|
|
174
|
+
type: "googleAnalyticsData",
|
|
175
|
+
category: "CLI",
|
|
176
|
+
}, gaSettings);
|
|
177
|
+
this.$logger.trace("Will send the following information to Google Analytics:", googleAnalyticsData);
|
|
178
|
+
return this.sendMessageToBroker(googleAnalyticsData);
|
|
179
|
+
}
|
|
180
|
+
setProjectRelatedCustomDimensions(customDimensions, projectDir) {
|
|
181
|
+
if (!projectDir) {
|
|
182
|
+
try {
|
|
183
|
+
projectDir = this.$projectHelper.projectDir;
|
|
184
|
+
}
|
|
185
|
+
catch (err) {
|
|
186
|
+
this.$logger.trace("Unable to get the projectDir from projectHelper", err);
|
|
187
|
+
}
|
|
188
|
+
}
|
|
189
|
+
if (projectDir) {
|
|
190
|
+
const projectData = this.$projectDataService.getProjectData(projectDir);
|
|
191
|
+
customDimensions["cd2"] =
|
|
192
|
+
projectData.projectType;
|
|
193
|
+
customDimensions["cd9"] = projectData.isShared.toString();
|
|
194
|
+
}
|
|
195
|
+
return customDimensions;
|
|
196
|
+
}
|
|
197
|
+
dispose() {
|
|
198
|
+
if (this.brokerProcess && this.shouldDisposeInstance) {
|
|
199
|
+
this.brokerProcess.disconnect();
|
|
200
|
+
}
|
|
201
|
+
}
|
|
202
|
+
addDataToLabel(label, newData) {
|
|
203
|
+
if (newData && label) {
|
|
204
|
+
return `${label}_${newData}`;
|
|
205
|
+
}
|
|
206
|
+
return label || newData || "";
|
|
207
|
+
}
|
|
208
|
+
getAnalyticsBroker() {
|
|
209
|
+
return new Promise((resolve, reject) => {
|
|
210
|
+
const brokerProcessArgs = this.getBrokerProcessArgs();
|
|
211
|
+
const broker = this.$childProcess.spawn(process.execPath, brokerProcessArgs, {
|
|
212
|
+
stdio: ["ignore", "ignore", "ignore", "ipc"],
|
|
213
|
+
detached: true,
|
|
214
|
+
});
|
|
215
|
+
broker.unref();
|
|
216
|
+
let isSettled = false;
|
|
217
|
+
const timeoutId = setTimeout(() => {
|
|
218
|
+
if (!isSettled) {
|
|
219
|
+
reject(new Error("Unable to start Analytics Broker process."));
|
|
220
|
+
}
|
|
221
|
+
}, AnalyticsService.ANALYTICS_BROKER_START_TIMEOUT);
|
|
222
|
+
broker.on("error", (err) => {
|
|
223
|
+
clearTimeout(timeoutId);
|
|
224
|
+
if (!isSettled) {
|
|
225
|
+
isSettled = true;
|
|
226
|
+
reject(err);
|
|
227
|
+
}
|
|
228
|
+
});
|
|
229
|
+
broker.on("message", (data) => {
|
|
230
|
+
if (data === "ProcessReadyToReceive") {
|
|
231
|
+
clearTimeout(timeoutId);
|
|
232
|
+
if (!isSettled) {
|
|
233
|
+
isSettled = true;
|
|
234
|
+
this.brokerProcess = broker;
|
|
235
|
+
resolve(broker);
|
|
236
|
+
}
|
|
237
|
+
}
|
|
238
|
+
});
|
|
239
|
+
});
|
|
240
|
+
}
|
|
241
|
+
getBrokerProcessArgs() {
|
|
242
|
+
const brokerProcessArgs = [
|
|
243
|
+
path.join(__dirname, "analytics-broker-process.js"),
|
|
244
|
+
this.$staticConfig.PATH_TO_BOOTSTRAP,
|
|
245
|
+
];
|
|
246
|
+
if (this.$options.analyticsLogFile) {
|
|
247
|
+
brokerProcessArgs.push(this.$options.analyticsLogFile);
|
|
248
|
+
}
|
|
249
|
+
return brokerProcessArgs;
|
|
250
|
+
}
|
|
251
|
+
sendInfoForTracking(trackingInfo, settingName) {
|
|
252
|
+
return __awaiter(this, void 0, void 0, function* () {
|
|
253
|
+
yield this.initAnalyticsStatuses();
|
|
254
|
+
if (!this.$staticConfig.disableAnalytics &&
|
|
255
|
+
this.analyticsStatuses[settingName] === "enabled") {
|
|
256
|
+
return this.sendMessageToBroker(trackingInfo);
|
|
257
|
+
}
|
|
258
|
+
});
|
|
259
|
+
}
|
|
260
|
+
sendMessageToBroker(message) {
|
|
261
|
+
return __awaiter(this, void 0, void 0, function* () {
|
|
262
|
+
let broker;
|
|
263
|
+
try {
|
|
264
|
+
broker = yield this.getAnalyticsBroker();
|
|
265
|
+
}
|
|
266
|
+
catch (err) {
|
|
267
|
+
this.$logger.trace("Unable to get broker instance due to error: ", err);
|
|
268
|
+
return;
|
|
269
|
+
}
|
|
270
|
+
return new Promise((resolve, reject) => {
|
|
271
|
+
if (broker && broker.connected) {
|
|
272
|
+
try {
|
|
273
|
+
broker.send(message, (error) => resolve());
|
|
274
|
+
}
|
|
275
|
+
catch (err) {
|
|
276
|
+
this.$logger.trace("Error while trying to send message to broker:", err);
|
|
277
|
+
resolve();
|
|
278
|
+
}
|
|
279
|
+
}
|
|
280
|
+
else {
|
|
281
|
+
this.$logger.trace("Broker not found or not connected.");
|
|
282
|
+
resolve();
|
|
283
|
+
}
|
|
284
|
+
});
|
|
285
|
+
});
|
|
286
|
+
}
|
|
287
|
+
initAnalyticsStatuses() {
|
|
288
|
+
return __awaiter(this, void 0, void 0, function* () {
|
|
289
|
+
if (yield this.$analyticsSettingsService.canDoRequest()) {
|
|
290
|
+
this.$logger.trace("Initializing analytics statuses.");
|
|
291
|
+
const settingsNames = [
|
|
292
|
+
this.$staticConfig.TRACK_FEATURE_USAGE_SETTING_NAME,
|
|
293
|
+
this.$staticConfig.ERROR_REPORT_SETTING_NAME,
|
|
294
|
+
];
|
|
295
|
+
for (const settingName of settingsNames) {
|
|
296
|
+
yield this.getStatus(settingName);
|
|
297
|
+
}
|
|
298
|
+
this.$logger.trace("Analytics statuses: ", this.analyticsStatuses);
|
|
299
|
+
}
|
|
300
|
+
});
|
|
301
|
+
}
|
|
302
|
+
getStatus(settingName) {
|
|
303
|
+
return __awaiter(this, void 0, void 0, function* () {
|
|
304
|
+
if (!_.has(this.analyticsStatuses, settingName)) {
|
|
305
|
+
const settingValue = yield this.$userSettingsService.getSettingValue(settingName);
|
|
306
|
+
if (settingValue) {
|
|
307
|
+
const isEnabled = (0, helpers_1.toBoolean)(settingValue);
|
|
308
|
+
if (isEnabled) {
|
|
309
|
+
this.analyticsStatuses[settingName] = "enabled";
|
|
310
|
+
}
|
|
311
|
+
else {
|
|
312
|
+
this.analyticsStatuses[settingName] = "disabled";
|
|
313
|
+
}
|
|
314
|
+
}
|
|
315
|
+
else {
|
|
316
|
+
this.analyticsStatuses[settingName] = "not confirmed";
|
|
317
|
+
}
|
|
318
|
+
}
|
|
319
|
+
return this.analyticsStatuses[settingName];
|
|
320
|
+
});
|
|
321
|
+
}
|
|
322
|
+
isNotConfirmed(settingName) {
|
|
323
|
+
return __awaiter(this, void 0, void 0, function* () {
|
|
324
|
+
const analyticsStatus = yield this.getStatus(settingName);
|
|
325
|
+
return analyticsStatus === "not confirmed";
|
|
326
|
+
});
|
|
327
|
+
}
|
|
328
|
+
getHumanReadableStatusMessage(settingName, readableSettingName) {
|
|
329
|
+
return __awaiter(this, void 0, void 0, function* () {
|
|
330
|
+
let status = null;
|
|
331
|
+
if (yield this.isNotConfirmed(settingName)) {
|
|
332
|
+
status = "disabled until confirmed";
|
|
333
|
+
}
|
|
334
|
+
else {
|
|
335
|
+
status = yield this.getStatus(settingName);
|
|
336
|
+
}
|
|
337
|
+
return `${readableSettingName} is ${status}.`;
|
|
338
|
+
});
|
|
339
|
+
}
|
|
340
|
+
getJsonStatusMessage(settingName) {
|
|
341
|
+
return __awaiter(this, void 0, void 0, function* () {
|
|
342
|
+
const status = yield this.getStatus(settingName);
|
|
343
|
+
const enabled = status === "not confirmed"
|
|
344
|
+
? null
|
|
345
|
+
: status === "enabled";
|
|
346
|
+
return JSON.stringify({ enabled });
|
|
347
|
+
});
|
|
348
|
+
}
|
|
349
|
+
trackException(exception, message) {
|
|
350
|
+
const data = {
|
|
351
|
+
type: "exception",
|
|
352
|
+
exception,
|
|
353
|
+
message,
|
|
354
|
+
};
|
|
355
|
+
return this.sendInfoForTracking(data, this.$staticConfig.ERROR_REPORT_SETTING_NAME);
|
|
356
|
+
}
|
|
357
|
+
}
|
|
358
|
+
AnalyticsService.ANALYTICS_BROKER_START_TIMEOUT = 10 * 1000;
|
|
359
|
+
__decorate([
|
|
360
|
+
(0, decorators_1.cache)()
|
|
361
|
+
], AnalyticsService.prototype, "getAnalyticsBroker", null);
|
|
362
|
+
__decorate([
|
|
363
|
+
(0, decorators_1.cache)()
|
|
364
|
+
], AnalyticsService.prototype, "initAnalyticsStatuses", null);
|
|
365
|
+
exports.AnalyticsService = AnalyticsService;
|
|
366
|
+
yok_1.injector.register("analyticsService", AnalyticsService);
|
|
@@ -0,0 +1,55 @@
|
|
|
1
|
+
import { TrackingTypes } from "../../common/declarations";
|
|
2
|
+
import { IGoogleAnalyticsData } from "../../common/definitions/google-analytics";
|
|
3
|
+
|
|
4
|
+
/**
|
|
5
|
+
* Describes the information that will be passed to analytics for tracking.
|
|
6
|
+
*/
|
|
7
|
+
interface ITrackingInformation {
|
|
8
|
+
/**
|
|
9
|
+
* The type of the data sent to analytics service - initalization data, feature to be tracked, error to be tracked, etc.
|
|
10
|
+
*/
|
|
11
|
+
type: TrackingTypes;
|
|
12
|
+
}
|
|
13
|
+
|
|
14
|
+
/**
|
|
15
|
+
* Describes information for exception that should be tracked.
|
|
16
|
+
*/
|
|
17
|
+
interface IExceptionsTrackingInformation extends ITrackingInformation {
|
|
18
|
+
/**
|
|
19
|
+
* The exception that should be tracked.
|
|
20
|
+
*/
|
|
21
|
+
exception: Error;
|
|
22
|
+
|
|
23
|
+
/**
|
|
24
|
+
* The message of the error that should be tracked.
|
|
25
|
+
*/
|
|
26
|
+
message: string;
|
|
27
|
+
}
|
|
28
|
+
|
|
29
|
+
/**
|
|
30
|
+
* Describes the broker used to pass information to all analytics providers.
|
|
31
|
+
*/
|
|
32
|
+
interface IAnalyticsBroker {
|
|
33
|
+
/**
|
|
34
|
+
* Sends the specified tracking information to all providers.
|
|
35
|
+
* @param {ITrackingInformation} trackInfo The information that should be passed to all providers.
|
|
36
|
+
* @returns {Promise<void>}
|
|
37
|
+
*/
|
|
38
|
+
sendDataForTracking(trackInfo: ITrackingInformation): Promise<void>;
|
|
39
|
+
}
|
|
40
|
+
|
|
41
|
+
interface IGoogleAnalyticsTrackingInformation
|
|
42
|
+
extends IGoogleAnalyticsData,
|
|
43
|
+
ITrackingInformation {}
|
|
44
|
+
|
|
45
|
+
/**
|
|
46
|
+
* Describes methods required to track in Google Analytics.
|
|
47
|
+
*/
|
|
48
|
+
interface IGoogleAnalyticsProvider {
|
|
49
|
+
/**
|
|
50
|
+
* Tracks hit types.
|
|
51
|
+
* @param {IGoogleAnalyticsData} data Data that has to be tracked.
|
|
52
|
+
* @returns {Promise<void>}
|
|
53
|
+
*/
|
|
54
|
+
trackHit(data: IGoogleAnalyticsData): Promise<void>;
|
|
55
|
+
}
|
|
@@ -0,0 +1,152 @@
|
|
|
1
|
+
"use strict";
|
|
2
|
+
var __decorate = (this && this.__decorate) || function (decorators, target, key, desc) {
|
|
3
|
+
var c = arguments.length, r = c < 3 ? target : desc === null ? desc = Object.getOwnPropertyDescriptor(target, key) : desc, d;
|
|
4
|
+
if (typeof Reflect === "object" && typeof Reflect.decorate === "function") r = Reflect.decorate(decorators, target, key, desc);
|
|
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
|
+
return c > 3 && r && Object.defineProperty(target, key, r), r;
|
|
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
|
+
Object.defineProperty(exports, "__esModule", { value: true });
|
|
18
|
+
exports.GoogleAnalyticsProvider = void 0;
|
|
19
|
+
const uuid_1 = require("uuid");
|
|
20
|
+
const ua = require("universal-analytics");
|
|
21
|
+
const decorators_1 = require("../../common/decorators");
|
|
22
|
+
const _ = require("lodash");
|
|
23
|
+
const yok_1 = require("../../common/yok");
|
|
24
|
+
class GoogleAnalyticsProvider {
|
|
25
|
+
constructor(clientId, $staticConfig, $analyticsSettingsService, $logger, $proxyService, $config, analyticsLoggingService) {
|
|
26
|
+
this.clientId = clientId;
|
|
27
|
+
this.$staticConfig = $staticConfig;
|
|
28
|
+
this.$analyticsSettingsService = $analyticsSettingsService;
|
|
29
|
+
this.$logger = $logger;
|
|
30
|
+
this.$proxyService = $proxyService;
|
|
31
|
+
this.$config = $config;
|
|
32
|
+
this.analyticsLoggingService = analyticsLoggingService;
|
|
33
|
+
}
|
|
34
|
+
trackHit(trackInfo) {
|
|
35
|
+
return __awaiter(this, void 0, void 0, function* () {
|
|
36
|
+
const sessionId = (0, uuid_1.v4)();
|
|
37
|
+
try {
|
|
38
|
+
yield this.track(this.$config.GA_TRACKING_ID, trackInfo, sessionId);
|
|
39
|
+
}
|
|
40
|
+
catch (e) {
|
|
41
|
+
this.analyticsLoggingService.logData({
|
|
42
|
+
type: "Error",
|
|
43
|
+
message: `Unable to track information ${JSON.stringify(trackInfo)}. Error is: ${e}`,
|
|
44
|
+
});
|
|
45
|
+
this.$logger.trace("Analytics exception: ", e);
|
|
46
|
+
}
|
|
47
|
+
});
|
|
48
|
+
}
|
|
49
|
+
getVisitor(gaTrackingId, proxy) {
|
|
50
|
+
this.analyticsLoggingService.logData({
|
|
51
|
+
message: `Initializing Google Analytics visitor for id: ${gaTrackingId} with clientId: ${this.clientId}.`,
|
|
52
|
+
});
|
|
53
|
+
const visitor = ua({
|
|
54
|
+
tid: gaTrackingId,
|
|
55
|
+
cid: this.clientId,
|
|
56
|
+
headers: {
|
|
57
|
+
["User-Agent"]: this.$analyticsSettingsService.getUserAgentString(`tnsCli/${this.$staticConfig.version}`),
|
|
58
|
+
},
|
|
59
|
+
requestOptions: {
|
|
60
|
+
proxy,
|
|
61
|
+
},
|
|
62
|
+
https: true,
|
|
63
|
+
});
|
|
64
|
+
this.analyticsLoggingService.logData({
|
|
65
|
+
message: `Successfully initialized Google Analytics visitor for id: ${gaTrackingId} with clientId: ${this.clientId}.`,
|
|
66
|
+
});
|
|
67
|
+
return visitor;
|
|
68
|
+
}
|
|
69
|
+
track(gaTrackingId, trackInfo, sessionId) {
|
|
70
|
+
return __awaiter(this, void 0, void 0, function* () {
|
|
71
|
+
const proxySettings = yield this.$proxyService.getCache();
|
|
72
|
+
const proxy = proxySettings && proxySettings.proxy;
|
|
73
|
+
const visitor = this.getVisitor(gaTrackingId, proxy);
|
|
74
|
+
yield this.setCustomDimensions(visitor, trackInfo.customDimensions, sessionId);
|
|
75
|
+
switch (trackInfo.googleAnalyticsDataType) {
|
|
76
|
+
case "pageview":
|
|
77
|
+
yield this.trackPageView(visitor, trackInfo);
|
|
78
|
+
break;
|
|
79
|
+
case "event":
|
|
80
|
+
yield this.trackEvent(visitor, trackInfo);
|
|
81
|
+
break;
|
|
82
|
+
}
|
|
83
|
+
});
|
|
84
|
+
}
|
|
85
|
+
setCustomDimensions(visitor, customDimensions, sessionId) {
|
|
86
|
+
return __awaiter(this, void 0, void 0, function* () {
|
|
87
|
+
const defaultValues = {
|
|
88
|
+
["cd1"]: this.$staticConfig.version,
|
|
89
|
+
["cd6"]: process.version,
|
|
90
|
+
["cd3"]: this.clientId,
|
|
91
|
+
["cd2"]: null,
|
|
92
|
+
["cd9"]: null,
|
|
93
|
+
["cd4"]: sessionId,
|
|
94
|
+
["cd5"]: "Unknown",
|
|
95
|
+
};
|
|
96
|
+
customDimensions = _.merge(defaultValues, customDimensions);
|
|
97
|
+
_.each(customDimensions, (value, key) => {
|
|
98
|
+
this.analyticsLoggingService.logData({
|
|
99
|
+
message: `Setting custom dimension ${key} to value ${value}`,
|
|
100
|
+
});
|
|
101
|
+
visitor.set(key, value);
|
|
102
|
+
});
|
|
103
|
+
});
|
|
104
|
+
}
|
|
105
|
+
trackEvent(visitor, trackInfo) {
|
|
106
|
+
return new Promise((resolve, reject) => {
|
|
107
|
+
visitor.event(trackInfo.category, trackInfo.action, trackInfo.label, trackInfo.value, { p: this.currentPage }, (err) => {
|
|
108
|
+
if (err) {
|
|
109
|
+
this.analyticsLoggingService.logData({
|
|
110
|
+
message: `Unable to track event with category: '${trackInfo.category}', action: '${trackInfo.action}', label: '${trackInfo.label}', ` +
|
|
111
|
+
`value: '${trackInfo.value}' attached page: ${this.currentPage}. Error is: ${err}.`,
|
|
112
|
+
type: "Error",
|
|
113
|
+
});
|
|
114
|
+
reject(err);
|
|
115
|
+
return;
|
|
116
|
+
}
|
|
117
|
+
this.analyticsLoggingService.logData({
|
|
118
|
+
message: `Tracked event with category: '${trackInfo.category}', action: '${trackInfo.action}', label: '${trackInfo.label}', value: '${trackInfo.value}' attached page: ${this.currentPage}.`,
|
|
119
|
+
});
|
|
120
|
+
resolve();
|
|
121
|
+
});
|
|
122
|
+
});
|
|
123
|
+
}
|
|
124
|
+
trackPageView(visitor, trackInfo) {
|
|
125
|
+
return new Promise((resolve, reject) => {
|
|
126
|
+
this.currentPage = trackInfo.path;
|
|
127
|
+
const pageViewData = {
|
|
128
|
+
dp: trackInfo.path,
|
|
129
|
+
dt: trackInfo.title,
|
|
130
|
+
};
|
|
131
|
+
visitor.pageview(pageViewData, (err) => {
|
|
132
|
+
if (err) {
|
|
133
|
+
this.analyticsLoggingService.logData({
|
|
134
|
+
message: `Unable to track pageview with path '${trackInfo.path}' and title: '${trackInfo.title}' Error is: ${err}.`,
|
|
135
|
+
type: "Error",
|
|
136
|
+
});
|
|
137
|
+
reject(err);
|
|
138
|
+
return;
|
|
139
|
+
}
|
|
140
|
+
this.analyticsLoggingService.logData({
|
|
141
|
+
message: `Tracked pageview with path '${trackInfo.path}' and title: '${trackInfo.title}'.`,
|
|
142
|
+
});
|
|
143
|
+
resolve();
|
|
144
|
+
});
|
|
145
|
+
});
|
|
146
|
+
}
|
|
147
|
+
}
|
|
148
|
+
__decorate([
|
|
149
|
+
(0, decorators_1.cache)()
|
|
150
|
+
], GoogleAnalyticsProvider.prototype, "getVisitor", null);
|
|
151
|
+
exports.GoogleAnalyticsProvider = GoogleAnalyticsProvider;
|
|
152
|
+
yok_1.injector.register("googleAnalyticsProvider", GoogleAnalyticsProvider);
|
|
@@ -0,0 +1,104 @@
|
|
|
1
|
+
"use strict";
|
|
2
|
+
var __decorate = (this && this.__decorate) || function (decorators, target, key, desc) {
|
|
3
|
+
var c = arguments.length, r = c < 3 ? target : desc === null ? desc = Object.getOwnPropertyDescriptor(target, key) : desc, d;
|
|
4
|
+
if (typeof Reflect === "object" && typeof Reflect.decorate === "function") r = Reflect.decorate(decorators, target, key, desc);
|
|
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
|
+
return c > 3 && r && Object.defineProperty(target, key, r), r;
|
|
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
|
+
Object.defineProperty(exports, "__esModule", { value: true });
|
|
18
|
+
const helpers_1 = require("../common/helpers");
|
|
19
|
+
const decorators_1 = require("../common/decorators");
|
|
20
|
+
const _ = require("lodash");
|
|
21
|
+
const yok_1 = require("../common/yok");
|
|
22
|
+
const color_1 = require("../color");
|
|
23
|
+
class AnalyticsSettingsService {
|
|
24
|
+
constructor($userSettingsService, $staticConfig, $hostInfo, $osInfo, $logger) {
|
|
25
|
+
this.$userSettingsService = $userSettingsService;
|
|
26
|
+
this.$staticConfig = $staticConfig;
|
|
27
|
+
this.$hostInfo = $hostInfo;
|
|
28
|
+
this.$osInfo = $osInfo;
|
|
29
|
+
this.$logger = $logger;
|
|
30
|
+
}
|
|
31
|
+
canDoRequest() {
|
|
32
|
+
return __awaiter(this, void 0, void 0, function* () {
|
|
33
|
+
return true;
|
|
34
|
+
});
|
|
35
|
+
}
|
|
36
|
+
getUserId() {
|
|
37
|
+
return this.getSettingValueOrDefault("USER_ID");
|
|
38
|
+
}
|
|
39
|
+
getClientId() {
|
|
40
|
+
return this.getSettingValueOrDefault(this.$staticConfig.ANALYTICS_INSTALLATION_ID_SETTING_NAME);
|
|
41
|
+
}
|
|
42
|
+
getClientName() {
|
|
43
|
+
return "" + color_1.color.cyan.bold(this.$staticConfig.CLIENT_NAME_ALIAS);
|
|
44
|
+
}
|
|
45
|
+
getUserSessionsCount(projectName) {
|
|
46
|
+
return __awaiter(this, void 0, void 0, function* () {
|
|
47
|
+
const sessionsCountForProject = yield this.$userSettingsService.getSettingValue(this.getSessionsProjectKey(projectName));
|
|
48
|
+
return sessionsCountForProject || 0;
|
|
49
|
+
});
|
|
50
|
+
}
|
|
51
|
+
setUserSessionsCount(count, projectName) {
|
|
52
|
+
return __awaiter(this, void 0, void 0, function* () {
|
|
53
|
+
return this.$userSettingsService.saveSetting(this.getSessionsProjectKey(projectName), count);
|
|
54
|
+
});
|
|
55
|
+
}
|
|
56
|
+
getUserAgentString(identifier) {
|
|
57
|
+
let osString = "";
|
|
58
|
+
const osRelease = this.$osInfo.release();
|
|
59
|
+
if (this.$hostInfo.isWindows) {
|
|
60
|
+
osString = `Windows NT ${osRelease}`;
|
|
61
|
+
}
|
|
62
|
+
else if (this.$hostInfo.isDarwin) {
|
|
63
|
+
osString = `Macintosh`;
|
|
64
|
+
const macRelease = this.getMacOSReleaseVersion(osRelease);
|
|
65
|
+
if (macRelease) {
|
|
66
|
+
osString += `; Intel Mac OS X ${macRelease}`;
|
|
67
|
+
}
|
|
68
|
+
}
|
|
69
|
+
else {
|
|
70
|
+
osString = `Linux x86`;
|
|
71
|
+
if (this.$osInfo.arch() === "x64") {
|
|
72
|
+
osString += "_64";
|
|
73
|
+
}
|
|
74
|
+
}
|
|
75
|
+
const userAgent = `${identifier} (${osString}; ${this.$osInfo.arch()})`;
|
|
76
|
+
return userAgent;
|
|
77
|
+
}
|
|
78
|
+
getMacOSReleaseVersion(osRelease) {
|
|
79
|
+
const majorVersion = osRelease && _.first(osRelease.split("."));
|
|
80
|
+
return majorVersion && `10.${+majorVersion - 4}`;
|
|
81
|
+
}
|
|
82
|
+
getSessionsProjectKey(projectName) {
|
|
83
|
+
return `${AnalyticsSettingsService.SESSIONS_STARTED_KEY_PREFIX}${projectName}`;
|
|
84
|
+
}
|
|
85
|
+
getSettingValueOrDefault(settingName) {
|
|
86
|
+
return __awaiter(this, void 0, void 0, function* () {
|
|
87
|
+
let guid = yield this.$userSettingsService.getSettingValue(settingName);
|
|
88
|
+
if (!guid) {
|
|
89
|
+
guid = (0, helpers_1.createGUID)(false);
|
|
90
|
+
this.$logger.trace(`Setting new ${settingName}: ${guid}.`);
|
|
91
|
+
yield this.$userSettingsService.saveSetting(settingName, guid);
|
|
92
|
+
}
|
|
93
|
+
return guid;
|
|
94
|
+
});
|
|
95
|
+
}
|
|
96
|
+
}
|
|
97
|
+
AnalyticsSettingsService.SESSIONS_STARTED_KEY_PREFIX = "SESSIONS_STARTED_";
|
|
98
|
+
__decorate([
|
|
99
|
+
(0, decorators_1.exported)("analyticsSettingsService")
|
|
100
|
+
], AnalyticsSettingsService.prototype, "getClientId", null);
|
|
101
|
+
__decorate([
|
|
102
|
+
(0, decorators_1.exported)("analyticsSettingsService")
|
|
103
|
+
], AnalyticsSettingsService.prototype, "getUserAgentString", null);
|
|
104
|
+
yok_1.injector.register("analyticsSettingsService", AnalyticsSettingsService);
|