Class: DocLog::Sync

Inherits:
Object
  • Object
show all
Defined in:
app/service/doc_log/sync.rb

Class Method Summary collapse

Class Method Details

.fetch(page_number, start_date) ⇒ Object



11
12
13
14
15
16
# File 'app/service/doc_log/sync.rb', line 11

def self.fetch(page_number, start_date)
  result = fetch_by_page(page_number, start_date)
  puts "Processing Page: #{page_number}"
  process_results(result)
  fetch(page_number + 1, start_date) if result.present?
end

.fetch_by_page(page_number, start_date) ⇒ Object



18
19
20
21
22
23
24
25
26
27
28
29
30
# File 'app/service/doc_log/sync.rb', line 18

def self.fetch_by_page(page_number, start_date)
  puts "Fetching Page: #{page_number}"
  DocRaptor.api_key DocLog::Engine.config.api_key
  begin
    dr = DocRaptor.list_doc_logs!(search: { start: start_date, end: DateTime.now },
                                page: page_number, per_page: 10)
  rescue DocRaptorException::DocumentListingFailure
    puts '*********************************************************'
    puts 'Error reading page'
    puts '*********************************************************'
  end
  dr.parsed_response['doc_logs']
end

.process_results(results) ⇒ Object



32
33
34
35
36
37
38
39
40
# File 'app/service/doc_log/sync.rb', line 32

def self.process_results(results)
  results.each do |row|
    raw_log = RawLog.where(doc_raptor_log_id: row['id']).first_or_create
    # rename some of the keys to ensure they don't clash
    row['doc_raptor_log_id'] = row['id']
    row['doc_raptor_created_at'] = row['created_at']
    raw_log.update_attributes(row.except('id', 'created_at'))
  end
end

.syncObject



4
5
6
7
# File 'app/service/doc_log/sync.rb', line 4

def self.sync
  puts "Last Updated: #{RawLog.last_updated}"
  fetch(1, RawLog.last_updated)
end