--- /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 Youporn < Website
+
+ VALID_YOUPORN_URL_REGEX = /^(http:\/\/)?(www\.)?youporn\.com\/watch\/(\d+)(\/.*)?$/
+
+ def self.owns_url?(url)
+ return url =~ VALID_YOUPORN_URL_REGEX
+ end
+
+
+ def get_video_url()
+ page_data = self.get_page_data(@url)
+ video_url = self.parse_video_url(page_data)
+ return video_url
+ end
+
+
+ protected;
+
+ # Get the FLV file URL from the HTML page for this movie.
+ # They don't obfuscate it or anything, so we assume here
+ # that the first "download" url ending in ".flv" is the
+ # movie file we want.
+ def parse_video_url(page_data)
+ flv_regex = /http:\/\/download\.youporn\.com\/.*?\.flv/
+ matches = flv_regex.match(page_data)
+ flv_url = matches[0] if not matches.nil?
+
+ return flv_url
+ end
+
+
+ def get_page_data(url)
+ uri = URI.parse(url)
+
+ response = Net::HTTP.start(uri.host, uri.port) do |http|
+ # Bypass the stupid age verification.
+ form_data = 'user_choice=Enter'
+ http.post(uri.path, form_data, self.get_headers())
+ end
+
+ return response.body
+ end
+
+ # Build the header hash from the URL we're requesting.
+ def get_headers()
+ headers = { 'Referer' => @url,
+ 'Content-Type' => 'application/x-www-form-urlencoded' }
+ return headers
+ end
+
+
+end