lib/bs2_api/entities/payment.rb in bs2_api-1.7.0 vs lib/bs2_api/entities/payment.rb in bs2_api-1.8.0
- old
+ new
@@ -1,25 +1,29 @@
# frozen_string_literal: true
module Bs2Api
module Entities
class Payment
- attr_accessor :payment_id, :end_to_end_id, :receiver, :payer, :status
+ attr_accessor :payment_id, :end_to_end_id, :receiver, :payer, :status, :error_message, :error_code
def initialize(args = {})
@payment_id = args.fetch(:payment_id, nil)
@end_to_end_id = args.fetch(:end_to_end_id, nil)
@receiver = args.fetch(:receiver, nil)
@payer = args.fetch(:payer, nil)
@status = args.fetch(:status, nil)
+ @error_code = args.fetch(:error_code, nil)
+ @error_message = args.fetch(:error_message, nil)
end
def to_hash
hash_data = {
- "pagamentoId": @payment_id,
- "endToEndId": @end_to_end_id,
- "status": @status
+ "pagamentoId": @payment_id,
+ "endToEndId": @end_to_end_id,
+ "status": @status,
+ "error_code": @error_code,
+ "error_message": @error_message
}
hash_data.merge!({ "recebedor": @receiver.to_hash } ) if @receiver.present?
hash_data.merge!({ "pagador": @payer.to_hash } ) if @payer.present?
ActiveSupport::HashWithIndifferentAccess.new(hash_data)
@@ -31,10 +35,12 @@
Bs2Api::Entities::Payment.new(
payment_id: hash["pagamentoId"] || hash["cobranca"]["id"],
end_to_end_id: hash["endToEndId"],
receiver: Bs2Api::Entities::Bank.from_response(hash["recebedor"]),
payer: Bs2Api::Entities::Bank.from_response(hash["pagador"]),
- status: hash["status"]
+ status: hash["status"],
+ error_code: hash.dig('erro', 'erroCodigo'),
+ error_message: hash.dig('erro', 'erroDescricao')
)
end
end
end
end