shopify-cli 1.7.1 → 1.11.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 (103) hide show
  1. checksums.yaml +4 -4
  2. data/.github/PULL_REQUEST_TEMPLATE.md +1 -0
  3. data/.github/workflows/build.yml +28 -0
  4. data/.rubocop_todo.yml +15 -2
  5. data/CHANGELOG.md +25 -0
  6. data/Gemfile.lock +15 -15
  7. data/README.md +2 -1
  8. data/dev.yml +3 -0
  9. data/lib/docgen/markdown.rb +1 -1
  10. data/lib/graphql/extension_create.graphql +17 -2
  11. data/lib/graphql/fetch_specifications.graphql +14 -0
  12. data/lib/project_types/extension/cli.rb +8 -10
  13. data/lib/project_types/extension/commands/create.rb +2 -2
  14. data/lib/project_types/extension/commands/extension_command.rb +10 -6
  15. data/lib/project_types/extension/commands/push.rb +2 -2
  16. data/lib/project_types/extension/commands/register.rb +6 -5
  17. data/lib/project_types/extension/commands/serve.rb +64 -22
  18. data/lib/project_types/extension/commands/tunnel.rb +3 -1
  19. data/lib/project_types/extension/extension_project.rb +20 -4
  20. data/lib/project_types/extension/extension_project_keys.rb +2 -1
  21. data/lib/project_types/extension/features/argo.rb +19 -44
  22. data/lib/project_types/extension/features/argo_runtime.rb +63 -0
  23. data/lib/project_types/extension/features/argo_serve.rb +79 -0
  24. data/lib/project_types/extension/features/argo_serve_options.rb +40 -0
  25. data/lib/project_types/extension/features/argo_setup.rb +1 -1
  26. data/lib/project_types/extension/forms/questions/ask_type.rb +16 -5
  27. data/lib/project_types/extension/messages/message_loading.rb +3 -1
  28. data/lib/project_types/extension/messages/messages.rb +9 -6
  29. data/lib/project_types/extension/models/npm_package.rb +14 -0
  30. data/lib/project_types/extension/models/registration.rb +1 -0
  31. data/lib/project_types/extension/models/specification.rb +7 -2
  32. data/lib/project_types/extension/models/specification_handlers/checkout_argo_extension.rb +18 -0
  33. data/lib/project_types/extension/models/specification_handlers/default.rb +35 -2
  34. data/lib/project_types/extension/models/specifications.rb +12 -1
  35. data/lib/project_types/extension/models/version.rb +1 -1
  36. data/lib/project_types/extension/tasks/choose_next_available_port.rb +36 -0
  37. data/lib/project_types/extension/tasks/configure_features.rb +5 -1
  38. data/lib/project_types/extension/tasks/converters/registration_converter.rb +2 -0
  39. data/lib/project_types/extension/tasks/fetch_specifications.rb +8 -28
  40. data/lib/project_types/extension/tasks/find_npm_packages.rb +106 -0
  41. data/lib/project_types/node/commands/generate.rb +0 -22
  42. data/lib/project_types/node/forms/create.rb +10 -1
  43. data/lib/project_types/node/messages/messages.rb +5 -4
  44. data/lib/project_types/rails/forms/create.rb +11 -1
  45. data/lib/project_types/rails/messages/messages.rb +5 -4
  46. data/lib/project_types/script/cli.rb +7 -8
  47. data/lib/project_types/script/commands/create.rb +0 -7
  48. data/lib/project_types/script/commands/push.rb +3 -3
  49. data/lib/project_types/script/config/extension_points.yml +17 -0
  50. data/lib/project_types/script/errors.rb +0 -19
  51. data/lib/project_types/script/forms/create.rb +3 -14
  52. data/lib/project_types/script/graphql/app_script_update_or_create.graphql +5 -5
  53. data/lib/project_types/script/graphql/get_app_scripts.graphql +6 -0
  54. data/lib/project_types/script/graphql/script_service_proxy.graphql +1 -2
  55. data/lib/project_types/script/layers/application/build_script.rb +1 -2
  56. data/lib/project_types/script/layers/application/create_script.rb +32 -49
  57. data/lib/project_types/script/layers/application/extension_points.rb +3 -2
  58. data/lib/project_types/script/layers/application/push_script.rb +5 -5
  59. data/lib/project_types/script/layers/domain/errors.rb +0 -2
  60. data/lib/project_types/script/layers/domain/extension_point.rb +60 -45
  61. data/lib/project_types/script/layers/domain/metadata.rb +18 -25
  62. data/lib/project_types/script/layers/domain/push_package.rb +4 -4
  63. data/lib/project_types/script/layers/domain/script_project.rb +54 -0
  64. data/lib/project_types/script/layers/infrastructure/assemblyscript_project_creator.rb +39 -14
  65. data/lib/project_types/script/layers/infrastructure/assemblyscript_task_runner.rb +14 -43
  66. data/lib/project_types/script/layers/infrastructure/command_runner.rb +19 -0
  67. data/lib/project_types/script/layers/infrastructure/errors.rb +40 -20
  68. data/lib/project_types/script/layers/infrastructure/push_package_repository.rb +12 -13
  69. data/lib/project_types/script/layers/infrastructure/rust_project_creator.rb +9 -10
  70. data/lib/project_types/script/layers/infrastructure/rust_task_runner.rb +6 -7
  71. data/lib/project_types/script/layers/infrastructure/script_project_repository.rb +172 -0
  72. data/lib/project_types/script/layers/infrastructure/script_service.rb +25 -76
  73. data/lib/project_types/script/messages/messages.rb +20 -53
  74. data/lib/project_types/script/tasks/ensure_env.rb +85 -0
  75. data/lib/project_types/script/ui/error_handler.rb +32 -41
  76. data/lib/shopify-cli/context.rb +28 -0
  77. data/lib/shopify-cli/js_system.rb +2 -2
  78. data/lib/shopify-cli/messages/messages.rb +50 -45
  79. data/lib/shopify-cli/method_object.rb +4 -4
  80. data/lib/shopify-cli/oauth.rb +9 -3
  81. data/lib/shopify-cli/packager.rb +1 -1
  82. data/lib/shopify-cli/partners_api/organizations.rb +3 -3
  83. data/lib/shopify-cli/resolve_constant.rb +1 -1
  84. data/lib/shopify-cli/resources/env_file.rb +1 -1
  85. data/lib/shopify-cli/tasks/ensure_dev_store.rb +1 -1
  86. data/lib/shopify-cli/tasks/select_org_and_shop.rb +6 -4
  87. data/lib/shopify-cli/transform_data_structure.rb +2 -2
  88. data/lib/shopify-cli/tunnel.rb +22 -1
  89. data/lib/shopify-cli/version.rb +1 -1
  90. data/lib/shopify_cli.rb +0 -1
  91. data/vendor/deps/smart_properties/REVISION +1 -1
  92. data/vendor/deps/smart_properties/lib/smart_properties/property.rb +7 -1
  93. data/vendor/deps/smart_properties/lib/smart_properties/version.rb +1 -1
  94. metadata +17 -12
  95. data/.travis.yml +0 -14
  96. data/lib/project_types/script/commands/disable.rb +0 -25
  97. data/lib/project_types/script/commands/enable.rb +0 -80
  98. data/lib/project_types/script/graphql/shop_script_delete.graphql +0 -14
  99. data/lib/project_types/script/graphql/shop_script_update_or_create.graphql +0 -28
  100. data/lib/project_types/script/layers/application/disable_script.rb +0 -21
  101. data/lib/project_types/script/layers/application/enable_script.rb +0 -23
  102. data/lib/project_types/script/layers/infrastructure/config_ui_repository.rb +0 -46
  103. data/lib/project_types/script/script_project.rb +0 -64
@@ -8,8 +8,8 @@ module Node
8
8
 
9
9
  def ask
10
10
  self.title ||= CLI::UI::Prompt.ask(ctx.message("node.forms.create.app_name"))
11
+ self.name = format_name
11
12
  self.type = ask_type
12
- self.name = self.title.downcase.split(" ").join("_")
13
13
  res = ShopifyCli::Tasks::SelectOrgAndShop.call(ctx, organization_id: organization_id, shop_domain: shop_domain)
14
14
  self.organization_id = res[:organization_id]
15
15
  self.shop_domain = res[:shop_domain]
@@ -17,6 +17,15 @@ module Node
17
17
 
18
18
  private
19
19
 
20
+ def format_name
21
+ name = title.downcase.split(" ").join("_")
22
+
23
+ if name.include?("shopify")
24
+ ctx.abort(ctx.message("node.forms.create.error.invalid_app_name"))
25
+ end
26
+ name
27
+ end
28
+
20
29
  def ask_type
21
30
  if type.nil?
22
31
  return CLI::UI::Prompt.ask(ctx.message("node.forms.create.app_type.select")) do |handler|
@@ -59,21 +59,21 @@ module Node
59
59
  installed: "Installed Heroku CLI",
60
60
  authenticating: "Authenticating with Heroku…",
61
61
  authenticated: "{{v}} Authenticated with Heroku",
62
- authenticated_with_account: "{{v}} Authenticated with Heroku as `%s`",
62
+ authenticated_with_account: "{{v}} Authenticated with Heroku as {{green:%s}}",
63
63
  deploying: "Deploying to Heroku…",
64
64
  deployed: "{{v}} Deployed to Heroku",
65
65
  git: {
66
66
  checking: "Checking git repo…",
67
67
  initialized: "Git repo initialized",
68
68
  what_branch: "What branch would you like to deploy?",
69
- branch_selected: "{{v}} Git branch `%s` selected for deploy",
69
+ branch_selected: "{{v}} Git branch {{green:%s}} selected for deploy",
70
70
  },
71
71
  app: {
72
72
  no_apps_found: "No existing Heroku app found. What would you like to do?",
73
73
  name: "What is your Heroku app’s name?",
74
74
  select: "Specify an existing Heroku app",
75
- selecting: "Selecting Heroku app `%s`…",
76
- selected: "{{v}} Heroku app `%s` selected",
75
+ selecting: "Selecting Heroku app %s",
76
+ selected: "{{v}} Heroku app {{green:%s}} selected",
77
77
  create: "Create a new Heroku app",
78
78
  creating: "Creating new Heroku app…",
79
79
  created: "{{v}} New Heroku app created",
@@ -202,6 +202,7 @@ module Node
202
202
  forms: {
203
203
  create: {
204
204
  error: {
205
+ invalid_app_name: "App name cannot contain 'Shopify'",
205
206
  invalid_app_type: "Invalid app type %s",
206
207
  },
207
208
  app_name: "App name",
@@ -20,8 +20,8 @@ module Rails
20
20
 
21
21
  def ask
22
22
  self.title ||= CLI::UI::Prompt.ask(ctx.message("rails.forms.create.app_name"))
23
+ self.name = format_name
23
24
  self.type = ask_type
24
- self.name = self.title.downcase.split(" ").join("_")
25
25
  res = ShopifyCli::Tasks::SelectOrgAndShop.call(ctx, organization_id: organization_id, shop_domain: shop_domain)
26
26
  self.organization_id = res[:organization_id]
27
27
  self.shop_domain = res[:shop_domain]
@@ -30,6 +30,16 @@ module Rails
30
30
 
31
31
  private
32
32
 
33
+ def format_name
34
+ name = title.downcase.split(" ").join("_")
35
+
36
+ if name.include?("shopify")
37
+ ctx.abort(ctx.message("rails.forms.create.error.invalid_app_name"))
38
+ end
39
+
40
+ name
41
+ end
42
+
33
43
  def ask_type
34
44
  if type.nil?
35
45
  return CLI::UI::Prompt.ask(ctx.message("rails.forms.create.app_type.select")) do |handler|
@@ -89,7 +89,7 @@ module Rails
89
89
  downloaded: "Downloaded Heroku CLI",
90
90
  installing: "Installing Heroku CLI...",
91
91
  installed: "Installed Heroku CLI",
92
- authenticated_with_account: "{{v}} Authenticated with Heroku as `%s`",
92
+ authenticated_with_account: "{{v}} Authenticated with Heroku as {{green:%s}}",
93
93
  authenticating: "Authenticating with Heroku...",
94
94
  authenticated: "{{v}} Authenticated with Heroku",
95
95
  deploying: "Deploying to Heroku...",
@@ -109,14 +109,14 @@ module Rails
109
109
  checking: "Checking git repo...",
110
110
  initialized: "Git repo initialized",
111
111
  what_branch: "What branch would you like to deploy?",
112
- branch_selected: "{{v}} Git branch `%s` selected for deploy",
112
+ branch_selected: "{{v}} Git branch {{green:%s}} selected for deploy",
113
113
  },
114
114
  app: {
115
115
  no_apps_found: "No existing Heroku app found. What would you like to do?",
116
116
  name: "What is your Heroku app’s name?",
117
117
  select: "Specify an existing Heroku app",
118
- selecting: "Selecting Heroku app `%s`...",
119
- selected: "{{v}} Heroku app `%s` selected",
118
+ selecting: "Selecting Heroku app %s...",
119
+ selected: "{{v}} Heroku app {{green:%s}} selected",
120
120
  create: "Create a new Heroku app",
121
121
  creating: "Creating new Heroku app...",
122
122
  created: "{{v}} New Heroku app created",
@@ -257,6 +257,7 @@ module Rails
257
257
  forms: {
258
258
  create: {
259
259
  error: {
260
+ invalid_app_name: "App name cannot contain 'Shopify'",
260
261
  invalid_app_type: "Invalid app type %s",
261
262
  invalid_db_type: "Invalid database type %s",
262
263
  },
@@ -7,8 +7,6 @@ module Script
7
7
  creator("Script::Commands::Create")
8
8
 
9
9
  register_command("Script::Commands::Push", "push")
10
- register_command("Script::Commands::Disable", "disable")
11
- register_command("Script::Commands::Enable", "enable")
12
10
 
13
11
  require Project.project_filepath("messages/messages")
14
12
  register_messages(Script::Messages::MESSAGES)
@@ -18,8 +16,6 @@ module Script
18
16
  module Commands
19
17
  autoload :Create, Project.project_filepath("commands/create")
20
18
  autoload :Push, Project.project_filepath("commands/push")
21
- autoload :Disable, Project.project_filepath("commands/disable")
22
- autoload :Enable, Project.project_filepath("commands/enable")
23
19
  end
24
20
 
25
21
  # define/autoload project specific Forms
@@ -28,13 +24,15 @@ module Script
28
24
  autoload :ScriptForm, Project.project_filepath("forms/script_form")
29
25
  end
30
26
 
27
+ module Tasks
28
+ autoload :EnsureEnv, Project.project_filepath("tasks/ensure_env")
29
+ end
30
+
31
31
  module Layers
32
32
  module Application
33
33
  autoload :BuildScript, Project.project_filepath("layers/application/build_script")
34
34
  autoload :CreateScript, Project.project_filepath("layers/application/create_script")
35
35
  autoload :PushScript, Project.project_filepath("layers/application/push_script")
36
- autoload :DisableScript, Project.project_filepath("layers/application/disable_script")
37
- autoload :EnableScript, Project.project_filepath("layers/application/enable_script")
38
36
  autoload :ExtensionPoints, Project.project_filepath("layers/application/extension_points")
39
37
  autoload :ProjectDependencies, Project.project_filepath("layers/application/project_dependencies")
40
38
  end
@@ -45,6 +43,7 @@ module Script
45
43
  autoload :PushPackage, Project.project_filepath("layers/domain/push_package")
46
44
  autoload :Metadata, Project.project_filepath("layers/domain/metadata")
47
45
  autoload :ExtensionPoint, Project.project_filepath("layers/domain/extension_point")
46
+ autoload :ScriptProject, Project.project_filepath("layers/domain/script_project")
48
47
  end
49
48
 
50
49
  module Infrastructure
@@ -55,14 +54,15 @@ module Script
55
54
  Project.project_filepath("layers/infrastructure/assemblyscript_project_creator")
56
55
  autoload :AssemblyScriptTaskRunner, Project.project_filepath("layers/infrastructure/assemblyscript_task_runner")
57
56
  autoload :AssemblyScriptTsConfig, Project.project_filepath("layers/infrastructure/assemblyscript_tsconfig")
57
+ autoload :CommandRunner, Project.project_filepath("layers/infrastructure/command_runner")
58
58
  autoload :RustProjectCreator,
59
59
  Project.project_filepath("layers/infrastructure/rust_project_creator.rb")
60
60
  autoload :RustTaskRunner, Project.project_filepath("layers/infrastructure/rust_task_runner")
61
61
 
62
- autoload :ConfigUiRepository, Project.project_filepath("layers/infrastructure/config_ui_repository")
63
62
  autoload :PushPackageRepository, Project.project_filepath("layers/infrastructure/push_package_repository")
64
63
  autoload :ExtensionPointRepository, Project.project_filepath("layers/infrastructure/extension_point_repository")
65
64
  autoload :ProjectCreator, Project.project_filepath("layers/infrastructure/project_creator")
65
+ autoload :ScriptProjectRepository, Project.project_filepath("layers/infrastructure/script_project_repository")
66
66
  autoload :ScriptService, Project.project_filepath("layers/infrastructure/script_service")
67
67
  autoload :TaskRunner, Project.project_filepath("layers/infrastructure/task_runner")
68
68
  end
@@ -74,7 +74,6 @@ module Script
74
74
  autoload :StrictSpinner, Project.project_filepath("ui/strict_spinner")
75
75
  end
76
76
 
77
- autoload :ScriptProject, Project.project_filepath("script_project")
78
77
  autoload :Errors, Project.project_filepath("errors")
79
78
 
80
79
  class ScriptProjectError < StandardError; end
@@ -5,7 +5,6 @@ module Script
5
5
  class Create < ShopifyCli::SubCommand
6
6
  options do |parser, flags|
7
7
  parser.on("--name=NAME") { |name| flags[:name] = name }
8
- parser.on("--description=DESCRIPTION") { |description| flags[:description] = description }
9
8
  parser.on("--extension_point=EP_NAME") { |ep_name| flags[:extension_point] = ep_name }
10
9
  parser.on("--extension-point=EP_NAME") { |ep_name| flags[:extension_point] = ep_name }
11
10
  parser.on("--language=LANGUAGE") { |language| flags[:language] = language }
@@ -13,8 +12,6 @@ module Script
13
12
  end
14
13
 
15
14
  def call(args, _name)
16
- cur_dir = @ctx.root
17
-
18
15
  form = Forms::Create.ask(@ctx, args, options.flags)
19
16
  return @ctx.puts(self.class.help) if form.nil?
20
17
 
@@ -27,14 +24,10 @@ module Script
27
24
  language: form.language,
28
25
  script_name: form.name,
29
26
  extension_point_type: form.extension_point,
30
- description: form.description,
31
27
  no_config_ui: options.flags.key?(:no_config_ui)
32
28
  )
33
29
  @ctx.puts(@ctx.message("script.create.change_directory_notice", project.script_name))
34
- rescue Script::Errors::ScriptProjectAlreadyExistsError => e
35
- UI::ErrorHandler.pretty_print_and_raise(e, failed_op: @ctx.message("script.create.error.operation_failed"))
36
30
  rescue StandardError => e
37
- ScriptProject.cleanup(ctx: @ctx, script_name: form.name, root_dir: cur_dir) if form
38
31
  UI::ErrorHandler.pretty_print_and_raise(e, failed_op: @ctx.message("script.create.error.operation_failed"))
39
32
  end
40
33
 
@@ -8,15 +8,15 @@ module Script
8
8
  end
9
9
 
10
10
  def call(_args, _name)
11
- ShopifyCli::Tasks::EnsureEnv.call(@ctx, required: [:api_key, :secret, :shop])
11
+ Tasks::EnsureEnv.call(@ctx)
12
12
 
13
- api_key = ScriptProject.current.api_key
13
+ api_key = Layers::Infrastructure::ScriptProjectRepository.new(ctx: @ctx).get.api_key
14
14
  return @ctx.puts(self.class.help) unless api_key
15
15
 
16
16
  Layers::Application::PushScript.call(ctx: @ctx, force: options.flags.key?(:force))
17
17
  @ctx.puts(@ctx.message("script.push.script_pushed", api_key: api_key))
18
18
  rescue StandardError => e
19
- msg = @ctx.message("script.push.error.operation_failed", api_key: ShopifyCli::Project.current.env.api_key)
19
+ msg = @ctx.message("script.push.error.operation_failed", api_key: api_key)
20
20
  UI::ErrorHandler.pretty_print_and_raise(e, failed_op: msg)
21
21
  end
22
22
 
@@ -5,11 +5,13 @@ discount:
5
5
  sdk-version: "^9.0.0"
6
6
  toolchain-version: "^5.0.0"
7
7
  unit_limit_per_order:
8
+ beta: true
8
9
  assemblyscript:
9
10
  package: "@shopify/extension-point-as-unit-limit-per-order"
10
11
  sdk-version: "^9.0.0"
11
12
  toolchain-version: "^5.0.0"
12
13
  payment_filter:
14
+ deprecated: true
13
15
  assemblyscript:
14
16
  package: "@shopify/extension-point-as-payment-filter"
15
17
  sdk-version: "^9.0.0"
@@ -18,12 +20,27 @@ payment_filter:
18
20
  beta: true
19
21
  package: "https://github.com/Shopify/scripts-apis-rs"
20
22
  shipping_filter:
23
+ deprecated: true
21
24
  assemblyscript:
22
25
  package: "@shopify/extension-point-as-shipping-filter"
23
26
  sdk-version: "^9.0.0"
24
27
  toolchain-version: "^5.0.0"
25
28
  tax_filter:
29
+ beta: true
26
30
  assemblyscript:
27
31
  package: "@shopify/extension-point-as-tax-filter"
28
32
  sdk-version: "^9.0.0"
29
33
  toolchain-version: "^5.0.0"
34
+ payment_methods:
35
+ domain: 'checkout'
36
+ assemblyscript:
37
+ package: "@shopify/scripts-checkout-apis"
38
+ toolchain-version: "^5.0.0"
39
+ sdk-version: "^9.0.0"
40
+ shipping_methods:
41
+ domain: 'checkout'
42
+ assemblyscript:
43
+ package: "@shopify/scripts-checkout-apis"
44
+ sdk-version: "^9.0.0"
45
+ toolchain-version: "^5.0.0"
46
+
@@ -2,7 +2,6 @@
2
2
 
3
3
  module Script
4
4
  module Errors
5
- class InvalidContextError < ScriptProjectError; end
6
5
  class InvalidScriptNameError < ScriptProjectError; end
7
6
 
8
7
  class NoExistingAppsError < ScriptProjectError; end
@@ -16,7 +15,6 @@ module Script
16
15
  end
17
16
  end
18
17
 
19
- class ScriptProjectAlreadyExistsError < ScriptProjectError; end
20
18
  class InvalidConfigProps < ScriptProjectError; end
21
19
 
22
20
  class InvalidConfigYAMLError < ScriptProjectError
@@ -26,22 +24,5 @@ module Script
26
24
  @config_file = config_file
27
25
  end
28
26
  end
29
-
30
- class InvalidLanguageError < ScriptProjectError
31
- attr_reader :language, :extension_point_type
32
- def initialize(language, extension_point_type)
33
- super()
34
- @language = language
35
- @extension_point_type = extension_point_type
36
- end
37
- end
38
-
39
- class DeprecatedEPError < ScriptProjectError
40
- attr_reader :ep
41
- def initialize(ep)
42
- super()
43
- @ep = ep
44
- end
45
- end
46
27
  end
47
28
  end
@@ -3,11 +3,10 @@
3
3
  module Script
4
4
  module Forms
5
5
  class Create < ShopifyCli::Form
6
- flag_arguments :extension_point, :name, :language, :description
6
+ flag_arguments :extension_point, :name, :language
7
7
 
8
8
  def ask
9
9
  self.name = valid_name
10
- self.description ||= ask_description
11
10
  self.extension_point ||= ask_extension_point
12
11
  self.language = ask_language
13
12
  end
@@ -17,7 +16,7 @@ module Script
17
16
  def ask_extension_point
18
17
  CLI::UI::Prompt.ask(
19
18
  @ctx.message("script.forms.create.select_extension_point"),
20
- options: Layers::Application::ExtensionPoints.non_deprecated_types
19
+ options: Layers::Application::ExtensionPoints.available_types
21
20
  )
22
21
  end
23
22
 
@@ -25,10 +24,6 @@ module Script
25
24
  CLI::UI::Prompt.ask(@ctx.message("script.forms.create.script_name"))
26
25
  end
27
26
 
28
- def ask_description
29
- CLI::UI::Prompt.ask(@ctx.message("script.forms.create.description"))
30
- end
31
-
32
27
  def valid_name
33
28
  n = (name || ask_name).downcase.gsub(" ", "_")
34
29
  return n if n.match?(/^[0-9A-Za-z_-]*$/)
@@ -36,13 +31,7 @@ module Script
36
31
  end
37
32
 
38
33
  def ask_language
39
- if language
40
- if Layers::Application::ExtensionPoints.supported_language?(type: extension_point, language: language)
41
- return language.downcase
42
- else
43
- raise Errors::InvalidLanguageError.new(language, extension_point)
44
- end
45
- end
34
+ return language.downcase if language
46
35
 
47
36
  all_languages = Layers::Application::ExtensionPoints.languages(type: extension_point)
48
37
  return all_languages.first if all_languages.count == 1
@@ -1,26 +1,26 @@
1
1
  mutation AppScriptUpdateOrCreate(
2
2
  $extensionPointName: ExtensionPointName!,
3
3
  $title: String,
4
- $description: String,
5
4
  $configUi: String,
6
5
  $sourceCode: String,
7
6
  $language: String,
8
7
  $force: Boolean,
9
8
  $schemaMajorVersion: String,
10
9
  $schemaMinorVersion: String,
11
- $useMsgpack: Boolean
10
+ $useMsgpack: Boolean,
11
+ $uuid: String
12
12
  ) {
13
13
  appScriptUpdateOrCreate(
14
14
  extensionPointName: $extensionPointName
15
15
  title: $title
16
- description: $description
17
16
  configUi: $configUi
18
17
  sourceCode: $sourceCode
19
18
  language: $language
20
19
  force: $force
21
20
  schemaMajorVersion: $schemaMajorVersion
22
21
  schemaMinorVersion: $schemaMinorVersion
23
- useMsgpack: $useMsgpack
22
+ useMsgpack: $useMsgpack,
23
+ uuid: $uuid
24
24
  ) {
25
25
  userErrors {
26
26
  field
@@ -28,11 +28,11 @@ mutation AppScriptUpdateOrCreate(
28
28
  tag
29
29
  }
30
30
  appScript {
31
+ uuid
31
32
  appKey
32
33
  configSchema
33
34
  extensionPointName
34
35
  title
35
- description
36
36
  }
37
37
  }
38
38
  }
@@ -0,0 +1,6 @@
1
+ query GetAppScripts($appKey: String!, $extensionPointName: ExtensionPointName!) {
2
+ appScripts(appKeys: [$appKey], extensionPointName: $extensionPointName) {
3
+ uuid
4
+ title
5
+ }
6
+ }
@@ -1,7 +1,6 @@
1
- query ProxyRequest($api_key: String, $shop_domain: String, $query: String!, $variables: String) {
1
+ query ProxyRequest($api_key: String, $query: String!, $variables: String) {
2
2
  scriptServiceProxy(
3
3
  apiKey: $api_key
4
- shopDomain: $shop_domain
5
4
  query: $query
6
5
  variables: $variables
7
6
  )
@@ -5,7 +5,7 @@ module Script
5
5
  module Application
6
6
  class BuildScript
7
7
  class << self
8
- def call(ctx:, task_runner:, script_project:, config_ui:)
8
+ def call(ctx:, task_runner:, script_project:)
9
9
  CLI::UI::Frame.open(ctx.message("script.application.building")) do
10
10
  begin
11
11
  UI::StrictSpinner.spin(ctx.message("script.application.building_script")) do |spinner|
@@ -14,7 +14,6 @@ module Script
14
14
  script_content: task_runner.build,
15
15
  compiled_type: task_runner.compiled_type,
16
16
  metadata: task_runner.metadata,
17
- config_ui: config_ui,
18
17
  )
19
18
  spinner.update_title(ctx.message("script.application.built"))
20
19
  end