lib/isomorfeus/operation/handler/operation_handler.rb in isomorfeus-operation-1.0.0.zeta5 vs lib/isomorfeus/operation/handler/operation_handler.rb in isomorfeus-operation-1.0.0.zeta6

- old
+ new

@@ -2,25 +2,24 @@ module Isomorfeus module Operation module Handler class OperationHandler < LucidHandler::Base - on_request do |pub_sub_client, current_user, request, response| - result = { error: 'No such thing' } + on_request do |pub_sub_client, current_user, response_agent| # promise_send_path('Isomorfeus::Operation::Handler::OperationHandler', self.to_s, props_hash) - request.each_key do |operation_class_name| + response_agent.request.each_key do |operation_class_name| if Isomorfeus.valid_operation_class_name?(operation_class_name) operation_class = Isomorfeus.cached_operation_class(operation_class_name) if operation_class - props_json = request[operation_class_name] + props_json = response_agent.request[operation_class_name] begin props = Oj.load(props_json, mode: :strict) props.merge!({pub_sub_client: pub_sub_client, current_user: current_user}) if current_user.authorized?(operation_class, :promise_run, props) operation_promise = operation_class.promise_run(props) if operation_promise.realized? - result = { success: 'ok' , result: operation_promise.value } + response_agent.agent_result = { success: 'ok' , result: operation_promise.value } else start = Time.now timeout = false while !operation_promise.realized? if (Time.now - start) > 20 @@ -28,32 +27,31 @@ break end sleep 0.01 end if timeout - result = { error: 'Timeout' } + response_agent.error = { error: 'Timeout' } else - result = { success: 'ok' , result: operation_promise.value } + response_agent.agent_result = { success: 'ok' , result: operation_promise.value } end end else - result = { error: 'Access denied!' } + response_agent.error = { error: 'Access denied!' } end rescue Exception => e - result = if Isomorfeus.production? - { error: { operation_class_name => 'No such thing!' }} - else - { error: { operation_class_name => "Isomorfeus::Operation::Handler::OperationHandler: #{e.message}" }} - end + response_agent.error = if Isomorfeus.production? + { error: { operation_class_name => 'No such thing!' }} + else + { error: { operation_class_name => "Isomorfeus::Operation::Handler::OperationHandler: #{e.message}" }} + end end else - result = { error: { operation_class_name => 'No such thing!' }} + response_agent.error = { error: { operation_class_name => 'No such thing!' }} end else - result = { error: { operation_class_name => 'No such thing!' }} + response_agent.error = { error: { operation_class_name => 'No such thing!' }} end end - result end end end end end