Sha256: 883cd86648186fb6c2fec77980ac7e2d9f502f029107d17ea87c1b8d856357bf
Contents?: true
Size: 1.67 KB
Versions: 3
Compression:
Stored size: 1.67 KB
Contents
# frozen_string_literal: true module Miteru class Orchestrator < Service def call Miteru.logger.info("#{websites.length} websites loaded in total.") if verbose? if Miteru.sidekiq? websites.each do |website| Jobs::CrawleJob.perform_async(website.url, website.source) Miteru.logger.info("Website:#{website.truncated_url} crawler job queued.") if verbose? end else Miteru.logger.info("Use #{threads} thread(s).") if verbose? Parallel.each(websites, in_threads: threads) do |website| Miteru.logger.info("Website:#{website.truncated_url} crawling started.") if verbose? result = Crawler.result(website) if result.success? Miteru.logger.info("Crawler:#{website.truncated_url} succeeded.") else Miteru.logger.info("Crawler:#{website.truncated_url} failed - #{result.failure}.") end end end end # # @return [Array<Miteru::Websites>] # def websites @websites ||= [].tap do |out| feeds.each do |feed| result = feed.result if result.success? websites = result.value! Miteru.logger.info("Feed:#{feed.source} has #{websites.length} websites.") if verbose? out << websites else Miteru.logger.warn("Feed:#{feed.source} failed - #{result.failure}") end end end.flatten.uniq(&:url) end # # @return [Array<Miteru::Feeds::Base>] # def feeds Miteru.feeds.map(&:new) end private def threads Miteru.config.threads end def verbose? Miteru.config.verbose end end end
Version data entries
3 entries across 3 versions & 1 rubygems
Version | Path |
---|---|
miteru-2.1.1 | lib/miteru/orchestrator.rb |
miteru-2.1.0 | lib/miteru/orchestrator.rb |
miteru-2.0.3 | lib/miteru/orchestrator.rb |