module Substation # Base class for action responses # # The following code illustrates context and serves as setup for all # instance method doc examples # # module App # class Environment # def initialize(storage, logger) # @storage, @logger = storage, logger # end # end # # class SuccessfulAction # def self.call(request) # data = perform_work # request.success(data) # end # end # # class FailingAction # def self.call(request) # error = perform_work # request.error(error) # end # end # end # # storage = SomeStorageAbstraction.new # env = App::Environment.new(storage, Logger.new($stdout)) # dispatcher = Substation::Dispatcher.coerce({ # :successful_action => { :action => App::SuccessfulAction }, # :failing_action => { :action => App::FailingAction } # }, env) # # @abstract class Response include AbstractType include Equalizer.new(:request, :output) include Adamantium::Flat # The request that lead to this response # # @example # # response = dispatcher.call(:successful_action, :some_input) # response.request # => request passed to action named :successful_action # # @return [Request] # # @api public attr_reader :request # The application environment used within an action # # @example # # response = dispatcher.call(:successful_action, :some_input) # response.env # => env passed to Substation::Dispatcher.coerce(config, env) # # @return [Object] # # @api public attr_reader :env # The request model instance passed into an action # # @example # # response = dispatcher.call(:successful_action, :some_input) # response.input # => :some_input # # @see Request#input # # @return [Object] # # @api public attr_reader :input # The data wrapped inside an action {Response} # # @example # # response = dispatcher.call(:successful_action, :some_input) # response.output # => data passed to request.success(data) # # @return [Object] # # @api public attr_reader :output # Initialize a new instance # # @param [Request] request # the request passed to the action that returned this response # # @param [Object] output # the data returned from the action that returned this response # # @return [undefined] # # @api private def initialize(request, output) @request = request @env = @request.env @input = @request.input @output = output end # Indicates wether this is a successful response or not # # @abstract # # @see Success#success? # @see Failure#success? # # @example # # response = dispatcher.call(:successful_action, :some_input) # response.success? # => true # # @return [Boolean] # true if successful, false otherwise # # @api public abstract_method :success? # An errorneous {Response} class Failure < self # Tests wether this response was successful # # @example # # response = dispatcher.call(:failing_action, :some_input) # response.success? # => false # # @return [false] # # @api public def success? false end end # A successful {Response} class Success < self # Tests wether this response was successful # # @example # # response = dispatcher.call(:successful_action, :some_input) # response.success? # => true # # @return [true] # # @api public def success? true end end end end