2014-02-26 02:35:08 +08:00
|
|
|
|
|
|
|
Dir["#{Rails.root}/lib/onebox/engine/*_onebox.rb"].each {|f|
|
|
|
|
require_dependency(f.split('/')[-3..-1].join('/'))
|
|
|
|
}
|
|
|
|
|
2013-02-06 03:16:51 +08:00
|
|
|
module Oneboxer
|
2014-01-28 04:09:09 +08:00
|
|
|
|
2014-02-26 02:35:08 +08:00
|
|
|
|
2013-04-30 10:43:21 +08:00
|
|
|
# keep reloaders happy
|
|
|
|
unless defined? Oneboxer::Result
|
|
|
|
Result = Struct.new(:doc, :changed) do
|
|
|
|
def to_html
|
|
|
|
doc.to_html
|
|
|
|
end
|
2013-04-10 15:52:38 +08:00
|
|
|
|
2013-04-30 10:43:21 +08:00
|
|
|
def changed?
|
|
|
|
changed
|
|
|
|
end
|
2013-04-10 15:52:38 +08:00
|
|
|
end
|
|
|
|
end
|
|
|
|
|
2014-01-28 04:09:09 +08:00
|
|
|
def self.preview(url, options=nil)
|
|
|
|
options ||= {}
|
|
|
|
Oneboxer.invalidate(url) if options[:invalidate_oneboxes]
|
2014-03-18 10:12:58 +08:00
|
|
|
onebox_raw(url).placeholder_html
|
2013-02-06 03:16:51 +08:00
|
|
|
end
|
|
|
|
|
2014-01-28 04:09:09 +08:00
|
|
|
def self.onebox(url, options=nil)
|
|
|
|
options ||= {}
|
|
|
|
Oneboxer.invalidate(url) if options[:invalidate_oneboxes]
|
2014-03-18 10:12:58 +08:00
|
|
|
onebox_raw(url).to_s
|
|
|
|
end
|
|
|
|
|
|
|
|
def self.cached_onebox(url)
|
|
|
|
Rails.cache.read(onebox_cache_key(url))
|
|
|
|
.to_s
|
|
|
|
end
|
|
|
|
|
|
|
|
def self.cached_preview(url)
|
|
|
|
Rails.cache.read(onebox_cache_key(url))
|
|
|
|
.try(:placeholder_html)
|
|
|
|
.to_s
|
2013-08-14 23:05:53 +08:00
|
|
|
end
|
|
|
|
|
2014-01-29 02:18:19 +08:00
|
|
|
def self.oneboxer_exists_for_url?(url)
|
2014-01-28 04:09:09 +08:00
|
|
|
Onebox.has_matcher?(url)
|
2013-02-06 03:16:51 +08:00
|
|
|
end
|
|
|
|
|
2014-01-29 02:18:19 +08:00
|
|
|
def self.invalidate(url)
|
2014-03-18 10:12:58 +08:00
|
|
|
Rails.cache.delete(onebox_cache_key(url))
|
2013-02-06 03:16:51 +08:00
|
|
|
end
|
2014-01-29 02:18:19 +08:00
|
|
|
|
2013-02-06 03:16:51 +08:00
|
|
|
# Parse URLs out of HTML, returning the document when finished.
|
|
|
|
def self.each_onebox_link(string_or_doc)
|
|
|
|
doc = string_or_doc
|
2013-04-10 15:52:38 +08:00
|
|
|
doc = Nokogiri::HTML::fragment(doc) if doc.is_a?(String)
|
2013-02-06 03:16:51 +08:00
|
|
|
|
|
|
|
onebox_links = doc.search("a.onebox")
|
|
|
|
if onebox_links.present?
|
|
|
|
onebox_links.each do |link|
|
|
|
|
if link['href'].present?
|
|
|
|
yield link['href'], link
|
|
|
|
end
|
|
|
|
end
|
|
|
|
end
|
|
|
|
|
|
|
|
doc
|
|
|
|
end
|
|
|
|
|
2013-04-10 15:52:38 +08:00
|
|
|
def self.apply(string_or_doc)
|
|
|
|
doc = string_or_doc
|
|
|
|
doc = Nokogiri::HTML::fragment(doc) if doc.is_a?(String)
|
|
|
|
changed = false
|
|
|
|
|
|
|
|
Oneboxer.each_onebox_link(doc) do |url, element|
|
|
|
|
onebox, preview = yield(url,element)
|
|
|
|
if onebox
|
|
|
|
parsed_onebox = Nokogiri::HTML::fragment(onebox)
|
2013-05-01 14:37:27 +08:00
|
|
|
next unless parsed_onebox.children.count > 0
|
2013-04-10 15:52:38 +08:00
|
|
|
|
|
|
|
# special logic to strip empty p elements
|
2013-05-01 14:37:27 +08:00
|
|
|
if element.parent &&
|
|
|
|
element.parent.node_name.downcase == "p" &&
|
|
|
|
element.parent.children.count == 1 &&
|
2013-04-10 15:52:38 +08:00
|
|
|
parsed_onebox.children.first.name.downcase == "div"
|
2013-05-01 14:37:27 +08:00
|
|
|
element = element.parent
|
2013-04-10 15:52:38 +08:00
|
|
|
end
|
|
|
|
changed = true
|
|
|
|
element.swap parsed_onebox.to_html
|
|
|
|
end
|
|
|
|
end
|
|
|
|
|
|
|
|
Result.new(doc, changed)
|
|
|
|
end
|
|
|
|
|
2014-03-18 10:12:58 +08:00
|
|
|
private
|
|
|
|
def self.onebox_cache_key(url)
|
|
|
|
"onebox_#{url}"
|
|
|
|
end
|
|
|
|
|
|
|
|
def self.onebox_raw(url)
|
|
|
|
Rails.cache.fetch(onebox_cache_key(url)){
|
|
|
|
Onebox.preview(url, cache: {})
|
|
|
|
}
|
|
|
|
end
|
|
|
|
|
2013-02-06 03:16:51 +08:00
|
|
|
end
|
2014-01-28 04:09:09 +08:00
|
|
|
|