Class: ActionSmser::DeliveryReport
- Inherits:
-
ActiveRecord::Base
- Object
- ActiveRecord::Base
- ActionSmser::DeliveryReport
- Defined in:
- app/models/action_smser/delivery_report.rb
Class Method Summary collapse
Instance Method Summary collapse
- #add_log(str) ⇒ Object
-
#re_delivarable_sms ⇒ Object
This updates re_delivered attribute for itself.
- #status=(stat, skip_log = false) ⇒ Object
-
#to_sms ⇒ Object
Copy this delivery_report information to a new sms object.
Class Method Details
.build_from_sms(sms, to, msg_id) ⇒ Object
7 8 9 10 11 12 13 14 15 16 17 18 |
# File 'app/models/action_smser/delivery_report.rb', line 7 def self.build_from_sms(sms, to, msg_id) @delivery_report = self.new [:from, :body, :sms_type, :re_delivery_of_delivery_report_id].each do |var| @delivery_report.send("#{var}=", sms.send(var)) end @delivery_report.to = to @delivery_report.msg_id = msg_id @delivery_report.status = "LOCAL_SENT" @delivery_report.gateway = sms.[:delivery_method].to_s @delivery_report end |
.create_from_sms(sms, to, sms_id) ⇒ Object
20 21 22 23 24 |
# File 'app/models/action_smser/delivery_report.rb', line 20 def self.create_from_sms(sms, to, sms_id) @delivery_report = self.build_from_sms(sms, to, sms_id) @delivery_report.save @delivery_report end |
Instance Method Details
#add_log(str) ⇒ Object
32 33 34 35 |
# File 'app/models/action_smser/delivery_report.rb', line 32 def add_log(str) self.log = "" if self.log.nil? self.log += "#{str}\n" end |
#re_delivarable_sms ⇒ Object
This updates re_delivered attribute for itself
47 48 49 50 51 52 53 54 55 56 |
# File 'app/models/action_smser/delivery_report.rb', line 47 def re_delivarable_sms() ActionSmser::Logger.info("Re_delivering: #{self.inspect}") self.update_attribute(:re_delivered, true) sms_new = self.to_sms sms_new.sms_type = "#{sms_new.sms_type}.re_delivery" sms_new.re_delivery_of_delivery_report_id = self.id sms_new end |
#status=(stat, skip_log = false) ⇒ Object
26 27 28 29 30 |
# File 'app/models/action_smser/delivery_report.rb', line 26 def status=(stat, skip_log = false) self[:status] = stat self.status_updated_at = Time.now add_log("#{Time.now.to_s(:db)}: #{stat}") unless skip_log end |
#to_sms ⇒ Object
Copy this delivery_report information to a new sms object
38 39 40 41 42 43 44 |
# File 'app/models/action_smser/delivery_report.rb', line 38 def to_sms sms_new = ActionSmser::Base.new() [:sms_type, :to, :from, :body, :sms_type].each do |var| sms_new.send("#{var}=", self.send(var)) end sms_new end |