2014-01-27 15:09:09 -05:00
|
|
|
require_dependency 'oneboxer'
|
|
|
|
|
2013-05-30 14:34:44 -04:00
|
|
|
class PostAnalyzer
|
|
|
|
|
|
|
|
def initialize(raw, topic_id)
|
|
|
|
@raw = raw
|
|
|
|
@topic_id = topic_id
|
|
|
|
end
|
|
|
|
|
|
|
|
# What we use to cook posts
|
|
|
|
def cook(*args)
|
|
|
|
cooked = PrettyText.cook(*args)
|
|
|
|
|
|
|
|
result = Oneboxer.apply(cooked) do |url, elem|
|
2013-06-19 03:19:42 -04:00
|
|
|
Oneboxer.invalidate(url) if args.last[:invalidate_oneboxes]
|
2014-03-17 22:12:58 -04:00
|
|
|
Oneboxer.cached_onebox url
|
2013-05-30 14:34:44 -04:00
|
|
|
end
|
|
|
|
|
|
|
|
cooked = result.to_html if result.changed?
|
|
|
|
cooked
|
|
|
|
end
|
|
|
|
|
|
|
|
# How many images are present in the post
|
|
|
|
def image_count
|
|
|
|
return 0 unless @raw.present?
|
|
|
|
|
|
|
|
cooked_document.search("img").reject do |t|
|
|
|
|
dom_class = t["class"]
|
|
|
|
if dom_class
|
|
|
|
(Post.white_listed_image_classes & dom_class.split(" ")).count > 0
|
|
|
|
end
|
|
|
|
end.count
|
|
|
|
end
|
|
|
|
|
2013-07-21 20:39:17 -04:00
|
|
|
# How many attachments are present in the post
|
|
|
|
def attachment_count
|
|
|
|
return 0 unless @raw.present?
|
2013-10-17 12:44:09 -04:00
|
|
|
|
2013-07-31 17:26:34 -04:00
|
|
|
attachments = cooked_document.css("a.attachment[href^=\"#{Discourse.store.absolute_base_url}\"]")
|
|
|
|
attachments += cooked_document.css("a.attachment[href^=\"#{Discourse.store.relative_base_url}\"]") if Discourse.store.internal?
|
|
|
|
attachments.count
|
2013-07-21 20:39:17 -04:00
|
|
|
end
|
|
|
|
|
2013-05-30 14:34:44 -04:00
|
|
|
def raw_mentions
|
|
|
|
return [] if @raw.blank?
|
|
|
|
return @raw_mentions if @raw_mentions.present?
|
2013-07-30 18:01:42 -04:00
|
|
|
|
2013-10-17 12:44:09 -04:00
|
|
|
# strip quotes and code blocks
|
|
|
|
cooked_stripped = cooked_document
|
2014-06-30 18:10:46 -04:00
|
|
|
cooked_stripped.css("aside.quote").remove
|
|
|
|
cooked_stripped.css("pre").remove
|
|
|
|
cooked_stripped.css("code").remove
|
2013-05-30 14:34:44 -04:00
|
|
|
|
2013-10-17 12:44:09 -04:00
|
|
|
results = cooked_stripped.to_html.scan(PrettyText.mention_matcher)
|
2013-05-30 14:34:44 -04:00
|
|
|
@raw_mentions = results.uniq.map { |un| un.first.downcase.gsub!(/^@/, '') }
|
|
|
|
end
|
|
|
|
|
|
|
|
# Count how many hosts are linked in the post
|
|
|
|
def linked_hosts
|
|
|
|
return {} if raw_links.blank?
|
|
|
|
return @linked_hosts if @linked_hosts.present?
|
|
|
|
|
|
|
|
@linked_hosts = {}
|
2013-10-17 12:44:09 -04:00
|
|
|
|
2013-05-30 14:34:44 -04:00
|
|
|
raw_links.each do |u|
|
2013-07-15 06:11:23 -04:00
|
|
|
begin
|
|
|
|
uri = URI.parse(u)
|
|
|
|
host = uri.host
|
2014-03-07 04:44:04 -05:00
|
|
|
@linked_hosts[host] ||= 1 unless host.nil?
|
2013-07-15 06:11:23 -04:00
|
|
|
rescue URI::InvalidURIError
|
|
|
|
# An invalid URI does not count as a raw link.
|
|
|
|
next
|
|
|
|
end
|
2013-05-30 14:34:44 -04:00
|
|
|
end
|
2013-10-17 12:44:09 -04:00
|
|
|
|
2013-05-30 14:34:44 -04:00
|
|
|
@linked_hosts
|
|
|
|
end
|
|
|
|
|
|
|
|
# Returns an array of all links in a post excluding mentions
|
|
|
|
def raw_links
|
|
|
|
return [] unless @raw.present?
|
|
|
|
return @raw_links if @raw_links.present?
|
|
|
|
|
|
|
|
@raw_links = []
|
2013-10-17 12:44:09 -04:00
|
|
|
|
2013-10-16 12:19:20 -04:00
|
|
|
cooked_document.search("a").each do |l|
|
2014-03-07 04:44:04 -05:00
|
|
|
# Don't include @mentions in the link count
|
2013-10-16 12:19:20 -04:00
|
|
|
next if l.attributes['href'].nil? || link_is_a_mention?(l)
|
2013-05-30 14:34:44 -04:00
|
|
|
url = l.attributes['href'].to_s
|
|
|
|
@raw_links << url
|
|
|
|
end
|
2013-10-17 12:44:09 -04:00
|
|
|
|
2013-05-30 14:34:44 -04:00
|
|
|
@raw_links
|
|
|
|
end
|
|
|
|
|
|
|
|
# How many links are present in the post
|
|
|
|
def link_count
|
|
|
|
raw_links.size
|
|
|
|
end
|
|
|
|
|
|
|
|
private
|
|
|
|
|
2013-07-22 16:24:47 -04:00
|
|
|
def cooked_document
|
|
|
|
@cooked_document ||= Nokogiri::HTML.fragment(cook(@raw, topic_id: @topic_id))
|
|
|
|
end
|
|
|
|
|
2013-05-30 14:34:44 -04:00
|
|
|
def link_is_a_mention?(l)
|
|
|
|
html_class = l.attributes['class']
|
|
|
|
return false if html_class.nil?
|
|
|
|
html_class.to_s == 'mention' && l.attributes['href'].to_s =~ /^\/users\//
|
|
|
|
end
|
|
|
|
end
|