# frozen_string_literal: true require "base64" require "json" module Script module Layers module Infrastructure class ScriptService def initialize(client:, api_key:) @client = client @api_key = api_key end def set_app_script( uuid:, extension_point_type:, title:, description:, force: false, metadata:, script_config:, app_bridge:, module_upload_url:, library:, input_query: nil ) query_name = "app_script_set" variables = { uuid: uuid, extensionPointName: extension_point_type.upcase, title: title, description: description, force: force, schemaMajorVersion: metadata.schema_major_version.to_s, # API expects string value schemaMinorVersion: metadata.schema_minor_version.to_s, # API expects string value scriptConfigVersion: script_config.version, configurationUi: script_config.configuration_ui, configurationDefinition: script_config.configuration&.to_json, appBridge: { createPath: app_bridge.create_path, detailsPath: app_bridge.details_path, }, moduleUploadUrl: module_upload_url, inputQuery: input_query, } variables[:library] = { language: library[:language], version: library[:version], } if library resp_hash = make_request(query_name: query_name, variables: variables) user_errors = resp_hash["data"]["appScriptSet"]["userErrors"] return resp_hash["data"]["appScriptSet"]["appScript"]["uuid"] if user_errors.empty? if user_errors.any? { |e| e["tag"] == "already_exists_error" } raise Errors::ScriptRepushError, uuid elsif (errors = user_errors.select { |err| err["tag"] == "configuration_definition_error" }).any? raise Errors::ScriptConfigurationDefinitionError.new( messages: errors.map { |e| e["message"] }, filename: script_config.filename, ) elsif (e = user_errors.any? { |err| err["tag"] == "configuration_definition_syntax_error" }) raise Errors::ScriptConfigSyntaxError, script_config.filename elsif (e = user_errors.find { |err| err["tag"] == "configuration_definition_missing_keys_error" }) raise Errors::ScriptConfigMissingKeysError.new( missing_keys: e["message"], filename: script_config.filename, ) elsif (e = user_errors.find { |err| err["tag"] == "configuration_definition_invalid_value_error" }) raise Errors::ScriptConfigInvalidValueError.new( valid_input_modes: e["message"], filename: script_config.filename, ) elsif (e = user_errors.find do |err| err["tag"] == "configuration_definition_schema_field_missing_keys_error" end) raise Errors::ScriptConfigFieldsMissingKeysError.new( missing_keys: e["message"], filename: script_config.filename, ) elsif (e = user_errors.find do |err| err["tag"] == "configuration_definition_schema_field_invalid_value_error" end) raise Errors::ScriptConfigFieldsInvalidValueError.new( valid_types: e["message"], filename: script_config.filename, ) elsif (errors = user_errors.filter { |err| err["tag"] == "input_query_validation_error" }).any? raise Errors::InvalidInputQueryErrors, errors.map { |err| err["message"] } elsif user_errors.find { |err| %w(not_use_msgpack_error schema_version_argument_error).include?(err["tag"]) } raise Domain::Errors::MetadataValidationError else raise Errors::GraphqlError, user_errors end end def get_app_scripts(extension_point_type:) query_name = "get_app_scripts" variables = { appKey: @api_key, extensionPointName: extension_point_type.upcase } response = make_request(query_name: query_name, variables: variables) response["data"]["appScripts"] end def generate_module_upload_details query_name = "module_upload_url_generate" variables = {} response = make_request(query_name: query_name, variables: variables) user_errors = response["data"]["moduleUploadUrlGenerate"]["userErrors"] raise Errors::GraphqlError, user_errors if user_errors.any? data = response["data"]["moduleUploadUrlGenerate"]["details"] { url: data["url"], headers: data["headers"], max_size: data["humanizedMaxSize"] } end private def make_request(query_name:, variables: {}) response = @client.query(query_name, variables: variables) raise Errors::EmptyResponseError if response.nil? raise Errors::GraphqlError, response["errors"] if response.key?("errors") response end end end end end