# frozen_string_literal: true module Qismo # Qismo ruby client # class Client include Qismo::Api # @return [String, NilClass] DEFAULT_APP_ID = ENV["QISCUS_APP_ID"] # @return [String, NilClass] DEFAULT_SECRET_KEY = ENV["QISCUS_SECRET_KEY"] # @return [String] DEFAULT_URL = ENV["QISCUS_OMNICHANNEL_URL"] || "https://qismo.qiscus.com" # @return [Hash] DEFAULT_OPTIONS = { app_id: DEFAULT_APP_ID, secret_key: DEFAULT_SECRET_KEY, url: DEFAULT_URL, logger: nil, instrumentation: nil, timeout: nil, proxy: nil } attr_accessor(*DEFAULT_OPTIONS.keys) attr_reader :admin_email # Initialize client # # @param options [Hash] def initialize(options = {}) DEFAULT_OPTIONS.merge(options).each do |key, value| instance_variable_set("@#{key}", value) end @admin_email = "#{@app_id}_admin@qismo.com" end # Send http request with post method # # @param path [String] # @param body [Hash] # @return [Qismo::ObjectifiedHash] def post(path, body = {}) request(:post, path, json: body.compact) end # Send HTTP request with post method to upload file # # @param path [String] # @param body [Hash] # @return [Qismo::SingleObject] def post_upload(path, body = {}) request(:post, path, form: body.compact) end # Send HTTP request with get method # # @param path [String] # @param params [Hash] # @return [Qismo::ObjectifiedHash] def get(path, params = {}) request(:get, path, params: params.compact) end # Send HTTP request with delete method # # @param path [String] # @param params [Hash] # @return [Qismo::ObjectifiedHash] def delete(path, params = {}) request(:delete, path, params: params.compact) end # Send HTTP request # # @param method [Symbol, String] # @param path [String] # @param headers [Hash] # @param params [Hash] # @param json [Hash] # @return [Qismo::ObjectifiedHash] def request(method, path, options = {}) res = connection.request(method, @url + path, options.compact) if res.status.success? begin return JSON.parse(res.to_s, object_class: Qismo::ObjectifiedHash) rescue JSON::ParserError return res.to_s end end if res.status.server_error? raise InternalServerError.new("Qiscus Omnichannel server error", status_code: res.code, response_body: res.to_s) end if res.status.client_error? body = JSON.parse(res.to_s, object_class: Qismo::ObjectifiedHash) error = body.errors error = error.message if error.is_a?(Hash) error_klass_map = { 400 => BadRequestError, 401 => UnauthorizedError, 402 => PaymentRequiredError, 403 => ForbiddenError, 404 => NotFoundError, 429 => TooManyRequestError } error_klass = error_klass_map[res.code] || HTTPRequestError raise error_klass.new(error, status_code: res.code, response_body: res.to_s) end end # Http connection config # # @return [HTTP::Chainable] def connection http = HTTP unless @logger.nil? http = http.use(logging: @logger) end unless @instrumentation.nil? http = http.use(instrumentation: @instrumentation) end unless @timeout.nil? http = if @timeout.is_a?(Hash) http.timeout(**@timeout) else http.timeout(@timeout) end end unless @proxy.nil? http = http.via(*@proxy) end http.headers({ "Qiscus-App-Id": @app_id, "Qiscus-Secret-Key": @secret_key, "User-Agent": user_agent }) end # Http user agent config # # @return [Hash] def user_agent format = { lib_name: "Qismo Ruby", lib_version: Qismo::VERSION, lang: "ruby", lang_version: RUBY_VERSION, platform: RUBY_PLATFORM, engine: defined?(RUBY_ENGINE) ? RUBY_ENGINE : "" } "#{format[:lib_name]}/#{format[:lib_version]} (#{format[:platform]}; #{format[:lang]}; v#{format[:lang_version]}) app_id:#{@app_id}" end # Default broadcast name for using in send broadcast api # # @return [String] def default_broadcast_name Time.current.strftime("%d/%m/%Y, %H:%I %z") end end end