shopify-cli 2.2.1 → 2.5.0

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 (249) hide show
  1. checksums.yaml +4 -4
  2. data/.github/CODEOWNERS +1 -0
  3. data/.github/ISSUE_TEMPLATE.md +0 -4
  4. data/.github/workflows/shopify.yml +104 -0
  5. data/.gitignore +2 -0
  6. data/.rubocop.yml +14 -14
  7. data/.rubocop_todo.yml +3 -3
  8. data/CHANGELOG.md +23 -0
  9. data/CONTRIBUTING.md +23 -0
  10. data/Dockerfile +19 -0
  11. data/Gemfile +1 -0
  12. data/Gemfile.lock +50 -13
  13. data/RELEASING.md +1 -1
  14. data/Rakefile +84 -18
  15. data/bin/shopify +3 -3
  16. data/dev.yml +11 -1
  17. data/ext/shopify-extensions/extconf.rb +21 -0
  18. data/ext/shopify-extensions/shopify_extensions.rb +152 -0
  19. data/ext/shopify-extensions/version +1 -0
  20. data/lib/project_types/extension/cli.rb +17 -3
  21. data/lib/project_types/extension/commands/build.rb +31 -3
  22. data/lib/project_types/extension/commands/check.rb +2 -2
  23. data/lib/project_types/extension/commands/connect.rb +1 -1
  24. data/lib/project_types/extension/commands/create.rb +59 -16
  25. data/lib/project_types/extension/commands/extension_command.rb +1 -1
  26. data/lib/project_types/extension/commands/info.rb +1 -1
  27. data/lib/project_types/extension/commands/push.rb +1 -1
  28. data/lib/project_types/extension/commands/register.rb +2 -2
  29. data/lib/project_types/extension/commands/serve.rb +5 -5
  30. data/lib/project_types/extension/commands/tunnel.rb +6 -6
  31. data/lib/project_types/extension/extension_project.rb +4 -4
  32. data/lib/project_types/extension/features/argo.rb +2 -2
  33. data/lib/project_types/extension/features/argo_config.rb +5 -5
  34. data/lib/project_types/extension/features/argo_serve.rb +20 -6
  35. data/lib/project_types/extension/features/argo_setup.rb +1 -1
  36. data/lib/project_types/extension/features/argo_setup_step.rb +1 -1
  37. data/lib/project_types/extension/features/argo_setup_steps.rb +2 -2
  38. data/lib/project_types/extension/forms/connect.rb +2 -2
  39. data/lib/project_types/extension/forms/create.rb +6 -3
  40. data/lib/project_types/extension/forms/questions/ask_app.rb +2 -2
  41. data/lib/project_types/extension/forms/questions/ask_name.rb +1 -1
  42. data/lib/project_types/extension/forms/questions/ask_registration.rb +2 -2
  43. data/lib/project_types/extension/forms/questions/ask_template.rb +44 -0
  44. data/lib/project_types/extension/forms/questions/ask_type.rb +2 -2
  45. data/lib/project_types/extension/messages/message_loading.rb +2 -2
  46. data/lib/project_types/extension/messages/messages.rb +3 -0
  47. data/lib/project_types/extension/models/development_server.rb +74 -0
  48. data/lib/project_types/extension/models/development_server_requirements.rb +36 -0
  49. data/lib/project_types/extension/models/lazy_specification_handler.rb +1 -1
  50. data/lib/project_types/extension/models/server_config/base.rb +31 -0
  51. data/lib/project_types/extension/models/server_config/development.rb +23 -0
  52. data/lib/project_types/extension/models/server_config/development_entries.rb +38 -0
  53. data/lib/project_types/extension/models/server_config/development_renderer.rb +30 -0
  54. data/lib/project_types/extension/models/server_config/extension.rb +35 -0
  55. data/lib/project_types/extension/models/server_config/root.rb +18 -0
  56. data/lib/project_types/extension/models/server_config/user.rb +10 -0
  57. data/lib/project_types/extension/models/specification.rb +1 -1
  58. data/lib/project_types/extension/models/specification_handlers/checkout_ui_extension.rb +1 -1
  59. data/lib/project_types/extension/models/specification_handlers/default.rb +10 -2
  60. data/lib/project_types/extension/models/specification_handlers/theme_app_extension.rb +1 -1
  61. data/lib/project_types/extension/models/specifications.rb +4 -4
  62. data/lib/project_types/extension/tasks/choose_next_available_port.rb +2 -2
  63. data/lib/project_types/extension/tasks/configure_features.rb +1 -1
  64. data/lib/project_types/extension/tasks/configure_options.rb +1 -1
  65. data/lib/project_types/extension/tasks/converters/product_converter.rb +1 -1
  66. data/lib/project_types/extension/tasks/create_extension.rb +2 -2
  67. data/lib/project_types/extension/tasks/fetch_specifications.rb +2 -2
  68. data/lib/project_types/extension/tasks/find_npm_packages.rb +3 -3
  69. data/lib/project_types/extension/tasks/get_app.rb +2 -2
  70. data/lib/project_types/extension/tasks/get_apps.rb +2 -2
  71. data/lib/project_types/extension/tasks/get_extensions.rb +2 -2
  72. data/lib/project_types/extension/tasks/get_product.rb +2 -2
  73. data/lib/project_types/extension/tasks/run_extension_command.rb +65 -0
  74. data/lib/project_types/extension/tasks/update_draft.rb +2 -2
  75. data/lib/project_types/node/cli.rb +3 -3
  76. data/lib/project_types/node/commands/connect.rb +4 -4
  77. data/lib/project_types/node/commands/create.rb +10 -14
  78. data/lib/project_types/node/commands/deploy/heroku.rb +4 -4
  79. data/lib/project_types/node/commands/deploy.rb +3 -3
  80. data/lib/project_types/node/commands/generate.rb +2 -2
  81. data/lib/project_types/node/commands/open.rb +3 -3
  82. data/lib/project_types/node/commands/serve.rb +7 -7
  83. data/lib/project_types/node/commands/tunnel.rb +6 -6
  84. data/lib/project_types/node/forms/create.rb +3 -3
  85. data/lib/project_types/php/cli.rb +27 -0
  86. data/lib/project_types/php/commands/connect.rb +19 -0
  87. data/lib/project_types/php/commands/create.rb +143 -0
  88. data/lib/project_types/php/commands/deploy/heroku.rb +129 -0
  89. data/lib/project_types/php/commands/deploy.rb +32 -0
  90. data/lib/project_types/php/commands/open.rb +16 -0
  91. data/lib/project_types/php/commands/serve.rb +51 -0
  92. data/lib/project_types/php/commands/tunnel.rb +37 -0
  93. data/lib/project_types/php/forms/create.rb +45 -0
  94. data/lib/project_types/php/messages/messages.rb +191 -0
  95. data/lib/project_types/rails/cli.rb +3 -3
  96. data/lib/project_types/rails/commands/connect.rb +4 -4
  97. data/lib/project_types/rails/commands/create.rb +12 -16
  98. data/lib/project_types/rails/commands/deploy/heroku.rb +4 -4
  99. data/lib/project_types/rails/commands/deploy.rb +3 -3
  100. data/lib/project_types/rails/commands/generate/webhook.rb +3 -3
  101. data/lib/project_types/rails/commands/generate.rb +3 -3
  102. data/lib/project_types/rails/commands/open.rb +3 -3
  103. data/lib/project_types/rails/commands/serve.rb +8 -8
  104. data/lib/project_types/rails/commands/tunnel.rb +6 -6
  105. data/lib/project_types/rails/forms/create.rb +3 -3
  106. data/lib/project_types/rails/gem.rb +1 -1
  107. data/lib/project_types/rails/ruby.rb +1 -1
  108. data/lib/project_types/script/cli.rb +12 -3
  109. data/lib/project_types/script/commands/create.rb +2 -2
  110. data/lib/project_types/script/commands/push.rb +2 -2
  111. data/lib/project_types/script/forms/create.rb +1 -1
  112. data/lib/project_types/script/graphql/app_script_set.graphql +40 -0
  113. data/lib/project_types/script/graphql/app_script_update_or_create.graphql +0 -44
  114. data/lib/project_types/script/graphql/module_upload_url_generate.graphql +9 -0
  115. data/lib/project_types/script/layers/application/extension_points.rb +2 -2
  116. data/lib/project_types/script/layers/application/push_script.rb +13 -1
  117. data/lib/project_types/script/layers/domain/push_package.rb +1 -14
  118. data/lib/project_types/script/layers/domain/script_project.rb +2 -2
  119. data/lib/project_types/script/layers/infrastructure/api_clients/partners_proxy_api_client.rb +55 -0
  120. data/lib/project_types/script/layers/infrastructure/api_clients/script_service_api_client.rb +35 -0
  121. data/lib/project_types/script/layers/infrastructure/command_runner.rb +1 -1
  122. data/lib/project_types/script/layers/infrastructure/errors.rb +2 -0
  123. data/lib/project_types/script/layers/infrastructure/languages/assemblyscript_project_creator.rb +2 -2
  124. data/lib/project_types/script/layers/infrastructure/languages/rust_project_creator.rb +1 -1
  125. data/lib/project_types/script/layers/infrastructure/push_package_repository.rb +1 -2
  126. data/lib/project_types/script/layers/infrastructure/script_project_repository.rb +5 -5
  127. data/lib/project_types/script/layers/infrastructure/script_service.rb +28 -97
  128. data/lib/project_types/script/layers/infrastructure/script_uploader.rb +27 -0
  129. data/lib/project_types/script/layers/infrastructure/service_locator.rb +20 -0
  130. data/lib/project_types/script/messages/messages.rb +3 -0
  131. data/lib/project_types/script/tasks/ensure_env.rb +7 -7
  132. data/lib/project_types/script/ui/error_handler.rb +79 -74
  133. data/lib/project_types/script/ui/printing_spinner.rb +1 -1
  134. data/lib/project_types/theme/cli.rb +3 -3
  135. data/lib/project_types/theme/commands/check.rb +3 -3
  136. data/lib/project_types/theme/commands/delete.rb +7 -7
  137. data/lib/project_types/theme/commands/init.rb +3 -3
  138. data/lib/project_types/theme/commands/language_server.rb +2 -2
  139. data/lib/project_types/theme/commands/package.rb +2 -2
  140. data/lib/project_types/theme/commands/publish.rb +5 -5
  141. data/lib/project_types/theme/commands/pull.rb +15 -9
  142. data/lib/project_types/theme/commands/push.rb +18 -12
  143. data/lib/project_types/theme/commands/serve.rb +4 -4
  144. data/lib/project_types/theme/forms/confirm_store.rb +1 -1
  145. data/lib/project_types/theme/forms/select.rb +2 -2
  146. data/lib/{shopify-cli → shopify_cli}/admin_api/populate_resource_command.rb +3 -3
  147. data/lib/{shopify-cli → shopify_cli}/admin_api/schema.rb +4 -4
  148. data/lib/{shopify-cli → shopify_cli}/admin_api.rb +27 -27
  149. data/lib/{shopify-cli → shopify_cli}/api.rb +8 -8
  150. data/lib/{shopify-cli → shopify_cli}/command.rb +3 -3
  151. data/lib/{shopify-cli → shopify_cli}/commands/config.rb +14 -14
  152. data/lib/{shopify-cli → shopify_cli}/commands/help.rb +4 -4
  153. data/lib/{shopify-cli → shopify_cli}/commands/login.rb +7 -7
  154. data/lib/shopify_cli/commands/logout.rb +39 -0
  155. data/lib/{shopify-cli → shopify_cli}/commands/populate/customer.rb +4 -4
  156. data/lib/{shopify-cli → shopify_cli}/commands/populate/draft_order.rb +4 -4
  157. data/lib/{shopify-cli → shopify_cli}/commands/populate/product.rb +4 -4
  158. data/lib/shopify_cli/commands/populate.rb +23 -0
  159. data/lib/shopify_cli/commands/store.rb +15 -0
  160. data/lib/{shopify-cli → shopify_cli}/commands/switch.rb +5 -5
  161. data/lib/{shopify-cli → shopify_cli}/commands/system.rb +10 -10
  162. data/lib/shopify_cli/commands/version.rb +15 -0
  163. data/lib/{shopify-cli → shopify_cli}/commands/whoami.rb +7 -7
  164. data/lib/shopify_cli/commands.rb +34 -0
  165. data/lib/{shopify-cli → shopify_cli}/connect.rb +3 -3
  166. data/lib/shopify_cli/constants.rb +26 -0
  167. data/lib/{shopify-cli → shopify_cli}/context.rb +6 -6
  168. data/lib/{shopify-cli → shopify_cli}/core/entry_point.rb +7 -7
  169. data/lib/{shopify-cli → shopify_cli}/core/executor.rb +3 -3
  170. data/lib/{shopify-cli → shopify_cli}/core/finalize.rb +1 -1
  171. data/lib/{shopify-cli → shopify_cli}/core/help_resolver.rb +2 -2
  172. data/lib/{shopify-cli → shopify_cli}/core/monorail.rb +8 -8
  173. data/lib/shopify_cli/core.rb +8 -0
  174. data/lib/{shopify-cli → shopify_cli}/db.rb +8 -8
  175. data/lib/shopify_cli/environment.rb +60 -0
  176. data/lib/{shopify-cli → shopify_cli}/feature.rb +8 -8
  177. data/lib/{shopify-cli → shopify_cli}/form.rb +2 -2
  178. data/lib/{shopify-cli → shopify_cli}/git.rb +8 -8
  179. data/lib/{shopify-cli → shopify_cli}/helpers/haikunator.rb +1 -1
  180. data/lib/shopify_cli/helpers.rb +5 -0
  181. data/lib/{shopify-cli → shopify_cli}/heroku.rb +38 -13
  182. data/lib/{shopify-cli → shopify_cli}/http_request.rb +1 -1
  183. data/lib/{shopify-cli → shopify_cli}/identity_auth/servlet.rb +1 -1
  184. data/lib/{shopify-cli → shopify_cli}/identity_auth.rb +24 -31
  185. data/lib/{shopify-cli → shopify_cli}/js_deps.rb +7 -7
  186. data/lib/{shopify-cli → shopify_cli}/js_system.rb +10 -10
  187. data/lib/{shopify-cli → shopify_cli}/lazy_delegator.rb +2 -2
  188. data/lib/{shopify-cli → shopify_cli}/messages/messages.rb +17 -1
  189. data/lib/{shopify-cli → shopify_cli}/method_object.rb +4 -4
  190. data/lib/{shopify-cli → shopify_cli}/options.rb +1 -1
  191. data/lib/{shopify-cli → shopify_cli}/packager.rb +8 -8
  192. data/lib/{shopify-cli → shopify_cli}/partners_api/organizations.rb +1 -1
  193. data/lib/{shopify-cli → shopify_cli}/partners_api.rb +16 -40
  194. data/lib/shopify_cli/php_deps.rb +102 -0
  195. data/lib/{shopify-cli → shopify_cli}/process_supervision.rb +23 -21
  196. data/lib/{shopify-cli → shopify_cli}/project.rb +15 -15
  197. data/lib/{shopify-cli → shopify_cli}/project_commands.rb +3 -3
  198. data/lib/{shopify-cli → shopify_cli}/project_type.rb +5 -5
  199. data/lib/{shopify-cli → shopify_cli}/resolve_constant.rb +5 -5
  200. data/lib/{shopify-cli → shopify_cli}/resources/env_file.rb +1 -1
  201. data/lib/shopify_cli/resources.rb +5 -0
  202. data/lib/{shopify-cli → shopify_cli}/result.rb +11 -11
  203. data/lib/{shopify-cli → shopify_cli}/shopifolk.rb +6 -6
  204. data/lib/{shopify-cli → shopify_cli}/sub_command.rb +1 -1
  205. data/lib/{shopify-cli → shopify_cli}/task.rb +1 -1
  206. data/lib/{shopify-cli → shopify_cli}/tasks/confirm_store.rb +3 -3
  207. data/lib/{shopify-cli → shopify_cli}/tasks/create_api_client.rb +4 -4
  208. data/lib/shopify_cli/tasks/ensure_authenticated.rb +13 -0
  209. data/lib/{shopify-cli → shopify_cli}/tasks/ensure_dev_store.rb +5 -5
  210. data/lib/{shopify-cli → shopify_cli}/tasks/ensure_env.rb +3 -3
  211. data/lib/{shopify-cli → shopify_cli}/tasks/ensure_loopback_url.rb +4 -4
  212. data/lib/{shopify-cli → shopify_cli}/tasks/ensure_project_type.rb +3 -3
  213. data/lib/{shopify-cli → shopify_cli}/tasks/select_org_and_shop.rb +8 -8
  214. data/lib/{shopify-cli → shopify_cli}/tasks/update_dashboard_urls.rb +6 -6
  215. data/lib/{shopify-cli → shopify_cli}/tasks.rb +10 -10
  216. data/lib/{shopify-cli → shopify_cli}/theme/dev_server/certificate_manager.rb +5 -5
  217. data/lib/{shopify-cli → shopify_cli}/theme/dev_server/header_hash.rb +5 -1
  218. data/lib/{shopify-cli → shopify_cli}/theme/dev_server/hot-reload.js +0 -0
  219. data/lib/{shopify-cli → shopify_cli}/theme/dev_server/hot_reload.rb +5 -6
  220. data/lib/{shopify-cli → shopify_cli}/theme/dev_server/local_assets.rb +1 -1
  221. data/lib/{shopify-cli → shopify_cli}/theme/dev_server/proxy.rb +15 -3
  222. data/lib/{shopify-cli → shopify_cli}/theme/dev_server/sse.rb +1 -1
  223. data/lib/{shopify-cli → shopify_cli}/theme/dev_server/watcher.rb +1 -1
  224. data/lib/{shopify-cli → shopify_cli}/theme/dev_server/web_server.rb +1 -1
  225. data/lib/{shopify-cli → shopify_cli}/theme/dev_server.rb +3 -3
  226. data/lib/shopify_cli/theme/development_theme.rb +83 -0
  227. data/lib/{shopify-cli → shopify_cli}/theme/file.rb +12 -4
  228. data/lib/{shopify-cli → shopify_cli}/theme/ignore_filter.rb +8 -1
  229. data/lib/{shopify-cli → shopify_cli}/theme/mime_type.rb +1 -1
  230. data/lib/{shopify-cli → shopify_cli}/theme/syncer.rb +7 -7
  231. data/lib/{shopify-cli → shopify_cli}/theme/theme.rb +4 -4
  232. data/lib/{shopify-cli → shopify_cli}/transform_data_structure.rb +4 -4
  233. data/lib/{shopify-cli → shopify_cli}/tunnel.rb +14 -14
  234. data/lib/shopify_cli/version.rb +3 -0
  235. data/lib/shopify_cli.rb +52 -49
  236. data/shopify-cli.gemspec +5 -5
  237. metadata +130 -95
  238. data/.github/workflows/build.yml +0 -28
  239. data/lib/shopify-cli/commands/logout.rb +0 -39
  240. data/lib/shopify-cli/commands/populate.rb +0 -23
  241. data/lib/shopify-cli/commands/store.rb +0 -15
  242. data/lib/shopify-cli/commands/version.rb +0 -15
  243. data/lib/shopify-cli/commands.rb +0 -34
  244. data/lib/shopify-cli/core.rb +0 -8
  245. data/lib/shopify-cli/helpers.rb +0 -5
  246. data/lib/shopify-cli/resources.rb +0 -5
  247. data/lib/shopify-cli/tasks/ensure_authenticated.rb +0 -13
  248. data/lib/shopify-cli/theme/development_theme.rb +0 -69
  249. data/lib/shopify-cli/version.rb +0 -3
@@ -9,7 +9,7 @@ module Script
9
9
  UUID_ENV_KEY = "UUID"
10
10
 
11
11
  property! :id, accepts: String
12
- property :env, accepts: ShopifyCli::Resources::EnvFile
12
+ property :env, accepts: ShopifyCLI::Resources::EnvFile
13
13
 
14
14
  property! :extension_point_type, accepts: String
15
15
  property! :script_name, accepts: String
@@ -20,7 +20,7 @@ module Script
20
20
  def initialize(*)
21
21
  super
22
22
 
23
- ShopifyCli::Core::Monorail.metadata = {
23
+ ShopifyCLI::Core::Monorail.metadata = {
24
24
  "script_name" => script_name,
25
25
  "extension_point_type" => extension_point_type,
26
26
  "language" => language,
@@ -0,0 +1,55 @@
1
+ module Script
2
+ module Layers
3
+ module Infrastructure
4
+ module ApiClients
5
+ class PartnersProxyApiClient
6
+ def initialize(ctx, api_key)
7
+ @ctx = ctx
8
+ @api_key = api_key
9
+ end
10
+
11
+ def query(query_name, variables: {})
12
+ proxy_response = ShimAPI.query(@ctx, query_name, api_key: @api_key, variables: variables.to_json)
13
+ raise_if_graphql_failed(proxy_response)
14
+
15
+ response = proxy_response["data"]["scriptServiceProxy"]
16
+ JSON.parse(response) if response
17
+ end
18
+
19
+ private
20
+
21
+ def raise_if_graphql_failed(response)
22
+ raise Errors::EmptyResponseError if response.nil?
23
+
24
+ return unless response.key?("errors")
25
+ case error_code(response["errors"])
26
+ when "forbidden"
27
+ raise Errors::ForbiddenError
28
+ when "forbidden_on_shop"
29
+ raise Errors::ShopAuthenticationError
30
+ when "app_not_installed_on_shop"
31
+ raise Errors::AppNotInstalledError
32
+ else
33
+ raise Errors::GraphqlError, response["errors"]
34
+ end
35
+ end
36
+
37
+ def error_code(errors)
38
+ errors.map do |e|
39
+ code = e.dig("extensions", "code")
40
+ return code if code
41
+ end
42
+ end
43
+
44
+ class ShimAPI < ShopifyCLI::PartnersAPI
45
+ def query(query_name, variables: {})
46
+ variables[:query] = load_query(query_name)
47
+ super("script_service_proxy", variables: variables)
48
+ end
49
+ end
50
+ private_constant(:ShimAPI)
51
+ end
52
+ end
53
+ end
54
+ end
55
+ end
@@ -0,0 +1,35 @@
1
+ module Script
2
+ module Layers
3
+ module Infrastructure
4
+ module ApiClients
5
+ class ScriptServiceApiClient
6
+ LOCAL_INSTANCE_URL = "https://script-service.myshopify.io"
7
+
8
+ def initialize(ctx, api_key)
9
+ instance_url = script_service_url
10
+ @api = ShopifyCLI::API.new(
11
+ ctx: ctx,
12
+ url: "#{instance_url}/graphql",
13
+ token: { "APP_KEY" => api_key }.compact.to_json,
14
+ auth_header: "X-Shopify-Authenticated-Tokens"
15
+ )
16
+ end
17
+
18
+ def query(query_name, variables: {})
19
+ @api.query(query_name, variables: variables)
20
+ end
21
+
22
+ private
23
+
24
+ def script_service_url
25
+ if ::ShopifyCLI::Environment.use_spin_partners_instance?
26
+ "https://script-service.#{::ShopifyCLI::Environment.spin_url}"
27
+ else
28
+ LOCAL_INSTANCE_URL
29
+ end
30
+ end
31
+ end
32
+ end
33
+ end
34
+ end
35
+ end
@@ -6,7 +6,7 @@ module Script
6
6
  class CommandRunner
7
7
  include SmartProperties
8
8
 
9
- property! :ctx, accepts: ShopifyCli::Context
9
+ property! :ctx, accepts: ShopifyCLI::Context
10
10
 
11
11
  def call(cmd)
12
12
  out, status = ctx.capture2e(cmd)
@@ -93,6 +93,8 @@ module Script
93
93
  super("WebAssembly binary not found")
94
94
  end
95
95
  end
96
+
97
+ class ScriptUploadError < ScriptProjectError; end
96
98
  end
97
99
  end
98
100
  end
@@ -6,7 +6,7 @@ module Script
6
6
  module Languages
7
7
  class AssemblyScriptProjectCreator
8
8
  include SmartProperties
9
- property! :ctx, accepts: ShopifyCli::Context
9
+ property! :ctx, accepts: ShopifyCLI::Context
10
10
  property! :extension_point, accepts: Domain::ExtensionPoint
11
11
  property! :script_name, accepts: String
12
12
  property! :path_to_project, accepts: String
@@ -40,7 +40,7 @@ module Script
40
40
  def extension_point_version
41
41
  return extension_point.sdks.assemblyscript.version if extension_point.sdks.assemblyscript.versioned?
42
42
 
43
- out = command_runner.call("npm show #{extension_point.sdks.assemblyscript.package} version --json")
43
+ out = command_runner.call("npm -s show #{extension_point.sdks.assemblyscript.package} version --json")
44
44
  "^#{JSON.parse(out)}"
45
45
  end
46
46
 
@@ -6,7 +6,7 @@ module Script
6
6
  module Languages
7
7
  class RustProjectCreator
8
8
  include SmartProperties
9
- property! :ctx, accepts: ShopifyCli::Context
9
+ property! :ctx, accepts: ShopifyCLI::Context
10
10
  property! :extension_point, accepts: Domain::ExtensionPoint
11
11
  property! :script_name, accepts: String
12
12
  property! :path_to_project, accepts: String
@@ -5,7 +5,7 @@ module Script
5
5
  module Infrastructure
6
6
  class PushPackageRepository
7
7
  include SmartProperties
8
- property! :ctx, accepts: ShopifyCli::Context
8
+ property! :ctx, accepts: ShopifyCLI::Context
9
9
 
10
10
  def create_push_package(script_project:, script_content:, compiled_type:, metadata:)
11
11
  build_file_path = file_path(script_project.id, compiled_type)
@@ -32,7 +32,6 @@ module Script
32
32
  uuid: script_project.uuid,
33
33
  extension_point_type: script_project.extension_point_type,
34
34
  script_content: script_content,
35
- compiled_type: compiled_type,
36
35
  metadata: metadata,
37
36
  script_json: script_project.script_json,
38
37
  )
@@ -5,7 +5,7 @@ module Script
5
5
  module Infrastructure
6
6
  class ScriptProjectRepository
7
7
  include SmartProperties
8
- property! :ctx, accepts: ShopifyCli::Context
8
+ property! :ctx, accepts: ShopifyCLI::Context
9
9
 
10
10
  SCRIPT_JSON_FILENAME = "script.json"
11
11
  MUTABLE_ENV_VALUES = %i(uuid)
@@ -13,7 +13,7 @@ module Script
13
13
  def create(script_name:, extension_point_type:, language:)
14
14
  validate_metadata!(extension_point_type, language)
15
15
 
16
- ShopifyCli::Project.write(
16
+ ShopifyCLI::Project.write(
17
17
  ctx,
18
18
  project_type: :script,
19
19
  organization_id: nil,
@@ -63,7 +63,7 @@ module Script
63
63
  end
64
64
 
65
65
  def create_env(api_key:, secret:, uuid:)
66
- ShopifyCli::Resources::EnvFile.new(
66
+ ShopifyCLI::Resources::EnvFile.new(
67
67
  api_key: api_key,
68
68
  secret: secret,
69
69
  extra: {
@@ -125,7 +125,7 @@ module Script
125
125
  end
126
126
 
127
127
  def project
128
- @project ||= ShopifyCli::Project.current(force_reload: true)
128
+ @project ||= ShopifyCLI::Project.current(force_reload: true)
129
129
  end
130
130
 
131
131
  def default_language
@@ -142,7 +142,7 @@ module Script
142
142
 
143
143
  class ScriptJsonRepository
144
144
  include SmartProperties
145
- property! :ctx, accepts: ShopifyCli::Context
145
+ property! :ctx, accepts: ShopifyCLI::Context
146
146
 
147
147
  def get
148
148
  current_script_json || raise(Domain::Errors::NoScriptJsonFile)
@@ -7,39 +7,37 @@ module Script
7
7
  module Layers
8
8
  module Infrastructure
9
9
  class ScriptService
10
- include SmartProperties
11
- property! :ctx, accepts: ShopifyCli::Context
10
+ def initialize(client:, api_key:)
11
+ @client = client
12
+ @api_key = api_key
13
+ end
12
14
 
13
- def push(
15
+ def set_app_script(
14
16
  uuid:,
15
17
  extension_point_type:,
16
- script_content:,
17
- compiled_type:,
18
- api_key: nil,
19
18
  force: false,
20
19
  metadata:,
21
- script_json:
20
+ script_json:,
21
+ module_upload_url:
22
22
  )
23
- query_name = "app_script_update_or_create"
23
+ query_name = "app_script_set"
24
24
  variables = {
25
25
  uuid: uuid,
26
26
  extensionPointName: extension_point_type.upcase,
27
27
  title: script_json.title,
28
28
  description: script_json.description,
29
- sourceCode: Base64.encode64(script_content),
30
- language: compiled_type,
31
29
  force: force,
32
30
  schemaMajorVersion: metadata.schema_major_version.to_s, # API expects string value
33
31
  schemaMinorVersion: metadata.schema_minor_version.to_s, # API expects string value
34
- useMsgpack: metadata.use_msgpack,
35
32
  scriptJsonVersion: script_json.version,
36
33
  configurationUi: script_json.configuration_ui,
37
34
  configurationDefinition: script_json.configuration&.to_json,
35
+ moduleUploadUrl: module_upload_url,
38
36
  }
39
- resp_hash = script_service_request(query_name: query_name, api_key: api_key, variables: variables)
40
- user_errors = resp_hash["data"]["appScriptUpdateOrCreate"]["userErrors"]
37
+ resp_hash = make_request(query_name: query_name, variables: variables)
38
+ user_errors = resp_hash["data"]["appScriptSet"]["userErrors"]
41
39
 
42
- return resp_hash["data"]["appScriptUpdateOrCreate"]["appScript"]["uuid"] if user_errors.empty?
40
+ return resp_hash["data"]["appScriptSet"]["appScript"]["uuid"] if user_errors.empty?
43
41
 
44
42
  if user_errors.any? { |e| e["tag"] == "already_exists_error" }
45
43
  raise Errors::ScriptRepushError, uuid
@@ -64,98 +62,31 @@ module Script
64
62
  end
65
63
  end
66
64
 
67
- def get_app_scripts(api_key:, extension_point_type:)
65
+ def get_app_scripts(extension_point_type:)
68
66
  query_name = "get_app_scripts"
69
- variables = { appKey: api_key, extensionPointName: extension_point_type.upcase }
70
- script_service_request(query_name: query_name, api_key: api_key, variables: variables)["data"]["appScripts"]
71
- end
72
-
73
- private
74
-
75
- class ScriptServiceAPI < ShopifyCli::API
76
- property(:api_key, accepts: String)
77
-
78
- LOCAL_INSTANCE_URL = "https://script-service.myshopify.io"
79
-
80
- def self.query(ctx, query_name, api_key: nil, variables: {})
81
- api_client(ctx, api_key).query(query_name, variables: variables)
82
- end
83
-
84
- def self.api_client(ctx, api_key)
85
- instance_url = spin_instance_url || LOCAL_INSTANCE_URL
86
- new(
87
- ctx: ctx,
88
- url: "#{instance_url}/graphql",
89
- token: "",
90
- api_key: api_key
91
- )
92
- end
93
-
94
- def self.spin_instance_url
95
- workspace = ENV["SPIN_WORKSPACE"]
96
- namespace = ENV["SPIN_NAMESPACE"]
97
- return if workspace.nil? || namespace.nil?
98
-
99
- "https://script-service.#{workspace}.#{namespace}.us.spin.dev"
100
- end
101
-
102
- def auth_headers(*)
103
- tokens = { "APP_KEY" => api_key }.compact.to_json
104
- { "X-Shopify-Authenticated-Tokens" => tokens }
105
- end
106
- end
107
- private_constant(:ScriptServiceAPI)
108
-
109
- class PartnersProxyAPI < ShopifyCli::PartnersAPI
110
- def query(query_name, variables: {})
111
- variables[:query] = load_query(query_name)
112
- super("script_service_proxy", variables: variables)
113
- end
67
+ variables = { appKey: @api_key, extensionPointName: extension_point_type.upcase }
68
+ response = make_request(query_name: query_name, variables: variables)
69
+ response["data"]["appScripts"]
114
70
  end
115
- private_constant(:PartnersProxyAPI)
116
71
 
117
- def script_service_request(query_name:, variables: nil, **options)
118
- resp = if bypass_partners_proxy
119
- ScriptServiceAPI.query(ctx, query_name, variables: variables, **options)
120
- else
121
- proxy_through_partners(query_name: query_name, variables: variables, **options)
122
- end
123
- raise_if_graphql_failed(resp)
124
- resp
125
- end
72
+ def generate_module_upload_url
73
+ query_name = "module_upload_url_generate"
74
+ variables = {}
75
+ response = make_request(query_name: query_name, variables: variables)
76
+ user_errors = response["data"]["moduleUploadUrlGenerate"]["userErrors"]
126
77
 
127
- def bypass_partners_proxy
128
- !ENV["BYPASS_PARTNERS_PROXY"].nil?
78
+ raise Errors::GraphqlError, user_errors if user_errors.any?
79
+ response["data"]["moduleUploadUrlGenerate"]["url"]
129
80
  end
130
81
 
131
- def proxy_through_partners(query_name:, variables: nil, **options)
132
- options[:variables] = variables.to_json if variables
133
- resp = PartnersProxyAPI.query(ctx, query_name, **options)
134
- raise_if_graphql_failed(resp)
135
- JSON.parse(resp["data"]["scriptServiceProxy"])
136
- end
82
+ private
137
83
 
138
- def raise_if_graphql_failed(response)
84
+ def make_request(query_name:, variables: {})
85
+ response = @client.query(query_name, variables: variables)
139
86
  raise Errors::EmptyResponseError if response.nil?
87
+ raise Errors::GraphqlError, response["errors"] if response.key?("errors")
140
88
 
141
- return unless response.key?("errors")
142
- case error_code(response["errors"])
143
- when "forbidden"
144
- raise Errors::ForbiddenError
145
- when "forbidden_on_shop"
146
- raise Errors::ShopAuthenticationError
147
- when "app_not_installed_on_shop"
148
- raise Errors::AppNotInstalledError
149
- else
150
- raise Errors::GraphqlError, response["errors"]
151
- end
152
- end
153
-
154
- def error_code(errors)
155
- errors.map do |e|
156
- code = e.dig("extensions", "code")
157
- return code if code
158
- end
89
+ response
159
90
  end
160
91
  end
161
92
  end
@@ -0,0 +1,27 @@
1
+ module Script
2
+ module Layers
3
+ module Infrastructure
4
+ class ScriptUploader
5
+ def initialize(script_service)
6
+ @script_service = script_service
7
+ end
8
+
9
+ def upload(script_content)
10
+ @script_service.generate_module_upload_url.tap do |url|
11
+ url = URI(url)
12
+
13
+ https = Net::HTTP.new(url.host, url.port)
14
+ https.use_ssl = true
15
+
16
+ request = Net::HTTP::Put.new(url)
17
+ request["Content-Type"] = "application/wasm"
18
+ request.body = script_content
19
+
20
+ response = https.request(request)
21
+ raise Errors::ScriptUploadError unless response.code == "200"
22
+ end
23
+ end
24
+ end
25
+ end
26
+ end
27
+ end
@@ -0,0 +1,20 @@
1
+ module Script
2
+ module Layers
3
+ module Infrastructure
4
+ class ServiceLocator
5
+ def self.api_client(ctx:, api_key:)
6
+ if ENV["BYPASS_PARTNERS_PROXY"]
7
+ ApiClients::ScriptServiceApiClient.new(ctx, api_key)
8
+ else
9
+ ApiClients::PartnersProxyApiClient.new(ctx, api_key)
10
+ end
11
+ end
12
+
13
+ def self.script_service(ctx:, api_key:)
14
+ client = api_client(ctx: ctx, api_key: api_key)
15
+ ScriptService.new(client: client, api_key: api_key)
16
+ end
17
+ end
18
+ end
19
+ end
20
+ end
@@ -141,6 +141,9 @@ module Script
141
141
  web_assembly_binary_not_found_suggestion: "No WebAssembly binary found." \
142
142
  "Check that your build npm script outputs the generated binary to the root of the directory." \
143
143
  "Generated binary should match the script name: <script_name>.wasm",
144
+
145
+ script_upload_cause: "Fail to upload script.",
146
+ script_upload_help: "Try again.",
144
147
  },
145
148
 
146
149
  create: {
@@ -2,7 +2,7 @@ require "shopify_cli"
2
2
 
3
3
  module Script
4
4
  module Tasks
5
- class EnsureEnv < ShopifyCli::Task
5
+ class EnsureEnv < ShopifyCLI::Task
6
6
  attr_accessor :ctx
7
7
 
8
8
  def call(ctx)
@@ -31,11 +31,11 @@ module Script
31
31
  def ask_org
32
32
  return stubbed_org if partner_proxy_bypass
33
33
 
34
- if ShopifyCli::Shopifolk.check && wants_to_run_against_shopify_org?
35
- ShopifyCli::Shopifolk.act_as_shopify_organization
34
+ if ShopifyCLI::Shopifolk.check && wants_to_run_against_shopify_org?
35
+ ShopifyCLI::Shopifolk.act_as_shopify_organization
36
36
  end
37
37
 
38
- orgs = ShopifyCli::PartnersAPI::Organizations.fetch_with_app(ctx)
38
+ orgs = ShopifyCLI::PartnersAPI::Organizations.fetch_with_app(ctx)
39
39
  if orgs.count == 1
40
40
  default = orgs.first
41
41
  ctx.puts(ctx.message("script.application.ensure_env.organization", default["businessName"], default["id"]))
@@ -69,7 +69,7 @@ module Script
69
69
  end
70
70
 
71
71
  def ask_app(apps)
72
- unless ShopifyCli::Shopifolk.acting_as_shopify_organization?
72
+ unless ShopifyCLI::Shopifolk.acting_as_shopify_organization?
73
73
  apps = apps.select { |app| app["appType"] == "custom" }
74
74
  end
75
75
 
@@ -89,8 +89,8 @@ module Script
89
89
  end
90
90
 
91
91
  def ask_script_uuid(app, extension_point_type)
92
- script_service = Layers::Infrastructure::ScriptService.new(ctx: ctx)
93
- scripts = script_service.get_app_scripts(api_key: app["apiKey"], extension_point_type: extension_point_type)
92
+ script_service = Layers::Infrastructure::ServiceLocator.script_service(ctx: ctx, api_key: app["apiKey"])
93
+ scripts = script_service.get_app_scripts(extension_point_type: extension_point_type)
94
94
 
95
95
  return nil unless scripts.count > 0 &&
96
96
  CLI::UI::Prompt.confirm(ctx.message("script.application.ensure_env.ask_connect_to_existing_script"))