Class: Hutils::Ltap::PaperTrailDrainer
- Inherits:
-
Object
- Object
- Hutils::Ltap::PaperTrailDrainer
- Defined in:
- lib/hutils/ltap/paper_trail_drainer.rb
Defined Under Namespace
Classes: RateLimited
Constant Summary collapse
- PAPER_TRAIL_URL =
"https://papertrailapp.com"
Instance Method Summary collapse
- #cancel_job ⇒ Object
-
#initialize(earliest:, key:, timeout:, query:, timestamps:, url:, verbose:) ⇒ PaperTrailDrainer
constructor
A new instance of PaperTrailDrainer.
- #run ⇒ Object
Constructor Details
#initialize(earliest:, key:, timeout:, query:, timestamps:, url:, verbose:) ⇒ PaperTrailDrainer
Returns a new instance of PaperTrailDrainer.
7 8 9 10 11 12 13 14 15 16 17 |
# File 'lib/hutils/ltap/paper_trail_drainer.rb', line 7 def initialize(earliest:, key:, timeout:, query:, timestamps:, url:, verbose:) @api = Excon.new(PAPER_TRAIL_URL, headers: { "X-Papertrail-Token" => key }) @earliest = earliest @query = query @timeout = timeout @timestamps = @verbose = verbose end |
Instance Method Details
#cancel_job ⇒ Object
54 55 56 |
# File 'lib/hutils/ltap/paper_trail_drainer.rb', line 54 def cancel_job debug("cancelled [noop]") end |
#run ⇒ Object
19 20 21 22 23 24 25 26 27 28 29 30 31 32 33 34 35 36 37 38 39 40 41 42 43 44 45 46 47 48 49 50 51 52 |
# File 'lib/hutils/ltap/paper_trail_drainer.rb', line 19 def run = [] min_id = nil start = Time.now loop do , reached_beginning, min_id, min_time = fetch_page(min_id) += # break if PaperTrail has indicated that we've reached the beginning of # our results if reached_beginning debug("breaking: reached beginning") break end # or if we've reached back before our earliest if min_time && min_time < @earliest debug("breaking: before earliest: #{@earliest}") break end # or if we've approximately hit our timeout if (Time.now - start).to_i > @timeout debug("breaking: reached timeout") break end end rescue RateLimited $stderr.puts "Papertrail rate limit reached" end |