@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,133 @@
|
|
|
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.HostInfo = void 0;
|
|
19
|
+
const decorators_1 = require("./decorators");
|
|
20
|
+
const _ = require("lodash");
|
|
21
|
+
const yok_1 = require("./yok");
|
|
22
|
+
class HostInfo {
|
|
23
|
+
get $childProcess() {
|
|
24
|
+
return this.$injector.resolve("childProcess");
|
|
25
|
+
}
|
|
26
|
+
get $osInfo() {
|
|
27
|
+
return this.$injector.resolve("osInfo");
|
|
28
|
+
}
|
|
29
|
+
get $logger() {
|
|
30
|
+
return this.$injector.resolve("logger");
|
|
31
|
+
}
|
|
32
|
+
constructor($errors, $injector) {
|
|
33
|
+
this.$errors = $errors;
|
|
34
|
+
this.$injector = $injector;
|
|
35
|
+
}
|
|
36
|
+
get isWindows() {
|
|
37
|
+
return process.platform === HostInfo.WIN32_NAME;
|
|
38
|
+
}
|
|
39
|
+
get isWindows64() {
|
|
40
|
+
return (this.isWindows &&
|
|
41
|
+
(process.arch === "x64" ||
|
|
42
|
+
process.env.hasOwnProperty(HostInfo.PROCESSOR_ARCHITEW6432)));
|
|
43
|
+
}
|
|
44
|
+
get isWindows32() {
|
|
45
|
+
return this.isWindows && !this.isWindows64;
|
|
46
|
+
}
|
|
47
|
+
get isDarwin() {
|
|
48
|
+
return process.platform === HostInfo.DARWIN_OS_NAME;
|
|
49
|
+
}
|
|
50
|
+
get isLinux() {
|
|
51
|
+
return process.platform === HostInfo.LINUX_OS_NAME;
|
|
52
|
+
}
|
|
53
|
+
get isLinux64() {
|
|
54
|
+
return this.isLinux && process.config.variables.host_arch === "x64";
|
|
55
|
+
}
|
|
56
|
+
getMacOSVersion() {
|
|
57
|
+
return __awaiter(this, void 0, void 0, function* () {
|
|
58
|
+
if (!this.isDarwin) {
|
|
59
|
+
return null;
|
|
60
|
+
}
|
|
61
|
+
const systemProfileCommand = "system_profiler SPSoftwareDataType -detailLevel mini";
|
|
62
|
+
this.$logger.trace("Trying to get macOS version.");
|
|
63
|
+
let macOSVersion;
|
|
64
|
+
try {
|
|
65
|
+
const systemProfileOutput = yield this.$childProcess.exec(systemProfileCommand);
|
|
66
|
+
const versionRegExp = /System Version:\s+?macOS\s+?(\d+\.\d+)(\.\d+)?\s+/g;
|
|
67
|
+
const regExpMatchers = versionRegExp.exec(systemProfileOutput);
|
|
68
|
+
macOSVersion = regExpMatchers && regExpMatchers[1];
|
|
69
|
+
if (macOSVersion) {
|
|
70
|
+
this.$logger.trace(`macOS version based on system_profiler is ${macOSVersion}.`);
|
|
71
|
+
return macOSVersion;
|
|
72
|
+
}
|
|
73
|
+
this.$logger.trace(`Unable to get macOS version from ${systemProfileCommand} output.`);
|
|
74
|
+
}
|
|
75
|
+
catch (err) {
|
|
76
|
+
this.$logger.trace(`Unable to get macOS version from ${systemProfileCommand}. Error is: ${err}`);
|
|
77
|
+
}
|
|
78
|
+
const osRelease = this.$osInfo.release();
|
|
79
|
+
const majorVersion = osRelease && _.first(osRelease.split("."));
|
|
80
|
+
macOSVersion = majorVersion && `10.${+majorVersion - 4}`;
|
|
81
|
+
this.$logger.trace(`macOS version based on os.release() (${osRelease}) is ${macOSVersion}.`);
|
|
82
|
+
return macOSVersion;
|
|
83
|
+
});
|
|
84
|
+
}
|
|
85
|
+
dotNetVersion() {
|
|
86
|
+
if (this.isWindows) {
|
|
87
|
+
return new Promise((resolve, reject) => {
|
|
88
|
+
const Winreg = require("winreg");
|
|
89
|
+
const regKey = new Winreg({
|
|
90
|
+
hive: Winreg.HKLM,
|
|
91
|
+
key: HostInfo.DOT_NET_REGISTRY_PATH,
|
|
92
|
+
});
|
|
93
|
+
regKey.get("Version", (err, value) => {
|
|
94
|
+
if (err) {
|
|
95
|
+
reject(err);
|
|
96
|
+
}
|
|
97
|
+
else {
|
|
98
|
+
resolve(value.value);
|
|
99
|
+
}
|
|
100
|
+
});
|
|
101
|
+
});
|
|
102
|
+
}
|
|
103
|
+
else {
|
|
104
|
+
return Promise.resolve(null);
|
|
105
|
+
}
|
|
106
|
+
}
|
|
107
|
+
isDotNet40Installed(message) {
|
|
108
|
+
return __awaiter(this, void 0, void 0, function* () {
|
|
109
|
+
if (this.isWindows) {
|
|
110
|
+
try {
|
|
111
|
+
yield this.dotNetVersion();
|
|
112
|
+
return true;
|
|
113
|
+
}
|
|
114
|
+
catch (e) {
|
|
115
|
+
this.$errors.fail(message || "An error occurred while reading the registry.");
|
|
116
|
+
}
|
|
117
|
+
}
|
|
118
|
+
else {
|
|
119
|
+
return false;
|
|
120
|
+
}
|
|
121
|
+
});
|
|
122
|
+
}
|
|
123
|
+
}
|
|
124
|
+
HostInfo.WIN32_NAME = "win32";
|
|
125
|
+
HostInfo.PROCESSOR_ARCHITEW6432 = "PROCESSOR_ARCHITEW6432";
|
|
126
|
+
HostInfo.DARWIN_OS_NAME = "darwin";
|
|
127
|
+
HostInfo.LINUX_OS_NAME = "linux";
|
|
128
|
+
HostInfo.DOT_NET_REGISTRY_PATH = "\\Software\\Microsoft\\NET Framework Setup\\NDP\\v4\\Client";
|
|
129
|
+
__decorate([
|
|
130
|
+
(0, decorators_1.cache)()
|
|
131
|
+
], HostInfo.prototype, "getMacOSVersion", null);
|
|
132
|
+
exports.HostInfo = HostInfo;
|
|
133
|
+
yok_1.injector.register("hostInfo", HostInfo);
|
|
@@ -0,0 +1,173 @@
|
|
|
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
|
+
Object.defineProperty(exports, "__esModule", { value: true });
|
|
12
|
+
exports.HttpClient = void 0;
|
|
13
|
+
const _ = require("lodash");
|
|
14
|
+
const os_1 = require("os");
|
|
15
|
+
const util = require("util");
|
|
16
|
+
const yok_1 = require("./yok");
|
|
17
|
+
const axios_1 = require("axios");
|
|
18
|
+
const constants_1 = require("./constants");
|
|
19
|
+
const tunnel = require("tunnel");
|
|
20
|
+
class HttpClient {
|
|
21
|
+
constructor($logger, $proxyService, $staticConfig) {
|
|
22
|
+
this.$logger = $logger;
|
|
23
|
+
this.$proxyService = $proxyService;
|
|
24
|
+
this.$staticConfig = $staticConfig;
|
|
25
|
+
}
|
|
26
|
+
httpRequest(options, proxySettings) {
|
|
27
|
+
return __awaiter(this, void 0, void 0, function* () {
|
|
28
|
+
try {
|
|
29
|
+
const result = yield this.httpRequestCore(options, proxySettings);
|
|
30
|
+
return {
|
|
31
|
+
response: result,
|
|
32
|
+
body: result.body,
|
|
33
|
+
headers: result.headers,
|
|
34
|
+
};
|
|
35
|
+
}
|
|
36
|
+
catch (err) {
|
|
37
|
+
if (err.message === HttpClient.STUCK_REQUEST_ERROR_MESSAGE ||
|
|
38
|
+
err.message === HttpClient.STUCK_RESPONSE_ERROR_MESSAGE) {
|
|
39
|
+
this.$logger.warn("%s Retrying request to %s...", err.message, options.url || options);
|
|
40
|
+
const retryResult = yield this.httpRequestCore(options, proxySettings);
|
|
41
|
+
return {
|
|
42
|
+
response: retryResult,
|
|
43
|
+
body: retryResult.body,
|
|
44
|
+
headers: retryResult.headers,
|
|
45
|
+
};
|
|
46
|
+
}
|
|
47
|
+
throw err;
|
|
48
|
+
}
|
|
49
|
+
});
|
|
50
|
+
}
|
|
51
|
+
httpRequestCore(options, proxySettings) {
|
|
52
|
+
return __awaiter(this, void 0, void 0, function* () {
|
|
53
|
+
if (_.isString(options)) {
|
|
54
|
+
options = {
|
|
55
|
+
url: options,
|
|
56
|
+
method: "GET",
|
|
57
|
+
};
|
|
58
|
+
}
|
|
59
|
+
const cliProxySettings = yield this.$proxyService.getCache();
|
|
60
|
+
const requestProto = options.proto || "http";
|
|
61
|
+
options.headers = options.headers || {};
|
|
62
|
+
const headers = options.headers;
|
|
63
|
+
yield this.useProxySettings(proxySettings, cliProxySettings, options, headers, requestProto);
|
|
64
|
+
if (!headers["User-Agent"]) {
|
|
65
|
+
if (!this.defaultUserAgent) {
|
|
66
|
+
this.defaultUserAgent = `${this.$staticConfig.USER_AGENT_NAME}/${this.$staticConfig.version} (Node.js ${process.versions.node}; ${process.platform}; ${process.arch})`;
|
|
67
|
+
this.$logger.trace("User-Agent: %s", this.defaultUserAgent);
|
|
68
|
+
}
|
|
69
|
+
headers["User-Agent"] = this.defaultUserAgent;
|
|
70
|
+
}
|
|
71
|
+
if (!headers["Accept-Encoding"]) {
|
|
72
|
+
headers["Accept-Encoding"] = "gzip,deflate";
|
|
73
|
+
}
|
|
74
|
+
this.$logger.trace("httpRequest: %s", util.inspect(options));
|
|
75
|
+
let agent;
|
|
76
|
+
if (cliProxySettings) {
|
|
77
|
+
agent = tunnel.httpsOverHttp({
|
|
78
|
+
proxy: {
|
|
79
|
+
host: cliProxySettings.hostname,
|
|
80
|
+
port: parseInt(cliProxySettings.port),
|
|
81
|
+
},
|
|
82
|
+
});
|
|
83
|
+
}
|
|
84
|
+
const result = yield (0, axios_1.default)({
|
|
85
|
+
url: options.url,
|
|
86
|
+
headers: options.headers,
|
|
87
|
+
method: options.method,
|
|
88
|
+
proxy: false,
|
|
89
|
+
httpAgent: agent,
|
|
90
|
+
data: options.body,
|
|
91
|
+
}).catch((err) => {
|
|
92
|
+
this.$logger.trace("An error occurred while sending the request:", err);
|
|
93
|
+
if (err.response) {
|
|
94
|
+
const errorMessage = this.getErrorMessage(err.response.status, null);
|
|
95
|
+
err.proxyAuthenticationRequired =
|
|
96
|
+
err.response.status === constants_1.HttpStatusCodes.PROXY_AUTHENTICATION_REQUIRED;
|
|
97
|
+
err.message = errorMessage || err.message;
|
|
98
|
+
}
|
|
99
|
+
else if (err.request) {
|
|
100
|
+
}
|
|
101
|
+
else {
|
|
102
|
+
}
|
|
103
|
+
throw err;
|
|
104
|
+
});
|
|
105
|
+
if (result) {
|
|
106
|
+
this.$logger.trace("httpRequest: Done. code = %d", result.status.toString());
|
|
107
|
+
return {
|
|
108
|
+
response: result,
|
|
109
|
+
body: JSON.stringify(result.data),
|
|
110
|
+
headers: result.headers,
|
|
111
|
+
};
|
|
112
|
+
}
|
|
113
|
+
});
|
|
114
|
+
}
|
|
115
|
+
getErrorMessage(statusCode, body) {
|
|
116
|
+
if (statusCode === constants_1.HttpStatusCodes.PROXY_AUTHENTICATION_REQUIRED) {
|
|
117
|
+
const clientNameLowerCase = this.$staticConfig.CLIENT_NAME.toLowerCase();
|
|
118
|
+
this.$logger.error(`You can run ${os_1.EOL}\t${clientNameLowerCase} proxy set <url> <username> <password>.${os_1.EOL}In order to supply ${clientNameLowerCase} with the credentials needed.`);
|
|
119
|
+
return "Your proxy requires authentication.";
|
|
120
|
+
}
|
|
121
|
+
else if (statusCode === constants_1.HttpStatusCodes.PAYMENT_REQUIRED) {
|
|
122
|
+
return "Your subscription has expired.";
|
|
123
|
+
}
|
|
124
|
+
else if (statusCode === constants_1.HttpStatusCodes.CONFLICTING_RESOURCE) {
|
|
125
|
+
return "The request conflicts with the current state of the server.";
|
|
126
|
+
}
|
|
127
|
+
else {
|
|
128
|
+
this.$logger.trace("Request was unsuccessful. Server returned: ", body);
|
|
129
|
+
try {
|
|
130
|
+
const err = JSON.parse(body);
|
|
131
|
+
if (_.isString(err)) {
|
|
132
|
+
return err;
|
|
133
|
+
}
|
|
134
|
+
if (err && err.ExceptionMessage) {
|
|
135
|
+
return err.ExceptionMessage;
|
|
136
|
+
}
|
|
137
|
+
if (err && err.Message) {
|
|
138
|
+
return err.Message;
|
|
139
|
+
}
|
|
140
|
+
}
|
|
141
|
+
catch (parsingFailed) {
|
|
142
|
+
this.$logger.trace("Failed to get error from http request: ", parsingFailed);
|
|
143
|
+
return `The server returned unexpected response: ${body}`;
|
|
144
|
+
}
|
|
145
|
+
return body;
|
|
146
|
+
}
|
|
147
|
+
}
|
|
148
|
+
useProxySettings(proxySettings, cliProxySettings, options, headers, requestProto) {
|
|
149
|
+
return __awaiter(this, void 0, void 0, function* () {
|
|
150
|
+
const isLocalRequest = options.host === "localhost" || options.host === "127.0.0.1";
|
|
151
|
+
if (!isLocalRequest && (proxySettings || cliProxySettings)) {
|
|
152
|
+
const proto = (proxySettings && proxySettings.protocol) ||
|
|
153
|
+
cliProxySettings.protocol ||
|
|
154
|
+
"http:";
|
|
155
|
+
const host = (proxySettings && proxySettings.hostname) || cliProxySettings.hostname;
|
|
156
|
+
const port = (proxySettings && proxySettings.port) || cliProxySettings.port;
|
|
157
|
+
let credentialsPart = "";
|
|
158
|
+
if (cliProxySettings.username && cliProxySettings.password) {
|
|
159
|
+
credentialsPart = `${cliProxySettings.username}:${cliProxySettings.password}@`;
|
|
160
|
+
}
|
|
161
|
+
options.proxy = `${proto}//${credentialsPart}${host}:${port}`;
|
|
162
|
+
options.rejectUnauthorized = proxySettings
|
|
163
|
+
? proxySettings.rejectUnauthorized
|
|
164
|
+
: cliProxySettings.rejectUnauthorized;
|
|
165
|
+
this.$logger.trace("Using proxy: %s", options.proxy);
|
|
166
|
+
}
|
|
167
|
+
});
|
|
168
|
+
}
|
|
169
|
+
}
|
|
170
|
+
HttpClient.STUCK_REQUEST_ERROR_MESSAGE = "The request can't receive any response.";
|
|
171
|
+
HttpClient.STUCK_RESPONSE_ERROR_MESSAGE = "Can't receive all parts of the response.";
|
|
172
|
+
exports.HttpClient = HttpClient;
|
|
173
|
+
yok_1.injector.register("httpClient", HttpClient);
|
|
@@ -0,0 +1,24 @@
|
|
|
1
|
+
"use strict";
|
|
2
|
+
Object.defineProperty(exports, "__esModule", { value: true });
|
|
3
|
+
exports.configure = void 0;
|
|
4
|
+
const constants_1 = require("../../../constants");
|
|
5
|
+
function cliAppender(layout) {
|
|
6
|
+
const appender = (loggingEvent) => {
|
|
7
|
+
if (loggingEvent && loggingEvent.data) {
|
|
8
|
+
const stream = loggingEvent.context[constants_1.LoggerConfigData.useStderr]
|
|
9
|
+
? process.stderr
|
|
10
|
+
: process.stdout;
|
|
11
|
+
const preparedData = layout(loggingEvent);
|
|
12
|
+
stream.write(preparedData);
|
|
13
|
+
}
|
|
14
|
+
};
|
|
15
|
+
return appender;
|
|
16
|
+
}
|
|
17
|
+
function configure(config, layouts) {
|
|
18
|
+
let layout = layouts.messagePassThroughLayout;
|
|
19
|
+
if (config.layout) {
|
|
20
|
+
layout = layouts.layout(config.layout.type, config.layout);
|
|
21
|
+
}
|
|
22
|
+
return cliAppender(layout);
|
|
23
|
+
}
|
|
24
|
+
exports.configure = configure;
|
|
@@ -0,0 +1,30 @@
|
|
|
1
|
+
"use strict";
|
|
2
|
+
Object.defineProperty(exports, "__esModule", { value: true });
|
|
3
|
+
exports.configure = void 0;
|
|
4
|
+
const constants_1 = require("../../../constants");
|
|
5
|
+
function emitAppender(layout, emitter) {
|
|
6
|
+
const appender = (loggingEvent) => {
|
|
7
|
+
emitter.emit(constants_1.EMIT_APPENDER_EVENT_NAME, {
|
|
8
|
+
loggingEvent,
|
|
9
|
+
formattedMessage: layout(loggingEvent),
|
|
10
|
+
});
|
|
11
|
+
};
|
|
12
|
+
appender.shutdown = () => {
|
|
13
|
+
emitter.removeAllListeners(constants_1.EMIT_APPENDER_EVENT_NAME);
|
|
14
|
+
};
|
|
15
|
+
return appender;
|
|
16
|
+
}
|
|
17
|
+
function configure(config, layouts) {
|
|
18
|
+
if (!config.emitter) {
|
|
19
|
+
throw new Error("Emitter must be passed to emit-appender");
|
|
20
|
+
}
|
|
21
|
+
if (!config.emitter.emit || typeof config.emitter.emit !== "function") {
|
|
22
|
+
throw new Error("The passed emitter must be instance of EventEmitter");
|
|
23
|
+
}
|
|
24
|
+
let layout = layouts.messagePassThroughLayout;
|
|
25
|
+
if (config.layout) {
|
|
26
|
+
layout = layouts.layout(config.layout.type, config.layout);
|
|
27
|
+
}
|
|
28
|
+
return emitAppender(layout, config.emitter);
|
|
29
|
+
}
|
|
30
|
+
exports.configure = configure;
|
|
@@ -0,0 +1,33 @@
|
|
|
1
|
+
"use strict";
|
|
2
|
+
Object.defineProperty(exports, "__esModule", { value: true });
|
|
3
|
+
exports.layout = void 0;
|
|
4
|
+
const util_1 = require("util");
|
|
5
|
+
const helpers_1 = require("../../helpers");
|
|
6
|
+
const constants_1 = require("../../../constants");
|
|
7
|
+
const os_1 = require("os");
|
|
8
|
+
const color_1 = require("../../../color");
|
|
9
|
+
function layout(config) {
|
|
10
|
+
return function (logEvent) {
|
|
11
|
+
let msg = util_1.format.apply(null, logEvent.data);
|
|
12
|
+
if (logEvent.context[constants_1.LoggerConfigData.wrapMessageWithBorders]) {
|
|
13
|
+
msg = (0, helpers_1.getMessageWithBorders)(msg);
|
|
14
|
+
}
|
|
15
|
+
if (!logEvent.context[constants_1.LoggerConfigData.skipNewLine]) {
|
|
16
|
+
msg += os_1.EOL;
|
|
17
|
+
}
|
|
18
|
+
if (logEvent.level.isEqualTo(constants_1.LoggerLevel.INFO)) {
|
|
19
|
+
return msg;
|
|
20
|
+
}
|
|
21
|
+
if (logEvent.level.isEqualTo(constants_1.LoggerLevel.ERROR)) {
|
|
22
|
+
return color_1.color.red.bold(msg);
|
|
23
|
+
}
|
|
24
|
+
if (logEvent.level.isEqualTo(constants_1.LoggerLevel.WARN)) {
|
|
25
|
+
return color_1.color.yellow(msg);
|
|
26
|
+
}
|
|
27
|
+
if (logEvent.level.isEqualTo(constants_1.LoggerLevel.TRACE)) {
|
|
28
|
+
return color_1.color.grey(msg);
|
|
29
|
+
}
|
|
30
|
+
return msg;
|
|
31
|
+
};
|
|
32
|
+
}
|
|
33
|
+
exports.layout = layout;
|
|
@@ -0,0 +1,199 @@
|
|
|
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
|
+
Object.defineProperty(exports, "__esModule", { value: true });
|
|
9
|
+
exports.Logger = void 0;
|
|
10
|
+
const log4js = require("log4js");
|
|
11
|
+
const util = require("util");
|
|
12
|
+
const readline = require("readline");
|
|
13
|
+
const stream = require("stream");
|
|
14
|
+
const marked_1 = require("marked");
|
|
15
|
+
const _ = require("lodash");
|
|
16
|
+
const decorators_1 = require("../decorators");
|
|
17
|
+
const cli_layout_1 = require("./layouts/cli-layout");
|
|
18
|
+
const constants_1 = require("../../constants");
|
|
19
|
+
const yok_1 = require("../yok");
|
|
20
|
+
const color_1 = require("../../color");
|
|
21
|
+
const TerminalRenderer = require("marked-terminal");
|
|
22
|
+
class Logger {
|
|
23
|
+
constructor($config) {
|
|
24
|
+
this.$config = $config;
|
|
25
|
+
this.log4jsLogger = null;
|
|
26
|
+
this.passwordRegex = /(password=).*?(['&,]|$)|(password["']?\s*:\s*["']).*?(["'])/i;
|
|
27
|
+
this.passwordReplacement = "$1$3*******$2$4";
|
|
28
|
+
this.defaultLogLevel = this.$config.DEBUG
|
|
29
|
+
? constants_1.LoggerLevel.TRACE
|
|
30
|
+
: constants_1.LoggerLevel.INFO;
|
|
31
|
+
}
|
|
32
|
+
initialize(opts) {
|
|
33
|
+
opts = opts || {};
|
|
34
|
+
const { appenderOptions: appenderOpts, level } = opts;
|
|
35
|
+
const appender = {
|
|
36
|
+
type: "console",
|
|
37
|
+
layout: {
|
|
38
|
+
type: "messagePassThrough",
|
|
39
|
+
},
|
|
40
|
+
};
|
|
41
|
+
if (appenderOpts) {
|
|
42
|
+
_.merge(appender, appenderOpts);
|
|
43
|
+
}
|
|
44
|
+
const appenders = {
|
|
45
|
+
out: appender,
|
|
46
|
+
};
|
|
47
|
+
const categories = {
|
|
48
|
+
default: {
|
|
49
|
+
appenders: ["out"],
|
|
50
|
+
level: level || this.defaultLogLevel,
|
|
51
|
+
},
|
|
52
|
+
};
|
|
53
|
+
log4js.configure({ appenders, categories });
|
|
54
|
+
this.log4jsLogger = log4js.getLogger();
|
|
55
|
+
if (level === constants_1.LoggerLevel.TRACE || level === constants_1.LoggerLevel.ALL) {
|
|
56
|
+
this.warn(`The "${level}" log level might print some sensitive data like secrets or access tokens in request URLs. Be careful when you share this output.`, { wrapMessageWithBorders: true });
|
|
57
|
+
}
|
|
58
|
+
}
|
|
59
|
+
initializeCliLogger(opts) {
|
|
60
|
+
log4js.addLayout("cli", cli_layout_1.layout);
|
|
61
|
+
this.initialize({
|
|
62
|
+
appenderOptions: {
|
|
63
|
+
type: constants_1.LoggerAppenders.cliAppender,
|
|
64
|
+
layout: { type: "cli" },
|
|
65
|
+
},
|
|
66
|
+
level: opts.level || this.defaultLogLevel,
|
|
67
|
+
});
|
|
68
|
+
}
|
|
69
|
+
getLevel() {
|
|
70
|
+
this.initialize();
|
|
71
|
+
return this.log4jsLogger.level.toString();
|
|
72
|
+
}
|
|
73
|
+
fatal(...args) {
|
|
74
|
+
this.logMessage(args, constants_1.LoggerLevel.FATAL);
|
|
75
|
+
}
|
|
76
|
+
error(...args) {
|
|
77
|
+
args.push({ [constants_1.LoggerConfigData.useStderr]: true });
|
|
78
|
+
this.logMessage(args, constants_1.LoggerLevel.ERROR);
|
|
79
|
+
}
|
|
80
|
+
warn(...args) {
|
|
81
|
+
this.logMessage(args, constants_1.LoggerLevel.WARN);
|
|
82
|
+
}
|
|
83
|
+
info(...args) {
|
|
84
|
+
this.logMessage(args, constants_1.LoggerLevel.INFO);
|
|
85
|
+
}
|
|
86
|
+
debug(...args) {
|
|
87
|
+
const encodedArgs = this.getPasswordEncodedArguments(args);
|
|
88
|
+
this.logMessage(encodedArgs, constants_1.LoggerLevel.DEBUG);
|
|
89
|
+
}
|
|
90
|
+
trace(...args) {
|
|
91
|
+
const encodedArgs = this.getPasswordEncodedArguments(args);
|
|
92
|
+
this.logMessage(encodedArgs, constants_1.LoggerLevel.TRACE);
|
|
93
|
+
}
|
|
94
|
+
prepare(item) {
|
|
95
|
+
if (typeof item === "undefined" || item === null) {
|
|
96
|
+
return "[no content]";
|
|
97
|
+
}
|
|
98
|
+
if (typeof item === "string") {
|
|
99
|
+
return item;
|
|
100
|
+
}
|
|
101
|
+
if (item instanceof stream.Readable) {
|
|
102
|
+
return "[ReadableStream]";
|
|
103
|
+
}
|
|
104
|
+
if (item instanceof Buffer) {
|
|
105
|
+
return "[Buffer]";
|
|
106
|
+
}
|
|
107
|
+
return JSON.stringify(item);
|
|
108
|
+
}
|
|
109
|
+
printMarkdown(...args) {
|
|
110
|
+
const opts = {
|
|
111
|
+
unescape: true,
|
|
112
|
+
link: color_1.color.red,
|
|
113
|
+
strong: color_1.color.green.bold,
|
|
114
|
+
firstHeading: color_1.color.blue.bold,
|
|
115
|
+
tableOptions: {
|
|
116
|
+
chars: { mid: "", "left-mid": "", "mid-mid": "", "right-mid": "" },
|
|
117
|
+
style: {
|
|
118
|
+
"padding-left": 1,
|
|
119
|
+
"padding-right": 1,
|
|
120
|
+
head: ["green", "bold"],
|
|
121
|
+
border: ["grey"],
|
|
122
|
+
compact: false,
|
|
123
|
+
},
|
|
124
|
+
},
|
|
125
|
+
};
|
|
126
|
+
marked_1.marked.setOptions({ renderer: new TerminalRenderer(opts) });
|
|
127
|
+
const formattedMessage = (0, marked_1.marked)(util.format.apply(null, args));
|
|
128
|
+
this.info(formattedMessage, { [constants_1.LoggerConfigData.skipNewLine]: true });
|
|
129
|
+
}
|
|
130
|
+
isVerbose() {
|
|
131
|
+
return log4js.levels.DEBUG.isGreaterThanOrEqualTo(this.getLevel());
|
|
132
|
+
}
|
|
133
|
+
clearScreen() {
|
|
134
|
+
const repeatCount = process.stdout.rows - 2;
|
|
135
|
+
const blank = repeatCount > 0 ? "\n".repeat(repeatCount) : "";
|
|
136
|
+
console.log(blank);
|
|
137
|
+
readline.cursorTo(process.stdout, 0, 0);
|
|
138
|
+
readline.clearScreenDown(process.stdout);
|
|
139
|
+
}
|
|
140
|
+
logMessage(inputData, logMethod) {
|
|
141
|
+
this.initialize();
|
|
142
|
+
const logOpts = this.getLogOptionsForMessage(inputData);
|
|
143
|
+
const data = logOpts.data;
|
|
144
|
+
delete logOpts.data;
|
|
145
|
+
for (const prop in logOpts) {
|
|
146
|
+
this.log4jsLogger.addContext(prop, logOpts[prop]);
|
|
147
|
+
}
|
|
148
|
+
this.log4jsLogger[logMethod.toLowerCase()].apply(this.log4jsLogger, data);
|
|
149
|
+
for (const prop in logOpts) {
|
|
150
|
+
this.log4jsLogger.removeContext(prop);
|
|
151
|
+
}
|
|
152
|
+
}
|
|
153
|
+
getLogOptionsForMessage(data) {
|
|
154
|
+
const loggerOptionKeys = _.keys(constants_1.LoggerConfigData);
|
|
155
|
+
const dataToCheck = data.filter((el) => {
|
|
156
|
+
if (!!el &&
|
|
157
|
+
typeof el === "object" &&
|
|
158
|
+
el.hasOwnProperty &&
|
|
159
|
+
typeof el.hasOwnProperty === "function") {
|
|
160
|
+
for (const key of loggerOptionKeys) {
|
|
161
|
+
if (el.hasOwnProperty(key)) {
|
|
162
|
+
return true;
|
|
163
|
+
}
|
|
164
|
+
}
|
|
165
|
+
}
|
|
166
|
+
return false;
|
|
167
|
+
});
|
|
168
|
+
const result = {
|
|
169
|
+
data: _.difference(data, dataToCheck),
|
|
170
|
+
};
|
|
171
|
+
for (const element of dataToCheck) {
|
|
172
|
+
if (loggerOptionKeys.length === 0) {
|
|
173
|
+
break;
|
|
174
|
+
}
|
|
175
|
+
const remainingOpts = _.cloneDeep(loggerOptionKeys);
|
|
176
|
+
for (const prop of remainingOpts) {
|
|
177
|
+
const hasProp = element && element.hasOwnProperty(prop);
|
|
178
|
+
if (hasProp) {
|
|
179
|
+
loggerOptionKeys.splice(loggerOptionKeys.indexOf(prop), 1);
|
|
180
|
+
result[prop] = element[prop];
|
|
181
|
+
}
|
|
182
|
+
}
|
|
183
|
+
}
|
|
184
|
+
return result;
|
|
185
|
+
}
|
|
186
|
+
getPasswordEncodedArguments(args) {
|
|
187
|
+
return _.map(args, (argument) => {
|
|
188
|
+
if (typeof argument === "string" && !!argument.match(/password/i)) {
|
|
189
|
+
argument = argument.replace(this.passwordRegex, this.passwordReplacement);
|
|
190
|
+
}
|
|
191
|
+
return argument;
|
|
192
|
+
});
|
|
193
|
+
}
|
|
194
|
+
}
|
|
195
|
+
__decorate([
|
|
196
|
+
(0, decorators_1.cache)()
|
|
197
|
+
], Logger.prototype, "initialize", null);
|
|
198
|
+
exports.Logger = Logger;
|
|
199
|
+
yok_1.injector.register("logger", Logger);
|
|
@@ -0,0 +1,10 @@
|
|
|
1
|
+
//
|
|
2
|
+
// automatically generated code; do not edit manually!
|
|
3
|
+
//
|
|
4
|
+
interface IMessages {
|
|
5
|
+
Devices: {
|
|
6
|
+
NotFoundDeviceByIdentifierErrorMessage: string;
|
|
7
|
+
NotFoundDeviceByIdentifierErrorMessageWithIdentifier: string;
|
|
8
|
+
NotFoundDeviceByIndexErrorMessage: string;
|
|
9
|
+
};
|
|
10
|
+
}
|
|
@@ -0,0 +1,15 @@
|
|
|
1
|
+
"use strict";
|
|
2
|
+
Object.defineProperty(exports, "__esModule", { value: true });
|
|
3
|
+
exports.Messages = void 0;
|
|
4
|
+
const yok_1 = require("../yok");
|
|
5
|
+
class Messages {
|
|
6
|
+
constructor() {
|
|
7
|
+
this.Devices = {
|
|
8
|
+
NotFoundDeviceByIdentifierErrorMessage: "Devices.NotFoundDeviceByIdentifierErrorMessage",
|
|
9
|
+
NotFoundDeviceByIdentifierErrorMessageWithIdentifier: "Devices.NotFoundDeviceByIdentifierErrorMessageWithIdentifier",
|
|
10
|
+
NotFoundDeviceByIndexErrorMessage: "Devices.NotFoundDeviceByIndexErrorMessage",
|
|
11
|
+
};
|
|
12
|
+
}
|
|
13
|
+
}
|
|
14
|
+
exports.Messages = Messages;
|
|
15
|
+
yok_1.injector.register("messages", Messages);
|