shopify-cli 1.4.0 → 1.7.1

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 (302) hide show
  1. checksums.yaml +4 -4
  2. data/.github/CODEOWNERS +2 -2
  3. data/.github/CONTRIBUTING.md +9 -1
  4. data/.github/PULL_REQUEST_TEMPLATE.md +10 -1
  5. data/.github/workflows/release.yml +61 -0
  6. data/.github/workflows/triage.yml +22 -0
  7. data/.rubocop.yml +56 -7
  8. data/.rubocop_todo.yml +4 -13
  9. data/.travis.yml +1 -0
  10. data/CHANGELOG.md +27 -1
  11. data/Gemfile +12 -10
  12. data/Gemfile.lock +33 -31
  13. data/README.md +39 -7
  14. data/RELEASING.md +5 -27
  15. data/Rakefile +32 -28
  16. data/bin/load_shopify.rb +6 -6
  17. data/bin/shopify +2 -2
  18. data/dev.yml +2 -2
  19. data/docs/_config.yml +1 -18
  20. data/docs/app/node/commands/index.md +2 -80
  21. data/docs/app/node/index.md +2 -33
  22. data/docs/app/rails/commands/index.md +2 -78
  23. data/docs/app/rails/index.md +2 -34
  24. data/docs/core/index.md +2 -84
  25. data/docs/getting-started/index.md +2 -25
  26. data/docs/getting-started/install/index.md +1 -118
  27. data/docs/getting-started/migrate/index.md +2 -94
  28. data/docs/getting-started/uninstall/index.md +2 -35
  29. data/docs/getting-started/upgrade/index.md +2 -39
  30. data/docs/help/start-app/index.md +2 -4
  31. data/docs/index.md +2 -24
  32. data/ext/shopify-cli/extconf.rb +7 -7
  33. data/install.sh +1 -1
  34. data/lib/docgen/markdown.rb +11 -11
  35. data/lib/{project_types/extension/graphql → graphql}/get_app_by_api_key.graphql +0 -0
  36. data/lib/project_types/extension/cli.rb +64 -47
  37. data/lib/project_types/extension/commands/build.rb +3 -3
  38. data/lib/project_types/extension/commands/create.rb +16 -9
  39. data/lib/project_types/extension/commands/extension_command.rb +8 -5
  40. data/lib/project_types/extension/commands/push.rb +8 -8
  41. data/lib/project_types/extension/commands/register.rb +19 -30
  42. data/lib/project_types/extension/commands/serve.rb +23 -3
  43. data/lib/project_types/extension/commands/tunnel.rb +12 -12
  44. data/lib/project_types/extension/extension_project.rb +4 -4
  45. data/lib/project_types/extension/extension_project_keys.rb +4 -4
  46. data/lib/project_types/extension/features/argo.rb +117 -0
  47. data/lib/project_types/extension/features/argo_config.rb +5 -5
  48. data/lib/project_types/extension/features/argo_dependencies.rb +5 -5
  49. data/lib/project_types/extension/features/argo_setup.rb +2 -2
  50. data/lib/project_types/extension/features/argo_setup_steps.rb +4 -4
  51. data/lib/project_types/extension/forms/create.rb +28 -34
  52. data/lib/project_types/extension/forms/questions/ask_app.rb +53 -0
  53. data/lib/project_types/extension/forms/questions/ask_name.rb +40 -0
  54. data/lib/project_types/extension/forms/questions/ask_type.rb +36 -0
  55. data/lib/project_types/extension/messages/messages.rb +53 -52
  56. data/lib/project_types/extension/models/lazy_specification_handler.rb +12 -0
  57. data/lib/project_types/extension/models/specification.rb +35 -0
  58. data/lib/project_types/extension/models/specification_handlers/checkout_post_purchase.rb +19 -0
  59. data/lib/project_types/extension/models/specification_handlers/default.rb +67 -0
  60. data/lib/project_types/extension/models/specifications.rb +77 -0
  61. data/lib/project_types/extension/tasks/configure_features.rb +52 -0
  62. data/lib/project_types/extension/tasks/converters/app_converter.rb +6 -6
  63. data/lib/project_types/extension/tasks/converters/registration_converter.rb +6 -6
  64. data/lib/project_types/extension/tasks/converters/validation_error_converter.rb +4 -4
  65. data/lib/project_types/extension/tasks/converters/version_converter.rb +7 -7
  66. data/lib/project_types/extension/tasks/create_extension.rb +4 -4
  67. data/lib/project_types/extension/tasks/fetch_specifications.rb +38 -0
  68. data/lib/project_types/extension/tasks/get_app.rb +4 -4
  69. data/lib/project_types/extension/tasks/get_apps.rb +3 -3
  70. data/lib/project_types/extension/tasks/update_draft.rb +4 -4
  71. data/lib/project_types/extension/tasks/user_errors.rb +4 -4
  72. data/lib/project_types/node/cli.rb +19 -16
  73. data/lib/project_types/node/commands/connect.rb +15 -0
  74. data/lib/project_types/node/commands/create.rb +44 -41
  75. data/lib/project_types/node/commands/deploy.rb +4 -4
  76. data/lib/project_types/node/commands/deploy/heroku.rb +24 -24
  77. data/lib/project_types/node/commands/generate.rb +9 -18
  78. data/lib/project_types/node/commands/open.rb +2 -2
  79. data/lib/project_types/node/commands/populate.rb +6 -6
  80. data/lib/project_types/node/commands/populate/customer.rb +5 -5
  81. data/lib/project_types/node/commands/populate/draft_order.rb +5 -5
  82. data/lib/project_types/node/commands/populate/product.rb +5 -5
  83. data/lib/project_types/node/commands/serve.rb +9 -9
  84. data/lib/project_types/node/commands/tunnel.rb +7 -7
  85. data/lib/project_types/node/forms/create.rb +7 -7
  86. data/lib/project_types/node/messages/messages.rb +19 -53
  87. data/lib/project_types/rails/cli.rb +21 -18
  88. data/lib/project_types/rails/commands/connect.rb +15 -0
  89. data/lib/project_types/rails/commands/create.rb +58 -57
  90. data/lib/project_types/rails/commands/deploy.rb +4 -4
  91. data/lib/project_types/rails/commands/deploy/heroku.rb +30 -30
  92. data/lib/project_types/rails/commands/generate.rb +7 -7
  93. data/lib/project_types/rails/commands/generate/webhook.rb +6 -6
  94. data/lib/project_types/rails/commands/open.rb +2 -2
  95. data/lib/project_types/rails/commands/populate.rb +6 -6
  96. data/lib/project_types/rails/commands/populate/customer.rb +5 -5
  97. data/lib/project_types/rails/commands/populate/draft_order.rb +5 -5
  98. data/lib/project_types/rails/commands/populate/product.rb +5 -5
  99. data/lib/project_types/rails/commands/serve.rb +11 -11
  100. data/lib/project_types/rails/commands/tunnel.rb +7 -7
  101. data/lib/project_types/rails/forms/create.rb +24 -24
  102. data/lib/project_types/rails/gem.rb +24 -24
  103. data/lib/project_types/rails/messages/messages.rb +12 -9
  104. data/lib/project_types/rails/ruby.rb +2 -2
  105. data/lib/project_types/script/cli.rb +44 -38
  106. data/lib/project_types/script/commands/create.rb +15 -10
  107. data/lib/project_types/script/commands/disable.rb +3 -3
  108. data/lib/project_types/script/commands/enable.rb +19 -9
  109. data/lib/project_types/script/commands/push.rb +10 -17
  110. data/lib/project_types/script/config/extension_points.yml +17 -12
  111. data/lib/project_types/script/errors.rb +22 -0
  112. data/lib/project_types/script/forms/create.rb +29 -5
  113. data/lib/project_types/script/graphql/app_script_update_or_create.graphql +12 -1
  114. data/lib/project_types/script/layers/application/build_script.rb +19 -19
  115. data/lib/project_types/script/layers/application/create_script.rb +41 -12
  116. data/lib/project_types/script/layers/application/disable_script.rb +2 -2
  117. data/lib/project_types/script/layers/application/enable_script.rb +2 -2
  118. data/lib/project_types/script/layers/application/extension_points.rb +24 -0
  119. data/lib/project_types/script/layers/application/project_dependencies.rb +4 -4
  120. data/lib/project_types/script/layers/application/push_script.rb +15 -18
  121. data/lib/project_types/script/layers/domain/config_ui.rb +16 -0
  122. data/lib/project_types/script/layers/domain/errors.rb +23 -0
  123. data/lib/project_types/script/layers/domain/extension_point.rb +62 -7
  124. data/lib/project_types/script/layers/domain/metadata.rb +55 -0
  125. data/lib/project_types/script/layers/domain/push_package.rb +29 -6
  126. data/lib/project_types/script/layers/infrastructure/assemblyscript_project_creator.rb +19 -55
  127. data/lib/project_types/script/layers/infrastructure/assemblyscript_task_runner.rb +49 -18
  128. data/lib/project_types/script/layers/infrastructure/config_ui_repository.rb +46 -0
  129. data/lib/project_types/script/layers/infrastructure/errors.rb +37 -1
  130. data/lib/project_types/script/layers/infrastructure/extension_point_repository.rb +12 -6
  131. data/lib/project_types/script/layers/infrastructure/project_creator.rb +2 -1
  132. data/lib/project_types/script/layers/infrastructure/push_package_repository.rb +20 -13
  133. data/lib/project_types/script/layers/infrastructure/rust_project_creator.rb +72 -0
  134. data/lib/project_types/script/layers/infrastructure/rust_task_runner.rb +59 -0
  135. data/lib/project_types/script/layers/infrastructure/script_service.rb +39 -17
  136. data/lib/project_types/script/layers/infrastructure/task_runner.rb +4 -3
  137. data/lib/project_types/script/messages/messages.rb +79 -10
  138. data/lib/project_types/script/script_project.rb +26 -16
  139. data/lib/project_types/script/ui/error_handler.rb +141 -45
  140. data/lib/project_types/script/ui/printing_spinner.rb +1 -1
  141. data/lib/project_types/script/ui/strict_spinner.rb +1 -1
  142. data/lib/project_types/theme/cli.rb +40 -0
  143. data/lib/project_types/theme/commands/connect.rb +54 -0
  144. data/lib/project_types/theme/commands/create.rb +48 -0
  145. data/lib/project_types/theme/commands/deploy.rb +38 -0
  146. data/lib/project_types/theme/commands/generate.rb +20 -0
  147. data/lib/project_types/theme/commands/generate/env.rb +79 -0
  148. data/lib/project_types/theme/commands/push.rb +55 -0
  149. data/lib/project_types/theme/commands/serve.rb +31 -0
  150. data/lib/project_types/theme/forms/connect.rb +34 -0
  151. data/lib/project_types/theme/forms/create.rb +22 -0
  152. data/lib/project_types/theme/messages/messages.rb +147 -0
  153. data/lib/project_types/theme/tasks/ensure_themekit_installed.rb +78 -0
  154. data/lib/project_types/theme/themekit.rb +113 -0
  155. data/lib/rubygems_plugin.rb +3 -3
  156. data/lib/shopify-cli/admin_api.rb +52 -12
  157. data/lib/shopify-cli/admin_api/populate_resource_command.rb +17 -17
  158. data/lib/shopify-cli/admin_api/schema.rb +3 -3
  159. data/lib/shopify-cli/api.rb +36 -31
  160. data/lib/shopify-cli/command.rb +1 -1
  161. data/lib/shopify-cli/commands.rb +9 -9
  162. data/lib/shopify-cli/commands/config.rb +28 -28
  163. data/lib/shopify-cli/commands/connect.rb +35 -18
  164. data/lib/shopify-cli/commands/create.rb +5 -5
  165. data/lib/shopify-cli/commands/help.rb +6 -6
  166. data/lib/shopify-cli/commands/logout.rb +3 -3
  167. data/lib/shopify-cli/commands/system.rb +33 -33
  168. data/lib/shopify-cli/commands/version.rb +2 -2
  169. data/lib/shopify-cli/context.rb +43 -22
  170. data/lib/shopify-cli/core.rb +4 -4
  171. data/lib/shopify-cli/core/entry_point.rb +5 -5
  172. data/lib/shopify-cli/core/executor.rb +1 -1
  173. data/lib/shopify-cli/core/help_resolver.rb +2 -2
  174. data/lib/shopify-cli/core/monorail.rb +21 -19
  175. data/lib/shopify-cli/db.rb +2 -2
  176. data/lib/shopify-cli/feature.rb +1 -3
  177. data/lib/shopify-cli/form.rb +1 -1
  178. data/lib/shopify-cli/git.rb +17 -17
  179. data/lib/shopify-cli/helpers.rb +1 -1
  180. data/lib/shopify-cli/helpers/haikunator.rb +1 -1
  181. data/lib/shopify-cli/heroku.rb +28 -28
  182. data/lib/shopify-cli/http_request.rb +21 -9
  183. data/lib/shopify-cli/js_deps.rb +13 -13
  184. data/lib/shopify-cli/js_system.rb +5 -5
  185. data/lib/shopify-cli/lazy_delegator.rb +55 -0
  186. data/lib/shopify-cli/messages/messages.rb +21 -10
  187. data/lib/shopify-cli/method_object.rb +104 -0
  188. data/lib/shopify-cli/oauth.rb +25 -25
  189. data/lib/shopify-cli/oauth/servlet.rb +9 -9
  190. data/lib/shopify-cli/options.rb +3 -3
  191. data/lib/shopify-cli/packager.rb +24 -24
  192. data/lib/shopify-cli/partners_api.rb +38 -16
  193. data/lib/shopify-cli/partners_api/organizations.rb +10 -10
  194. data/lib/shopify-cli/process_supervision.rb +8 -8
  195. data/lib/shopify-cli/project.rb +27 -23
  196. data/lib/shopify-cli/project_type.rb +21 -5
  197. data/lib/shopify-cli/resolve_constant.rb +25 -0
  198. data/lib/shopify-cli/resources.rb +1 -1
  199. data/lib/shopify-cli/resources/env_file.rb +9 -9
  200. data/lib/shopify-cli/result.rb +432 -0
  201. data/lib/shopify-cli/shopifolk.rb +35 -18
  202. data/lib/shopify-cli/sub_command.rb +1 -1
  203. data/lib/shopify-cli/task.rb +9 -1
  204. data/lib/shopify-cli/tasks.rb +7 -7
  205. data/lib/shopify-cli/tasks/create_api_client.rb +17 -6
  206. data/lib/shopify-cli/tasks/ensure_dev_store.rb +11 -11
  207. data/lib/shopify-cli/tasks/ensure_env.rb +18 -15
  208. data/lib/shopify-cli/tasks/ensure_loopback_url.rb +4 -4
  209. data/lib/shopify-cli/tasks/select_org_and_shop.rb +29 -24
  210. data/lib/shopify-cli/tasks/update_dashboard_urls.rb +10 -10
  211. data/lib/shopify-cli/transform_data_structure.rb +86 -0
  212. data/lib/shopify-cli/tunnel.rb +36 -30
  213. data/lib/shopify-cli/version.rb +1 -1
  214. data/lib/shopify_cli.rb +57 -52
  215. data/shopify-cli.gemspec +6 -6
  216. data/shopify.fish +1 -1
  217. data/shopify.sh +1 -1
  218. data/vendor/deps/cli-kit/REVISION +1 -1
  219. data/vendor/deps/cli-kit/lib/cli/kit/logger.rb +2 -2
  220. data/vendor/deps/cli-kit/lib/cli/kit/system.rb +3 -3
  221. data/vendor/deps/cli-ui/REVISION +1 -1
  222. data/vendor/deps/cli-ui/lib/cli/ui.rb +26 -22
  223. data/vendor/deps/cli-ui/lib/cli/ui/ansi.rb +4 -6
  224. data/vendor/deps/cli-ui/lib/cli/ui/frame.rb +3 -3
  225. data/vendor/deps/cli-ui/lib/cli/ui/frame/frame_stack.rb +8 -9
  226. data/vendor/deps/cli-ui/lib/cli/ui/frame/frame_style.rb +1 -1
  227. data/vendor/deps/cli-ui/lib/cli/ui/glyph.rb +1 -0
  228. data/vendor/deps/cli-ui/lib/cli/ui/printer.rb +15 -3
  229. data/vendor/deps/cli-ui/lib/cli/ui/prompt/interactive_options.rb +4 -11
  230. data/vendor/deps/cli-ui/lib/cli/ui/spinner.rb +3 -5
  231. data/vendor/deps/cli-ui/lib/cli/ui/terminal.rb +10 -10
  232. data/vendor/deps/cli-ui/lib/cli/ui/version.rb +1 -1
  233. data/vendor/deps/cli-ui/lib/cli/ui/wrap.rb +56 -0
  234. data/vendor/deps/webrick/.gitignore +9 -0
  235. data/vendor/deps/webrick/Gemfile +3 -0
  236. data/vendor/deps/webrick/LICENSE.txt +22 -0
  237. data/vendor/deps/webrick/README.md +61 -0
  238. data/vendor/deps/webrick/Rakefile +10 -0
  239. data/vendor/deps/webrick/lib/webrick.rb +232 -0
  240. data/vendor/deps/webrick/lib/webrick/accesslog.rb +157 -0
  241. data/vendor/deps/webrick/lib/webrick/cgi.rb +313 -0
  242. data/vendor/deps/webrick/lib/webrick/compat.rb +36 -0
  243. data/vendor/deps/webrick/lib/webrick/config.rb +158 -0
  244. data/vendor/deps/webrick/lib/webrick/cookie.rb +172 -0
  245. data/vendor/deps/webrick/lib/webrick/htmlutils.rb +30 -0
  246. data/vendor/deps/webrick/lib/webrick/httpauth.rb +96 -0
  247. data/vendor/deps/webrick/lib/webrick/httpauth/authenticator.rb +117 -0
  248. data/vendor/deps/webrick/lib/webrick/httpauth/basicauth.rb +116 -0
  249. data/vendor/deps/webrick/lib/webrick/httpauth/digestauth.rb +395 -0
  250. data/vendor/deps/webrick/lib/webrick/httpauth/htdigest.rb +132 -0
  251. data/vendor/deps/webrick/lib/webrick/httpauth/htgroup.rb +97 -0
  252. data/vendor/deps/webrick/lib/webrick/httpauth/htpasswd.rb +158 -0
  253. data/vendor/deps/webrick/lib/webrick/httpauth/userdb.rb +53 -0
  254. data/vendor/deps/webrick/lib/webrick/httpproxy.rb +354 -0
  255. data/vendor/deps/webrick/lib/webrick/httprequest.rb +636 -0
  256. data/vendor/deps/webrick/lib/webrick/httpresponse.rb +564 -0
  257. data/vendor/deps/webrick/lib/webrick/https.rb +152 -0
  258. data/vendor/deps/webrick/lib/webrick/httpserver.rb +294 -0
  259. data/vendor/deps/webrick/lib/webrick/httpservlet.rb +23 -0
  260. data/vendor/deps/webrick/lib/webrick/httpservlet/abstract.rb +152 -0
  261. data/vendor/deps/webrick/lib/webrick/httpservlet/cgi_runner.rb +47 -0
  262. data/vendor/deps/webrick/lib/webrick/httpservlet/cgihandler.rb +126 -0
  263. data/vendor/deps/webrick/lib/webrick/httpservlet/erbhandler.rb +88 -0
  264. data/vendor/deps/webrick/lib/webrick/httpservlet/filehandler.rb +552 -0
  265. data/vendor/deps/webrick/lib/webrick/httpservlet/prochandler.rb +47 -0
  266. data/vendor/deps/webrick/lib/webrick/httpstatus.rb +194 -0
  267. data/vendor/deps/webrick/lib/webrick/httputils.rb +512 -0
  268. data/vendor/deps/webrick/lib/webrick/httpversion.rb +76 -0
  269. data/vendor/deps/webrick/lib/webrick/log.rb +156 -0
  270. data/vendor/deps/webrick/lib/webrick/server.rb +381 -0
  271. data/vendor/deps/webrick/lib/webrick/ssl.rb +215 -0
  272. data/vendor/deps/webrick/lib/webrick/utils.rb +265 -0
  273. data/vendor/deps/webrick/lib/webrick/version.rb +18 -0
  274. data/vendor/deps/webrick/webrick.gemspec +74 -0
  275. data/vendor/gen/template/bin/update-deps +9 -9
  276. metadata +83 -29
  277. data/docs/Gemfile +0 -5
  278. data/docs/Gemfile.lock +0 -258
  279. data/docs/_data/nav.yml +0 -35
  280. data/docs/_includes/footer.html +0 -15
  281. data/docs/_includes/head.html +0 -19
  282. data/docs/_includes/sidebar_nav.html +0 -22
  283. data/docs/_includes/toc.html +0 -112
  284. data/docs/_layouts/default.html +0 -79
  285. data/docs/css/docs.css +0 -157
  286. data/docs/images/header.png +0 -0
  287. data/docs/installing-ruby.md +0 -28
  288. data/lib/project_types/extension/features/argo/admin.rb +0 -20
  289. data/lib/project_types/extension/features/argo/base.rb +0 -129
  290. data/lib/project_types/extension/features/argo/checkout.rb +0 -20
  291. data/lib/project_types/extension/forms/register.rb +0 -47
  292. data/lib/project_types/extension/models/type.rb +0 -81
  293. data/lib/project_types/extension/models/types/checkout_post_purchase.rb +0 -23
  294. data/lib/project_types/extension/models/types/product_subscription.rb +0 -24
  295. data/lib/project_types/node/commands/generate/billing.rb +0 -39
  296. data/lib/project_types/node/commands/generate/page.rb +0 -59
  297. data/lib/project_types/node/commands/generate/webhook.rb +0 -37
  298. data/lib/project_types/script/layers/domain/script.rb +0 -18
  299. data/lib/project_types/script/layers/infrastructure/assemblyscript_tsconfig.rb +0 -38
  300. data/lib/project_types/script/layers/infrastructure/script_repository.rb +0 -59
  301. data/lib/project_types/script/templates/ts/as-pect.config.js +0 -27
  302. data/lib/project_types/script/templates/ts/as-pect.d.ts +0 -1
@@ -1,5 +1,5 @@
1
- require 'shopify_cli'
2
- require 'optparse'
1
+ require "shopify_cli"
2
+ require "optparse"
3
3
 
4
4
  module ShopifyCli
5
5
  class AdminAPI
@@ -36,7 +36,7 @@ module ShopifyCli
36
36
 
37
37
  if @help
38
38
  output = display_parent_extended_help
39
- output += "\n#{@ctx.message('core.populate.options.header', camel_case_resource_type)}\n"
39
+ output += "\n#{@ctx.message("core.populate.options.header", camel_case_resource_type)}\n"
40
40
  output += resource_options.help
41
41
  return @ctx.puts(output)
42
42
  end
@@ -45,7 +45,7 @@ module ShopifyCli
45
45
 
46
46
  if @silent
47
47
  spin_group = CLI::UI::SpinGroup.new
48
- spin_group.add(@ctx.message('core.populate.populating', @count, camel_case_resource_type)) do |spinner|
48
+ spin_group.add(@ctx.message("core.populate.populating", @count, camel_case_resource_type)) do |spinner|
49
49
  populate
50
50
  spinner.update_title(completion_message)
51
51
  end
@@ -78,18 +78,18 @@ module ShopifyCli
78
78
  opts.on(
79
79
  "-c #{DEFAULT_COUNT}",
80
80
  "--count=#{DEFAULT_COUNT}",
81
- @ctx.message('core.populate.options.count_help')
81
+ @ctx.message("core.populate.options.count_help")
82
82
  ) do |value|
83
83
  @count = value.to_i
84
84
  end
85
85
 
86
- opts.on('-h', '--help', 'print help') do |value|
86
+ opts.on("-h", "--help", "print help") do |value|
87
87
  @help = value
88
88
  end
89
89
 
90
90
  opts.on("--silent") { |v| @silent = v }
91
91
 
92
- opts.on('--shop=', '-s') { |value| @shop = value }
92
+ opts.on("--shop=", "-s") { |value| @shop = value }
93
93
  end
94
94
  end
95
95
 
@@ -100,12 +100,12 @@ module ShopifyCli
100
100
  end
101
101
 
102
102
  def input_options
103
- schema.type(self.class.input_type)['inputFields'].each do |field|
103
+ schema.type(self.class.input_type)["inputFields"].each do |field|
104
104
  resource_options.on(
105
- "--#{field['name']}=#{field['defaultValue']}",
106
- field['description']
105
+ "--#{field["name"]}=#{field["defaultValue"]}",
106
+ field["description"]
107
107
  ) do |value|
108
- @input[field['name']] = value
108
+ @input[field["name"]] = value
109
109
  end
110
110
  end
111
111
  end
@@ -120,14 +120,14 @@ module ShopifyCli
120
120
  resp = AdminAPI.query(
121
121
  @ctx, "create_#{snake_case_resource_type}", **kwargs
122
122
  )
123
- @ctx.abort(resp['errors']) if resp['errors']
124
- @ctx.done(message(resp['data'])) unless @silent
123
+ @ctx.abort(resp["errors"]) if resp["errors"]
124
+ @ctx.done(message(resp["data"])) unless @silent
125
125
  end
126
126
 
127
127
  def completion_message
128
128
  plural = @count > 1 ? "s" : ""
129
129
  @ctx.message(
130
- 'core.populate.completion_message',
130
+ "core.populate.completion_message",
131
131
  @count,
132
132
  "#{camel_case_resource_type}#{plural}",
133
133
  Project.current.env.shop,
@@ -142,7 +142,7 @@ module ShopifyCli
142
142
  end
143
143
 
144
144
  def price
145
- format('%.2f', rand(1..10))
145
+ format("%.2f", rand(1..10))
146
146
  end
147
147
 
148
148
  private
@@ -155,7 +155,7 @@ module ShopifyCli
155
155
  end
156
156
 
157
157
  def camel_case_resource_type
158
- @camel_case_resource_type ||= self.class.to_s.split('::').last
158
+ @camel_case_resource_type ||= self.class.to_s.split("::").last
159
159
  end
160
160
 
161
161
  def snake_case_resource_type
@@ -167,7 +167,7 @@ module ShopifyCli
167
167
  end
168
168
 
169
169
  def parent_command_klass
170
- @parent_command_klass ||= Module.const_get(self.class.to_s.split('::')[0..-2].join('::'))
170
+ @parent_command_klass ||= Module.const_get(self.class.to_s.split("::")[0..-2].join("::"))
171
171
  end
172
172
  end
173
173
  end
@@ -1,4 +1,4 @@
1
- require 'shopify_cli'
1
+ require "shopify_cli"
2
2
 
3
3
  module ShopifyCli
4
4
  class AdminAPI
@@ -7,7 +7,7 @@ module ShopifyCli
7
7
  def get(ctx)
8
8
  unless ShopifyCli::DB.exists?(:shopify_admin_schema)
9
9
  shop = Project.current.env.shop || get_shop(ctx)
10
- schema = AdminAPI.query(ctx, 'admin_introspection', shop: shop)
10
+ schema = AdminAPI.query(ctx, "admin_introspection", shop: shop)
11
11
  ShopifyCli::DB.set(shopify_admin_schema: JSON.dump(schema))
12
12
  end
13
13
  # This is ruby magic for making a new hash with another hash.
@@ -30,7 +30,7 @@ module ShopifyCli
30
30
  data = self["data"]
31
31
  schema = data["__schema"]
32
32
  schema["types"].find do |object|
33
- object['name'] == name.to_s
33
+ object["name"] == name.to_s
34
34
  end
35
35
  end
36
36
 
@@ -1,4 +1,4 @@
1
- require 'shopify_cli'
1
+ require "shopify_cli"
2
2
 
3
3
  module ShopifyCli
4
4
  class API
@@ -19,49 +19,36 @@ module ShopifyCli
19
19
  class APIRequestThrottledError < APIRequestRetriableError; end
20
20
 
21
21
  def self.gid_to_id(gid)
22
- gid.split('/').last
22
+ gid.split("/").last
23
23
  end
24
24
 
25
25
  def query(query_name, variables: {})
26
26
  _, resp = request(
27
- load_query(query_name),
28
- variables: variables,
29
- headers: default_headers,
30
- graphql_url: url,
27
+ body: JSON.dump(query: load_query(query_name).tr("\n", ""), variables: variables),
28
+ url: url,
31
29
  )
32
30
  ctx.debug(resp)
33
31
  resp
34
32
  rescue API::APIRequestServerError, API::APIRequestUnexpectedError => e
35
- ctx.puts(ctx.message('core.api.error.internal_server_error'))
36
- ctx.debug(ctx.message('core.api.error.internal_server_error_debug', e.message))
33
+ ctx.puts(ctx.message("core.api.error.internal_server_error"))
34
+ ctx.debug(ctx.message("core.api.error.internal_server_error_debug", e.message))
37
35
  end
38
36
 
39
- protected
40
-
41
- def load_query(name)
42
- project_type = ShopifyCli::Project.current_project_type
43
- project_file_path = File.join(
44
- ShopifyCli::ROOT, 'lib', 'project_types', project_type.to_s, 'graphql', "#{name}.graphql"
45
- )
46
- if !project_type.nil? && File.exist?(project_file_path)
47
- File.read(project_file_path)
48
- else
49
- File.read(File.join(ShopifyCli::ROOT, 'lib', 'graphql', "#{name}.graphql"))
50
- end
51
- end
52
-
53
- private
54
-
55
- def request(body, graphql_url:, variables: {}, headers: {})
37
+ def request(url:, body: nil, headers: {}, method: "POST")
56
38
  CLI::Kit::Util.begin do
57
- uri = URI.parse(graphql_url)
39
+ uri = URI.parse(url)
58
40
  unless uri.is_a?(URI::HTTP)
59
- ctx.abort("Invalid URL: #{graphql_url}")
41
+ ctx.abort(ctx.message("core.api.error.invalid_url", url))
60
42
  end
61
43
 
62
44
  # we delay this require so as to avoid a performance hit on starting the CLI
63
- require 'shopify-cli/http_request'
64
- response = HttpRequest.call(uri, body, variables, headers)
45
+ require "shopify-cli/http_request"
46
+ headers = default_headers.merge(headers)
47
+ response = if method == "POST"
48
+ HttpRequest.post(uri, body, headers)
49
+ elsif method == "GET"
50
+ HttpRequest.get(uri, body, headers)
51
+ end
65
52
 
66
53
  case response.code.to_i
67
54
  when 200..399
@@ -84,14 +71,32 @@ module ShopifyCli
84
71
  end
85
72
  end
86
73
 
74
+ protected
75
+
76
+ def load_query(name)
77
+ project_type = ShopifyCli::Project.current_project_type
78
+ project_file_path = File.join(
79
+ ShopifyCli::ROOT, "lib", "project_types", project_type.to_s, "graphql", "#{name}.graphql"
80
+ )
81
+ if !project_type.nil? && File.exist?(project_file_path)
82
+ File.read(project_file_path)
83
+ else
84
+ File.read(File.join(ShopifyCli::ROOT, "lib", "graphql", "#{name}.graphql"))
85
+ end
86
+ end
87
+
88
+ private
89
+
87
90
  def current_sha
88
91
  @current_sha ||= Git.sha(dir: ShopifyCli::ROOT)
89
92
  end
90
93
 
91
94
  def default_headers
92
95
  {
93
- 'User-Agent' => "Shopify App CLI #{ShopifyCli::VERSION} #{current_sha} | #{ctx.uname}",
94
- }.merge(auth_headers(token))
96
+ "User-Agent" => "Shopify App CLI #{ShopifyCli::VERSION} #{current_sha} | #{ctx.uname}",
97
+ }.tap do |headers|
98
+ headers["X-Shopify-Cli-Employee"] = "1" if Shopifolk.acting_as_shopify_organization?
99
+ end.merge(auth_headers(token))
95
100
  end
96
101
 
97
102
  def auth_headers(token)
@@ -1,5 +1,5 @@
1
1
  # frozen_string_literal: true
2
- require 'shopify_cli'
2
+ require "shopify_cli"
3
3
 
4
4
  module ShopifyCli
5
5
  class Command < CLI::Kit::BaseCommand
@@ -1,9 +1,9 @@
1
- require 'shopify_cli'
1
+ require "shopify_cli"
2
2
 
3
3
  module ShopifyCli
4
4
  module Commands
5
5
  Registry = CLI::Kit::CommandRegistry.new(
6
- default: 'help',
6
+ default: "help",
7
7
  contextual_resolver: nil,
8
8
  )
9
9
  @core_commands = []
@@ -18,12 +18,12 @@ module ShopifyCli
18
18
  @core_commands.include?(cmd)
19
19
  end
20
20
 
21
- register :Config, 'config', 'shopify-cli/commands/config', true
22
- register :Connect, 'connect', 'shopify-cli/commands/connect', true
23
- register :Create, 'create', 'shopify-cli/commands/create', true
24
- register :Help, 'help', 'shopify-cli/commands/help', true
25
- register :Logout, 'logout', 'shopify-cli/commands/logout', true
26
- register :System, 'system', 'shopify-cli/commands/system', true
27
- register :Version, 'version', 'shopify-cli/commands/version', true
21
+ register :Config, "config", "shopify-cli/commands/config", true
22
+ register :Connect, "connect", "shopify-cli/commands/connect", true
23
+ register :Create, "create", "shopify-cli/commands/create", true
24
+ register :Help, "help", "shopify-cli/commands/help", true
25
+ register :Logout, "logout", "shopify-cli/commands/logout", true
26
+ register :System, "system", "shopify-cli/commands/system", true
27
+ register :Version, "version", "shopify-cli/commands/version", true
28
28
  end
29
29
  end
@@ -1,73 +1,73 @@
1
- require 'shopify_cli'
1
+ require "shopify_cli"
2
2
 
3
3
  module ShopifyCli
4
4
  module Commands
5
5
  class Config < ShopifyCli::Command
6
6
  hidden_feature(feature_set: :debug)
7
7
 
8
- subcommand :Feature, 'feature'
9
- subcommand :Analytics, 'analytics'
8
+ subcommand :Feature, "feature"
9
+ subcommand :Analytics, "analytics"
10
10
 
11
11
  def call(*)
12
12
  @ctx.puts(self.class.help)
13
13
  end
14
14
 
15
15
  def self.help
16
- ShopifyCli::Context.message('core.config.help', ShopifyCli::TOOL_NAME)
16
+ ShopifyCli::Context.message("core.config.help", ShopifyCli::TOOL_NAME)
17
17
  end
18
18
 
19
19
  class Feature < ShopifyCli::SubCommand
20
20
  def self.help
21
- ShopifyCli::Context.message('core.config.feature.help', ShopifyCli::TOOL_NAME)
21
+ ShopifyCli::Context.message("core.config.feature.help", ShopifyCli::TOOL_NAME)
22
22
  end
23
23
 
24
24
  options do |parser, flags|
25
- parser.on('--enable') { flags[:action] = 'enable' }
26
- parser.on('--disable') { flags[:action] = 'disable' }
27
- parser.on('--status') { flags[:action] = 'status' }
25
+ parser.on("--enable") { flags[:action] = "enable" }
26
+ parser.on("--disable") { flags[:action] = "disable" }
27
+ parser.on("--status") { flags[:action] = "status" }
28
28
  end
29
29
 
30
30
  def call(args, _name)
31
31
  feature_name = args.shift
32
- return @ctx.puts(@ctx.message('core.config.help', ShopifyCli::TOOL_NAME)) if feature_name.nil?
32
+ return @ctx.puts(@ctx.message("core.config.help", ShopifyCli::TOOL_NAME)) if feature_name.nil?
33
33
  is_enabled = ShopifyCli::Feature.enabled?(feature_name)
34
- if options.flags[:action] == 'disable' && is_enabled
34
+ if options.flags[:action] == "disable" && is_enabled
35
35
  ShopifyCli::Feature.disable(feature_name)
36
- @ctx.puts(@ctx.message('core.config.feature.disabled', feature_name))
37
- elsif options.flags[:action] == 'enable' && !is_enabled
36
+ @ctx.puts(@ctx.message("core.config.feature.disabled", feature_name))
37
+ elsif options.flags[:action] == "enable" && !is_enabled
38
38
  ShopifyCli::Feature.enable(feature_name)
39
- @ctx.puts(@ctx.message('core.config.feature.enabled', feature_name))
39
+ @ctx.puts(@ctx.message("core.config.feature.enabled", feature_name))
40
40
  elsif is_enabled
41
- @ctx.puts(@ctx.message('core.config.feature.is_enabled', feature_name))
41
+ @ctx.puts(@ctx.message("core.config.feature.is_enabled", feature_name))
42
42
  else
43
- @ctx.puts(@ctx.message('core.config.feature.is_disabled', feature_name))
43
+ @ctx.puts(@ctx.message("core.config.feature.is_disabled", feature_name))
44
44
  end
45
45
  end
46
46
  end
47
47
 
48
48
  class Analytics < ShopifyCli::SubCommand
49
49
  def self.help
50
- ShopifyCli::Context.message('core.config.analytics.help', ShopifyCli::TOOL_NAME)
50
+ ShopifyCli::Context.message("core.config.analytics.help", ShopifyCli::TOOL_NAME)
51
51
  end
52
52
 
53
53
  options do |parser, flags|
54
- parser.on('--enable') { flags[:action] = 'enable' }
55
- parser.on('--disable') { flags[:action] = 'disable' }
56
- parser.on('--status') { flags[:action] = 'status' }
54
+ parser.on("--enable") { flags[:action] = "enable" }
55
+ parser.on("--disable") { flags[:action] = "disable" }
56
+ parser.on("--status") { flags[:action] = "status" }
57
57
  end
58
58
 
59
59
  def call(_args, _name)
60
- is_enabled = ShopifyCli::Config.get_bool('analytics', 'enabled')
61
- if options.flags[:action] == 'disable' && is_enabled
62
- ShopifyCli::Config.set('analytics', 'enabled', false)
63
- @ctx.puts(@ctx.message('core.config.analytics.disabled'))
64
- elsif options.flags[:action] == 'enable' && !is_enabled
65
- ShopifyCli::Config.set('analytics', 'enabled', true)
66
- @ctx.puts(@ctx.message('core.config.analytics.enabled'))
60
+ is_enabled = ShopifyCli::Config.get_bool("analytics", "enabled")
61
+ if options.flags[:action] == "disable" && is_enabled
62
+ ShopifyCli::Config.set("analytics", "enabled", false)
63
+ @ctx.puts(@ctx.message("core.config.analytics.disabled"))
64
+ elsif options.flags[:action] == "enable" && !is_enabled
65
+ ShopifyCli::Config.set("analytics", "enabled", true)
66
+ @ctx.puts(@ctx.message("core.config.analytics.enabled"))
67
67
  elsif is_enabled
68
- @ctx.puts(@ctx.message('core.config.analytics.is_enabled'))
68
+ @ctx.puts(@ctx.message("core.config.analytics.is_enabled"))
69
69
  else
70
- @ctx.puts(@ctx.message('core.config.analytics.is_disabled'))
70
+ @ctx.puts(@ctx.message("core.config.analytics.is_disabled"))
71
71
  end
72
72
  end
73
73
  end
@@ -1,46 +1,63 @@
1
- require 'shopify_cli'
1
+ require "shopify_cli"
2
2
 
3
3
  module ShopifyCli
4
4
  module Commands
5
5
  class Connect < ShopifyCli::Command
6
- def call(*)
7
- project_type = ask_project_type unless Project.has_current?
8
-
9
- if Project.has_current? && Project.current && Project.current.env
10
- @ctx.puts @ctx.message('core.connect.already_connected_warning')
11
- prod_warning = @ctx.message('core.connect.production_warning')
12
- @ctx.puts prod_warning if [:rails, :node].include?(Project.current_project_type)
6
+ class << self
7
+ def call(args, command_name)
8
+ ProjectType.load_type(args[0]) unless args.empty?
9
+ super
13
10
  end
14
11
 
15
- org = ShopifyCli::Tasks::EnsureEnv.call(@ctx, regenerate: true)
16
- write_cli_yml(project_type, org['id']) unless Project.has_current?
17
- api_key = Project.current(force_reload: true).env['api_key']
18
- @ctx.puts(@ctx.message('core.connect.connected', get_app(org['apps'], api_key).first["title"]))
12
+ def help
13
+ ShopifyCli::Context.message("core.connect.help", ShopifyCli::TOOL_NAME)
14
+ end
19
15
  end
20
16
 
21
- def get_app(apps, api_key)
22
- apps.select { |app| app["apiKey"] == api_key }
17
+ def call(args, command_name)
18
+ if Project.current&.env
19
+ @ctx.puts(@ctx.message("core.connect.already_connected_warning"))
20
+ end
21
+
22
+ project_type = ask_project_type
23
+
24
+ klass = ProjectType.load_type(project_type)&.connect_command
25
+
26
+ if klass
27
+ klass.ctx = @ctx
28
+ klass.call(args, command_name, "connect")
29
+ else
30
+ app = default_connect(project_type)
31
+ @ctx.done(@ctx.message("core.connect.connected", app))
32
+ end
23
33
  end
24
34
 
25
35
  def ask_project_type
26
- CLI::UI::Prompt.ask(@ctx.message('core.connect.project_type_select')) do |handler|
36
+ CLI::UI::Prompt.ask(@ctx.message("core.connect.project_type_select")) do |handler|
27
37
  ShopifyCli::Commands::Create.all_visible_type.each do |type|
28
38
  handler.option(type.project_name) { type.project_type }
29
39
  end
30
40
  end
31
41
  end
32
42
 
43
+ def default_connect(project_type)
44
+ org = ShopifyCli::Tasks::EnsureEnv.call(@ctx, regenerate: true)
45
+ write_cli_yml(project_type, org["id"]) unless Project.has_current?
46
+ api_key = Project.current(force_reload: true).env["api_key"]
47
+ get_app(org["apps"], api_key).first["title"]
48
+ end
49
+
33
50
  def write_cli_yml(project_type, org_id)
34
51
  ShopifyCli::Project.write(
35
52
  @ctx,
36
53
  project_type: project_type,
37
54
  organization_id: org_id,
38
55
  )
39
- @ctx.done(@ctx.message('core.connect.cli_yml_saved'))
56
+ @ctx.done(@ctx.message("core.connect.cli_yml_saved"))
40
57
  end
41
58
 
42
- def self.help
43
- ShopifyCli::Context.message('core.connect.help', ShopifyCli::TOOL_NAME)
59
+ def get_app(apps, api_key)
60
+ apps.select { |app| app["apiKey"] == api_key }
44
61
  end
45
62
  end
46
63
  end