@scandipwa/magento-scripts 2.0.3 → 2.0.4

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 (347) hide show
  1. package/.eslintrc +6 -1
  2. package/exec.js +75 -39
  3. package/index.js +87 -46
  4. package/lib/commands/cleanup.js +18 -21
  5. package/lib/commands/cli.js +138 -73
  6. package/lib/commands/execute.js +5 -5
  7. package/lib/commands/import-db.js +21 -24
  8. package/lib/commands/link.js +17 -20
  9. package/lib/commands/logs.js +91 -91
  10. package/lib/commands/start.js +229 -191
  11. package/lib/commands/status.js +64 -50
  12. package/lib/commands/stop.js +14 -11
  13. package/lib/config/check-configuration-file.js +33 -28
  14. package/lib/config/cma-config.js +4 -4
  15. package/lib/config/config.js +40 -18
  16. package/lib/config/dependencies-for-platforms.js +33 -3
  17. package/lib/config/docker.js +259 -157
  18. package/lib/config/get-magento-version-config.js +45 -38
  19. package/lib/config/get-port-config.js +30 -44
  20. package/lib/config/get-project-configuration.js +8 -8
  21. package/lib/config/index.js +51 -42
  22. package/lib/config/magento/required-php-extensions/index.js +33 -19
  23. package/lib/config/magento/required-php-extensions/magento-2.3.js +2 -2
  24. package/lib/config/magento/required-php-extensions/magento-2.4.js +2 -2
  25. package/lib/config/magento-config.js +4 -4
  26. package/lib/config/php-config.js +8 -6
  27. package/lib/config/port-config.js +62 -43
  28. package/lib/config/save-config.js +6 -6
  29. package/lib/config/scandipwa-versions.js +2 -2
  30. package/lib/config/services/composer/versions/composer-1.js +2 -2
  31. package/lib/config/services/composer/versions/composer-2.js +2 -2
  32. package/lib/config/services/composer/versions/index.js +1 -1
  33. package/lib/config/services/elasticsearch/base-repo.js +1 -1
  34. package/lib/config/services/elasticsearch/default-es-env.js +4 -1
  35. package/lib/config/services/elasticsearch/versions/elasticsearch-6.8.js +17 -14
  36. package/lib/config/services/elasticsearch/versions/elasticsearch-7.10.js +4 -4
  37. package/lib/config/services/elasticsearch/versions/elasticsearch-7.12.js +4 -4
  38. package/lib/config/services/elasticsearch/versions/elasticsearch-7.16.js +4 -4
  39. package/lib/config/services/elasticsearch/versions/elasticsearch-7.17.js +4 -4
  40. package/lib/config/services/elasticsearch/versions/elasticsearch-7.6.js +4 -4
  41. package/lib/config/services/elasticsearch/versions/elasticsearch-7.7.js +4 -4
  42. package/lib/config/services/elasticsearch/versions/elasticsearch-7.9.js +4 -4
  43. package/lib/config/services/elasticsearch/versions/index.js +9 -9
  44. package/lib/config/services/maildev/index.js +5 -2
  45. package/lib/config/services/mariadb/versions/index.js +1 -1
  46. package/lib/config/services/mariadb/versions/mariadb-10.2.js +3 -3
  47. package/lib/config/services/mariadb/versions/mariadb-10.3.js +3 -3
  48. package/lib/config/services/mariadb/versions/mariadb-10.4.js +3 -3
  49. package/lib/config/services/nginx/versions/index.js +1 -1
  50. package/lib/config/services/nginx/versions/nginx-1.18.js +5 -4
  51. package/lib/config/services/php/base-repo.js +1 -1
  52. package/lib/config/services/php/extensions/apcu.js +3 -3
  53. package/lib/config/services/php/extensions/bcmath.js +2 -2
  54. package/lib/config/services/php/extensions/curl.js +3 -6
  55. package/lib/config/services/php/extensions/gd.js +4 -3
  56. package/lib/config/services/php/extensions/index.js +9 -8
  57. package/lib/config/services/php/extensions/intl.js +3 -5
  58. package/lib/config/services/php/extensions/opcache.js +3 -5
  59. package/lib/config/services/php/extensions/pdo_mysql.js +2 -2
  60. package/lib/config/services/php/extensions/soap.js +3 -5
  61. package/lib/config/services/php/extensions/sodium.js +3 -5
  62. package/lib/config/services/php/extensions/xdebug.js +5 -3
  63. package/lib/config/services/php/extensions/xsl.js +3 -5
  64. package/lib/config/services/php/extensions/zip.js +3 -5
  65. package/lib/config/services/php/versions/index.js +1 -1
  66. package/lib/config/services/php/versions/php-7.2.js +13 -9
  67. package/lib/config/services/php/versions/php-7.3.js +13 -9
  68. package/lib/config/services/php/versions/php-7.4.js +13 -9
  69. package/lib/config/services/php/versions/php-8.1.js +13 -9
  70. package/lib/config/services/redis/index.js +1 -1
  71. package/lib/config/services/redis/redis-5.0.js +2 -2
  72. package/lib/config/services/redis/redis-6.0.js +2 -2
  73. package/lib/config/services/redis/redis-6.2.js +2 -2
  74. package/lib/config/services/ssl-terminator/index.js +6 -5
  75. package/lib/config/services/varnish/index.js +1 -1
  76. package/lib/config/services/varnish/varnish-6-0.js +7 -5
  77. package/lib/config/services/varnish/varnish-6-6.js +7 -5
  78. package/lib/config/services/varnish/varnish-7-0.js +7 -5
  79. package/lib/config/system-config.js +55 -32
  80. package/lib/config/templates/mariadb.template.cnf +2 -0
  81. package/lib/config/versions/index.js +48 -27
  82. package/lib/config/versions/magento-2.2.10.js +22 -15
  83. package/lib/config/versions/magento-2.3.0.js +22 -15
  84. package/lib/config/versions/magento-2.3.1.js +22 -15
  85. package/lib/config/versions/magento-2.3.2-p1.js +22 -15
  86. package/lib/config/versions/magento-2.3.2-p2.js +22 -15
  87. package/lib/config/versions/magento-2.3.2.js +22 -15
  88. package/lib/config/versions/magento-2.3.3-p1.js +22 -15
  89. package/lib/config/versions/magento-2.3.3.js +22 -15
  90. package/lib/config/versions/magento-2.3.4-p1.js +22 -15
  91. package/lib/config/versions/magento-2.3.4-p2.js +22 -15
  92. package/lib/config/versions/magento-2.3.4.js +22 -15
  93. package/lib/config/versions/magento-2.3.5-p1.js +22 -15
  94. package/lib/config/versions/magento-2.3.5-p2.js +22 -15
  95. package/lib/config/versions/magento-2.3.5.js +27 -15
  96. package/lib/config/versions/magento-2.3.6-p1.js +22 -15
  97. package/lib/config/versions/magento-2.3.6.js +22 -15
  98. package/lib/config/versions/magento-2.3.7-p1.js +22 -15
  99. package/lib/config/versions/magento-2.3.7-p2.js +22 -15
  100. package/lib/config/versions/magento-2.3.7-p3.js +22 -15
  101. package/lib/config/versions/magento-2.3.7-p4.js +22 -15
  102. package/lib/config/versions/magento-2.3.7.js +22 -15
  103. package/lib/config/versions/magento-2.4.0-p1.js +22 -15
  104. package/lib/config/versions/magento-2.4.0.js +22 -15
  105. package/lib/config/versions/magento-2.4.1-p1.js +23 -16
  106. package/lib/config/versions/magento-2.4.1.js +23 -16
  107. package/lib/config/versions/magento-2.4.2-p1.js +23 -16
  108. package/lib/config/versions/magento-2.4.2-p2.js +23 -16
  109. package/lib/config/versions/magento-2.4.2.js +23 -16
  110. package/lib/config/versions/magento-2.4.3-p1.js +23 -16
  111. package/lib/config/versions/magento-2.4.3-p2.js +23 -16
  112. package/lib/config/versions/magento-2.4.3-p3.js +23 -16
  113. package/lib/config/versions/magento-2.4.3.js +23 -16
  114. package/lib/config/versions/magento-2.4.4-p1.js +23 -16
  115. package/lib/config/versions/magento-2.4.4-p2.js +23 -16
  116. package/lib/config/versions/magento-2.4.4.js +23 -16
  117. package/lib/config/versions/magento-2.4.5-p1.js +23 -16
  118. package/lib/config/versions/magento-2.4.5.js +23 -17
  119. package/lib/config/xml-parser.js +21 -20
  120. package/lib/errors/known-error.js +8 -6
  121. package/lib/errors/unknown-error.js +8 -6
  122. package/lib/tasks/cache/create-cache-folder.js +10 -10
  123. package/lib/tasks/cache/index.js +1 -1
  124. package/lib/tasks/cache/remove-cache-folder.js +9 -9
  125. package/lib/tasks/cleanup.js +22 -24
  126. package/lib/tasks/cli/create-bashrc-config.js +19 -11
  127. package/lib/tasks/cli/index.js +10 -13
  128. package/lib/tasks/composer/index.js +20 -15
  129. package/lib/tasks/composer/local-auth-json.js +32 -18
  130. package/lib/tasks/database/connect-to-database.js +71 -51
  131. package/lib/tasks/database/create-magento-database.js +7 -7
  132. package/lib/tasks/database/create-magento-user.js +33 -20
  133. package/lib/tasks/database/default-magento-database.js +1 -1
  134. package/lib/tasks/database/default-magento-user.js +2 -2
  135. package/lib/tasks/database/dump-theme-config.js +16 -12
  136. package/lib/tasks/database/fix-db.js +62 -52
  137. package/lib/tasks/database/import-dump-to-database.js +122 -85
  138. package/lib/tasks/database/import-remote-db/index.js +16 -18
  139. package/lib/tasks/database/import-remote-db/ssh/database-dump-command.js +2 -2
  140. package/lib/tasks/database/import-remote-db/ssh/index.js +34 -35
  141. package/lib/tasks/database/import-remote-db/ssh/readymage.js +41 -38
  142. package/lib/tasks/database/import-remote-db/ssh/regular-server.js +44 -46
  143. package/lib/tasks/database/index.js +1 -1
  144. package/lib/tasks/database/magento-tables.js +3 -3
  145. package/lib/tasks/database/restore-theme-config.js +26 -19
  146. package/lib/tasks/docker/api.d.ts +1 -1
  147. package/lib/tasks/docker/api.js +31 -33
  148. package/lib/tasks/docker/containers/container-api.d.ts +49 -14
  149. package/lib/tasks/docker/containers/container-api.js +112 -83
  150. package/lib/tasks/docker/containers/index.js +3 -3
  151. package/lib/tasks/docker/containers/tasks.js +171 -99
  152. package/lib/tasks/docker/convert-composer-home-to-composer-cache-volume.js +34 -25
  153. package/lib/tasks/docker/convert-legacy-volumes.js +91 -55
  154. package/lib/tasks/docker/convert-mysql-to-mariadb.js +178 -147
  155. package/lib/tasks/docker/image/image-api.d.ts +2 -3
  156. package/lib/tasks/docker/image/image-api.js +41 -34
  157. package/lib/tasks/docker/image/index.js +2 -2
  158. package/lib/tasks/docker/index.js +26 -21
  159. package/lib/tasks/docker/network/index.js +3 -3
  160. package/lib/tasks/docker/network/network-api.d.ts +11 -8
  161. package/lib/tasks/docker/network/network-api.js +53 -61
  162. package/lib/tasks/docker/network/tasks.js +41 -31
  163. package/lib/tasks/docker/project-image-builder.js +175 -92
  164. package/lib/tasks/docker/system/index.js +2 -2
  165. package/lib/tasks/docker/system/system-api.d.ts +2 -2
  166. package/lib/tasks/docker/system/system-api.js +16 -19
  167. package/lib/tasks/docker/volume/index.js +3 -3
  168. package/lib/tasks/docker/volume/tasks.js +63 -46
  169. package/lib/tasks/docker/volume/volume-api.d.ts +8 -5
  170. package/lib/tasks/docker/volume/volume-api.js +59 -76
  171. package/lib/tasks/execute.js +91 -55
  172. package/lib/tasks/file-system/create-mariadb-config.js +18 -10
  173. package/lib/tasks/file-system/create-nginx-config.js +18 -19
  174. package/lib/tasks/file-system/create-php-config.js +12 -8
  175. package/lib/tasks/file-system/create-php-debug-config.js +23 -18
  176. package/lib/tasks/file-system/create-php-fpm-config.js +14 -9
  177. package/lib/tasks/file-system/create-phpstorm-config/database-config.js +144 -112
  178. package/lib/tasks/file-system/create-phpstorm-config/eslint-config.js +69 -45
  179. package/lib/tasks/file-system/create-phpstorm-config/exclude-folder-config.js +69 -70
  180. package/lib/tasks/file-system/create-phpstorm-config/index.js +28 -24
  181. package/lib/tasks/file-system/create-phpstorm-config/inspection-tools-config/coding-standard-config.js +9 -9
  182. package/lib/tasks/file-system/create-phpstorm-config/inspection-tools-config/config.js +23 -23
  183. package/lib/tasks/file-system/create-phpstorm-config/inspection-tools-config/custom-ruleset-path-config.js +22 -19
  184. package/lib/tasks/file-system/create-phpstorm-config/inspection-tools-config/default-properties-config.js +26 -16
  185. package/lib/tasks/file-system/create-phpstorm-config/inspection-tools-config/eslint-inspection-config.js +14 -15
  186. package/lib/tasks/file-system/create-phpstorm-config/inspection-tools-config/index.js +43 -34
  187. package/lib/tasks/file-system/create-phpstorm-config/inspection-tools-config/inspection-tools-config.js +14 -6
  188. package/lib/tasks/file-system/create-phpstorm-config/inspection-tools-config/magento-coding-standard-config.js +9 -9
  189. package/lib/tasks/file-system/create-phpstorm-config/inspection-tools-config/mess-detector-validation-inspection-config.js +53 -47
  190. package/lib/tasks/file-system/create-phpstorm-config/inspection-tools-config/paths.js +41 -12
  191. package/lib/tasks/file-system/create-phpstorm-config/inspection-tools-config/php-cs-fixer-validation-inspection-config.js +33 -30
  192. package/lib/tasks/file-system/create-phpstorm-config/inspection-tools-config/php-cs-validation-inspection-config.js +35 -38
  193. package/lib/tasks/file-system/create-phpstorm-config/inspection-tools-config/stylelint-inspection-config.js +14 -15
  194. package/lib/tasks/file-system/create-phpstorm-config/keys.js +10 -10
  195. package/lib/tasks/file-system/create-phpstorm-config/php-config/index.js +33 -25
  196. package/lib/tasks/file-system/create-phpstorm-config/php-config/mess-detector-config.js +28 -25
  197. package/lib/tasks/file-system/create-phpstorm-config/php-config/php-code-sniffer-config.js +53 -32
  198. package/lib/tasks/file-system/create-phpstorm-config/php-config/php-config.js +7 -7
  199. package/lib/tasks/file-system/create-phpstorm-config/php-config/php-cs-fixer-config.js +37 -27
  200. package/lib/tasks/file-system/create-phpstorm-config/php-config/php-interpreters-config.js +53 -31
  201. package/lib/tasks/file-system/create-phpstorm-config/php-config/php-project-shared-configuration-config.js +42 -30
  202. package/lib/tasks/file-system/create-phpstorm-config/php-docker-settings-config/index.js +33 -20
  203. package/lib/tasks/file-system/create-phpstorm-config/php-docker-settings-config/php-docker-settings-config.js +3 -3
  204. package/lib/tasks/file-system/create-phpstorm-config/php-docker-settings-config/setup-php-docker-container-settings-config.js +27 -16
  205. package/lib/tasks/file-system/create-phpstorm-config/setup-xml-structure.js +14 -13
  206. package/lib/tasks/file-system/create-phpstorm-config/stylelint-config.js +52 -34
  207. package/lib/tasks/file-system/create-phpstorm-config/workspace-config/composer-settings-config.js +41 -33
  208. package/lib/tasks/file-system/create-phpstorm-config/workspace-config/format-setting-config.js +39 -27
  209. package/lib/tasks/file-system/create-phpstorm-config/workspace-config/index.js +34 -30
  210. package/lib/tasks/file-system/create-phpstorm-config/workspace-config/mess-detector-project-configuration-config.js +32 -22
  211. package/lib/tasks/file-system/create-phpstorm-config/workspace-config/php-code-sniffer-project-configuration-config.js +32 -22
  212. package/lib/tasks/file-system/create-phpstorm-config/workspace-config/php-cs-fixer-project-configuration-config.js +32 -22
  213. package/lib/tasks/file-system/create-phpstorm-config/workspace-config/php-debug-general-config.js +42 -31
  214. package/lib/tasks/file-system/create-phpstorm-config/workspace-config/php-server-config.js +45 -33
  215. package/lib/tasks/file-system/create-phpstorm-config/workspace-config/php-stan-project-configuration-config.js.js +32 -22
  216. package/lib/tasks/file-system/create-phpstorm-config/workspace-config/php-workspace-project-configuration-config.js +22 -19
  217. package/lib/tasks/file-system/create-phpstorm-config/workspace-config/properties-component-config.js +35 -21
  218. package/lib/tasks/file-system/create-phpstorm-config/workspace-config/psalm-project-configuration-config.js.js +31 -22
  219. package/lib/tasks/file-system/create-phpstorm-config/workspace-config/run-manager-config.js +38 -28
  220. package/lib/tasks/file-system/create-phpstorm-config/workspace-config/workspace-config.js +5 -5
  221. package/lib/tasks/file-system/create-phpstorm-config/xml-utils.js +3 -2
  222. package/lib/tasks/file-system/create-ssl-terminator-config.js +46 -34
  223. package/lib/tasks/file-system/create-varnish-config.js +20 -23
  224. package/lib/tasks/file-system/create-vscode-config.js +66 -49
  225. package/lib/tasks/file-system/index.js +29 -25
  226. package/lib/tasks/import-dump.js +54 -45
  227. package/lib/tasks/link.js +24 -23
  228. package/lib/tasks/magento/enable-magento-composer-plugins.js +213 -149
  229. package/lib/tasks/magento/index.js +1 -1
  230. package/lib/tasks/magento/install-magento-project.js +158 -97
  231. package/lib/tasks/magento/remove-magento.js +30 -24
  232. package/lib/tasks/magento/setup-magento/adjust-full-page-cache.js +27 -15
  233. package/lib/tasks/magento/setup-magento/configure-elasticsearch.js +23 -10
  234. package/lib/tasks/magento/setup-magento/create-admin.js +21 -13
  235. package/lib/tasks/magento/setup-magento/delete-admin-users.js +5 -5
  236. package/lib/tasks/magento/setup-magento/delete-customers.js +16 -10
  237. package/lib/tasks/magento/setup-magento/delete-orders.js +16 -10
  238. package/lib/tasks/magento/setup-magento/disable-2fa.js +11 -8
  239. package/lib/tasks/magento/setup-magento/disable-maintenance-mode.js +7 -7
  240. package/lib/tasks/magento/setup-magento/disable-page-builder.js +5 -4
  241. package/lib/tasks/magento/setup-magento/flush-redis-config.js +14 -8
  242. package/lib/tasks/magento/setup-magento/increase-admin-session-lifetime.js +21 -17
  243. package/lib/tasks/magento/setup-magento/index-products.js +4 -6
  244. package/lib/tasks/magento/setup-magento/index.js +54 -47
  245. package/lib/tasks/magento/setup-magento/install-magento.js +112 -79
  246. package/lib/tasks/magento/setup-magento/migrate-database.js +115 -96
  247. package/lib/tasks/magento/setup-magento/set-base-url.js +35 -21
  248. package/lib/tasks/magento/setup-magento/set-deployment-mode.js +15 -13
  249. package/lib/tasks/magento/setup-magento/set-mail-config.js +20 -14
  250. package/lib/tasks/magento/setup-magento/set-url-rewrite.js +13 -9
  251. package/lib/tasks/magento/setup-magento/upgrade-magento.js +30 -22
  252. package/lib/tasks/magento/setup-magento/urn-highlighter.js +11 -11
  253. package/lib/tasks/magento/setup-magento/varnish-config.js +42 -32
  254. package/lib/tasks/magento/setup-magento/waiting-for-redis.js +6 -8
  255. package/lib/tasks/magento/setup-magento/waiting-for-varnish.js +108 -65
  256. package/lib/tasks/magento/uninstall-magento.js +19 -16
  257. package/lib/tasks/php/php-container.d.ts +19 -0
  258. package/lib/tasks/php/php-container.js +50 -46
  259. package/lib/tasks/php/update-env-php.js +50 -30
  260. package/lib/tasks/project-config/index.js +12 -8
  261. package/lib/tasks/requirements/composer-credentials.js +215 -112
  262. package/lib/tasks/requirements/docker/context.js +49 -37
  263. package/lib/tasks/requirements/docker/index.js +123 -89
  264. package/lib/tasks/requirements/docker/install-on-mac.js +21 -14
  265. package/lib/tasks/requirements/docker/install.js +63 -52
  266. package/lib/tasks/requirements/docker/performance.js +40 -24
  267. package/lib/tasks/requirements/docker/permissions.js +27 -17
  268. package/lib/tasks/requirements/docker/running-status.js +79 -66
  269. package/lib/tasks/requirements/docker/version.js +14 -11
  270. package/lib/tasks/requirements/index.js +33 -29
  271. package/lib/tasks/requirements/node-version.js +8 -8
  272. package/lib/tasks/requirements/php-version.js +14 -11
  273. package/lib/tasks/requirements/platform.js +42 -26
  274. package/lib/tasks/requirements/rosetta.js +15 -12
  275. package/lib/tasks/start.js +172 -148
  276. package/lib/tasks/status/index.js +155 -88
  277. package/lib/tasks/stop.js +22 -18
  278. package/lib/tasks/theme/build-theme.js +50 -33
  279. package/lib/tasks/theme/install-theme.js +31 -18
  280. package/lib/tasks/theme/link-theme.js +27 -21
  281. package/lib/tasks/theme/retrieve-theme-data.js +24 -18
  282. package/lib/tasks/theme/setup-themes.js +87 -59
  283. package/lib/tasks/theme/symlink-theme.js +44 -22
  284. package/lib/util/CSA-theme.js +23 -21
  285. package/lib/util/analytics.js +130 -75
  286. package/lib/util/arch.js +22 -18
  287. package/lib/util/clean-object.js +15 -10
  288. package/lib/util/config-file-validator.js +63 -54
  289. package/lib/util/config-php-json.js +34 -16
  290. package/lib/util/connection-string.js +41 -27
  291. package/lib/util/console-block.js +112 -65
  292. package/lib/util/database.js +56 -33
  293. package/lib/util/deepmerge.d.ts +1 -1
  294. package/lib/util/deepmerge.js +19 -28
  295. package/lib/util/dockerfile-builder/build-instructions.js +159 -143
  296. package/lib/util/dockerfile-builder/index.js +47 -73
  297. package/lib/util/dockerfile-builder/types.d.ts +2 -1
  298. package/lib/util/download-file.js +28 -16
  299. package/lib/util/env-php-json.js +42 -16
  300. package/lib/util/exec-async-command.d.ts +9 -9
  301. package/lib/util/exec-async-command.js +82 -59
  302. package/lib/util/exec-async.d.ts +2 -0
  303. package/lib/util/exec-async.js +12 -5
  304. package/lib/util/execute-in-container.js +22 -27
  305. package/lib/util/execute-sudo-command.js +11 -15
  306. package/lib/util/get-brew-bin-path.js +27 -23
  307. package/lib/util/get-installed-magento-version.js +22 -16
  308. package/lib/util/get-jsonfile-data.js +14 -9
  309. package/lib/util/install-dependencies-task.js +53 -41
  310. package/lib/util/instance-metadata.js +44 -29
  311. package/lib/util/ip.js +16 -12
  312. package/lib/util/is-running-root.js +6 -3
  313. package/lib/util/is-wsl.js +10 -10
  314. package/lib/util/macos-version.js +12 -11
  315. package/lib/util/magento-task.js +14 -9
  316. package/lib/util/match-filesystem.js +22 -16
  317. package/lib/util/move-file.js +40 -25
  318. package/lib/util/nginx-logs-parser.js +50 -39
  319. package/lib/util/open-browser.js +8 -5
  320. package/lib/util/os-platform.js +40 -32
  321. package/lib/util/path-exists-sync.js +10 -6
  322. package/lib/util/path-exists.js +6 -6
  323. package/lib/util/php-task.js +11 -10
  324. package/lib/util/portscanner.js +97 -85
  325. package/lib/util/prefix.js +31 -22
  326. package/lib/util/resolve-configuration-with-overrides.js +30 -15
  327. package/lib/util/rmdir-safe.js +15 -11
  328. package/lib/util/run-composer.js +16 -16
  329. package/lib/util/run-container-image.js +9 -4
  330. package/lib/util/run-magento.js +16 -17
  331. package/lib/util/run-php.js +16 -21
  332. package/lib/util/safe-regex-extract.js +8 -12
  333. package/lib/util/set-config.js +24 -15
  334. package/lib/util/sleep.js +7 -2
  335. package/lib/util/systemctl.js +62 -44
  336. package/lib/util/wait-for-it.js +42 -33
  337. package/lib/util/wait-for-logs.js +42 -35
  338. package/lib/util/xdg-open-exists.js +19 -19
  339. package/package.json +7 -3
  340. package/tsconfig.json +24 -0
  341. package/typings/context.d.ts +76 -34
  342. package/typings/index.d.ts +44 -19
  343. package/typings/override.d.ts +14 -0
  344. package/typings/phpstorm.d.ts +19 -19
  345. package/.prettierrc +0 -3
  346. package/lib/util/get-php-for-phpbrew.js +0 -30
  347. package/lib/util/request.js +0 -0
@@ -1,10 +1,8 @@
1
1
  /**
2
- * @type {import('../../../../typings/index').PHPExtensionInstallationInstruction}
2
+ * @type {import('../../../../../typings/index').PHPExtensionInstallationInstruction}
3
3
  */
4
4
  module.exports = {
5
5
  name: 'soap',
6
6
  command: 'docker-php-ext-install soap',
7
- dependencies: [
8
- 'libxml2-dev'
9
- ]
10
- };
7
+ dependencies: ['libxml2-dev']
8
+ }
@@ -1,10 +1,8 @@
1
1
  /**
2
- * @type {import('../../../../typings/index').PHPExtensionInstallationInstruction}
2
+ * @type {import('../../../../../typings/index').PHPExtensionInstallationInstruction}
3
3
  */
4
4
  module.exports = {
5
5
  name: 'sodium',
6
6
  command: 'docker-php-ext-install sodium',
7
- dependencies: [
8
- 'libsodium-dev'
9
- ]
10
- };
7
+ dependencies: ['libsodium-dev']
8
+ }
@@ -1,12 +1,14 @@
1
1
  /* eslint-disable max-len */
2
2
  /**
3
- * @type {import('../../../../typings/index').PHPExtensionInstallationInstruction}
3
+ * @type {import('../../../../../typings/index').PHPExtensionInstallationInstruction}
4
4
  */
5
5
  module.exports = {
6
6
  name: 'xdebug',
7
- command: ({ version = '' } = {}) => `apk add --no-cache --virtual .build-deps \\$PHPIZE_DEPS \
7
+ command: ({
8
+ version = ''
9
+ }) => `apk add --no-cache --virtual .build-deps \\$PHPIZE_DEPS \
8
10
  && pecl install xdebug${version ? `-${version}` : ''} \
9
11
  && docker-php-ext-enable xdebug \
10
12
  && apk del -f .build-deps`,
11
13
  version: '3.1.5'
12
- };
14
+ }
@@ -1,10 +1,8 @@
1
1
  /**
2
- * @type {import('../../../../typings/index').PHPExtensionInstallationInstruction}
2
+ * @type {import('../../../../../typings/index').PHPExtensionInstallationInstruction}
3
3
  */
4
4
  module.exports = {
5
5
  name: 'xsl',
6
6
  command: 'docker-php-ext-install xsl',
7
- dependencies: [
8
- 'libxslt-dev'
9
- ]
10
- };
7
+ dependencies: ['libxslt-dev']
8
+ }
@@ -1,10 +1,8 @@
1
1
  /**
2
- * @type {import('../../../../typings/index').PHPExtensionInstallationInstruction}
2
+ * @type {import('../../../../../typings/index').PHPExtensionInstallationInstruction}
3
3
  */
4
4
  module.exports = {
5
5
  name: 'zip',
6
6
  command: 'docker-php-ext-install zip',
7
- dependencies: [
8
- 'libzip-dev'
9
- ]
10
- };
7
+ dependencies: ['libzip-dev']
8
+ }
@@ -3,4 +3,4 @@ module.exports = {
3
3
  php73: require('./php-7.3'),
4
4
  php74: require('./php-7.4'),
5
5
  php81: require('./php-8.1')
6
- };
6
+ }
@@ -1,17 +1,21 @@
1
- const path = require('path');
2
- const { repo } = require('../base-repo');
3
- const xdebug = require('../extensions/xdebug');
1
+ const path = require('path')
2
+ const { repo } = require('../base-repo')
3
+ const xdebug = require('../extensions/xdebug')
4
4
 
5
5
  /**
6
- * @returns {import('../../../../typings/index').PHPConfiguration}
6
+ * @param {Object} param0
7
+ * @param {string} param0.templateDir
8
+ * @param {import('../../../../../typings/index').PHPExtensions} [param0.extensions]
9
+ * @param {string} [param0.baseImage]
10
+ * @returns {import('../../../../../typings/index').PHPConfiguration}
7
11
  */
8
12
  const php72 = ({
9
13
  templateDir,
10
14
  extensions = {},
11
- baseImage = `${ repo }:php-7.2`
12
- } = {}) => ({
15
+ baseImage = `${repo}:php-7.2`
16
+ }) => ({
13
17
  baseImage,
14
- debugImage: `${ baseImage }-debug`,
18
+ debugImage: `${baseImage}-debug`,
15
19
  configTemplate: path.join(templateDir || '', 'php.template.ini'),
16
20
  fpmConfigTemplate: path.join(templateDir || '', 'php-fpm.template.conf'),
17
21
  debugTemplate: path.join(templateDir || '', 'php-debug.template.ini'),
@@ -19,6 +23,6 @@ const php72 = ({
19
23
  xdebug,
20
24
  ...extensions
21
25
  }
22
- });
26
+ })
23
27
 
24
- module.exports = php72;
28
+ module.exports = php72
@@ -1,17 +1,21 @@
1
- const path = require('path');
2
- const { repo } = require('../base-repo');
3
- const xdebug = require('../extensions/xdebug');
1
+ const path = require('path')
2
+ const { repo } = require('../base-repo')
3
+ const xdebug = require('../extensions/xdebug')
4
4
 
5
5
  /**
6
- * @returns {import('../../../../typings/index').PHPConfiguration}
6
+ * @param {Object} param0
7
+ * @param {string} param0.templateDir
8
+ * @param {import('../../../../../typings/index').PHPExtensions} [param0.extensions]
9
+ * @param {string} [param0.baseImage]
10
+ * @returns {import('../../../../../typings/index').PHPConfiguration}
7
11
  */
8
12
  const php73 = ({
9
13
  templateDir,
10
14
  extensions = {},
11
- baseImage = `${ repo }:php-7.3`
12
- } = {}) => ({
15
+ baseImage = `${repo}:php-7.3`
16
+ }) => ({
13
17
  baseImage,
14
- debugImage: `${ baseImage }-debug`,
18
+ debugImage: `${baseImage}-debug`,
15
19
  configTemplate: path.join(templateDir || '', 'php.template.ini'),
16
20
  fpmConfigTemplate: path.join(templateDir || '', 'php-fpm.template.conf'),
17
21
  debugTemplate: path.join(templateDir || '', 'php-debug.template.ini'),
@@ -19,6 +23,6 @@ const php73 = ({
19
23
  xdebug,
20
24
  ...extensions
21
25
  }
22
- });
26
+ })
23
27
 
24
- module.exports = php73;
28
+ module.exports = php73
@@ -1,17 +1,21 @@
1
- const path = require('path');
2
- const { repo } = require('../base-repo');
3
- const xdebug = require('../extensions/xdebug');
1
+ const path = require('path')
2
+ const { repo } = require('../base-repo')
3
+ const xdebug = require('../extensions/xdebug')
4
4
 
5
5
  /**
6
- * @returns {import('../../../../typings/index').PHPConfiguration}
6
+ * @param {Object} param0
7
+ * @param {string} param0.templateDir
8
+ * @param {import('../../../../../typings/index').PHPExtensions} [param0.extensions]
9
+ * @param {string} [param0.baseImage]
10
+ * @returns {import('../../../../../typings/index').PHPConfiguration}
7
11
  */
8
12
  const php74 = ({
9
13
  templateDir,
10
14
  extensions = {},
11
- baseImage = `${ repo }:php-7.4`
12
- } = {}) => ({
15
+ baseImage = `${repo}:php-7.4`
16
+ }) => ({
13
17
  baseImage,
14
- debugImage: `${ baseImage }-debug`,
18
+ debugImage: `${baseImage}-debug`,
15
19
  configTemplate: path.join(templateDir || '', 'php.template.ini'),
16
20
  fpmConfigTemplate: path.join(templateDir || '', 'php-fpm.template.conf'),
17
21
  debugTemplate: path.join(templateDir || '', 'php-debug.template.ini'),
@@ -19,6 +23,6 @@ const php74 = ({
19
23
  xdebug,
20
24
  ...extensions
21
25
  }
22
- });
26
+ })
23
27
 
24
- module.exports = php74;
28
+ module.exports = php74
@@ -1,17 +1,21 @@
1
- const path = require('path');
2
- const { repo } = require('../base-repo');
3
- const xdebug = require('../extensions/xdebug');
1
+ const path = require('path')
2
+ const { repo } = require('../base-repo')
3
+ const xdebug = require('../extensions/xdebug')
4
4
 
5
5
  /**
6
- * @returns {import('../../../../typings/index').PHPConfiguration}
6
+ * @param {Object} param0
7
+ * @param {string} param0.templateDir
8
+ * @param {import('../../../../../typings/index').PHPExtensions} [param0.extensions]
9
+ * @param {string} [param0.baseImage]
10
+ * @returns {import('../../../../../typings/index').PHPConfiguration}
7
11
  */
8
12
  const php81 = ({
9
13
  templateDir,
10
14
  extensions = {},
11
- baseImage = `${ repo }:php-8.1`
12
- } = {}) => ({
15
+ baseImage = `${repo}:php-8.1`
16
+ }) => ({
13
17
  baseImage,
14
- debugImage: `${ baseImage }-debug`,
18
+ debugImage: `${baseImage}-debug`,
15
19
  configTemplate: path.join(templateDir || '', 'php.template.ini'),
16
20
  fpmConfigTemplate: path.join(templateDir || '', 'php-fpm.template.conf'),
17
21
  debugTemplate: path.join(templateDir || '', 'php-debug.template.ini'),
@@ -19,6 +23,6 @@ const php81 = ({
19
23
  xdebug,
20
24
  ...extensions
21
25
  }
22
- });
26
+ })
23
27
 
24
- module.exports = php81;
28
+ module.exports = php81
@@ -2,4 +2,4 @@ module.exports = {
2
2
  redis50: require('./redis-5.0'),
3
3
  redis60: require('./redis-6.0'),
4
4
  redis62: require('./redis-6.2')
5
- };
5
+ }
@@ -3,6 +3,6 @@
3
3
  */
4
4
  const redis50 = () => ({
5
5
  image: 'redis:5.0-alpine'
6
- });
6
+ })
7
7
 
8
- module.exports = redis50;
8
+ module.exports = redis50
@@ -3,6 +3,6 @@
3
3
  */
4
4
  const redis60 = () => ({
5
5
  image: 'redis:6.0-alpine'
6
- });
6
+ })
7
7
 
8
- module.exports = redis60;
8
+ module.exports = redis60
@@ -3,6 +3,6 @@
3
3
  */
4
4
  const redis62 = () => ({
5
5
  image: 'redis:6.2-alpine'
6
- });
6
+ })
7
7
 
8
- module.exports = redis62;
8
+ module.exports = redis62
@@ -1,13 +1,14 @@
1
- const path = require('path');
1
+ const path = require('path')
2
2
 
3
3
  /**
4
- * @returns {import('../../../../typings/index').SSLTerminatorConfiguration}
4
+ * @param {{ templateDir: string }} param0
5
+ * @returns {import('../../../../typings/index').NginxConfiguration}
5
6
  */
6
7
  const sslTerminator = ({ templateDir }) => ({
7
- version: '1.18.0',
8
+ image: 'nginx:1.18.0',
8
9
  configTemplate: path.join(templateDir || '', 'ssl-terminator.template.conf')
9
- });
10
+ })
10
11
 
11
12
  module.exports = {
12
13
  sslTerminator
13
- };
14
+ }
@@ -2,4 +2,4 @@ module.exports = {
2
2
  varnish60: require('./varnish-6-0'),
3
3
  varnish66: require('./varnish-6-6'),
4
4
  varnish70: require('./varnish-7-0')
5
- };
5
+ }
@@ -1,13 +1,15 @@
1
- const path = require('path');
1
+ const path = require('path')
2
2
 
3
3
  /**
4
- * @returns {import('../../../typings/index').VarnishConfiguration}
4
+ * @param {Object} param0
5
+ * @param {string} param0.templateDir
6
+ * @returns {import('../../../../typings/index').VarnishConfiguration}
5
7
  */
6
8
  const varnish60 = ({ templateDir }) => ({
7
9
  enabled: true,
8
10
  healthCheck: false,
9
- version: '6.0',
11
+ image: 'varnish:6.0',
10
12
  configTemplate: path.join(templateDir || '', 'varnish.template.vcl')
11
- });
13
+ })
12
14
 
13
- module.exports = varnish60;
15
+ module.exports = varnish60
@@ -1,13 +1,15 @@
1
- const path = require('path');
1
+ const path = require('path')
2
2
 
3
3
  /**
4
- * @returns {import('../../../typings/index').VarnishConfiguration}
4
+ * @param {Object} param0
5
+ * @param {string} param0.templateDir
6
+ * @returns {import('../../../../typings/index').VarnishConfiguration}
5
7
  */
6
8
  const varnish66 = ({ templateDir }) => ({
7
9
  enabled: true,
8
10
  healthCheck: false,
9
- version: '6.6',
11
+ image: 'varnish:6.6',
10
12
  configTemplate: path.join(templateDir || '', 'varnish.template.vcl')
11
- });
13
+ })
12
14
 
13
- module.exports = varnish66;
15
+ module.exports = varnish66
@@ -1,13 +1,15 @@
1
- const path = require('path');
1
+ const path = require('path')
2
2
 
3
3
  /**
4
- * @returns {import('../../../typings/index').VarnishConfiguration}
4
+ * @param {Object} param0
5
+ * @param {string} param0.templateDir
6
+ * @returns {import('../../../../typings/index').VarnishConfiguration}
5
7
  */
6
8
  const varnish70 = ({ templateDir }) => ({
7
9
  enabled: true,
8
10
  healthCheck: false,
9
- version: '7.0',
11
+ image: 'varnish:7.0',
10
12
  configTemplate: path.join(templateDir || '', 'varnish.template.vcl')
11
- });
13
+ })
12
14
 
13
- module.exports = varnish70;
15
+ module.exports = varnish70
@@ -1,81 +1,104 @@
1
- const os = require('os');
2
- const path = require('path');
3
- const fs = require('fs');
4
- const pathExists = require('../util/path-exists');
5
- const { systemConfigurationSchema } = require('../util/config-file-validator');
6
- const { deepmerge } = require('../util/deepmerge');
7
- const pathExistsSync = require('../util/path-exists-sync');
8
- const KnownError = require('../errors/known-error');
1
+ const os = require('os')
2
+ const path = require('path')
3
+ const fs = require('fs')
4
+ const pathExists = require('../util/path-exists')
5
+ const { systemConfigurationSchema } = require('../util/config-file-validator')
6
+ const { deepmerge } = require('../util/deepmerge')
7
+ const pathExistsSync = require('../util/path-exists-sync')
8
+ const KnownError = require('../errors/known-error')
9
9
 
10
10
  const defaultSystemConfig = {
11
11
  analytics: true,
12
12
  useNonOverlappingPorts: false
13
- };
14
- const systemConfigPath = path.join(os.homedir(), '.cmarc');
13
+ }
14
+ const systemConfigPath = path.join(os.homedir(), '.cmarc')
15
15
 
16
16
  /**
17
17
  * @returns {Promise<typeof defaultSystemConfig>}
18
18
  */
19
19
  const getSystemConfig = async ({ validate = true } = {}) => {
20
20
  if (await pathExists(systemConfigPath)) {
21
- const userSystemConfig = await fs.promises.readFile(systemConfigPath, 'utf-8');
22
- let userSystemConfigParsed;
21
+ const userSystemConfig = await fs.promises.readFile(
22
+ systemConfigPath,
23
+ 'utf-8'
24
+ )
25
+ let userSystemConfigParsed
23
26
  try {
24
- userSystemConfigParsed = JSON.parse(userSystemConfig);
27
+ userSystemConfigParsed = JSON.parse(userSystemConfig)
25
28
  } catch (e) {
26
- throw new KnownError(`System configuration file is not a valid JSON!\n\nFile location: ${systemConfigPath}`);
29
+ throw new KnownError(
30
+ `System configuration file is not a valid JSON!\n\nFile location: ${systemConfigPath}`
31
+ )
27
32
  }
28
33
 
29
34
  if (validate) {
30
35
  try {
31
- await systemConfigurationSchema.validateAsync(userSystemConfigParsed);
36
+ await systemConfigurationSchema.validateAsync(
37
+ userSystemConfigParsed
38
+ )
32
39
  } catch (e) {
33
- throw new KnownError(`Configuration file validation error!\n\n${e.message}`);
40
+ if (e instanceof Error) {
41
+ throw new KnownError(
42
+ `Configuration file validation error!\n\n${e.message}`
43
+ )
44
+ }
45
+
46
+ throw e
34
47
  }
35
48
  }
36
49
 
37
- return deepmerge(defaultSystemConfig, userSystemConfigParsed);
50
+ return deepmerge(defaultSystemConfig, userSystemConfigParsed)
38
51
  }
39
52
 
40
- return defaultSystemConfig;
41
- };
53
+ return defaultSystemConfig
54
+ }
42
55
 
43
56
  const getSystemConfigSync = ({ validate = true } = {}) => {
44
57
  if (pathExistsSync(systemConfigPath)) {
45
- const userSystemConfig = fs.readFileSync(systemConfigPath, { encoding: 'utf-8' });
46
- let userSystemConfigParsed;
58
+ const userSystemConfig = fs.readFileSync(systemConfigPath, {
59
+ encoding: 'utf-8'
60
+ })
61
+ let userSystemConfigParsed
47
62
  try {
48
- userSystemConfigParsed = JSON.parse(userSystemConfig);
63
+ userSystemConfigParsed = JSON.parse(userSystemConfig)
49
64
  } catch (e) {
50
- throw new KnownError(`System configuration file is not a valid JSON!\n\nFile location: ${systemConfigPath}`);
65
+ throw new KnownError(
66
+ `System configuration file is not a valid JSON!\n\nFile location: ${systemConfigPath}`
67
+ )
51
68
  }
52
69
  if (validate) {
53
70
  try {
54
- systemConfigurationSchema.validate(userSystemConfigParsed);
71
+ systemConfigurationSchema.validate(userSystemConfigParsed)
55
72
  } catch (e) {
56
- throw new KnownError(`Configuration file validation error!\n\n${e.message}`);
73
+ if (e instanceof Error) {
74
+ throw new KnownError(
75
+ `Configuration file validation error!\n\n${e.message}`
76
+ )
77
+ }
78
+
79
+ throw e
57
80
  }
58
81
  }
59
82
 
60
- return deepmerge(defaultSystemConfig, userSystemConfigParsed);
83
+ return deepmerge(defaultSystemConfig, userSystemConfigParsed)
61
84
  }
62
85
 
63
- return defaultSystemConfig;
64
- };
86
+ return defaultSystemConfig
87
+ }
65
88
 
66
89
  /**
67
90
  * Get system configuration from configuration file located in user root directory.
68
- * @type {() => import('listr2').ListrTask<import('../../typings/context').ListrContext>}
91
+ * @returns {import('listr2').ListrTask<import('../../typings/context').ListrContext>}
69
92
  */
70
93
  const getSystemConfigTask = () => ({
71
94
  task: async (ctx) => {
72
- ctx.systemConfiguration = await getSystemConfig();
95
+ ctx.systemConfiguration = await getSystemConfig()
73
96
  }
74
- });
97
+ })
75
98
 
76
99
  module.exports = {
77
100
  defaultSystemConfig,
78
101
  getSystemConfigTask,
79
102
  getSystemConfig,
80
103
  getSystemConfigSync
81
- };
104
+ }
@@ -187,5 +187,7 @@ key_buffer = 16M
187
187
  [mariadb]
188
188
  skip-host-cache
189
189
  skip-name-resolve
190
+ optimizer_switch='rowid_filter=off'
191
+ optimizer_use_condition_selectivity=1
190
192
 
191
193
  !includedir /etc/mysql/conf.d/
@@ -1,48 +1,69 @@
1
- const path = require('path');
2
- const fs = require('fs');
3
- const semver = require('semver');
4
- const { deepmerge } = require('../../util/deepmerge');
1
+ const path = require('path')
2
+ const fs = require('fs')
3
+ const semver = require('semver')
4
+ const { deepmerge } = require('../../util/deepmerge')
5
5
 
6
6
  const defaultCMAConfig = {
7
7
  prefix: true
8
- };
8
+ }
9
9
 
10
- const magentoVersions = fs.readdirSync(__dirname, {
11
- withFileTypes: true
12
- })
10
+ const magentoVersions = fs
11
+ .readdirSync(__dirname, {
12
+ withFileTypes: true
13
+ })
13
14
  .filter((f) => f.isFile())
14
15
  .filter((f) => f.name.includes('magento'))
15
- .map((f) => require(path.join(__dirname, f.name)));
16
+ .map((f) => require(path.join(__dirname, f.name)))
16
17
 
17
- const getConfigurations = (config = {}) => magentoVersions.reduce(
18
- (acc, val) => ({
19
- ...acc,
20
- [val().magentoVersion]: deepmerge(defaultCMAConfig, {
21
- ...val(config)
22
- })
23
- }),
24
- {}
25
- );
18
+ const getConfigurations = (config = {}) =>
19
+ magentoVersions.reduce(
20
+ (acc, val) => ({
21
+ ...acc,
22
+ [val({}).magentoVersion]: deepmerge(defaultCMAConfig, {
23
+ ...val(config)
24
+ })
25
+ }),
26
+ {}
27
+ )
26
28
 
27
29
  const allVersions = Object.entries(getConfigurations())
28
30
  .map(([name, magentoConfig]) => ({ ...magentoConfig, name }))
29
31
  .sort((a, b) => {
30
- if (a.magentoVersion.replace(/-p[0-9]+$/i, '') === b.magentoVersion.replace(/-p[0-9]+$/i, '')) {
31
- if (a.magentoVersion.includes('-p') && !b.magentoVersion.includes('-p')) {
32
- return 1;
32
+ if (
33
+ a.magentoVersion.replace(/-p[0-9]+$/i, '') ===
34
+ b.magentoVersion.replace(/-p[0-9]+$/i, '')
35
+ ) {
36
+ if (
37
+ a.magentoVersion.includes('-p') &&
38
+ !b.magentoVersion.includes('-p')
39
+ ) {
40
+ return 1
33
41
  }
34
- const aPatchVersion = (a.magentoVersion.includes('-p') && Number.parseInt(a.magentoVersion.match(/-p([0-9]+)$/i)[1], 10)) || 0;
35
- const bPatchVersion = (b.magentoVersion.includes('-p') && Number.parseInt(b.magentoVersion.match(/-p([0-9]+)$/i)[1], 10)) || 0;
42
+ const aPatchVersion =
43
+ (a.magentoVersion.includes('-p') &&
44
+ Number.parseInt(
45
+ a.magentoVersion.match(/-p([0-9]+)$/i)[1],
46
+ 10
47
+ )) ||
48
+ 0
49
+ const bPatchVersion =
50
+ (b.magentoVersion.includes('-p') &&
51
+ Number.parseInt(
52
+ b.magentoVersion.match(/-p([0-9]+)$/i)[1],
53
+ 10
54
+ )) ||
55
+ 0
36
56
 
37
- return aPatchVersion - bPatchVersion;
57
+ return aPatchVersion - bPatchVersion
38
58
  }
39
59
 
40
- return semver.gt(a.magentoVersion, b.magentoVersion) ? 1 : -1;
41
- }).reverse();
60
+ return semver.gt(a.magentoVersion, b.magentoVersion) ? 1 : -1
61
+ })
62
+ .reverse()
42
63
 
43
64
  module.exports = {
44
65
  allVersions,
45
66
  getConfigurations,
46
67
  defaultConfiguration: allVersions.find((config) => config.isDefault),
47
68
  defaultCMAConfig
48
- };
69
+ }