Class: Edi::AmazonVc::OldSender
- Inherits:
-
BaseEdiService
- Object
- BaseService
- BaseEdiService
- Edi::AmazonVc::OldSender
- Defined in:
- app/services/edi/amazon_vc/old_sender.rb
Constant Summary
Constants included from Edi::AddressAbbreviator
Edi::AddressAbbreviator::MAX_LENGTH
Instance Attribute Summary
Attributes inherited from BaseEdiService
Instance Method Summary collapse
- #instantiate_transporter(transporter, transporter_profile = nil) ⇒ Object
-
#process(partner:, category:, transporter: :http_seller_api, transporter_profile: nil, data_type: 'json', remote_path: nil, edi_communication_logs: nil) ⇒ Object
What type of transporter?.
Methods inherited from BaseEdiService
#duplicate_po_already_notified?, #initialize, #mark_duplicate_po_as_notified, #report_order_creation_issues, #safe_process_edi_communication_log
Methods included from Edi::AddressAbbreviator
#abbreviate_street, #collect_street_originals, #record_address_abbreviation_notes
Methods inherited from BaseService
#initialize, #log_debug, #log_error, #log_info, #log_warning, #logger, #options, #tagged_logger
Constructor Details
This class inherits a constructor from Edi::BaseEdiService
Instance Method Details
#instantiate_transporter(transporter, transporter_profile = nil) ⇒ Object
30 31 32 33 34 35 36 37 |
# File 'app/services/edi/amazon_vc/old_sender.rb', line 30 def instantiate_transporter(transporter, transporter_profile = nil) case transporter when :http_seller_api Transport::HttpSellerApiConnection.new({ profile: transporter_profile }) else raise "Unknown transporter: #{transporter}" end end |
#process(partner:, category:, transporter: :http_seller_api, transporter_profile: nil, data_type: 'json', remote_path: nil, edi_communication_logs: nil) ⇒ Object
What type of transporter?
3 4 5 6 7 8 9 10 11 12 13 14 15 16 17 18 19 20 21 22 23 24 25 26 27 28 |
# File 'app/services/edi/amazon_vc/old_sender.rb', line 3 def process(partner:, category:, transporter: :http_seller_api, # What type of transporter? transporter_profile: nil, data_type: 'json', remote_path: nil, edi_communication_logs: nil) # Which category to send, e.g order_confirm transport = instantiate_transporter(transporter, transporter_profile) edi_communication_logs ||= EdiCommunicationLog.requiring_processing.where(partner: partner).where(category: category).order(:created_at) [edi_communication_logs].flatten.each do |ecl| logger.info "Sending #{category} data #{ecl.data} to using transporter: #{transporter} using profile #{transporter_profile}" res = transport.send_data(ecl.data, remote_path, 'POST') ecl.transmit_datetime = Time.current ecl.notes = "HTTP CODE: #{res[:http_result]&.code}, ATTEMPT NUMBER: #{res[:attempt_number_reached]}, HTTP BODY: #{res[:http_result]&.body}, Timestamp: #{Time.current.to_datetime.to_fs(:crm_default)}" logger.info "Result: HTTP CODE: #{res[:http_result]&.code}, HTTP BODY: #{res[:http_result]&.body}" if res[:success] && (data = res[:http_result]&.body.to_s).present? json_hash = JSON.parse(data).with_indifferent_access transaction_id = json_hash[:payload].dig('transactionId') # store it ecl.transaction_id = transaction_id ecl.transmit_datetime = Time.current ecl.start_process! else ecl.error end end edi_communication_logs end |