Sha256: 79852a78c1f837f79c8160bc8c8f424a3a339c32b9c7c265e61bf6c3fcd51bc8

Contents?: true

Size: 1.13 KB

Versions: 2

Compression:

Stored size: 1.13 KB

Contents

# frozen_string_literal: true

module Html2rss
  class AutoSource
    ##
    # The Scraper module contains all scrapers that can be used to extract articles.
    # Each scraper should implement a `call` method that returns an array of article hashes.
    # Each scraper should also implement an `articles?` method that returns true if the scraper
    # can potentially be used to extract articles from the given HTML.
    #
    module Scraper
      SCRAPERS = [
        Html,
        Schema,
        SemanticHtml
      ].freeze

      ##
      # Error raised when no suitable scraper is found.
      class NoScraperFound < Html2rss::Error; end

      ##
      # Returns an array of scrapers that claim to find articles in the parsed body.
      # @param parsed_body [Nokogiri::HTML::Document] The parsed HTML body.
      # @return [Array<Class>] An array of scraper classes that can handle the parsed body.
      def self.from(parsed_body)
        scrapers = SCRAPERS.select { |scraper| scraper.articles?(parsed_body) }
        raise NoScraperFound, 'No suitable scraper found for URL.' if scrapers.empty?

        scrapers
      end
    end
  end
end

Version data entries

2 entries across 2 versions & 1 rubygems

Version Path
html2rss-0.16.0 lib/html2rss/auto_source/scraper.rb
html2rss-0.15.0 lib/html2rss/auto_source/scraper.rb