@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.
Files changed (531) hide show
  1. package/LICENSE +201 -0
  2. package/README.md +385 -0
  3. package/bin/nativescript +3 -0
  4. package/bin/nativescript.js +3 -0
  5. package/bin/ns +3 -0
  6. package/bin/nsc +3 -0
  7. package/bin/nsc.js +3 -0
  8. package/bin/tns +12 -0
  9. package/bin/tns.cmd +1 -0
  10. package/config/config.json +8 -0
  11. package/config/test-dependencies.json +58 -0
  12. package/config/test-deps-versions-generated.json +1 -0
  13. package/docs/build-jekyll-md.sh +7 -0
  14. package/docs/helpers/favicon.ico +0 -0
  15. package/docs/helpers/logo.png +0 -0
  16. package/docs/man_pages/cloud/cloud-setup.md +29 -0
  17. package/docs/man_pages/device/device-android.md +32 -0
  18. package/docs/man_pages/device/device-ios.md +40 -0
  19. package/docs/man_pages/device/device-list-applications.md +37 -0
  20. package/docs/man_pages/device/device-log.md +37 -0
  21. package/docs/man_pages/device/device-run.md +55 -0
  22. package/docs/man_pages/device/device.md +46 -0
  23. package/docs/man_pages/env-configuration/setup.md +22 -0
  24. package/docs/man_pages/general/autocomplete-disable.md +37 -0
  25. package/docs/man_pages/general/autocomplete-enable.md +37 -0
  26. package/docs/man_pages/general/autocomplete-status.md +35 -0
  27. package/docs/man_pages/general/autocomplete.md +46 -0
  28. package/docs/man_pages/general/clean.md +22 -0
  29. package/docs/man_pages/general/doctor.md +33 -0
  30. package/docs/man_pages/general/error-reporting.md +41 -0
  31. package/docs/man_pages/general/extension-install.md +45 -0
  32. package/docs/man_pages/general/extension-uninstall.md +41 -0
  33. package/docs/man_pages/general/extension.md +35 -0
  34. package/docs/man_pages/general/help.md +39 -0
  35. package/docs/man_pages/general/info.md +33 -0
  36. package/docs/man_pages/general/migrate.md +79 -0
  37. package/docs/man_pages/general/package-manager-get.md +26 -0
  38. package/docs/man_pages/general/package-manager-set.md +29 -0
  39. package/docs/man_pages/general/package-manager.md +25 -0
  40. package/docs/man_pages/general/proxy-clear.md +26 -0
  41. package/docs/man_pages/general/proxy-set.md +45 -0
  42. package/docs/man_pages/general/proxy.md +31 -0
  43. package/docs/man_pages/general/update.md +40 -0
  44. package/docs/man_pages/general/usage-reporting.md +41 -0
  45. package/docs/man_pages/index.html +3 -0
  46. package/docs/man_pages/lib-management/plugin-add.md +42 -0
  47. package/docs/man_pages/lib-management/plugin-build.md +32 -0
  48. package/docs/man_pages/lib-management/plugin-create.md +48 -0
  49. package/docs/man_pages/lib-management/plugin-install.md +42 -0
  50. package/docs/man_pages/lib-management/plugin-remove.md +31 -0
  51. package/docs/man_pages/lib-management/plugin-update.md +41 -0
  52. package/docs/man_pages/lib-management/plugin.md +39 -0
  53. package/docs/man_pages/project/configuration/generate.md +36 -0
  54. package/docs/man_pages/project/configuration/install.md +43 -0
  55. package/docs/man_pages/project/configuration/open-android.md +27 -0
  56. package/docs/man_pages/project/configuration/open-ios.md +31 -0
  57. package/docs/man_pages/project/configuration/open.md +36 -0
  58. package/docs/man_pages/project/configuration/platform-add.md +46 -0
  59. package/docs/man_pages/project/configuration/platform-clean.md +41 -0
  60. package/docs/man_pages/project/configuration/platform-remove.md +41 -0
  61. package/docs/man_pages/project/configuration/platform-update.md +45 -0
  62. package/docs/man_pages/project/configuration/platform.md +29 -0
  63. package/docs/man_pages/project/configuration/prepare.md +49 -0
  64. package/docs/man_pages/project/configuration/resources/resources-generate-icons.md +39 -0
  65. package/docs/man_pages/project/configuration/resources/resources-generate-splashes.md +39 -0
  66. package/docs/man_pages/project/configuration/resources/resources-update.md +35 -0
  67. package/docs/man_pages/project/configuration/resources/resources.md +14 -0
  68. package/docs/man_pages/project/creation/create.md +64 -0
  69. package/docs/man_pages/project/testing/build-android.md +62 -0
  70. package/docs/man_pages/project/testing/build-ios.md +65 -0
  71. package/docs/man_pages/project/testing/build.md +66 -0
  72. package/docs/man_pages/project/testing/debug-android.md +64 -0
  73. package/docs/man_pages/project/testing/debug-ios.md +65 -0
  74. package/docs/man_pages/project/testing/debug.md +67 -0
  75. package/docs/man_pages/project/testing/deploy.md +72 -0
  76. package/docs/man_pages/project/testing/dev-test-android.md +31 -0
  77. package/docs/man_pages/project/testing/dev-test-ios.md +36 -0
  78. package/docs/man_pages/project/testing/preview.md +35 -0
  79. package/docs/man_pages/project/testing/run-android.md +79 -0
  80. package/docs/man_pages/project/testing/run-ios.md +83 -0
  81. package/docs/man_pages/project/testing/run.md +92 -0
  82. package/docs/man_pages/project/testing/test-android.md +46 -0
  83. package/docs/man_pages/project/testing/test-init.md +34 -0
  84. package/docs/man_pages/project/testing/test-ios.md +48 -0
  85. package/docs/man_pages/project/testing/test.md +48 -0
  86. package/docs/man_pages/project/testing/typings.md +52 -0
  87. package/docs/man_pages/publishing/apple-login.md +35 -0
  88. package/docs/man_pages/publishing/appstore-upload.md +52 -0
  89. package/docs/man_pages/publishing/appstore.md +42 -0
  90. package/docs/man_pages/publishing/publish-ios.md +55 -0
  91. package/docs/man_pages/publishing/publish.md +38 -0
  92. package/docs/man_pages/start.md +81 -0
  93. package/lib/.d.ts +494 -0
  94. package/lib/android-tools-info.js +135 -0
  95. package/lib/base-package-manager.js +129 -0
  96. package/lib/bash-scripts/terminateProcess.sh +12 -0
  97. package/lib/bootstrap.js +203 -0
  98. package/lib/bun-package-manager.js +135 -0
  99. package/lib/color.js +10 -0
  100. package/lib/commands/add-platform.js +49 -0
  101. package/lib/commands/apple-login.js +52 -0
  102. package/lib/commands/appstore-list.js +75 -0
  103. package/lib/commands/appstore-upload.js +106 -0
  104. package/lib/commands/build.js +161 -0
  105. package/lib/commands/clean.js +253 -0
  106. package/lib/commands/command-base.js +46 -0
  107. package/lib/commands/config.js +135 -0
  108. package/lib/commands/create-project.js +431 -0
  109. package/lib/commands/debug.js +191 -0
  110. package/lib/commands/deploy.js +78 -0
  111. package/lib/commands/extensibility/install-extension.js +33 -0
  112. package/lib/commands/extensibility/list-extensions.js +40 -0
  113. package/lib/commands/extensibility/uninstall-extension.js +32 -0
  114. package/lib/commands/fonts.js +64 -0
  115. package/lib/commands/generate-assets.js +71 -0
  116. package/lib/commands/generate-help.js +26 -0
  117. package/lib/commands/generate.js +78 -0
  118. package/lib/commands/info.js +26 -0
  119. package/lib/commands/install.js +80 -0
  120. package/lib/commands/list-platforms.js +45 -0
  121. package/lib/commands/migrate.js +44 -0
  122. package/lib/commands/platform-clean.js +54 -0
  123. package/lib/commands/plugin/add-plugin.js +43 -0
  124. package/lib/commands/plugin/build-plugin.js +70 -0
  125. package/lib/commands/plugin/create-plugin.js +175 -0
  126. package/lib/commands/plugin/list-plugins.js +54 -0
  127. package/lib/commands/plugin/remove-plugin.js +52 -0
  128. package/lib/commands/plugin/update-plugin.js +52 -0
  129. package/lib/commands/post-install.js +57 -0
  130. package/lib/commands/prepare.js +63 -0
  131. package/lib/commands/preview.js +93 -0
  132. package/lib/commands/remove-platform.js +40 -0
  133. package/lib/commands/resources/resources-update.js +45 -0
  134. package/lib/commands/run.js +177 -0
  135. package/lib/commands/setup.js +15 -0
  136. package/lib/commands/start.js +33 -0
  137. package/lib/commands/test-init.js +167 -0
  138. package/lib/commands/test.js +146 -0
  139. package/lib/commands/typings.js +180 -0
  140. package/lib/commands/update-platform.js +57 -0
  141. package/lib/commands/update.js +70 -0
  142. package/lib/common/LICENSE +201 -0
  143. package/lib/common/README.md +1084 -0
  144. package/lib/common/bin/common-lib.js +5 -0
  145. package/lib/common/bootstrap.js +97 -0
  146. package/lib/common/child-process.js +217 -0
  147. package/lib/common/codeGeneration/code-entity.js +47 -0
  148. package/lib/common/codeGeneration/code-generation.d.ts +47 -0
  149. package/lib/common/codeGeneration/code-printer.js +48 -0
  150. package/lib/common/command-params.js +45 -0
  151. package/lib/common/commands/analytics.js +81 -0
  152. package/lib/common/commands/autocompletion.js +110 -0
  153. package/lib/common/commands/device/device-log-stream.js +44 -0
  154. package/lib/common/commands/device/get-file.js +54 -0
  155. package/lib/common/commands/device/list-applications.js +42 -0
  156. package/lib/common/commands/device/list-devices.js +150 -0
  157. package/lib/common/commands/device/list-files.js +55 -0
  158. package/lib/common/commands/device/put-file.js +55 -0
  159. package/lib/common/commands/device/run-application.js +46 -0
  160. package/lib/common/commands/device/stop-application.js +42 -0
  161. package/lib/common/commands/device/uninstall-application.js +33 -0
  162. package/lib/common/commands/doctor.js +54 -0
  163. package/lib/common/commands/generate-messages.js +45 -0
  164. package/lib/common/commands/help.js +51 -0
  165. package/lib/common/commands/package-manager-get.js +32 -0
  166. package/lib/common/commands/package-manager-set.js +37 -0
  167. package/lib/common/commands/post-install.js +27 -0
  168. package/lib/common/commands/preuninstall.js +61 -0
  169. package/lib/common/commands/proxy/proxy-base.js +34 -0
  170. package/lib/common/commands/proxy/proxy-clear.js +32 -0
  171. package/lib/common/commands/proxy/proxy-get.js +31 -0
  172. package/lib/common/commands/proxy/proxy-set.js +150 -0
  173. package/lib/common/common-lib.js +5 -0
  174. package/lib/common/constants.js +122 -0
  175. package/lib/common/declarations.d.ts +1713 -0
  176. package/lib/common/decorators.js +201 -0
  177. package/lib/common/definitions/cli-global.d.ts +22 -0
  178. package/lib/common/definitions/commands-service.d.ts +27 -0
  179. package/lib/common/definitions/commands.d.ts +51 -0
  180. package/lib/common/definitions/config.d.ts +33 -0
  181. package/lib/common/definitions/extensibility.d.ts +147 -0
  182. package/lib/common/definitions/google-analytics.d.ts +109 -0
  183. package/lib/common/definitions/json-file-settings-service.d.ts +24 -0
  184. package/lib/common/definitions/key-commands.d.ts +62 -0
  185. package/lib/common/definitions/logger.d.ts +41 -0
  186. package/lib/common/definitions/mobile.d.ts +1499 -0
  187. package/lib/common/definitions/validator.d.ts +8 -0
  188. package/lib/common/definitions/yok.d.ts +56 -0
  189. package/lib/common/dispatchers.js +151 -0
  190. package/lib/common/docs/helpers/basic-extensions-page.html +15 -0
  191. package/lib/common/docs/helpers/basic-page.html +14 -0
  192. package/lib/common/docs/helpers/styles.css +365 -0
  193. package/lib/common/doctor.d.ts +6 -0
  194. package/lib/common/errors.js +206 -0
  195. package/lib/common/file-system.js +441 -0
  196. package/lib/common/header.js +30 -0
  197. package/lib/common/helpers.js +658 -0
  198. package/lib/common/host-info.js +133 -0
  199. package/lib/common/http-client.js +173 -0
  200. package/lib/common/logger/appenders/cli-appender.js +24 -0
  201. package/lib/common/logger/appenders/emit-appender.js +30 -0
  202. package/lib/common/logger/layouts/cli-layout.js +33 -0
  203. package/lib/common/logger/logger.js +199 -0
  204. package/lib/common/messages/messages.interface.d.ts +10 -0
  205. package/lib/common/messages/messages.js +15 -0
  206. package/lib/common/mobile/android/android-application-manager.js +228 -0
  207. package/lib/common/mobile/android/android-debug-bridge-result-handler.js +332 -0
  208. package/lib/common/mobile/android/android-debug-bridge.js +167 -0
  209. package/lib/common/mobile/android/android-device-file-system.js +176 -0
  210. package/lib/common/mobile/android/android-device-hash-service.js +133 -0
  211. package/lib/common/mobile/android/android-device.js +164 -0
  212. package/lib/common/mobile/android/android-emulator-services.js +205 -0
  213. package/lib/common/mobile/android/android-ini-file-parser.js +77 -0
  214. package/lib/common/mobile/android/android-log-filter.js +42 -0
  215. package/lib/common/mobile/android/android-virtual-device-service.js +360 -0
  216. package/lib/common/mobile/android/device-android-debug-bridge.js +48 -0
  217. package/lib/common/mobile/android/genymotion/genymotion-service.js +211 -0
  218. package/lib/common/mobile/android/genymotion/virtualbox-service.js +121 -0
  219. package/lib/common/mobile/android/logcat-helper.js +165 -0
  220. package/lib/common/mobile/application-manager-base.js +136 -0
  221. package/lib/common/mobile/device-emitter.js +61 -0
  222. package/lib/common/mobile/device-log-emitter.js +40 -0
  223. package/lib/common/mobile/device-log-provider-base.js +76 -0
  224. package/lib/common/mobile/device-log-provider.js +126 -0
  225. package/lib/common/mobile/device-platforms-constants.js +22 -0
  226. package/lib/common/mobile/emulator-helper.js +84 -0
  227. package/lib/common/mobile/ios/device/ios-application-manager.js +159 -0
  228. package/lib/common/mobile/ios/device/ios-device-file-system.js +133 -0
  229. package/lib/common/mobile/ios/device/ios-device-operations.js +234 -0
  230. package/lib/common/mobile/ios/device/ios-device.js +153 -0
  231. package/lib/common/mobile/ios/ios-device-base.js +108 -0
  232. package/lib/common/mobile/ios/ios-device-product-name-mapper.js +65 -0
  233. package/lib/common/mobile/ios/ios-log-filter.js +24 -0
  234. package/lib/common/mobile/ios/simulator/ios-emulator-services.js +139 -0
  235. package/lib/common/mobile/ios/simulator/ios-sim-resolver.js +23 -0
  236. package/lib/common/mobile/ios/simulator/ios-simulator-application-manager.js +147 -0
  237. package/lib/common/mobile/ios/simulator/ios-simulator-device.js +106 -0
  238. package/lib/common/mobile/ios/simulator/ios-simulator-file-system.js +81 -0
  239. package/lib/common/mobile/ios/simulator/ios-simulator-log-provider.js +69 -0
  240. package/lib/common/mobile/local-to-device-path-data-factory.js +37 -0
  241. package/lib/common/mobile/log-filter.js +51 -0
  242. package/lib/common/mobile/logging-levels.js +12 -0
  243. package/lib/common/mobile/mobile-core/android-device-discovery.js +91 -0
  244. package/lib/common/mobile/mobile-core/android-emulator-discovery.js +65 -0
  245. package/lib/common/mobile/mobile-core/android-process-service.js +259 -0
  246. package/lib/common/mobile/mobile-core/device-discovery.js +64 -0
  247. package/lib/common/mobile/mobile-core/devices-service.js +854 -0
  248. package/lib/common/mobile/mobile-core/ios-device-discovery.js +63 -0
  249. package/lib/common/mobile/mobile-core/ios-simulator-discovery.js +109 -0
  250. package/lib/common/mobile/mobile-helper.js +102 -0
  251. package/lib/common/mobile/wp8/wp8-emulator-services.js +82 -0
  252. package/lib/common/old.npmignore +12 -0
  253. package/lib/common/opener.js +16 -0
  254. package/lib/common/os-info.js +21 -0
  255. package/lib/common/plist-parser.js +24 -0
  256. package/lib/common/project-helper.js +70 -0
  257. package/lib/common/prompter.js +191 -0
  258. package/lib/common/queue.js +37 -0
  259. package/lib/common/resource-loader.js +25 -0
  260. package/lib/common/resources/messages/errorMessages.json +7 -0
  261. package/lib/common/resources/platform-tools/android/darwin/NOTICE.txt +3407 -0
  262. package/lib/common/resources/platform-tools/android/darwin/adb +0 -0
  263. package/lib/common/resources/platform-tools/android/linux/NOTICE.txt +4451 -0
  264. package/lib/common/resources/platform-tools/android/linux/adb +0 -0
  265. package/lib/common/resources/platform-tools/android/win32/AdbWinApi.dll +0 -0
  266. package/lib/common/resources/platform-tools/android/win32/AdbWinUsbApi.dll +0 -0
  267. package/lib/common/resources/platform-tools/android/win32/NOTICE.txt +4451 -0
  268. package/lib/common/resources/platform-tools/android/win32/adb.exe +0 -0
  269. package/lib/common/resources/platform-tools/android/win32/fastboot.exe +0 -0
  270. package/lib/common/resources/platform-tools/unzip/win32/unzip.exe +0 -0
  271. package/lib/common/services/analytics/google-analytics-custom-dimensions.d.ts +16 -0
  272. package/lib/common/services/auto-completion-service.js +265 -0
  273. package/lib/common/services/cancellation.js +67 -0
  274. package/lib/common/services/commands-service.js +268 -0
  275. package/lib/common/services/help-service.js +252 -0
  276. package/lib/common/services/hooks-service.js +318 -0
  277. package/lib/common/services/ios-notification-service.js +49 -0
  278. package/lib/common/services/json-file-settings-service.js +133 -0
  279. package/lib/common/services/lock-service.js +129 -0
  280. package/lib/common/services/message-contract-generator.js +83 -0
  281. package/lib/common/services/messages-service.js +77 -0
  282. package/lib/common/services/micro-templating-service.js +49 -0
  283. package/lib/common/services/net-service.js +137 -0
  284. package/lib/common/services/project-files-manager.js +100 -0
  285. package/lib/common/services/project-files-provider-base.js +54 -0
  286. package/lib/common/services/proxy-service.js +64 -0
  287. package/lib/common/services/qr.js +39 -0
  288. package/lib/common/services/settings-service.js +42 -0
  289. package/lib/common/services/xcode-select-service.js +62 -0
  290. package/lib/common/utils.js +31 -0
  291. package/lib/common/validators/project-name-validator.js +88 -0
  292. package/lib/common/validators/validation-result.js +16 -0
  293. package/lib/common/vendor/License.txt +4 -0
  294. package/lib/common/vendor/jaro-winkler_distance.js +111 -0
  295. package/lib/common/verify-node-version.js +78 -0
  296. package/lib/common/yok.js +426 -0
  297. package/lib/config.js +137 -0
  298. package/lib/constants-provider.js +12 -0
  299. package/lib/constants.js +350 -0
  300. package/lib/controllers/build-controller.js +133 -0
  301. package/lib/controllers/debug-controller.js +235 -0
  302. package/lib/controllers/deploy-controller.js +38 -0
  303. package/lib/controllers/migrate-controller.js +1114 -0
  304. package/lib/controllers/platform-controller.js +127 -0
  305. package/lib/controllers/prepare-controller.js +353 -0
  306. package/lib/controllers/run-controller.js +525 -0
  307. package/lib/controllers/update-controller-base.js +84 -0
  308. package/lib/controllers/update-controller.js +188 -0
  309. package/lib/data/build-data.js +44 -0
  310. package/lib/data/controller-data-base.js +11 -0
  311. package/lib/data/debug-data.js +6 -0
  312. package/lib/data/platform-data.js +13 -0
  313. package/lib/data/prepare-data.js +46 -0
  314. package/lib/data/run-data.js +11 -0
  315. package/lib/declarations.d.ts +1256 -0
  316. package/lib/definitions/android-bundle-tool-service.d.ts +17 -0
  317. package/lib/definitions/android-plugin-migrator.d.ts +52 -0
  318. package/lib/definitions/build.d.ts +92 -0
  319. package/lib/definitions/cleanup-service.d.ts +79 -0
  320. package/lib/definitions/data.d.ts +7 -0
  321. package/lib/definitions/debug.d.ts +166 -0
  322. package/lib/definitions/deploy.d.ts +3 -0
  323. package/lib/definitions/file-log-service.d.ts +19 -0
  324. package/lib/definitions/files-hash-service.d.ts +35 -0
  325. package/lib/definitions/gradle.d.ts +33 -0
  326. package/lib/definitions/hmr-status-service.d.ts +5 -0
  327. package/lib/definitions/initialize-service.d.ts +11 -0
  328. package/lib/definitions/ios-debugger-port-service.d.ts +29 -0
  329. package/lib/definitions/ios.d.ts +97 -0
  330. package/lib/definitions/ip-service.d.ts +10 -0
  331. package/lib/definitions/livesync-global.d.ts +7 -0
  332. package/lib/definitions/livesync.d.ts +601 -0
  333. package/lib/definitions/lock-service.d.ts +43 -0
  334. package/lib/definitions/log-parser-service.d.ts +14 -0
  335. package/lib/definitions/marking-mode-service.d.ts +11 -0
  336. package/lib/definitions/metadata-filtering-service.d.ts +48 -0
  337. package/lib/definitions/migrate.d.ts +46 -0
  338. package/lib/definitions/nativescript-dev-xcode.d.ts +87 -0
  339. package/lib/definitions/pacote-service.d.ts +50 -0
  340. package/lib/definitions/platform.d.ts +146 -0
  341. package/lib/definitions/plugins.d.ts +75 -0
  342. package/lib/definitions/prepare.d.ts +51 -0
  343. package/lib/definitions/project-changes.d.ts +34 -0
  344. package/lib/definitions/project.d.ts +858 -0
  345. package/lib/definitions/prompter.d.ts +27 -0
  346. package/lib/definitions/qr-code.d.ts +3 -0
  347. package/lib/definitions/require.d.ts +11 -0
  348. package/lib/definitions/run.d.ts +45 -0
  349. package/lib/definitions/start-service.d.ts +15 -0
  350. package/lib/definitions/subscription-service.d.ts +11 -0
  351. package/lib/definitions/system-warnings.d.ts +4 -0
  352. package/lib/definitions/temp-service.d.ts +9 -0
  353. package/lib/definitions/terminal-spinner-service.d.ts +12 -0
  354. package/lib/definitions/update.d.ts +16 -0
  355. package/lib/definitions/xcode.d.ts +12 -0
  356. package/lib/detached-processes/cleanup-js-subprocess.js +62 -0
  357. package/lib/detached-processes/cleanup-process-definitions.d.ts +70 -0
  358. package/lib/detached-processes/cleanup-process.js +281 -0
  359. package/lib/detached-processes/detached-process-enums.d.ts +70 -0
  360. package/lib/detached-processes/file-log-service.js +20 -0
  361. package/lib/device-path-provider.js +60 -0
  362. package/lib/device-sockets/ios/app-debug-socket-proxy-factory.js +217 -0
  363. package/lib/device-sockets/ios/notification.js +30 -0
  364. package/lib/device-sockets/ios/socket-request-executor.js +56 -0
  365. package/lib/helpers/android-bundle-validator-helper.js +52 -0
  366. package/lib/helpers/deploy-command-helper.js +70 -0
  367. package/lib/helpers/key-command-helper.js +124 -0
  368. package/lib/helpers/livesync-command-helper.js +220 -0
  369. package/lib/helpers/network-connectivity-validator.js +47 -0
  370. package/lib/helpers/options-track-helper.js +88 -0
  371. package/lib/helpers/package-path-helper.js +6 -0
  372. package/lib/helpers/platform-command-helper.js +192 -0
  373. package/lib/helpers/version-validator-helper.js +25 -0
  374. package/lib/key-commands/bootstrap.js +21 -0
  375. package/lib/key-commands/index.js +456 -0
  376. package/lib/nativescript-cli-lib-bootstrap.js +8 -0
  377. package/lib/nativescript-cli-lib.js +5 -0
  378. package/lib/nativescript-cli.js +55 -0
  379. package/lib/node/pbxproj-dom-xcode.js +5 -0
  380. package/lib/node/xcode.js +7 -0
  381. package/lib/node-package-manager.js +156 -0
  382. package/lib/options.js +393 -0
  383. package/lib/package-installation-manager.js +221 -0
  384. package/lib/package-manager.js +184 -0
  385. package/lib/platform-command-param.js +29 -0
  386. package/lib/pnpm-package-manager.js +136 -0
  387. package/lib/project-data.js +237 -0
  388. package/lib/providers/project-files-provider.js +46 -0
  389. package/lib/resolvers/livesync-service-resolver.js +22 -0
  390. package/lib/services/analytics/analytics-broker-process.js +77 -0
  391. package/lib/services/analytics/analytics-broker.js +53 -0
  392. package/lib/services/analytics/analytics-service.js +366 -0
  393. package/lib/services/analytics/analytics.d.ts +55 -0
  394. package/lib/services/analytics/google-analytics-cross-client-custom-dimensions.d.ts +6 -0
  395. package/lib/services/analytics/google-analytics-provider.js +152 -0
  396. package/lib/services/analytics-settings-service.js +104 -0
  397. package/lib/services/android/android-bundle-tool-service.js +81 -0
  398. package/lib/services/android/gradle-build-args-service.js +87 -0
  399. package/lib/services/android/gradle-build-service.js +68 -0
  400. package/lib/services/android/gradle-command-service.js +49 -0
  401. package/lib/services/android-device-debug-service.js +173 -0
  402. package/lib/services/android-plugin-build-service.js +527 -0
  403. package/lib/services/android-project-service.js +600 -0
  404. package/lib/services/android-resources-migration-service.js +104 -0
  405. package/lib/services/apple-portal/apple-portal-application-service.js +82 -0
  406. package/lib/services/apple-portal/apple-portal-cookie-service.js +53 -0
  407. package/lib/services/apple-portal/apple-portal-session-service.js +277 -0
  408. package/lib/services/apple-portal/definitions.d.ts +87 -0
  409. package/lib/services/assets-generation/assets-generation-service.js +178 -0
  410. package/lib/services/build-artifacts-service.js +113 -0
  411. package/lib/services/build-data-service.js +20 -0
  412. package/lib/services/build-info-file-service.js +79 -0
  413. package/lib/services/cleanup-service.js +194 -0
  414. package/lib/services/cocoapods-platform-manager.js +137 -0
  415. package/lib/services/cocoapods-service.js +354 -0
  416. package/lib/services/debug-data-service.js +21 -0
  417. package/lib/services/debug-service-base.js +44 -0
  418. package/lib/services/device/device-install-app-service.js +118 -0
  419. package/lib/services/doctor-service.js +294 -0
  420. package/lib/services/extensibility-service.js +220 -0
  421. package/lib/services/files-hash-service.js +79 -0
  422. package/lib/services/hmr-status-service.js +128 -0
  423. package/lib/services/info-service.js +14 -0
  424. package/lib/services/initialize-service.js +70 -0
  425. package/lib/services/ios/export-options-plist-service.js +131 -0
  426. package/lib/services/ios/ios-signing-service.js +265 -0
  427. package/lib/services/ios/spm-service.js +78 -0
  428. package/lib/services/ios/xcodebuild-args-service.js +163 -0
  429. package/lib/services/ios/xcodebuild-command-service.js +40 -0
  430. package/lib/services/ios/xcodebuild-service.js +93 -0
  431. package/lib/services/ios-debugger-port-service.js +140 -0
  432. package/lib/services/ios-device-debug-service.js +167 -0
  433. package/lib/services/ios-entitlements-service.js +78 -0
  434. package/lib/services/ios-extensions-service.js +63 -0
  435. package/lib/services/ios-log-filter.js +70 -0
  436. package/lib/services/ios-native-target-service.js +108 -0
  437. package/lib/services/ios-project-service.js +851 -0
  438. package/lib/services/ios-provision-service.js +173 -0
  439. package/lib/services/ios-watch-app-service.js +76 -0
  440. package/lib/services/ip-service.js +78 -0
  441. package/lib/services/itmstransporter-service.js +216 -0
  442. package/lib/services/karma-execution.js +16 -0
  443. package/lib/services/livesync/android-device-livesync-service-base.js +68 -0
  444. package/lib/services/livesync/android-device-livesync-service.js +203 -0
  445. package/lib/services/livesync/android-device-livesync-sockets-service.js +198 -0
  446. package/lib/services/livesync/android-livesync-service.js +76 -0
  447. package/lib/services/livesync/android-livesync-tool.js +427 -0
  448. package/lib/services/livesync/android-livesync-tool.md +211 -0
  449. package/lib/services/livesync/device-livesync-service-base.js +69 -0
  450. package/lib/services/livesync/ios-device-livesync-service.js +218 -0
  451. package/lib/services/livesync/ios-livesync-service.js +95 -0
  452. package/lib/services/livesync/livesync-socket.js +14 -0
  453. package/lib/services/livesync/platform-livesync-service-base.js +180 -0
  454. package/lib/services/livesync-process-data-service.js +43 -0
  455. package/lib/services/log-parser-service.js +52 -0
  456. package/lib/services/log-source-map-service.js +235 -0
  457. package/lib/services/marking-mode-service.js +56 -0
  458. package/lib/services/metadata-filtering-service.js +105 -0
  459. package/lib/services/npm-config-service.js +39 -0
  460. package/lib/services/pacote-service.js +109 -0
  461. package/lib/services/performance-service.js +92 -0
  462. package/lib/services/platform/add-platform-service.js +119 -0
  463. package/lib/services/platform/platform-validation-service.js +85 -0
  464. package/lib/services/platform/prepare-native-platform-service.js +87 -0
  465. package/lib/services/platform-environment-requirements.js +87 -0
  466. package/lib/services/platform-project-service-base.js +32 -0
  467. package/lib/services/platforms-data-service.js +31 -0
  468. package/lib/services/plugins-service.js +477 -0
  469. package/lib/services/prepare-data-service.js +21 -0
  470. package/lib/services/project-backup-service.js +114 -0
  471. package/lib/services/project-changes-service.js +274 -0
  472. package/lib/services/project-cleanup-service.js +102 -0
  473. package/lib/services/project-config-service.js +335 -0
  474. package/lib/services/project-data-service.js +478 -0
  475. package/lib/services/project-name-service.js +67 -0
  476. package/lib/services/project-service.js +204 -0
  477. package/lib/services/project-templates-service.js +114 -0
  478. package/lib/services/qr-code-terminal-service.js +20 -0
  479. package/lib/services/require-service.js +11 -0
  480. package/lib/services/start-service.js +116 -0
  481. package/lib/services/temp-service.js +36 -0
  482. package/lib/services/terminal-spinner-service.js +38 -0
  483. package/lib/services/test-execution-service.js +154 -0
  484. package/lib/services/test-initialization-service.js +54 -0
  485. package/lib/services/timeline-profiler-service.js +108 -0
  486. package/lib/services/user-settings-service.js +34 -0
  487. package/lib/services/versions-service.js +196 -0
  488. package/lib/services/watch-ignore-list-service.js +20 -0
  489. package/lib/services/webpack/webpack-compiler-service.js +405 -0
  490. package/lib/services/webpack/webpack.d.ts +227 -0
  491. package/lib/services/xcconfig-service.js +76 -0
  492. package/lib/services/xcproj-service.js +11 -0
  493. package/lib/shared-event-bus.js +7 -0
  494. package/lib/sys-info.js +120 -0
  495. package/lib/tools/config-manipulation/config-transformer.js +201 -0
  496. package/lib/tools/node-modules/node-modules-builder.js +42 -0
  497. package/lib/tools/node-modules/node-modules-dependencies-builder.js +100 -0
  498. package/lib/yarn-package-manager.js +134 -0
  499. package/lib/yarn2-package-manager.js +143 -0
  500. package/package.json +192 -0
  501. package/postinstall.js +10 -0
  502. package/preuninstall.js +14 -0
  503. package/resources/assets/image-definitions.json +655 -0
  504. package/resources/test/example.jasmine.js +6 -0
  505. package/resources/test/example.jasmine.ts +6 -0
  506. package/resources/test/example.mocha.js +9 -0
  507. package/resources/test/example.mocha.ts +9 -0
  508. package/resources/test/example.qunit.js +7 -0
  509. package/resources/test/example.qunit.ts +7 -0
  510. package/resources/test/karma.conf.js +93 -0
  511. package/resources/test/test-main.js +9 -0
  512. package/resources/test/test-main.ts +11 -0
  513. package/resources/test/tsconfig.spec.json +9 -0
  514. package/setup/mac-startup-shell-script.sh +2 -0
  515. package/vendor/aab-tool/LICENSE +202 -0
  516. package/vendor/aab-tool/README.txt +1 -0
  517. package/vendor/aab-tool/bundletool.jar +0 -0
  518. package/vendor/gradle-app/app/build.gradle +1054 -0
  519. package/vendor/gradle-app/app/gradle-helpers/AnalyticsCollector.gradle +48 -0
  520. package/vendor/gradle-app/app/gradle-helpers/BuildToolTask.gradle +50 -0
  521. package/vendor/gradle-app/app/gradle-helpers/CustomExecutionLogger.gradle +52 -0
  522. package/vendor/gradle-app/build.gradle +170 -0
  523. package/vendor/gradle-app/settings.gradle +78 -0
  524. package/vendor/gradle-plugin/LICENSE +995 -0
  525. package/vendor/gradle-plugin/build.gradle +363 -0
  526. package/vendor/gradle-plugin/gradle/wrapper/gradle-wrapper.jar +0 -0
  527. package/vendor/gradle-plugin/gradle/wrapper/gradle-wrapper.properties +6 -0
  528. package/vendor/gradle-plugin/gradle.properties +6 -0
  529. package/vendor/gradle-plugin/gradlew +172 -0
  530. package/vendor/gradle-plugin/gradlew.bat +84 -0
  531. 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);