shopify-cli 2.3.0 → 2.6.1

Sign up to get free protection for your applications and to get access to all the features.
Files changed (266) hide show
  1. checksums.yaml +4 -4
  2. data/.github/CODEOWNERS +1 -0
  3. data/.github/workflows/shopify.yml +104 -0
  4. data/.gitignore +3 -0
  5. data/.rubocop.yml +14 -14
  6. data/.rubocop_todo.yml +3 -3
  7. data/CHANGELOG.md +26 -0
  8. data/CONTRIBUTING.md +23 -0
  9. data/Dockerfile +17 -0
  10. data/Gemfile +1 -0
  11. data/Gemfile.lock +67 -24
  12. data/README.md +1 -1
  13. data/RELEASING.md +1 -1
  14. data/Rakefile +75 -18
  15. data/bin/console +11 -0
  16. data/bin/shopify +17 -4
  17. data/dev.yml +14 -1
  18. data/ext/shopify-cli/extconf.rb +2 -0
  19. data/ext/shopify-extensions/extconf.rb +21 -0
  20. data/ext/shopify-extensions/shopify_extensions.rb +152 -0
  21. data/ext/shopify-extensions/version +1 -0
  22. data/lib/project_types/extension/cli.rb +19 -3
  23. data/lib/project_types/extension/commands/build.rb +32 -3
  24. data/lib/project_types/extension/commands/check.rb +2 -2
  25. data/lib/project_types/extension/commands/connect.rb +1 -1
  26. data/lib/project_types/extension/commands/create.rb +59 -16
  27. data/lib/project_types/extension/commands/extension_command.rb +1 -1
  28. data/lib/project_types/extension/commands/info.rb +1 -1
  29. data/lib/project_types/extension/commands/push.rb +1 -1
  30. data/lib/project_types/extension/commands/register.rb +2 -2
  31. data/lib/project_types/extension/commands/serve.rb +5 -5
  32. data/lib/project_types/extension/commands/tunnel.rb +6 -6
  33. data/lib/project_types/extension/extension_project.rb +4 -4
  34. data/lib/project_types/extension/features/argo.rb +3 -3
  35. data/lib/project_types/extension/features/argo_config.rb +5 -5
  36. data/lib/project_types/extension/features/argo_serve.rb +21 -6
  37. data/lib/project_types/extension/features/argo_setup.rb +1 -1
  38. data/lib/project_types/extension/features/argo_setup_step.rb +1 -1
  39. data/lib/project_types/extension/features/argo_setup_steps.rb +2 -2
  40. data/lib/project_types/extension/forms/connect.rb +2 -2
  41. data/lib/project_types/extension/forms/create.rb +6 -3
  42. data/lib/project_types/extension/forms/questions/ask_app.rb +2 -2
  43. data/lib/project_types/extension/forms/questions/ask_name.rb +1 -1
  44. data/lib/project_types/extension/forms/questions/ask_registration.rb +2 -2
  45. data/lib/project_types/extension/forms/questions/ask_template.rb +44 -0
  46. data/lib/project_types/extension/forms/questions/ask_type.rb +2 -2
  47. data/lib/project_types/extension/messages/message_loading.rb +2 -2
  48. data/lib/project_types/extension/messages/messages.rb +3 -0
  49. data/lib/project_types/extension/models/development_server.rb +78 -0
  50. data/lib/project_types/extension/models/development_server_requirements.rb +35 -0
  51. data/lib/project_types/extension/models/lazy_specification_handler.rb +1 -1
  52. data/lib/project_types/extension/models/server_config/base.rb +31 -0
  53. data/lib/project_types/extension/models/server_config/development.rb +23 -0
  54. data/lib/project_types/extension/models/server_config/development_entries.rb +38 -0
  55. data/lib/project_types/extension/models/server_config/development_renderer.rb +30 -0
  56. data/lib/project_types/extension/models/server_config/extension.rb +35 -0
  57. data/lib/project_types/extension/models/server_config/root.rb +18 -0
  58. data/lib/project_types/extension/models/server_config/user.rb +10 -0
  59. data/lib/project_types/extension/models/specification.rb +1 -1
  60. data/lib/project_types/extension/models/specification_handlers/default.rb +14 -2
  61. data/lib/project_types/extension/models/specification_handlers/theme_app_extension.rb +1 -1
  62. data/lib/project_types/extension/models/specifications.rb +4 -4
  63. data/lib/project_types/extension/tasks/choose_next_available_port.rb +2 -2
  64. data/lib/project_types/extension/tasks/configure_features.rb +1 -1
  65. data/lib/project_types/extension/tasks/configure_options.rb +1 -1
  66. data/lib/project_types/extension/tasks/converters/product_converter.rb +1 -1
  67. data/lib/project_types/extension/tasks/converters/server_config_converter.rb +31 -0
  68. data/lib/project_types/extension/tasks/create_extension.rb +2 -2
  69. data/lib/project_types/extension/tasks/fetch_specifications.rb +2 -2
  70. data/lib/project_types/extension/tasks/find_npm_packages.rb +5 -5
  71. data/lib/project_types/extension/tasks/get_app.rb +2 -2
  72. data/lib/project_types/extension/tasks/get_apps.rb +2 -2
  73. data/lib/project_types/extension/tasks/get_extensions.rb +2 -2
  74. data/lib/project_types/extension/tasks/get_product.rb +2 -2
  75. data/lib/project_types/extension/tasks/load_server_config.rb +23 -0
  76. data/lib/project_types/extension/tasks/run_extension_command.rb +81 -0
  77. data/lib/project_types/extension/tasks/update_draft.rb +2 -2
  78. data/lib/project_types/node/cli.rb +3 -3
  79. data/lib/project_types/node/commands/connect.rb +4 -4
  80. data/lib/project_types/node/commands/create.rb +10 -14
  81. data/lib/project_types/node/commands/deploy/heroku.rb +4 -4
  82. data/lib/project_types/node/commands/deploy.rb +3 -3
  83. data/lib/project_types/node/commands/generate.rb +2 -2
  84. data/lib/project_types/node/commands/open.rb +3 -3
  85. data/lib/project_types/node/commands/serve.rb +15 -7
  86. data/lib/project_types/node/commands/tunnel.rb +6 -6
  87. data/lib/project_types/node/forms/create.rb +3 -3
  88. data/lib/project_types/node/messages/messages.rb +3 -0
  89. data/lib/project_types/php/cli.rb +27 -0
  90. data/lib/project_types/php/commands/connect.rb +19 -0
  91. data/lib/project_types/php/commands/create.rb +143 -0
  92. data/lib/project_types/php/commands/deploy/heroku.rb +129 -0
  93. data/lib/project_types/php/commands/deploy.rb +32 -0
  94. data/lib/project_types/php/commands/open.rb +16 -0
  95. data/lib/project_types/php/commands/serve.rb +51 -0
  96. data/lib/project_types/php/commands/tunnel.rb +37 -0
  97. data/lib/project_types/php/forms/create.rb +45 -0
  98. data/lib/project_types/php/messages/messages.rb +191 -0
  99. data/lib/project_types/rails/cli.rb +3 -3
  100. data/lib/project_types/rails/commands/connect.rb +4 -4
  101. data/lib/project_types/rails/commands/create.rb +12 -16
  102. data/lib/project_types/rails/commands/deploy/heroku.rb +4 -4
  103. data/lib/project_types/rails/commands/deploy.rb +3 -3
  104. data/lib/project_types/rails/commands/generate/webhook.rb +3 -3
  105. data/lib/project_types/rails/commands/generate.rb +3 -3
  106. data/lib/project_types/rails/commands/open.rb +3 -3
  107. data/lib/project_types/rails/commands/serve.rb +8 -8
  108. data/lib/project_types/rails/commands/tunnel.rb +6 -6
  109. data/lib/project_types/rails/forms/create.rb +3 -3
  110. data/lib/project_types/rails/gem.rb +1 -1
  111. data/lib/project_types/rails/ruby.rb +1 -1
  112. data/lib/project_types/script/cli.rb +16 -6
  113. data/lib/project_types/script/commands/create.rb +4 -2
  114. data/lib/project_types/script/commands/push.rb +2 -2
  115. data/lib/project_types/script/config/extension_points.yml +30 -29
  116. data/lib/project_types/script/forms/create.rb +1 -1
  117. data/lib/project_types/script/layers/application/create_script.rb +32 -12
  118. data/lib/project_types/script/layers/application/extension_points.rb +4 -4
  119. data/lib/project_types/script/layers/application/push_script.rb +13 -1
  120. data/lib/project_types/script/layers/domain/extension_point.rb +13 -45
  121. data/lib/project_types/script/layers/domain/push_package.rb +0 -12
  122. data/lib/project_types/script/layers/domain/script_project.rb +2 -2
  123. data/lib/project_types/script/layers/infrastructure/api_clients/partners_proxy_api_client.rb +57 -0
  124. data/lib/project_types/script/layers/infrastructure/api_clients/script_service_api_client.rb +35 -0
  125. data/lib/project_types/script/layers/infrastructure/command_runner.rb +1 -1
  126. data/lib/project_types/script/layers/infrastructure/errors.rb +5 -0
  127. data/lib/project_types/script/layers/infrastructure/languages/assemblyscript_project_creator.rb +10 -90
  128. data/lib/project_types/script/layers/infrastructure/languages/project_creator.rb +76 -11
  129. data/lib/project_types/script/layers/infrastructure/languages/task_runner.rb +1 -1
  130. data/lib/project_types/script/layers/infrastructure/languages/typescript_project_creator.rb +33 -0
  131. data/lib/project_types/script/layers/infrastructure/languages/typescript_task_runner.rb +105 -0
  132. data/lib/project_types/script/layers/infrastructure/push_package_repository.rb +1 -1
  133. data/lib/project_types/script/layers/infrastructure/script_project_repository.rb +6 -6
  134. data/lib/project_types/script/layers/infrastructure/script_service.rb +25 -144
  135. data/lib/project_types/script/layers/infrastructure/script_uploader.rb +27 -0
  136. data/lib/project_types/script/layers/infrastructure/service_locator.rb +20 -0
  137. data/lib/project_types/script/messages/messages.rb +4 -0
  138. data/lib/project_types/script/tasks/ensure_env.rb +7 -7
  139. data/lib/project_types/script/ui/error_handler.rb +84 -76
  140. data/lib/project_types/script/ui/printing_spinner.rb +1 -1
  141. data/lib/project_types/theme/cli.rb +3 -3
  142. data/lib/project_types/theme/commands/check.rb +3 -3
  143. data/lib/project_types/theme/commands/delete.rb +7 -7
  144. data/lib/project_types/theme/commands/init.rb +3 -3
  145. data/lib/project_types/theme/commands/language_server.rb +2 -2
  146. data/lib/project_types/theme/commands/package.rb +2 -2
  147. data/lib/project_types/theme/commands/publish.rb +5 -5
  148. data/lib/project_types/theme/commands/pull.rb +9 -9
  149. data/lib/project_types/theme/commands/push.rb +12 -12
  150. data/lib/project_types/theme/commands/serve.rb +4 -4
  151. data/lib/project_types/theme/forms/confirm_store.rb +1 -1
  152. data/lib/project_types/theme/forms/select.rb +2 -2
  153. data/lib/{shopify-cli → shopify_cli}/admin_api/populate_resource_command.rb +3 -3
  154. data/lib/{shopify-cli → shopify_cli}/admin_api/schema.rb +4 -4
  155. data/lib/{shopify-cli → shopify_cli}/admin_api.rb +27 -27
  156. data/lib/{shopify-cli → shopify_cli}/api.rb +12 -8
  157. data/lib/shopify_cli/command/app_sub_command.rb +16 -0
  158. data/lib/{shopify-cli → shopify_cli}/command.rb +3 -3
  159. data/lib/{shopify-cli → shopify_cli}/commands/config.rb +14 -14
  160. data/lib/{shopify-cli → shopify_cli}/commands/help.rb +4 -4
  161. data/lib/{shopify-cli → shopify_cli}/commands/login.rb +7 -7
  162. data/lib/shopify_cli/commands/logout.rb +39 -0
  163. data/lib/{shopify-cli → shopify_cli}/commands/populate/customer.rb +4 -4
  164. data/lib/{shopify-cli → shopify_cli}/commands/populate/draft_order.rb +4 -4
  165. data/lib/{shopify-cli → shopify_cli}/commands/populate/product.rb +4 -4
  166. data/lib/shopify_cli/commands/populate.rb +23 -0
  167. data/lib/shopify_cli/commands/store.rb +15 -0
  168. data/lib/{shopify-cli → shopify_cli}/commands/switch.rb +5 -5
  169. data/lib/{shopify-cli → shopify_cli}/commands/system.rb +10 -10
  170. data/lib/shopify_cli/commands/version.rb +15 -0
  171. data/lib/{shopify-cli → shopify_cli}/commands/whoami.rb +7 -7
  172. data/lib/shopify_cli/commands.rb +34 -0
  173. data/lib/{shopify-cli → shopify_cli}/connect.rb +3 -3
  174. data/lib/shopify_cli/constants.rb +54 -0
  175. data/lib/{shopify-cli → shopify_cli}/context.rb +6 -6
  176. data/lib/{shopify-cli → shopify_cli}/core/entry_point.rb +7 -7
  177. data/lib/{shopify-cli → shopify_cli}/core/executor.rb +8 -4
  178. data/lib/{shopify-cli → shopify_cli}/core/finalize.rb +1 -1
  179. data/lib/{shopify-cli → shopify_cli}/core/help_resolver.rb +2 -2
  180. data/lib/{shopify-cli → shopify_cli}/core/monorail.rb +8 -8
  181. data/lib/shopify_cli/core.rb +8 -0
  182. data/lib/{shopify-cli → shopify_cli}/db.rb +8 -8
  183. data/lib/shopify_cli/environment.rb +91 -0
  184. data/lib/shopify_cli/exception_reporter/permission_controller.rb +54 -0
  185. data/lib/shopify_cli/exception_reporter.rb +55 -0
  186. data/lib/{shopify-cli → shopify_cli}/feature.rb +8 -8
  187. data/lib/{shopify-cli → shopify_cli}/form.rb +2 -2
  188. data/lib/{shopify-cli → shopify_cli}/git.rb +38 -8
  189. data/lib/{shopify-cli → shopify_cli}/helpers/haikunator.rb +1 -1
  190. data/lib/shopify_cli/helpers.rb +5 -0
  191. data/lib/{shopify-cli → shopify_cli}/heroku.rb +38 -13
  192. data/lib/{shopify-cli → shopify_cli}/http_request.rb +1 -1
  193. data/lib/{shopify-cli → shopify_cli}/identity_auth/servlet.rb +1 -1
  194. data/lib/{shopify-cli → shopify_cli}/identity_auth.rb +24 -31
  195. data/lib/{shopify-cli → shopify_cli}/js_deps.rb +7 -7
  196. data/lib/{shopify-cli → shopify_cli}/js_system.rb +10 -10
  197. data/lib/{shopify-cli → shopify_cli}/lazy_delegator.rb +2 -2
  198. data/lib/{shopify-cli → shopify_cli}/messages/messages.rb +44 -2
  199. data/lib/{shopify-cli → shopify_cli}/method_object.rb +15 -8
  200. data/lib/shopify_cli/migrator/migration.rb +27 -0
  201. data/lib/shopify_cli/migrator/migrations/1631709766_noop.rb +13 -0
  202. data/lib/shopify_cli/migrator.rb +48 -0
  203. data/lib/{shopify-cli → shopify_cli}/options.rb +1 -1
  204. data/lib/{shopify-cli → shopify_cli}/packager.rb +8 -8
  205. data/lib/{shopify-cli → shopify_cli}/partners_api/organizations.rb +1 -1
  206. data/lib/{shopify-cli → shopify_cli}/partners_api.rb +16 -40
  207. data/lib/shopify_cli/php_deps.rb +102 -0
  208. data/lib/{shopify-cli → shopify_cli}/process_supervision.rb +10 -8
  209. data/lib/{shopify-cli → shopify_cli}/project.rb +15 -15
  210. data/lib/{shopify-cli → shopify_cli}/project_commands.rb +3 -3
  211. data/lib/{shopify-cli → shopify_cli}/project_type.rb +5 -5
  212. data/lib/{shopify-cli → shopify_cli}/resolve_constant.rb +5 -5
  213. data/lib/{shopify-cli → shopify_cli}/resources/env_file.rb +1 -1
  214. data/lib/shopify_cli/resources.rb +5 -0
  215. data/lib/{shopify-cli → shopify_cli}/result.rb +11 -11
  216. data/lib/{shopify-cli → shopify_cli}/shopifolk.rb +6 -6
  217. data/lib/{shopify-cli → shopify_cli}/sub_command.rb +1 -1
  218. data/lib/{shopify-cli → shopify_cli}/task.rb +1 -1
  219. data/lib/{shopify-cli → shopify_cli}/tasks/confirm_store.rb +3 -3
  220. data/lib/{shopify-cli → shopify_cli}/tasks/create_api_client.rb +4 -4
  221. data/lib/shopify_cli/tasks/ensure_authenticated.rb +13 -0
  222. data/lib/{shopify-cli → shopify_cli}/tasks/ensure_dev_store.rb +5 -5
  223. data/lib/{shopify-cli → shopify_cli}/tasks/ensure_env.rb +3 -3
  224. data/lib/{shopify-cli → shopify_cli}/tasks/ensure_loopback_url.rb +4 -4
  225. data/lib/{shopify-cli → shopify_cli}/tasks/ensure_project_type.rb +3 -3
  226. data/lib/{shopify-cli → shopify_cli}/tasks/select_org_and_shop.rb +8 -8
  227. data/lib/{shopify-cli → shopify_cli}/tasks/update_dashboard_urls.rb +6 -6
  228. data/lib/{shopify-cli → shopify_cli}/tasks.rb +10 -10
  229. data/lib/{shopify-cli → shopify_cli}/theme/dev_server/certificate_manager.rb +5 -5
  230. data/lib/{shopify-cli → shopify_cli}/theme/dev_server/header_hash.rb +1 -1
  231. data/lib/{shopify-cli → shopify_cli}/theme/dev_server/hot-reload.js +0 -0
  232. data/lib/{shopify-cli → shopify_cli}/theme/dev_server/hot_reload.rb +5 -6
  233. data/lib/{shopify-cli → shopify_cli}/theme/dev_server/local_assets.rb +1 -1
  234. data/lib/{shopify-cli → shopify_cli}/theme/dev_server/proxy.rb +2 -2
  235. data/lib/{shopify-cli → shopify_cli}/theme/dev_server/sse.rb +1 -1
  236. data/lib/{shopify-cli → shopify_cli}/theme/dev_server/watcher.rb +1 -1
  237. data/lib/{shopify-cli → shopify_cli}/theme/dev_server/web_server.rb +1 -1
  238. data/lib/{shopify-cli → shopify_cli}/theme/dev_server.rb +3 -3
  239. data/lib/shopify_cli/theme/development_theme.rb +83 -0
  240. data/lib/{shopify-cli → shopify_cli}/theme/file.rb +1 -1
  241. data/lib/{shopify-cli → shopify_cli}/theme/ignore_filter.rb +1 -1
  242. data/lib/{shopify-cli → shopify_cli}/theme/mime_type.rb +1 -1
  243. data/lib/{shopify-cli → shopify_cli}/theme/syncer.rb +6 -6
  244. data/lib/{shopify-cli → shopify_cli}/theme/theme.rb +4 -4
  245. data/lib/{shopify-cli → shopify_cli}/transform_data_structure.rb +4 -4
  246. data/lib/{shopify-cli → shopify_cli}/tunnel.rb +14 -14
  247. data/lib/shopify_cli/version.rb +3 -0
  248. data/lib/shopify_cli.rb +61 -50
  249. data/shopify-cli.gemspec +13 -5
  250. data/utilities/docker.rb +47 -0
  251. data/utilities/utilities.rb +5 -0
  252. metadata +155 -97
  253. data/.github/workflows/build.yml +0 -28
  254. data/lib/project_types/script/layers/infrastructure/languages/rust_project_creator.rb +0 -73
  255. data/lib/project_types/script/layers/infrastructure/languages/rust_task_runner.rb +0 -60
  256. data/lib/shopify-cli/commands/logout.rb +0 -39
  257. data/lib/shopify-cli/commands/populate.rb +0 -23
  258. data/lib/shopify-cli/commands/store.rb +0 -15
  259. data/lib/shopify-cli/commands/version.rb +0 -15
  260. data/lib/shopify-cli/commands.rb +0 -34
  261. data/lib/shopify-cli/core.rb +0 -8
  262. data/lib/shopify-cli/helpers.rb +0 -5
  263. data/lib/shopify-cli/resources.rb +0 -5
  264. data/lib/shopify-cli/tasks/ensure_authenticated.rb +0 -13
  265. data/lib/shopify-cli/theme/development_theme.rb +0 -69
  266. data/lib/shopify-cli/version.rb +0 -3
@@ -1,4 +1,4 @@
1
- module ShopifyCli
1
+ module ShopifyCLI
2
2
  class ProjectCommands < Command
3
3
  def call(*)
4
4
  @ctx.puts(self.class.help)
@@ -6,9 +6,9 @@ module ShopifyCli
6
6
 
7
7
  def self.help
8
8
  project_type = name.split("::")[0].downcase
9
- ShopifyCli::Context.message(
9
+ ShopifyCLI::Context.message(
10
10
  "#{project_type}.help",
11
- ShopifyCli::TOOL_NAME,
11
+ ShopifyCLI::TOOL_NAME,
12
12
  subcommand_registry.command_names.join(" | ")
13
13
  )
14
14
  end
@@ -1,4 +1,4 @@
1
- module ShopifyCli
1
+ module ShopifyCLI
2
2
  class ProjectType
3
3
  extend Feature::Set
4
4
 
@@ -20,7 +20,7 @@ module ShopifyCli
20
20
  end
21
21
 
22
22
  def load_type(current_type, shallow = false)
23
- filepath = File.join(ShopifyCli::ROOT, "lib", "project_types", current_type.to_s, "cli.rb")
23
+ filepath = File.join(ShopifyCLI::ROOT, "lib", "project_types", current_type.to_s, "cli.rb")
24
24
  return unless File.exist?(filepath)
25
25
  @shallow_load = shallow
26
26
  @current_type = current_type
@@ -31,7 +31,7 @@ module ShopifyCli
31
31
  end
32
32
 
33
33
  def load_all
34
- Dir.glob(File.join(ShopifyCli::ROOT, "lib", "project_types", "*", "cli.rb")).map do |filepath|
34
+ Dir.glob(File.join(ShopifyCLI::ROOT, "lib", "project_types", "*", "cli.rb")).map do |filepath|
35
35
  load_type(filepath.split(File::Separator)[-2].to_sym, true)
36
36
  end
37
37
  end
@@ -41,7 +41,7 @@ module ShopifyCli
41
41
  end
42
42
 
43
43
  def project_filepath(path)
44
- File.join(ShopifyCli::PROJECT_TYPES_DIR, project_type.to_s, path)
44
+ File.join(ShopifyCLI::PROJECT_TYPES_DIR, project_type.to_s, path)
45
45
  end
46
46
 
47
47
  def title(name)
@@ -50,7 +50,7 @@ module ShopifyCli
50
50
 
51
51
  def register_task(task, name)
52
52
  return if project_load_shallow
53
- ShopifyCli::Tasks.register(task, name)
53
+ ShopifyCLI::Tasks.register(task, name)
54
54
  end
55
55
 
56
56
  def register_messages(messages)
@@ -4,13 +4,13 @@
4
4
  # are resolved relative to `Kernal`, but the top-level namespace is
5
5
  # configurable:
6
6
  #
7
- # ShopifyCli::Resolve.call(:object).value # => Object
8
- # ShopifyCli::Resolve.call('minitest/test').value # => MiniTest::Test
9
- # ShopifyCli::Resolve.call(:test, namespace: MiniTest) # => MiniTest::Test
7
+ # ShopifyCLI::Resolve.call(:object).value # => Object
8
+ # ShopifyCLI::Resolve.call('minitest/test').value # => MiniTest::Test
9
+ # ShopifyCLI::Resolve.call(:test, namespace: MiniTest) # => MiniTest::Test
10
10
  #
11
- module ShopifyCli
11
+ module ShopifyCLI
12
12
  class ResolveConstant
13
- include ShopifyCli::MethodObject
13
+ include ShopifyCLI::MethodObject
14
14
  property! :namespace, accepts: ->(ns) { ns.respond_to?(:const_get) }, default: -> { Kernel }
15
15
 
16
16
  def call(name)
@@ -1,6 +1,6 @@
1
1
  # frozen_string_literal: true
2
2
 
3
- module ShopifyCli
3
+ module ShopifyCLI
4
4
  module Resources
5
5
  class EnvFile
6
6
  include SmartProperties
@@ -0,0 +1,5 @@
1
+ module ShopifyCLI
2
+ module Resources
3
+ autoload :EnvFile, "shopify_cli/resources/env_file"
4
+ end
5
+ end
@@ -1,4 +1,4 @@
1
- module ShopifyCli
1
+ module ShopifyCLI
2
2
  ##
3
3
  # This module defines two containers for wrapping the result of an action. One
4
4
  # for signifying the successful execution of an action and one for signifying
@@ -261,8 +261,8 @@ module ShopifyCli
261
261
  end
262
262
 
263
263
  ##
264
- # raises an `ShopifyCli::Result::UnexpectedError` as a
265
- # `ShopifyCli::Result::Failure` does not carry a success value.
264
+ # raises an `ShopifyCLI::Result::UnexpectedError` as a
265
+ # `ShopifyCLI::Result::Failure` does not carry a success value.
266
266
  #
267
267
  def value
268
268
  raise UnexpectedFailure
@@ -342,7 +342,7 @@ module ShopifyCli
342
342
  end
343
343
 
344
344
  ##
345
- # wraps the given value into a `ShopifyCli::Result::Success` container
345
+ # wraps the given value into a `ShopifyCLI::Result::Success` container
346
346
  #
347
347
  # #### Parameters
348
348
  #
@@ -353,7 +353,7 @@ module ShopifyCli
353
353
  end
354
354
 
355
355
  ##
356
- # wraps the given value into a `ShopifyCli::Result::Failure` container
356
+ # wraps the given value into a `ShopifyCLI::Result::Failure` container
357
357
  #
358
358
  # #### Parameters
359
359
  #
@@ -367,8 +367,8 @@ module ShopifyCli
367
367
  # takes either a value or a block and chooses the appropriate result
368
368
  # container based on the type of the value or the type of the block's return
369
369
  # value. If the type is an exception, it is wrapped in a
370
- # `ShopifyCli::Result::Failure` and otherwise in a
371
- # `ShopifyCli::Result::Success`. If a block was provided instead of value, a
370
+ # `ShopifyCLI::Result::Failure` and otherwise in a
371
+ # `ShopifyCLI::Result::Success`. If a block was provided instead of value, a
372
372
  # `Proc` is returned and the result wrapping doesn't occur until the block
373
373
  # is invoked.
374
374
  #
@@ -384,12 +384,12 @@ module ShopifyCli
384
384
  #
385
385
  # #### Examples
386
386
  #
387
- # Result.wrap(1) # => ShopifyCli::Result::Success
388
- # Result.wrap(RuntimeError.new) # => ShopifyCli::Result::Failure
387
+ # Result.wrap(1) # => ShopifyCLI::Result::Success
388
+ # Result.wrap(RuntimeError.new) # => ShopifyCLI::Result::Failure
389
389
  #
390
390
  # Result.wrap { 1 } # => Proc
391
- # Result.wrap { 1 }.call # => ShopifyCli::Result::Success
392
- # Result.wrap { raise }.call # => ShopifyCli::Result::Failure
391
+ # Result.wrap { 1 }.call # => ShopifyCLI::Result::Success
392
+ # Result.wrap { raise }.call # => ShopifyCLI::Result::Failure
393
393
  #
394
394
  # Result.wrap { |s| s.upcase }.call("hello").tap do |result|
395
395
  # result # => Result::Success
@@ -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
@@ -34,11 +34,10 @@ module ShopifyCli
34
34
  files = (modified + added).reject { |file| @ignore_filter&.ignore?(file) }
35
35
  .map { |file| @theme[file].relative_path }
36
36
 
37
- @streams.broadcast(JSON.generate(
38
- modified: files,
39
- ))
40
-
41
- @ctx.debug("[HotReload] Modified #{files.join(", ")}")
37
+ unless files.empty?
38
+ @streams.broadcast(JSON.generate(modified: files))
39
+ @ctx.debug("[HotReload] Modified #{files.join(", ")}")
40
+ end
42
41
  end
43
42
 
44
43
  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
  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