--- /dev/null
+#
+# Copyright Michael Orlitzky
+#
+# http://michael.orlitzky.com/
+#
+# This program is free software: you can redistribute it and/or modify
+# it under the terms of the GNU General Public License as published by
+# the Free Software Foundation, either version 3 of the License, or
+# (at your option) any later version.
+#
+# This program is distributed in the hope that it will be useful,
+# but WITHOUT ANY WARRANTY; without even the implied warranty of
+# MERCHANTABILITY or FITNESS FOR A PARTICULAR PURPOSE. See the
+# GNU General Public License for more details.
+#
+# http://www.fsf.org/licensing/licenses/gpl.html
+#
+
+require 'src/website'
+
+
+class Yikers < Website
+
+ VALID_YIKERS_URL_REGEX = /^(http:\/\/)?(www\.)?yikers\.com\/([[:alnum:]_]+)\.html$/
+
+ def self.owns_url?(url)
+ return url =~ VALID_YIKERS_URL_REGEX
+ end
+
+
+ def get_video_url()
+ # The video URL is usually just a fixed location, with the file
+ # name from the page URL slightly modified. For example,
+ #
+ # http://www.yikers.com/video_the_best_rapper_in_the_world.html
+ #
+ # gets mapped to,
+ #
+ # http://cdn.yikers.com/flv/flash8/yikers_the_best_rapper_in_the_world.flv
+ #
+ file_name = get_video_filename().sub('video_', 'yikers_')
+
+ video_url = "http://cdn.yikers.com/flv/flash8/#{file_name}"
+
+ return video_url
+ end
+
+
+ def get_video_filename()
+ # Default to whatever comes after the final frontslash
+ # in the main URL.
+ filename = @url.split('/').pop()
+
+ # These page URLs are actually descriptive, so we can use
+ # the file name of the HTML page as our video file name.
+ filename_regex = /\/([[:alnum:]_]+)\.html$/
+ matches = filename_regex.match(@url)
+
+ # Overwrite the default if our regex worked.
+ filename = matches[1] if not matches.nil? || matches.length < 1
+
+ return (filename + '.flv')
+ end
+
+end