# encoding: utf-8 module Punchblock module Component class Record < ComponentNode register :record, :record ## # Creates an Rayo Record command # # @param [Hash] options # @option options [String] :format to use for recording # @option options [Integer] :initial_timeout Controls how long the recognizer should wait after the end of the prompt for the caller to speak before sending a Recorder event. # @option options [Integer] :final_timeout Controls the length of a period of silence after callers have spoken to conclude they finished. # @option options [Integer] :max_duration Indicates the maximum duration for the recording. # @option options [true, false] :start_beep Indicates whether subsequent record will be preceded with a beep. # @option options [true, false] :start_paused Whether subsequent record will start in PAUSE mode. # # @return [Command::Record] a Rayo "record" command # # @example # record :text => 'Hello brown cow.' # # returns: # Hello brown cow. # def self.new(options = {}) super().tap do |new_node| options.each_pair { |k,v| new_node.send :"#{k}=", v } end end ## # @return [Integer] Controls the length of a period of silence after callers have spoken to conclude they finished. # def final_timeout read_attr :'final-timeout', :to_i end ## # @param [Integer] timeout Controls the length of a period of silence after callers have spoken to conclude they finished. # def final_timeout=(timeout) write_attr :'final-timeout', timeout, :to_i end ## # @return [String] the codec to use for recording # def format read_attr :format end ## # @param [String] codec to use for recording # def format=(format) write_attr :format, format end ## # @return [Integer] Controls how long the recognizer should wait after the end of the prompt for the caller to speak before sending a Recorder event. # def initial_timeout read_attr :'initial-timeout', :to_i end ## # @param [Integer] timeout Controls how long the recognizer should wait after the end of the prompt for the caller to speak before sending a Recorder event. # def initial_timeout=(timeout) write_attr :'initial-timeout', timeout, :to_i end ## # @return [Integer] Indicates the maximum duration for the recording. # def max_duration read_attr :'max-duration', :to_i end ## # @param [Integer] other Indicates the maximum duration for the recording. # def max_duration=(other) write_attr :'max-duration', other, :to_i end ## # @return [true, false] Indicates whether subsequent record will be preceded with a beep. # def start_beep read_attr(:'start-beep') == 'true' end ## # @param [true, false] sb Indicates whether subsequent record will be preceded with a beep. # def start_beep=(sb) write_attr :'start-beep', sb end ## # @return [true, false] Whether subsequent record will start in PAUSE mode. # def start_paused read_attr(:'start-paused') == 'true' end ## # @param [true, false] other Whether subsequent record will start in PAUSE mode. # def start_paused=(other) write_attr :'start-paused', other end def inspect_attributes # :nodoc: [:final_timeout, :format, :initial_timeout, :max_duration, :start_beep, :start_paused] + super end state_machine :state do event :paused do transition :executing => :paused end event :resumed do transition :paused => :executing end end # Pauses a running Record # # @return [Command::Record::Pause] an Rayo pause message for the current Record # # @example # record_obj.pause_action.to_xml # # returns: # def pause_action Pause.new :component_id => component_id, :target_call_id => target_call_id end ## # Sends an Rayo pause message for the current Record # def pause! raise InvalidActionError, "Cannot pause a Record that is not executing" unless executing? pause_action.tap do |action| result = write_action action paused! if result end end ## # Create an Rayo resume message for the current Record # # @return [Command::Record::Resume] an Rayo resume message # # @example # record_obj.resume_action.to_xml # # returns: # def resume_action Resume.new :component_id => component_id, :target_call_id => target_call_id end ## # Sends an Rayo resume message for the current Record # def resume! raise InvalidActionError, "Cannot resume a Record that is not paused." unless paused? resume_action.tap do |action| result = write_action action resumed! if result end end ## # Directly returns the recording for the component # @return [Punchblock::Component::Record::Recording] The recording object # def recording complete_event.recording end ## # Directly returns the recording URI for the component # @return [String] The recording URI # def recording_uri recording.uri end class Pause < CommandNode # :nodoc: register :pause, :record end class Resume < CommandNode # :nodoc: register :resume, :record end class Recording < Event register :recording, :record_complete def uri read_attr :uri end def uri=(other) write_attr :uri, other end def duration read_attr :duration, :to_i end def size read_attr :size, :to_i end def inspect_attributes # :nodoc: [:uri, :duration, :size] + super end end class Complete class Success < Event::Complete::Reason register :success, :record_complete end end end # Record end # Command end # Punchblock