Class: MastercardMerchantCheckout::Postback
- Inherits:
-
Object
- Object
- MastercardMerchantCheckout::Postback
- Includes:
- ROXML
- Defined in:
- lib/mastercard_merchant_checkout/models/postback.rb
Overview
This class contains different methods to send transaction details to Masterpass using PostbackApi.
Instance Attribute Summary collapse
-
#amount ⇒ Float
The transaction amount as an integer (10050 for $100.50).
-
#currency ⇒ String
The ISO-4217 code for currency of the transaction.
-
#payment_code ⇒ String
The six-digit approval code returned by payment API.
-
#payment_date ⇒ DateTime
The date of purchase.
-
#payment_successful ⇒ BOOLEAN
The payment status indicator.
-
#pre_checkout_transaction_id ⇒ String
The preCheckoutTransactionId from the ExpressCheckout response.
-
#transaction_id ⇒ String
The transaction identifiers.
Class Method Summary collapse
-
.attribute_map ⇒ Object
Attribute mapping from ruby-style variable name to JSON key.
Instance Method Summary collapse
-
#==(o) ⇒ Object
Check equality by comparing each attribute.
- #_deserialize(type, value) ⇒ Object
-
#_to_hash(value) ⇒ Object
Method to output non-array value in the form of hash For object, use to_hash.
-
#build_from_hash(attributes) ⇒ Object
build the object from hash.
- #eql?(o) ⇒ Boolean
-
#hash ⇒ Object
Calculate hash code according to all attributes.
-
#initialize(attributes = {}) ⇒ Postback
constructor
A new instance of Postback.
-
#to_body ⇒ Object
to_body is an alias to to_body (backward compatibility)).
-
#to_hash(include_root = false) ⇒ Object
return the object in the form of hash.
- #to_s ⇒ Object
Constructor Details
#initialize(attributes = {}) ⇒ Postback
Returns a new instance of Postback.
55 56 57 58 59 60 61 62 63 64 65 66 67 68 69 70 71 72 73 74 75 76 77 78 79 80 81 82 83 84 85 86 87 88 89 90 |
# File 'lib/mastercard_merchant_checkout/models/postback.rb', line 55 def initialize(attributes = {}) return unless attributes.is_a?(Hash) # convert string to symbol for hash key attributes = attributes.inject({}){|memo,(k,v)| memo[k.to_sym] = v; memo} if attributes.has_key?(:transaction_id) self.transaction_id = attributes[:transaction_id] end if attributes.has_key?(:currency) self.currency = attributes[:currency] end if attributes.has_key?(:amount) self.amount = attributes[:amount] end if attributes.has_key?(:payment_successful) self.payment_successful = attributes[:payment_successful] end if attributes.has_key?(:payment_code) self.payment_code = attributes[:payment_code] end if attributes.has_key?(:payment_date) self.payment_date = attributes[:payment_date] end if attributes.has_key?(:pre_checkout_transaction_id) self.pre_checkout_transaction_id = attributes[:pre_checkout_transaction_id] end end |
Instance Attribute Details
#amount ⇒ Float
Returns the transaction amount as an integer (10050 for $100.50).
22 |
# File 'lib/mastercard_merchant_checkout/models/postback.rb', line 22 xml_accessor :amount, :from =>"amount" |
#currency ⇒ String
Returns the ISO-4217 code for currency of the transaction.
18 |
# File 'lib/mastercard_merchant_checkout/models/postback.rb', line 18 xml_accessor :currency, :from =>"currency" |
#payment_code ⇒ String
Returns the six-digit approval code returned by payment API.
30 |
# File 'lib/mastercard_merchant_checkout/models/postback.rb', line 30 xml_accessor :payment_code, :from =>"paymentCode" |
#payment_date ⇒ DateTime
Returns the date of purchase.
34 |
# File 'lib/mastercard_merchant_checkout/models/postback.rb', line 34 xml_accessor :payment_date, :from =>"paymentDate" |
#payment_successful ⇒ BOOLEAN
Returns the payment status indicator. It is set to true if payment successful with payment processor else false.
26 |
# File 'lib/mastercard_merchant_checkout/models/postback.rb', line 26 xml_accessor :payment_successful, :from =>"paymentSuccessful" |
#pre_checkout_transaction_id ⇒ String
Returns the preCheckoutTransactionId from the ExpressCheckout response.
38 |
# File 'lib/mastercard_merchant_checkout/models/postback.rb', line 38 xml_accessor :pre_checkout_transaction_id, :from =>"preCheckoutTransactionId" |
#transaction_id ⇒ String
Returns the transaction identifiers. Identifies the transaction for which to return the consumer’s payment data. This is the oauth_verifier value sent by Masterpass in callback URL after the Masterpass user interface is closed.
14 |
# File 'lib/mastercard_merchant_checkout/models/postback.rb', line 14 xml_accessor :transaction_id, :from =>"transactionId" |
Class Method Details
.attribute_map ⇒ Object
Attribute mapping from ruby-style variable name to JSON key.
42 43 44 45 46 47 48 49 50 51 52 53 |
# File 'lib/mastercard_merchant_checkout/models/postback.rb', line 42 def self.attribute_map { :transaction_id => :transactionId , :currency => :currency , :amount => :amount , :payment_successful => :paymentSuccessful , :payment_code => :paymentCode , :payment_date => :paymentDate , :pre_checkout_transaction_id => :preCheckoutTransactionId } end |
Instance Method Details
#==(o) ⇒ Object
Check equality by comparing each attribute.
96 97 98 99 100 101 102 103 104 105 106 |
# File 'lib/mastercard_merchant_checkout/models/postback.rb', line 96 def ==(o) return true if self.equal?(o) self.class == o.class && transaction_id == o.transaction_id && currency == o.currency && amount == o.amount && payment_successful == o.payment_successful && payment_code == o.payment_code && payment_date == o.payment_date && pre_checkout_transaction_id == o.pre_checkout_transaction_id end |
#_deserialize(type, value) ⇒ Object
138 139 140 141 142 143 144 145 146 147 148 149 150 151 152 153 154 155 156 157 158 159 160 161 162 163 164 165 166 167 168 169 170 171 |
# File 'lib/mastercard_merchant_checkout/models/postback.rb', line 138 def _deserialize(type, value) case type.to_sym when :DateTime DateTime.parse(value) when :Date Date.parse(value) when :String value.to_s when :Integer value.to_i when :Float value.to_f when :BOOLEAN if value.to_s =~ /\A(true|t|yes|y|1)\z/i true else false end when /\AArray<(?<inner_type>.+)>\z/ inner_type = Regexp.last_match[:inner_type] value.map { |v| _deserialize(inner_type, v) } when /\AHash<(?<k_type>.+), (?<v_type>.+)>\z/ k_type = Regexp.last_match[:k_type] v_type = Regexp.last_match[:v_type] {}.tap do |hash| value.each do |k, v| hash[_deserialize(k_type, k)] = _deserialize(v_type, v) end end else # model _model = MastercardMerchantCheckout.const_get(type).new _model.build_from_hash(value) end end |
#_to_hash(value) ⇒ Object
Method to output non-array value in the form of hash For object, use to_hash. Otherwise, just return the value
197 198 199 200 201 202 203 204 205 206 207 208 209 |
# File 'lib/mastercard_merchant_checkout/models/postback.rb', line 197 def _to_hash(value) if value.is_a?(Array) value.compact.map{ |v| _to_hash(v) } elsif value.is_a?(Hash) {}.tap do |hash| value.each { |k, v| hash[k] = _to_hash(v) } end elsif value.respond_to? :to_hash value.to_hash else value end end |
#build_from_hash(attributes) ⇒ Object
build the object from hash
119 120 121 122 123 124 125 126 127 128 129 130 131 132 133 134 135 136 |
# File 'lib/mastercard_merchant_checkout/models/postback.rb', line 119 def build_from_hash(attributes) return nil unless attributes.is_a?(Hash) self.class.datatype_map.each_pair do |key, type| if type =~ /^Array<(.*)>/i if attributes[self.class.attribute_map[key]].is_a?(Array) self.send("#{key}=", attributes[self.class.attribute_map[key]].map{ |v| _deserialize($1, v) } ) else #TODO show warning in debug mode end elsif !attributes[self.class.attribute_map[key]].nil? self.send("#{key}=", _deserialize(type, attributes[self.class.attribute_map[key]])) else # data not found in attributes(hash), not an issue as the data can be optional end end self end |
#eql?(o) ⇒ Boolean
109 110 111 |
# File 'lib/mastercard_merchant_checkout/models/postback.rb', line 109 def eql?(o) self == o end |
#hash ⇒ Object
Calculate hash code according to all attributes.
114 115 116 |
# File 'lib/mastercard_merchant_checkout/models/postback.rb', line 114 def hash [transaction_id, currency, amount, payment_successful, payment_code, payment_date, pre_checkout_transaction_id].hash end |
#to_body ⇒ Object
to_body is an alias to to_body (backward compatibility))
178 179 180 |
# File 'lib/mastercard_merchant_checkout/models/postback.rb', line 178 def to_body to_hash end |
#to_hash(include_root = false) ⇒ Object
return the object in the form of hash
183 184 185 186 187 188 189 190 191 192 193 |
# File 'lib/mastercard_merchant_checkout/models/postback.rb', line 183 def to_hash(include_root = false) attributes_hash = {} hash = {} self.class.attribute_map.each_pair do |attr, param| value = self.send(attr) next if value.nil? hash[param] = _to_hash(value) end attributes_hash = include_root ? { "Postback" => hash } : hash return attributes_hash end |
#to_s ⇒ Object
173 174 175 |
# File 'lib/mastercard_merchant_checkout/models/postback.rb', line 173 def to_s to_hash.to_s end |