shopify-cli 2.4.0 → 2.6.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 (250) hide show
  1. checksums.yaml +4 -4
  2. data/.github/workflows/shopify.yml +0 -2
  3. data/.gitignore +1 -0
  4. data/.rubocop.yml +14 -14
  5. data/.rubocop_todo.yml +3 -3
  6. data/CHANGELOG.md +25 -0
  7. data/Dockerfile +1 -3
  8. data/Gemfile.lock +22 -16
  9. data/README.md +1 -1
  10. data/RELEASING.md +1 -1
  11. data/Rakefile +25 -34
  12. data/bin/console +11 -0
  13. data/bin/shopify +17 -4
  14. data/dev.yml +3 -0
  15. data/ext/shopify-cli/extconf.rb +1 -0
  16. data/lib/project_types/extension/cli.rb +5 -3
  17. data/lib/project_types/extension/commands/build.rb +4 -3
  18. data/lib/project_types/extension/commands/check.rb +2 -2
  19. data/lib/project_types/extension/commands/connect.rb +1 -1
  20. data/lib/project_types/extension/commands/create.rb +41 -23
  21. data/lib/project_types/extension/commands/extension_command.rb +1 -1
  22. data/lib/project_types/extension/commands/info.rb +1 -1
  23. data/lib/project_types/extension/commands/push.rb +1 -1
  24. data/lib/project_types/extension/commands/register.rb +2 -2
  25. data/lib/project_types/extension/commands/serve.rb +5 -5
  26. data/lib/project_types/extension/commands/tunnel.rb +6 -6
  27. data/lib/project_types/extension/extension_project.rb +4 -4
  28. data/lib/project_types/extension/features/argo.rb +3 -3
  29. data/lib/project_types/extension/features/argo_config.rb +5 -5
  30. data/lib/project_types/extension/features/argo_serve.rb +21 -6
  31. data/lib/project_types/extension/features/argo_setup.rb +1 -1
  32. data/lib/project_types/extension/features/argo_setup_step.rb +1 -1
  33. data/lib/project_types/extension/features/argo_setup_steps.rb +2 -2
  34. data/lib/project_types/extension/forms/connect.rb +2 -2
  35. data/lib/project_types/extension/forms/create.rb +2 -2
  36. data/lib/project_types/extension/forms/questions/ask_app.rb +2 -2
  37. data/lib/project_types/extension/forms/questions/ask_name.rb +1 -1
  38. data/lib/project_types/extension/forms/questions/ask_registration.rb +2 -2
  39. data/lib/project_types/extension/forms/questions/ask_template.rb +2 -2
  40. data/lib/project_types/extension/forms/questions/ask_type.rb +2 -2
  41. data/lib/project_types/extension/messages/message_loading.rb +2 -2
  42. data/lib/project_types/extension/models/development_server.rb +49 -6
  43. data/lib/project_types/extension/models/development_server_requirements.rb +21 -3
  44. data/lib/project_types/extension/models/lazy_specification_handler.rb +1 -1
  45. data/lib/project_types/extension/models/specification.rb +1 -1
  46. data/lib/project_types/extension/models/specification_handlers/default.rb +14 -2
  47. data/lib/project_types/extension/models/specification_handlers/theme_app_extension.rb +1 -1
  48. data/lib/project_types/extension/models/specifications.rb +4 -4
  49. data/lib/project_types/extension/tasks/choose_next_available_port.rb +1 -1
  50. data/lib/project_types/extension/tasks/configure_features.rb +1 -1
  51. data/lib/project_types/extension/tasks/configure_options.rb +1 -1
  52. data/lib/project_types/extension/tasks/converters/product_converter.rb +1 -1
  53. data/lib/project_types/extension/tasks/converters/server_config_converter.rb +31 -0
  54. data/lib/project_types/extension/tasks/create_extension.rb +2 -2
  55. data/lib/project_types/extension/tasks/fetch_specifications.rb +2 -2
  56. data/lib/project_types/extension/tasks/find_npm_packages.rb +5 -5
  57. data/lib/project_types/extension/tasks/get_app.rb +2 -2
  58. data/lib/project_types/extension/tasks/get_apps.rb +2 -2
  59. data/lib/project_types/extension/tasks/get_extensions.rb +2 -2
  60. data/lib/project_types/extension/tasks/get_product.rb +2 -2
  61. data/lib/project_types/extension/tasks/load_server_config.rb +23 -0
  62. data/lib/project_types/extension/tasks/run_extension_command.rb +34 -11
  63. data/lib/project_types/extension/tasks/update_draft.rb +2 -2
  64. data/lib/project_types/node/cli.rb +3 -3
  65. data/lib/project_types/node/commands/connect.rb +4 -4
  66. data/lib/project_types/node/commands/create.rb +10 -10
  67. data/lib/project_types/node/commands/deploy/heroku.rb +4 -4
  68. data/lib/project_types/node/commands/deploy.rb +3 -3
  69. data/lib/project_types/node/commands/generate.rb +2 -2
  70. data/lib/project_types/node/commands/open.rb +3 -3
  71. data/lib/project_types/node/commands/serve.rb +15 -7
  72. data/lib/project_types/node/commands/tunnel.rb +6 -6
  73. data/lib/project_types/node/forms/create.rb +3 -3
  74. data/lib/project_types/node/messages/messages.rb +3 -0
  75. data/lib/project_types/php/cli.rb +27 -0
  76. data/lib/project_types/php/commands/connect.rb +19 -0
  77. data/lib/project_types/php/commands/create.rb +143 -0
  78. data/lib/project_types/php/commands/deploy/heroku.rb +129 -0
  79. data/lib/project_types/php/commands/deploy.rb +32 -0
  80. data/lib/project_types/php/commands/open.rb +16 -0
  81. data/lib/project_types/php/commands/serve.rb +51 -0
  82. data/lib/project_types/php/commands/tunnel.rb +37 -0
  83. data/lib/project_types/php/forms/create.rb +45 -0
  84. data/lib/project_types/php/messages/messages.rb +191 -0
  85. data/lib/project_types/rails/cli.rb +3 -3
  86. data/lib/project_types/rails/commands/connect.rb +4 -4
  87. data/lib/project_types/rails/commands/create.rb +12 -12
  88. data/lib/project_types/rails/commands/deploy/heroku.rb +4 -4
  89. data/lib/project_types/rails/commands/deploy.rb +3 -3
  90. data/lib/project_types/rails/commands/generate/webhook.rb +3 -3
  91. data/lib/project_types/rails/commands/generate.rb +3 -3
  92. data/lib/project_types/rails/commands/open.rb +3 -3
  93. data/lib/project_types/rails/commands/serve.rb +8 -8
  94. data/lib/project_types/rails/commands/tunnel.rb +6 -6
  95. data/lib/project_types/rails/forms/create.rb +3 -3
  96. data/lib/project_types/rails/gem.rb +1 -1
  97. data/lib/project_types/rails/ruby.rb +1 -1
  98. data/lib/project_types/script/cli.rb +15 -7
  99. data/lib/project_types/script/commands/create.rb +4 -2
  100. data/lib/project_types/script/commands/push.rb +2 -2
  101. data/lib/project_types/script/config/extension_points.yml +30 -29
  102. data/lib/project_types/script/forms/create.rb +1 -1
  103. data/lib/project_types/script/layers/application/create_script.rb +32 -12
  104. data/lib/project_types/script/layers/application/extension_points.rb +4 -4
  105. data/lib/project_types/script/layers/application/push_script.rb +4 -1
  106. data/lib/project_types/script/layers/domain/extension_point.rb +13 -45
  107. data/lib/project_types/script/layers/domain/script_project.rb +2 -2
  108. data/lib/project_types/script/layers/infrastructure/api_clients/partners_proxy_api_client.rb +57 -0
  109. data/lib/project_types/script/layers/infrastructure/api_clients/script_service_api_client.rb +35 -0
  110. data/lib/project_types/script/layers/infrastructure/command_runner.rb +1 -1
  111. data/lib/project_types/script/layers/infrastructure/errors.rb +5 -0
  112. data/lib/project_types/script/layers/infrastructure/languages/assemblyscript_project_creator.rb +10 -90
  113. data/lib/project_types/script/layers/infrastructure/languages/project_creator.rb +76 -11
  114. data/lib/project_types/script/layers/infrastructure/languages/task_runner.rb +1 -1
  115. data/lib/project_types/script/layers/infrastructure/languages/typescript_project_creator.rb +33 -0
  116. data/lib/project_types/script/layers/infrastructure/languages/typescript_task_runner.rb +105 -0
  117. data/lib/project_types/script/layers/infrastructure/push_package_repository.rb +1 -1
  118. data/lib/project_types/script/layers/infrastructure/script_project_repository.rb +6 -6
  119. data/lib/project_types/script/layers/infrastructure/script_service.rb +4 -8
  120. data/lib/project_types/script/layers/infrastructure/service_locator.rb +20 -0
  121. data/lib/project_types/script/messages/messages.rb +4 -0
  122. data/lib/project_types/script/tasks/ensure_env.rb +6 -6
  123. data/lib/project_types/script/ui/error_handler.rb +83 -75
  124. data/lib/project_types/script/ui/printing_spinner.rb +1 -1
  125. data/lib/project_types/theme/cli.rb +3 -3
  126. data/lib/project_types/theme/commands/check.rb +3 -3
  127. data/lib/project_types/theme/commands/delete.rb +7 -7
  128. data/lib/project_types/theme/commands/init.rb +3 -3
  129. data/lib/project_types/theme/commands/language_server.rb +2 -2
  130. data/lib/project_types/theme/commands/package.rb +2 -2
  131. data/lib/project_types/theme/commands/publish.rb +5 -5
  132. data/lib/project_types/theme/commands/pull.rb +9 -9
  133. data/lib/project_types/theme/commands/push.rb +12 -12
  134. data/lib/project_types/theme/commands/serve.rb +4 -4
  135. data/lib/project_types/theme/forms/confirm_store.rb +1 -1
  136. data/lib/project_types/theme/forms/select.rb +2 -2
  137. data/lib/{shopify-cli → shopify_cli}/admin_api/populate_resource_command.rb +3 -3
  138. data/lib/{shopify-cli → shopify_cli}/admin_api/schema.rb +4 -4
  139. data/lib/{shopify-cli → shopify_cli}/admin_api.rb +27 -27
  140. data/lib/{shopify-cli → shopify_cli}/api.rb +12 -8
  141. data/lib/shopify_cli/command/app_sub_command.rb +16 -0
  142. data/lib/{shopify-cli → shopify_cli}/command.rb +3 -3
  143. data/lib/{shopify-cli → shopify_cli}/commands/config.rb +14 -14
  144. data/lib/{shopify-cli → shopify_cli}/commands/help.rb +4 -4
  145. data/lib/{shopify-cli → shopify_cli}/commands/login.rb +7 -7
  146. data/lib/shopify_cli/commands/logout.rb +39 -0
  147. data/lib/{shopify-cli → shopify_cli}/commands/populate/customer.rb +4 -4
  148. data/lib/{shopify-cli → shopify_cli}/commands/populate/draft_order.rb +4 -4
  149. data/lib/{shopify-cli → shopify_cli}/commands/populate/product.rb +4 -4
  150. data/lib/shopify_cli/commands/populate.rb +23 -0
  151. data/lib/shopify_cli/commands/store.rb +15 -0
  152. data/lib/{shopify-cli → shopify_cli}/commands/switch.rb +5 -5
  153. data/lib/{shopify-cli → shopify_cli}/commands/system.rb +10 -10
  154. data/lib/shopify_cli/commands/version.rb +15 -0
  155. data/lib/{shopify-cli → shopify_cli}/commands/whoami.rb +7 -7
  156. data/lib/shopify_cli/commands.rb +34 -0
  157. data/lib/{shopify-cli → shopify_cli}/connect.rb +3 -3
  158. data/lib/shopify_cli/constants.rb +54 -0
  159. data/lib/{shopify-cli → shopify_cli}/context.rb +6 -6
  160. data/lib/{shopify-cli → shopify_cli}/core/entry_point.rb +7 -7
  161. data/lib/{shopify-cli → shopify_cli}/core/executor.rb +8 -4
  162. data/lib/{shopify-cli → shopify_cli}/core/finalize.rb +1 -1
  163. data/lib/{shopify-cli → shopify_cli}/core/help_resolver.rb +2 -2
  164. data/lib/{shopify-cli → shopify_cli}/core/monorail.rb +8 -8
  165. data/lib/shopify_cli/core.rb +8 -0
  166. data/lib/{shopify-cli → shopify_cli}/db.rb +8 -8
  167. data/lib/{shopify-cli → shopify_cli}/environment.rb +36 -5
  168. data/lib/shopify_cli/exception_reporter/permission_controller.rb +54 -0
  169. data/lib/shopify_cli/exception_reporter.rb +55 -0
  170. data/lib/{shopify-cli → shopify_cli}/feature.rb +8 -8
  171. data/lib/{shopify-cli → shopify_cli}/form.rb +2 -2
  172. data/lib/{shopify-cli → shopify_cli}/git.rb +36 -6
  173. data/lib/{shopify-cli → shopify_cli}/helpers/haikunator.rb +1 -1
  174. data/lib/shopify_cli/helpers.rb +5 -0
  175. data/lib/{shopify-cli → shopify_cli}/heroku.rb +38 -13
  176. data/lib/{shopify-cli → shopify_cli}/http_request.rb +1 -1
  177. data/lib/{shopify-cli → shopify_cli}/identity_auth/servlet.rb +1 -1
  178. data/lib/{shopify-cli → shopify_cli}/identity_auth.rb +8 -8
  179. data/lib/{shopify-cli → shopify_cli}/js_deps.rb +7 -7
  180. data/lib/{shopify-cli → shopify_cli}/js_system.rb +10 -10
  181. data/lib/{shopify-cli → shopify_cli}/lazy_delegator.rb +2 -2
  182. data/lib/{shopify-cli → shopify_cli}/messages/messages.rb +44 -2
  183. data/lib/{shopify-cli → shopify_cli}/method_object.rb +15 -8
  184. data/lib/shopify_cli/migrator/migration.rb +27 -0
  185. data/lib/shopify_cli/migrator/migrations/1631709766_noop.rb +13 -0
  186. data/lib/shopify_cli/migrator.rb +48 -0
  187. data/lib/{shopify-cli → shopify_cli}/options.rb +1 -1
  188. data/lib/{shopify-cli → shopify_cli}/packager.rb +8 -8
  189. data/lib/{shopify-cli → shopify_cli}/partners_api/organizations.rb +1 -1
  190. data/lib/{shopify-cli → shopify_cli}/partners_api.rb +13 -13
  191. data/lib/shopify_cli/php_deps.rb +102 -0
  192. data/lib/{shopify-cli → shopify_cli}/process_supervision.rb +10 -8
  193. data/lib/{shopify-cli → shopify_cli}/project.rb +15 -15
  194. data/lib/{shopify-cli → shopify_cli}/project_commands.rb +3 -3
  195. data/lib/{shopify-cli → shopify_cli}/project_type.rb +5 -5
  196. data/lib/{shopify-cli → shopify_cli}/resolve_constant.rb +5 -5
  197. data/lib/{shopify-cli → shopify_cli}/resources/env_file.rb +1 -1
  198. data/lib/shopify_cli/resources.rb +5 -0
  199. data/lib/{shopify-cli → shopify_cli}/result.rb +11 -11
  200. data/lib/{shopify-cli → shopify_cli}/shopifolk.rb +6 -6
  201. data/lib/{shopify-cli → shopify_cli}/sub_command.rb +1 -1
  202. data/lib/{shopify-cli → shopify_cli}/task.rb +1 -1
  203. data/lib/{shopify-cli → shopify_cli}/tasks/confirm_store.rb +3 -3
  204. data/lib/{shopify-cli → shopify_cli}/tasks/create_api_client.rb +4 -4
  205. data/lib/shopify_cli/tasks/ensure_authenticated.rb +13 -0
  206. data/lib/{shopify-cli → shopify_cli}/tasks/ensure_dev_store.rb +5 -5
  207. data/lib/{shopify-cli → shopify_cli}/tasks/ensure_env.rb +3 -3
  208. data/lib/{shopify-cli → shopify_cli}/tasks/ensure_loopback_url.rb +4 -4
  209. data/lib/{shopify-cli → shopify_cli}/tasks/ensure_project_type.rb +3 -3
  210. data/lib/{shopify-cli → shopify_cli}/tasks/select_org_and_shop.rb +8 -8
  211. data/lib/{shopify-cli → shopify_cli}/tasks/update_dashboard_urls.rb +6 -6
  212. data/lib/{shopify-cli → shopify_cli}/tasks.rb +10 -10
  213. data/lib/{shopify-cli → shopify_cli}/theme/dev_server/certificate_manager.rb +5 -5
  214. data/lib/{shopify-cli → shopify_cli}/theme/dev_server/header_hash.rb +1 -1
  215. data/lib/{shopify-cli → shopify_cli}/theme/dev_server/hot-reload.js +0 -0
  216. data/lib/{shopify-cli → shopify_cli}/theme/dev_server/hot_reload.rb +1 -1
  217. data/lib/{shopify-cli → shopify_cli}/theme/dev_server/local_assets.rb +1 -1
  218. data/lib/{shopify-cli → shopify_cli}/theme/dev_server/proxy.rb +2 -2
  219. data/lib/{shopify-cli → shopify_cli}/theme/dev_server/sse.rb +1 -1
  220. data/lib/{shopify-cli → shopify_cli}/theme/dev_server/watcher.rb +1 -1
  221. data/lib/{shopify-cli → shopify_cli}/theme/dev_server/web_server.rb +1 -1
  222. data/lib/{shopify-cli → shopify_cli}/theme/dev_server.rb +3 -3
  223. data/lib/{shopify-cli → shopify_cli}/theme/development_theme.rb +9 -9
  224. data/lib/{shopify-cli → shopify_cli}/theme/file.rb +1 -1
  225. data/lib/{shopify-cli → shopify_cli}/theme/ignore_filter.rb +1 -1
  226. data/lib/{shopify-cli → shopify_cli}/theme/mime_type.rb +1 -1
  227. data/lib/{shopify-cli → shopify_cli}/theme/syncer.rb +6 -6
  228. data/lib/{shopify-cli → shopify_cli}/theme/theme.rb +4 -4
  229. data/lib/{shopify-cli → shopify_cli}/transform_data_structure.rb +4 -4
  230. data/lib/{shopify-cli → shopify_cli}/tunnel.rb +14 -14
  231. data/lib/shopify_cli/version.rb +3 -0
  232. data/lib/shopify_cli.rb +61 -52
  233. data/shopify-cli.gemspec +11 -3
  234. data/utilities/docker.rb +47 -0
  235. data/utilities/utilities.rb +5 -0
  236. metadata +133 -95
  237. data/lib/project_types/script/layers/infrastructure/api_clients.rb +0 -89
  238. data/lib/project_types/script/layers/infrastructure/languages/rust_project_creator.rb +0 -73
  239. data/lib/project_types/script/layers/infrastructure/languages/rust_task_runner.rb +0 -60
  240. data/lib/shopify-cli/commands/logout.rb +0 -39
  241. data/lib/shopify-cli/commands/populate.rb +0 -23
  242. data/lib/shopify-cli/commands/store.rb +0 -15
  243. data/lib/shopify-cli/commands/version.rb +0 -15
  244. data/lib/shopify-cli/commands.rb +0 -34
  245. data/lib/shopify-cli/constants.rb +0 -26
  246. data/lib/shopify-cli/core.rb +0 -8
  247. data/lib/shopify-cli/helpers.rb +0 -5
  248. data/lib/shopify-cli/resources.rb +0 -5
  249. data/lib/shopify-cli/tasks/ensure_authenticated.rb +0 -13
  250. data/lib/shopify-cli/version.rb +0 -3
@@ -1,6 +1,6 @@
1
- module ShopifyCli
1
+ module ShopifyCLI
2
2
  ##
3
- # ShopifyCli::Shopifolk contains the logic to determine if the user appears to be a Shopify staff
3
+ # ShopifyCLI::Shopifolk contains the logic to determine if the user appears to be a Shopify staff
4
4
  #
5
5
  # The Shopifolk Feature flag will persist between runs so if the flag is enabled or disabled,
6
6
  # it will still be in that same state until the next class invocation.
@@ -20,10 +20,10 @@ module ShopifyCli
20
20
  #
21
21
  # #### Example
22
22
  #
23
- # ShopifyCli::Shopifolk.check
23
+ # ShopifyCLI::Shopifolk.check
24
24
  #
25
25
  def check
26
- ShopifyCli::Shopifolk.new.shopifolk?
26
+ ShopifyCLI::Shopifolk.new.shopifolk?
27
27
  end
28
28
 
29
29
  def act_as_shopify_organization
@@ -52,10 +52,10 @@ module ShopifyCli
52
52
  return true if Feature.enabled?(FEATURE_NAME)
53
53
 
54
54
  if shopifolk_by_gcloud? && shopifolk_by_dev?
55
- ShopifyCli::Feature.enable(FEATURE_NAME)
55
+ ShopifyCLI::Feature.enable(FEATURE_NAME)
56
56
  true
57
57
  else
58
- ShopifyCli::Feature.disable(FEATURE_NAME)
58
+ ShopifyCLI::Feature.disable(FEATURE_NAME)
59
59
  false
60
60
  end
61
61
  end
@@ -1,7 +1,7 @@
1
1
  # frozen_string_literal: true
2
2
  require "shopify_cli"
3
3
 
4
- module ShopifyCli
4
+ module ShopifyCLI
5
5
  class SubCommand < Command
6
6
  class << self
7
7
  def call(args, command_name, parent_command)
@@ -1,6 +1,6 @@
1
1
  require "shopify_cli"
2
2
 
3
- module ShopifyCli
3
+ module ShopifyCLI
4
4
  class Task
5
5
  def self.call(*args, **kwargs)
6
6
  task = new
@@ -1,11 +1,11 @@
1
1
  require "shopify_cli"
2
2
 
3
- module ShopifyCli
3
+ module ShopifyCLI
4
4
  module Tasks
5
- class ConfirmStore < ShopifyCli::Task
5
+ class ConfirmStore < ShopifyCLI::Task
6
6
  def call(ctx)
7
7
  @ctx = ctx
8
- store = ShopifyCli::AdminAPI.get_shop_or_abort(ctx)
8
+ store = ShopifyCLI::AdminAPI.get_shop_or_abort(ctx)
9
9
  if CLI::UI::Prompt.confirm(ctx.message("core.tasks.confirm_store.prompt", store), default: false)
10
10
  ctx.puts(ctx.message("core.tasks.confirm_store.confirmation", store))
11
11
  else
@@ -1,13 +1,13 @@
1
1
  require "shopify_cli"
2
2
 
3
- module ShopifyCli
3
+ module ShopifyCLI
4
4
  module Tasks
5
- class CreateApiClient < ShopifyCli::Task
5
+ class CreateApiClient < ShopifyCLI::Task
6
6
  VALID_APP_TYPES = %w(public custom)
7
7
  DEFAULT_APP_URL = "https://shopify.github.io/shopify-cli/help/start-app/"
8
8
 
9
9
  def call(ctx, org_id:, title:, type:)
10
- resp = ShopifyCli::PartnersAPI.query(
10
+ resp = ShopifyCLI::PartnersAPI.query(
11
11
  ctx,
12
12
  "create_app",
13
13
  org: org_id.to_i,
@@ -31,7 +31,7 @@ module ShopifyCli
31
31
  ctx.abort(user_errors.map { |err| "#{err["field"]} #{err["message"]}" }.join(", "))
32
32
  end
33
33
 
34
- ShopifyCli::Core::Monorail.metadata[:api_key] = resp.dig("data", "appCreate", "app", "apiKey")
34
+ ShopifyCLI::Core::Monorail.metadata[:api_key] = resp.dig("data", "appCreate", "app", "apiKey")
35
35
 
36
36
  resp.dig("data", "appCreate", "app")
37
37
  end
@@ -0,0 +1,13 @@
1
+ require "shopify_cli"
2
+
3
+ module ShopifyCLI
4
+ module Tasks
5
+ class EnsureAuthenticated < ShopifyCLI::Task
6
+ def call(ctx)
7
+ ctx.abort(
8
+ ctx.message("core.identity_auth.login_prompt", ShopifyCLI::TOOL_NAME)
9
+ ) unless ShopifyCLI::IdentityAuth::IDENTITY_ACCESS_TOKENS.all? { |key| ShopifyCLI::DB.exists?(key) }
10
+ end
11
+ end
12
+ end
13
+ end
@@ -1,8 +1,8 @@
1
1
  require "shopify_cli"
2
2
 
3
- module ShopifyCli
3
+ module ShopifyCLI
4
4
  module Tasks
5
- class EnsureDevStore < ShopifyCli::Task
5
+ class EnsureDevStore < ShopifyCLI::Task
6
6
  def call(ctx)
7
7
  @ctx = ctx
8
8
  return ctx.abort(ctx.message(
@@ -12,7 +12,7 @@ module ShopifyCli
12
12
  return unless CLI::UI::Prompt.confirm(
13
13
  ctx.message("core.tasks.ensure_dev_store.convert_to_dev_store", project.env.shop)
14
14
  )
15
- ShopifyCli::PartnersAPI.query(ctx, "convert_dev_to_test_store", input: {
15
+ ShopifyCLI::PartnersAPI.query(ctx, "convert_dev_to_test_store", input: {
16
16
  organizationID: shop["orgID"].to_i,
17
17
  shopId: shop["shopId"],
18
18
  })
@@ -22,13 +22,13 @@ module ShopifyCli
22
22
  private
23
23
 
24
24
  def project
25
- @project ||= ShopifyCli::Project.current
25
+ @project ||= ShopifyCLI::Project.current
26
26
  end
27
27
 
28
28
  def shop
29
29
  @shop ||= begin
30
30
  current_domain = project.env.shop
31
- ShopifyCli::PartnersAPI::Organizations.fetch_all(@ctx).map do |org|
31
+ ShopifyCLI::PartnersAPI::Organizations.fetch_all(@ctx).map do |org|
32
32
  org["stores"].find do |store|
33
33
  store["orgID"] = org["id"]
34
34
  store["shopDomain"] == current_domain
@@ -1,8 +1,8 @@
1
1
  require "shopify_cli"
2
2
 
3
- module ShopifyCli
3
+ module ShopifyCLI
4
4
  module Tasks
5
- class EnsureEnv < ShopifyCli::Task
5
+ class EnsureEnv < ShopifyCLI::Task
6
6
  def call(ctx, regenerate: false, required: [:api_key, :secret])
7
7
  @ctx = ctx
8
8
  env_data =
@@ -50,7 +50,7 @@ module ShopifyCli
50
50
  handler.option(@ctx.message("core.tasks.ensure_env.app_type.select_public")) { "public" }
51
51
  handler.option(@ctx.message("core.tasks.ensure_env.app_type.select_custom")) { "custom" }
52
52
  end
53
- ShopifyCli::Tasks::CreateApiClient.call(@ctx, org_id: org_id, title: title, type: type)
53
+ ShopifyCLI::Tasks::CreateApiClient.call(@ctx, org_id: org_id, title: title, type: type)
54
54
  else
55
55
  CLI::UI::Prompt.ask(@ctx.message("core.tasks.ensure_env.app_select")) do |handler|
56
56
  apps.each { |app| handler.option(app["title"]) { app } }
@@ -1,16 +1,16 @@
1
- module ShopifyCli
1
+ module ShopifyCLI
2
2
  module Tasks
3
- class EnsureLoopbackURL < ShopifyCli::Task
3
+ class EnsureLoopbackURL < ShopifyCLI::Task
4
4
  def call(ctx)
5
5
  @ctx = ctx
6
6
  api_key = Project.current.env.api_key
7
- result = ShopifyCli::PartnersAPI.query(ctx, "get_app_urls", apiKey: api_key)
7
+ result = ShopifyCLI::PartnersAPI.query(ctx, "get_app_urls", apiKey: api_key)
8
8
  loopback = IdentityAuth::REDIRECT_HOST
9
9
  app = result["data"]["app"]
10
10
  urls = app["redirectUrlWhitelist"]
11
11
  if urls.grep(/#{loopback}/).empty?
12
12
  with_loopback = urls.push(loopback)
13
- ShopifyCli::PartnersAPI.query(@ctx, "update_dashboard_urls", input: {
13
+ ShopifyCLI::PartnersAPI.query(@ctx, "update_dashboard_urls", input: {
14
14
  redirectUrlWhitelist: with_loopback, apiKey: api_key
15
15
  })
16
16
  end
@@ -1,10 +1,10 @@
1
1
  require "shopify_cli"
2
2
 
3
- module ShopifyCli
3
+ module ShopifyCLI
4
4
  module Tasks
5
- class EnsureProjectType < ShopifyCli::Task
5
+ class EnsureProjectType < ShopifyCLI::Task
6
6
  def call(ctx, project_type)
7
- return true if project_type.to_sym == ShopifyCli::Project.current_project_type
7
+ return true if project_type.to_sym == ShopifyCLI::Project.current_project_type
8
8
  ctx.abort(ctx.message("core.tasks.ensure_project_type.wrong_project_type", project_type))
9
9
  end
10
10
  end
@@ -1,8 +1,8 @@
1
1
  require "shopify_cli"
2
2
 
3
- module ShopifyCli
3
+ module ShopifyCLI
4
4
  module Tasks
5
- class SelectOrgAndShop < ShopifyCli::Task
5
+ class SelectOrgAndShop < ShopifyCLI::Task
6
6
  attr_reader :ctx
7
7
 
8
8
  def call(ctx, organization_id: nil, shop_domain: nil)
@@ -12,7 +12,7 @@ module ShopifyCli
12
12
  unless Shopifolk.acting_as_shopify_organization?
13
13
  shop_domain ||= get_shop_domain(org)
14
14
  end
15
- ShopifyCli::Core::Monorail.metadata[:organization_id] = org["id"].to_i
15
+ ShopifyCLI::Core::Monorail.metadata[:organization_id] = org["id"].to_i
16
16
  response(org["id"].to_i, shop_domain)
17
17
  end
18
18
 
@@ -25,20 +25,20 @@ module ShopifyCli
25
25
  end
26
26
 
27
27
  def organizations
28
- @organizations ||= ShopifyCli::PartnersAPI::Organizations.fetch_all(ctx)
28
+ @organizations ||= ShopifyCLI::PartnersAPI::Organizations.fetch_all(ctx)
29
29
  end
30
30
 
31
31
  def get_organization(organization_id)
32
32
  @organization ||= if !organization_id.nil?
33
- org = ShopifyCli::PartnersAPI::Organizations.fetch(ctx, id: organization_id)
33
+ org = ShopifyCLI::PartnersAPI::Organizations.fetch(ctx, id: organization_id)
34
34
  if org.nil?
35
- ctx.puts(ctx.message("core.tasks.select_org_and_shop.authentication_issue", ShopifyCli::TOOL_NAME))
35
+ ctx.puts(ctx.message("core.tasks.select_org_and_shop.authentication_issue", ShopifyCLI::TOOL_NAME))
36
36
  ctx.abort(ctx.message("core.tasks.select_org_and_shop.error.organization_not_found"))
37
37
  end
38
38
  org
39
39
  elsif organizations.count == 0
40
40
  if Shopifolk.acting_as_shopify_organization?
41
- ctx.abort(ctx.message("core.tasks.select_org_and_shop.error.shopifolk_notice", ShopifyCli::TOOL_NAME))
41
+ ctx.abort(ctx.message("core.tasks.select_org_and_shop.error.shopifolk_notice", ShopifyCLI::TOOL_NAME))
42
42
  else
43
43
  ctx.abort(ctx.message("core.tasks.select_org_and_shop.error.no_organizations"))
44
44
  end
@@ -64,7 +64,7 @@ module ShopifyCli
64
64
  if valid_stores.count == 0
65
65
  ctx.puts(ctx.message("core.tasks.select_org_and_shop.error.no_development_stores"))
66
66
  ctx.puts(ctx.message("core.tasks.select_org_and_shop.create_store", organization["id"]))
67
- ctx.puts(ctx.message("core.tasks.select_org_and_shop.authentication_issue", ShopifyCli::TOOL_NAME))
67
+ ctx.puts(ctx.message("core.tasks.select_org_and_shop.authentication_issue", ShopifyCLI::TOOL_NAME))
68
68
  elsif valid_stores.count == 1
69
69
  domain = valid_stores.first["shopDomain"]
70
70
  ctx.puts(ctx.message("core.tasks.select_org_and_shop.development_store", domain))
@@ -1,24 +1,24 @@
1
- module ShopifyCli
1
+ module ShopifyCLI
2
2
  module Tasks
3
- class UpdateDashboardURLS < ShopifyCli::Task
3
+ class UpdateDashboardURLS < ShopifyCLI::Task
4
4
  NGROK_REGEX = /https:\/\/([a-z0-9\-]+\.ngrok\.io)(.*)/
5
5
 
6
6
  def call(ctx, url:, callback_url:)
7
7
  @ctx = ctx
8
- project = ShopifyCli::Project.current
8
+ project = ShopifyCLI::Project.current
9
9
  api_key = project.env.api_key
10
- result = ShopifyCli::PartnersAPI.query(ctx, "get_app_urls", apiKey: api_key)
10
+ result = ShopifyCLI::PartnersAPI.query(ctx, "get_app_urls", apiKey: api_key)
11
11
  app = result["data"]["app"]
12
12
  consent = check_application_url(app["applicationUrl"], url)
13
13
  constructed_urls = construct_redirect_urls(app["redirectUrlWhitelist"], url, callback_url)
14
14
  return if url == app["applicationUrl"]
15
- ShopifyCli::PartnersAPI.query(@ctx, "update_dashboard_urls", input: {
15
+ ShopifyCLI::PartnersAPI.query(@ctx, "update_dashboard_urls", input: {
16
16
  applicationUrl: consent ? url : app["applicationUrl"],
17
17
  redirectUrlWhitelist: constructed_urls, apiKey: api_key
18
18
  })
19
19
  @ctx.puts(@ctx.message("core.tasks.update_dashboard_urls.updated"))
20
20
  rescue
21
- @ctx.puts(@ctx.message("core.tasks.update_dashboard_urls.update_error", ShopifyCli::TOOL_NAME))
21
+ @ctx.puts(@ctx.message("core.tasks.update_dashboard_urls.update_error", ShopifyCLI::TOOL_NAME))
22
22
  raise
23
23
  end
24
24
 
@@ -1,6 +1,6 @@
1
1
  require "shopify_cli"
2
2
 
3
- module ShopifyCli
3
+ module ShopifyCLI
4
4
  module Tasks
5
5
  class TaskRegistry
6
6
  def initialize
@@ -30,14 +30,14 @@ module ShopifyCli
30
30
  Registry.add(-> () { const_get(task) }, name)
31
31
  end
32
32
 
33
- register :ConfirmStore, :confirm_store, "shopify-cli/tasks/confirm_store"
34
- register :CreateApiClient, :create_api_client, "shopify-cli/tasks/create_api_client"
35
- register :EnsureAuthenticated, :ensure_authenticated, "shopify-cli/tasks/ensure_authenticated"
36
- register :EnsureEnv, :ensure_env, "shopify-cli/tasks/ensure_env"
37
- register :EnsureLoopbackURL, :ensure_loopback_url, "shopify-cli/tasks/ensure_loopback_url"
38
- register :EnsureProjectType, :ensure_project_type, "shopify-cli/tasks/ensure_project_type"
39
- register :EnsureDevStore, :ensure_dev_store, "shopify-cli/tasks/ensure_dev_store"
40
- register :SelectOrgAndShop, :select_org_and_shop, "shopify-cli/tasks/select_org_and_shop"
41
- register :UpdateDashboardURLS, :update_dashboard_urls, "shopify-cli/tasks/update_dashboard_urls"
33
+ register :ConfirmStore, :confirm_store, "shopify_cli/tasks/confirm_store"
34
+ register :CreateApiClient, :create_api_client, "shopify_cli/tasks/create_api_client"
35
+ register :EnsureAuthenticated, :ensure_authenticated, "shopify_cli/tasks/ensure_authenticated"
36
+ register :EnsureEnv, :ensure_env, "shopify_cli/tasks/ensure_env"
37
+ register :EnsureLoopbackURL, :ensure_loopback_url, "shopify_cli/tasks/ensure_loopback_url"
38
+ register :EnsureProjectType, :ensure_project_type, "shopify_cli/tasks/ensure_project_type"
39
+ register :EnsureDevStore, :ensure_dev_store, "shopify_cli/tasks/ensure_dev_store"
40
+ register :SelectOrgAndShop, :select_org_and_shop, "shopify_cli/tasks/select_org_and_shop"
41
+ register :UpdateDashboardURLS, :update_dashboard_urls, "shopify_cli/tasks/update_dashboard_urls"
42
42
  end
43
43
  end
@@ -2,7 +2,7 @@
2
2
 
3
3
  require "openssl"
4
4
 
5
- module ShopifyCli
5
+ module ShopifyCLI
6
6
  module Theme
7
7
  module DevServer
8
8
  class CertificateManager
@@ -19,13 +19,13 @@ module ShopifyCli
19
19
  end
20
20
 
21
21
  def find_or_create_certificates!
22
- @private_key = if (private_key_pem = ShopifyCli::DB.get(:ssl_private_key))
22
+ @private_key = if (private_key_pem = ShopifyCLI::DB.get(:ssl_private_key))
23
23
  OpenSSL::PKey::RSA.new(private_key_pem)
24
24
  else
25
25
  OpenSSL::PKey::RSA.new(2048)
26
26
  end
27
27
 
28
- @certificate = if (certificate_pem = ShopifyCli::DB.get(:ssl_certificate))
28
+ @certificate = if (certificate_pem = ShopifyCLI::DB.get(:ssl_certificate))
29
29
  OpenSSL::X509::Certificate.new(certificate_pem)
30
30
  else
31
31
  x509_certificate = build_x509_certificate
@@ -35,8 +35,8 @@ module ShopifyCli
35
35
  x509_certificate
36
36
  end
37
37
 
38
- ShopifyCli::DB.set(ssl_certificate: certificate.to_pem)
39
- ShopifyCli::DB.set(ssl_private_key: private_key.to_pem)
38
+ ShopifyCLI::DB.set(ssl_certificate: certificate.to_pem)
39
+ ShopifyCLI::DB.set(ssl_private_key: private_key.to_pem)
40
40
  end
41
41
 
42
42
  private
@@ -1,6 +1,6 @@
1
1
  # frozen_string_literal: true
2
2
 
3
- module ShopifyCli
3
+ module ShopifyCLI
4
4
  module Theme
5
5
  module DevServer
6
6
  # Based on Rack::HeaderHash
@@ -1,6 +1,6 @@
1
1
  # frozen_string_literal: true
2
2
 
3
- module ShopifyCli
3
+ module ShopifyCLI
4
4
  module Theme
5
5
  module DevServer
6
6
  class HotReload
@@ -1,6 +1,6 @@
1
1
  # frozen_string_literal: true
2
2
 
3
- module ShopifyCli
3
+ module ShopifyCLI
4
4
  module Theme
5
5
  module DevServer
6
6
  class LocalAssets
@@ -3,7 +3,7 @@ require "net/http"
3
3
  require "stringio"
4
4
  require "time"
5
5
 
6
- module ShopifyCli
6
+ module ShopifyCLI
7
7
  module Theme
8
8
  module DevServer
9
9
  HOP_BY_HOP_HEADERS = [
@@ -79,7 +79,7 @@ module ShopifyCli
79
79
  end
80
80
 
81
81
  def bearer_token
82
- ShopifyCli::DB.get(:storefront_renderer_production_exchange_token) ||
82
+ ShopifyCLI::DB.get(:storefront_renderer_production_exchange_token) ||
83
83
  raise(KeyError, "storefront_renderer_production_exchange_token missing")
84
84
  end
85
85
 
@@ -1,7 +1,7 @@
1
1
  # frozen_string_literal: true
2
2
  require "thread"
3
3
 
4
- module ShopifyCli
4
+ module ShopifyCLI
5
5
  module Theme
6
6
  module DevServer
7
7
  # Server-Sent events implementation for Rack.
@@ -2,7 +2,7 @@
2
2
  require "listen"
3
3
  require "observer"
4
4
 
5
- module ShopifyCli
5
+ module ShopifyCLI
6
6
  module Theme
7
7
  module DevServer
8
8
  # Watches for file changes and publish events to the theme
@@ -3,7 +3,7 @@
3
3
  require "webrick"
4
4
  require "stringio"
5
5
 
6
- module ShopifyCli
6
+ module ShopifyCLI
7
7
  module Theme
8
8
  module DevServer
9
9
  # WEBrick will sometimes cause a fatal deadlock error on shutdown.
@@ -14,7 +14,7 @@ require_relative "dev_server/certificate_manager"
14
14
 
15
15
  require "pathname"
16
16
 
17
- module ShopifyCli
17
+ module ShopifyCLI
18
18
  module Theme
19
19
  module DevServer
20
20
  class << self
@@ -80,8 +80,8 @@ module ShopifyCli
80
80
  )
81
81
  watcher.stop
82
82
 
83
- rescue ShopifyCli::API::APIRequestForbiddenError,
84
- ShopifyCli::API::APIRequestUnauthorizedError
83
+ rescue ShopifyCLI::API::APIRequestForbiddenError,
84
+ ShopifyCLI::API::APIRequestUnauthorizedError
85
85
  @ctx.abort("You are not authorized to edit themes on #{theme.shop}.\n" \
86
86
  "Make sure you are a user of that store, and allowed to edit themes.")
87
87
  end
@@ -4,17 +4,17 @@ require_relative "theme"
4
4
  require "socket"
5
5
  require "securerandom"
6
6
 
7
- module ShopifyCli
7
+ module ShopifyCLI
8
8
  module Theme
9
9
  API_NAME_LIMIT = 50
10
10
 
11
11
  class DevelopmentTheme < Theme
12
12
  def id
13
- ShopifyCli::DB.get(:development_theme_id)
13
+ ShopifyCLI::DB.get(:development_theme_id)
14
14
  end
15
15
 
16
16
  def name
17
- existing_name = ShopifyCli::DB.get(:development_theme_name)
17
+ existing_name = ShopifyCLI::DB.get(:development_theme_name)
18
18
  # Up to version 2.3.0 (included) generated names stored locally
19
19
  # could have more than 50 characters and the API rejected them.
20
20
  # This code ensures we update the name for those users to ensure
@@ -36,27 +36,27 @@ module ShopifyCli
36
36
  else
37
37
  create
38
38
  @ctx.debug("Created temporary development theme: #{@id}")
39
- ShopifyCli::DB.set(development_theme_id: @id)
39
+ ShopifyCLI::DB.set(development_theme_id: @id)
40
40
  end
41
41
  end
42
42
 
43
43
  def exists?
44
44
  return false unless id
45
45
 
46
- ShopifyCli::AdminAPI.rest_request(
46
+ ShopifyCLI::AdminAPI.rest_request(
47
47
  @ctx,
48
48
  shop: shop,
49
49
  path: "themes/#{id}.json",
50
50
  api_version: "unstable",
51
51
  )
52
- rescue ShopifyCli::API::APIRequestNotFoundError
52
+ rescue ShopifyCLI::API::APIRequestNotFoundError
53
53
  false
54
54
  end
55
55
 
56
56
  def delete
57
57
  super if exists?
58
- ShopifyCli::DB.del(:development_theme_id) if ShopifyCli::DB.exists?(:development_theme_id)
59
- ShopifyCli::DB.del(:development_theme_name) if ShopifyCli::DB.exists?(:development_theme_name)
58
+ ShopifyCLI::DB.del(:development_theme_id) if ShopifyCLI::DB.exists?(:development_theme_id)
59
+ ShopifyCLI::DB.del(:development_theme_name) if ShopifyCLI::DB.exists?(:development_theme_name)
60
60
  end
61
61
 
62
62
  def self.delete(ctx)
@@ -74,7 +74,7 @@ module ShopifyCli
74
74
  identifier = "#{hash}-#{hostname[0, hostname_character_limit]}"
75
75
  theme_name = "Development (#{identifier})"
76
76
 
77
- ShopifyCli::DB.set(development_theme_name: theme_name)
77
+ ShopifyCLI::DB.set(development_theme_name: theme_name)
78
78
 
79
79
  theme_name
80
80
  end
@@ -1,7 +1,7 @@
1
1
  # frozen_string_literal: true
2
2
  require_relative "mime_type"
3
3
 
4
- module ShopifyCli
4
+ module ShopifyCLI
5
5
  module Theme
6
6
  class File < Struct.new(:path)
7
7
  attr_reader :relative_path
@@ -1,6 +1,6 @@
1
1
  # frozen_string_literal: true
2
2
 
3
- module ShopifyCli
3
+ module ShopifyCLI
4
4
  module Theme
5
5
  class IgnoreFilter
6
6
  FILE = ".shopifyignore"
@@ -1,7 +1,7 @@
1
1
  # frozen_string_literal: true
2
2
  require "webrick"
3
3
 
4
- module ShopifyCli
4
+ module ShopifyCLI
5
5
  module Theme
6
6
  class MimeType < Struct.new(:name)
7
7
  MIME_TYPES = WEBrick::HTTPUtils::DefaultMimeTypes.merge(
@@ -3,7 +3,7 @@ require "thread"
3
3
  require "json"
4
4
  require "base64"
5
5
 
6
- module ShopifyCli
6
+ module ShopifyCLI
7
7
  module Theme
8
8
  class Syncer
9
9
  class Operation < Struct.new(:method, :file)
@@ -80,7 +80,7 @@ module ShopifyCli
80
80
  end
81
81
 
82
82
  def fetch_checksums!
83
- _status, response = ShopifyCli::AdminAPI.rest_request(
83
+ _status, response = ShopifyCLI::AdminAPI.rest_request(
84
84
  @ctx,
85
85
  shop: @theme.shop,
86
86
  path: "themes/#{@theme.id}/assets.json",
@@ -211,7 +211,7 @@ module ShopifyCli
211
211
  used, total = limit.split("/").map(&:to_i)
212
212
  backoff_if_near_limit!(used, total)
213
213
  end
214
- rescue ShopifyCli::API::APIRequestError => e
214
+ rescue ShopifyCLI::API::APIRequestError => e
215
215
  report_error(
216
216
  "{{red:ERROR}} {{blue:#{operation}}}:\n " +
217
217
  parse_api_errors(e).join("\n ")
@@ -228,7 +228,7 @@ module ShopifyCli
228
228
  asset[:attachment] = Base64.encode64(file.read)
229
229
  end
230
230
 
231
- _status, body, response = ShopifyCli::AdminAPI.rest_request(
231
+ _status, body, response = ShopifyCLI::AdminAPI.rest_request(
232
232
  @ctx,
233
233
  shop: @theme.shop,
234
234
  path: "themes/#{@theme.id}/assets.json",
@@ -243,7 +243,7 @@ module ShopifyCli
243
243
  end
244
244
 
245
245
  def get(file)
246
- _status, body, response = ShopifyCli::AdminAPI.rest_request(
246
+ _status, body, response = ShopifyCLI::AdminAPI.rest_request(
247
247
  @ctx,
248
248
  shop: @theme.shop,
249
249
  path: "themes/#{@theme.id}/assets.json",
@@ -265,7 +265,7 @@ module ShopifyCli
265
265
  end
266
266
 
267
267
  def delete(file)
268
- _status, _body, response = ShopifyCli::AdminAPI.rest_request(
268
+ _status, _body, response = ShopifyCLI::AdminAPI.rest_request(
269
269
  @ctx,
270
270
  shop: @theme.shop,
271
271
  path: "themes/#{@theme.id}/assets.json",
@@ -4,7 +4,7 @@ require_relative "file"
4
4
  require "pathname"
5
5
  require "time"
6
6
 
7
- module ShopifyCli
7
+ module ShopifyCLI
8
8
  module Theme
9
9
  class InvalidThemeRole < StandardError; end
10
10
 
@@ -101,7 +101,7 @@ module ShopifyCli
101
101
  def create
102
102
  raise InvalidThemeRole, "Can't create live theme. Use publish." if live?
103
103
 
104
- _status, body = ShopifyCli::AdminAPI.rest_request(
104
+ _status, body = ShopifyCLI::AdminAPI.rest_request(
105
105
  @ctx,
106
106
  shop: shop,
107
107
  path: "themes.json",
@@ -144,11 +144,11 @@ module ShopifyCli
144
144
  end
145
145
 
146
146
  def current_development?
147
- development? && id == ShopifyCli::DB.get(:development_theme_id)
147
+ development? && id == ShopifyCLI::DB.get(:development_theme_id)
148
148
  end
149
149
 
150
150
  def foreign_development?
151
- development? && id != ShopifyCli::DB.get(:development_theme_id)
151
+ development? && id != ShopifyCLI::DB.get(:development_theme_id)
152
152
  end
153
153
 
154
154
  def to_h