mgleon08/instagram-crawler

View on GitHub
lib/instagram_crawler/parser/base.rb

Summary

Maintainability
A
0 mins
Test Coverage
module InstagramCrawler
  module Parser
    class Base
      private

      def parse_post(posts, time)
        posts.each.with_index(1) do |post, index|
          url =
            post["node"]["is_video"] ?
            post["node"]["video_url"] :
            post["node"]["display_url"]
          output(time, url)
          File.download(url, "post/#{time}", "#{index}.#{time}")
        end
      end

      def output(time, url)
        Logger.info "[#{time}]".light_cyan + " #{url}"
      end

      def parse_to_date(ts)
        Time.at(ts).strftime('%Y-%m-%dT%H:%M')
      end

      def check_after_time(time)
        if Config.after_date && (Config.parse_after_date > time)
          Logger.info "\nSuccess, the files after #{Config.after_date} have been downloaded!".light_green
          exit
        end
      end
    end
  end
end