module Wikipedia
class Page
def initialize(json)
require 'json'
@json = json
@data = JSON::load(json)
end
def page
@data['query']['pages'].values.first
end
def content
page['revisions'].first['*'] if page['revisions']
end
def sanitized_content
self.class.sanitize(content)
end
def redirect?
content && content.match(/\#REDIRECT\s*\[\[(.*?)\]\]/i)
end
def redirect_title
if matches = redirect?
matches[1]
end
end
def title
page['title']
end
def fullurl
page['fullurl']
end
def editurl
page['editurl']
end
def categories
page['categories'].map {|c| c['title'] } if page['categories']
end
def links
page['links'].map {|c| c['title'] } if page['links']
end
def extlinks
page['extlinks'].map {|c| c['*'] } if page['extlinks']
end
def images
page['images'].map {|c| c['title'] } if page['images']
end
def image_url
page['imageinfo'].first['url'] if page['imageinfo']
end
def image_descriptionurl
page['imageinfo'].first['descriptionurl'] if page['imageinfo']
end
def image_urls
image_metadata.map {|img| img.image_url }
end
def image_descriptionurls
image_metadata.map {|img| img.image_descriptionurl }
end
def coordinates
page['coordinates'].first.values if page['coordinates']
end
def raw_data
@data
end
def image_metadata
unless @cached_image_metadata
if list = images
filtered = list.select {|i| i =~ /:.+\.(jpg|jpeg|png|gif)$/i && !i.include?("LinkFA-star") }
@cached_image_metadata = filtered.map {|title| Wikipedia.find_image(title) }
end
end
@cached_image_metadata || []
end
def templates
page['templates'].map {|c| c['title'] } if page['templates']
end
def json
@json
end
def self.sanitize( s )
if s
s = s.dup
# strip anything inside curly braces!
while s =~ /\{\{[^\{\}]+?\}\}/
s.gsub!(/\{\{[^\{\}]+?\}\}/, '')
end
# strip info box
s.sub!(/^\{\|[^\{\}]+?\n\|\}\n/, '')
# strip internal links
s.gsub!(/\[\[([^\]\|]+?)\|([^\]\|]+?)\]\]/, '\2')
s.gsub!(/\[\[([^\]\|]+?)\]\]/, '\1')
# strip images and file links
s.gsub!(/\[\[Image:[^\[\]]+?\]\]/, '')
s.gsub!(/\[\[File:[^\[\]]+?\]\]/, '')
# convert bold/italic to html
s.gsub!(/'''''(.+?)'''''/, '\1')
s.gsub!(/'''(.+?)'''/, '\1')
s.gsub!(/''(.+?)''/, '\1')
# misc
s.gsub!(/[]*>[\s\S]*?<\/ref>/, '')
s.gsub!(//, '')
s.gsub!(' ', ' ')
s.strip!
# create paragraphs
sections = s.split("\n\n")
if sections.size > 1
s = sections.map {|s| "]#{s.strip}
" }.join("\n")
end
s
end
end
end
end