update to a snapshot, supports more sites etc.
Additional testing by laurent@, thanks.
This commit is contained in:
parent
cc0c067a84
commit
1c25416444
@ -1,10 +1,9 @@
|
|||||||
# $OpenBSD: Makefile,v 1.6 2011/03/11 00:39:44 sthen Exp $
|
# $OpenBSD: Makefile,v 1.7 2011/07/12 13:02:28 sthen Exp $
|
||||||
|
|
||||||
COMMENT= download flash video files from various sites
|
COMMENT= download flash video files from various sites
|
||||||
|
|
||||||
DISTNAME= App-get_flash_videos-1.24
|
DISTNAME= App-get_flash_videos-1.24.20110712
|
||||||
PKGNAME= ${DISTNAME:S/App-//}
|
PKGNAME= ${DISTNAME:S/App-//}
|
||||||
REVISION = 1
|
|
||||||
CATEGORIES= multimedia
|
CATEGORIES= multimedia
|
||||||
|
|
||||||
HOMEPAGE= http://get-flash-videos.googlecode.com/
|
HOMEPAGE= http://get-flash-videos.googlecode.com/
|
||||||
@ -12,14 +11,15 @@ HOMEPAGE= http://get-flash-videos.googlecode.com/
|
|||||||
MAINTAINER= Stuart Henderson <sthen@openbsd.org>
|
MAINTAINER= Stuart Henderson <sthen@openbsd.org>
|
||||||
|
|
||||||
# Apache 2.0
|
# Apache 2.0
|
||||||
PERMIT_PACKAGE_CDROM= Yes
|
PERMIT_PACKAGE_CDROM= Yes
|
||||||
PERMIT_PACKAGE_FTP= Yes
|
PERMIT_PACKAGE_FTP= Yes
|
||||||
PERMIT_DISTFILES_CDROM= Yes
|
PERMIT_DISTFILES_CDROM= Yes
|
||||||
PERMIT_DISTFILES_FTP= Yes
|
PERMIT_DISTFILES_FTP= Yes
|
||||||
|
|
||||||
MODULES= cpan
|
MODULES= cpan
|
||||||
CPAN_AUTHOR= MONSIEUR
|
CPAN_AUTHOR= MONSIEUR
|
||||||
USE_GROFF= Yes
|
# git checkout
|
||||||
|
MASTER_SITES= http://spacehopper.org/mirrors/
|
||||||
|
|
||||||
BUILD_DEPENDS= devel/p5-Tie-IxHash
|
BUILD_DEPENDS= devel/p5-Tie-IxHash
|
||||||
RUN_DEPENDS= devel/p5-Term-ReadKey \
|
RUN_DEPENDS= devel/p5-Term-ReadKey \
|
||||||
|
@ -1,5 +1,5 @@
|
|||||||
MD5 (App-get_flash_videos-1.24.tar.gz) = h77utGRO3pK/6wrAXByBWw==
|
MD5 (App-get_flash_videos-1.24.20110712.tar.gz) = wu0Qa9ceaugX+4PMbYiS7w==
|
||||||
RMD160 (App-get_flash_videos-1.24.tar.gz) = E2eVS6AMvS2sXahCZtGx+2RCahg=
|
RMD160 (App-get_flash_videos-1.24.20110712.tar.gz) = JZwii/hCcKsYyqd+6qBWLncQcqU=
|
||||||
SHA1 (App-get_flash_videos-1.24.tar.gz) = A1wdb+Kt5E08loeJgxcZ8tezXF0=
|
SHA1 (App-get_flash_videos-1.24.20110712.tar.gz) = Y3WG3+/UV/t2D9Ffx84mTxeRG8g=
|
||||||
SHA256 (App-get_flash_videos-1.24.tar.gz) = nUAvrPjWrf1VNlZikCq1ily18PVoYThb7ZROIgUvkTM=
|
SHA256 (App-get_flash_videos-1.24.20110712.tar.gz) = czF9tQzik0MUX8koV8DTbQ+X4vBmfJSeGmasLexgkkI=
|
||||||
SIZE (App-get_flash_videos-1.24.tar.gz) = 82383
|
SIZE (App-get_flash_videos-1.24.20110712.tar.gz) = 98009
|
||||||
|
@ -1,261 +0,0 @@
|
|||||||
$OpenBSD: patch-lib_FlashVideo_Site_Brightcove_pm,v 1.1 2011/03/07 23:50:09 sthen Exp $
|
|
||||||
--- lib/FlashVideo/Site/Brightcove.pm.orig Tue Nov 30 16:41:02 2010
|
|
||||||
+++ lib/FlashVideo/Site/Brightcove.pm Thu Mar 3 12:32:12 2011
|
|
||||||
@@ -5,56 +5,54 @@ use strict;
|
|
||||||
use FlashVideo::Utils;
|
|
||||||
use MIME::Base64;
|
|
||||||
|
|
||||||
+my $encode_rates = {
|
|
||||||
+ "low" => 480,
|
|
||||||
+ "medium" => 800,
|
|
||||||
+ "medium2" => 1200,
|
|
||||||
+ "high" => 1500 };
|
|
||||||
+
|
|
||||||
sub find_video {
|
|
||||||
- my ($self, $browser, $embed_url) = @_;
|
|
||||||
+ my ($self, $browser, $embed_url, $prefs) = @_;
|
|
||||||
|
|
||||||
my $metadata = { };
|
|
||||||
my ($video_id, $player_id);
|
|
||||||
|
|
||||||
# URL params, JSON, etc..
|
|
||||||
- $video_id = ($browser->content =~ /(?:clip|video)Id["'\] ]*[:=]["' ]*(\d+)/i)[0];
|
|
||||||
$player_id = ($browser->content =~ /playerId["'\] ]*[:=]["' ]*(\d+)/i)[0];
|
|
||||||
+ $metadata->{videoplayer} = ($browser->content =~ /videoPlayer=ref:(C\d+)/i)[0];
|
|
||||||
+ $metadata->{publisherId} = ($browser->content =~ /publisherID=(\d+)/i)[0];
|
|
||||||
|
|
||||||
# <object> params
|
|
||||||
$player_id ||= ($browser->content =~ /<param name=["']?playerID["']? value=["'](\d+) ?["']/i)[0];
|
|
||||||
- $video_id ||= ($browser->content =~ /<param name=["']?\@?video(?:Player|id)["']? value=["'](\d+)["']/i)[0];
|
|
||||||
|
|
||||||
# flashVar params (e.g. <embed>)
|
|
||||||
$player_id ||= ($browser->content =~ /flashVars.*playerID=(\d+)/i)[0];
|
|
||||||
- $video_id ||= ($browser->content =~ /flashVars.*video(?:Player|ID)=(\d+)/i)[0];
|
|
||||||
|
|
||||||
# Brightcove JavaScript API
|
|
||||||
if(!$player_id && $browser->content =~ /brightcove.player.create\(['"]?(\d+)['"]?,\s*['"]?(\d+)/) {
|
|
||||||
- $video_id = $1;
|
|
||||||
$player_id = $2;
|
|
||||||
}
|
|
||||||
|
|
||||||
+ $metadata->{sessionId} = ($browser->cookie_jar->as_string =~ /session=([0-9a-f]*);/)[0];
|
|
||||||
+
|
|
||||||
# Support direct links to videos
|
|
||||||
for my $url($browser->uri->as_string, $embed_url) {
|
|
||||||
- if($url =~ /(?:videoID|bctid)=?(\d+)/i) {
|
|
||||||
- $video_id ||= $1;
|
|
||||||
- }
|
|
||||||
|
|
||||||
if($url =~ /(?:playerID|bcpid)=?(\d+)/i) {
|
|
||||||
$player_id ||= $1;
|
|
||||||
}
|
|
||||||
-
|
|
||||||
- if($url =~ /(?:lineupID|bclid)=?(\d+)/i) {
|
|
||||||
- $metadata->{lineupId} ||= $1;
|
|
||||||
- }
|
|
||||||
}
|
|
||||||
|
|
||||||
- debug "Extracted playerId: $player_id, videoId: $video_id, lineupID: $metadata->{lineupId}"
|
|
||||||
+ debug "Extracted playerId: $player_id, sessionId: $metadata->{sessionId} videoplayer: $metadata->{videoplayer} publisherId: $metadata->{publisherId} "
|
|
||||||
if $player_id or $video_id;
|
|
||||||
|
|
||||||
die "Unable to extract Brightcove IDs from page" unless $player_id;
|
|
||||||
|
|
||||||
- $metadata->{videoId} = $video_id;
|
|
||||||
- return $self->amfgateway($browser, $player_id, $metadata);
|
|
||||||
+ return $self->amfgateway($browser, $player_id, $metadata, $prefs);
|
|
||||||
}
|
|
||||||
|
|
||||||
sub amfgateway {
|
|
||||||
- my($self, $browser, $player_id, $metadata) = @_;
|
|
||||||
+ my($self, $browser, $player_id, $metadata, $prefs) = @_;
|
|
||||||
|
|
||||||
my $has_amf_packet = eval { require Data::AMF::Packet };
|
|
||||||
if (!$has_amf_packet) {
|
|
||||||
@@ -62,36 +60,69 @@ sub amfgateway {
|
|
||||||
}
|
|
||||||
|
|
||||||
my $page_url = $browser->uri;
|
|
||||||
+ my $base_url = "" . $page_url;
|
|
||||||
|
|
||||||
- my $packet = Data::AMF::Packet->deserialize(decode_base64(<<EOF));
|
|
||||||
-AAAAAAABAEhjb20uYnJpZ2h0Y292ZS50ZW1wbGF0aW5nLlRlbXBsYXRpbmdGYWNhZGUuZ2V0Q29u
|
|
||||||
-dGVudEZvclRlbXBsYXRlSW5zdGFuY2UAAi8yAAACNQoAAAACAEH4tP+1EAAAEAA1Y29tLmJyaWdo
|
|
||||||
-dGNvdmUudGVtcGxhdGluZy5Db250ZW50UmVxdWVzdENvbmZpZ3VyYXRpb24ACnZpZGVvUmVmSWQG
|
|
||||||
-AAd2aWRlb0lkBgAIbGluZXVwSWQGAAtsaW5ldXBSZWZJZAYAF29wdGltaXplRmVhdHVyZWRDb250
|
|
||||||
-ZW50AQEAF2ZlYXR1cmVkTGluZXVwRmV0Y2hJbmZvEAAkY29tLmJyaWdodGNvdmUucGVyc2lzdGVu
|
|
||||||
-Y2UuRmV0Y2hJbmZvAApjaGlsZExpbWl0AEBZAAAAAAAAAA5mZXRjaExldmVsRW51bQBAEAAAAAAA
|
|
||||||
-AAALY29udGVudFR5cGUCAAtWaWRlb0xpbmV1cAAACQAKZmV0Y2hJbmZvcwoAAAACEAAkY29tLmJy
|
|
||||||
-aWdodGNvdmUucGVyc2lzdGVuY2UuRmV0Y2hJbmZvAApjaGlsZExpbWl0AEBZAAAAAAAAAA5mZXRj
|
|
||||||
-aExldmVsRW51bQA/8AAAAAAAAAALY29udGVudFR5cGUCAAtWaWRlb0xpbmV1cAAACRAAJGNvbS5i
|
|
||||||
-cmlnaHRjb3ZlLnBlcnNpc3RlbmNlLkZldGNoSW5mbwAKY2hpbGRMaW1pdABAWQAAAAAAAAAPZ3Jh
|
|
||||||
-bmRjaGlsZExpbWl0AEBZAAAAAAAAAA5mZXRjaExldmVsRW51bQBACAAAAAAAAAALY29udGVudFR5
|
|
||||||
-cGUCAA9WaWRlb0xpbmV1cExpc3QAAAkAAAk=
|
|
||||||
-EOF
|
|
||||||
+# AMF3 incompatable between Data::AMF and Brightcove
|
|
||||||
+# results in Brightcove rejecting message
|
|
||||||
+# create message without deserialize/serialize.
|
|
||||||
|
|
||||||
- if (defined $player_id) {
|
|
||||||
- $packet->messages->[0]->{value}->[0] = "$player_id";
|
|
||||||
- }
|
|
||||||
+ my $amf0_formatter = Data::AMF::Formatter->new(version =>0);
|
|
||||||
+ my $amf3_formatter = Data::AMF::Formatter->new(version =>3);
|
|
||||||
+ my @amf_pkt;
|
|
||||||
|
|
||||||
- if (ref $metadata) {
|
|
||||||
- for(keys %$metadata) {
|
|
||||||
- $packet->messages->[0]->{value}->[1]->{$_} = "$metadata->{$_}";
|
|
||||||
- }
|
|
||||||
- }
|
|
||||||
|
|
||||||
- my $data = $packet->serialize;
|
|
||||||
+ $amf_pkt[0] = decode_base64(<<EOF1);
|
|
||||||
+AAMAAAABAEZjb20uYnJpZ2h0Y292ZS5leHBlcmllbmNlLkV4cGVyaWVuY2VSdW50aW1lRmFjYWRl
|
|
||||||
+LmdldERhdGFGb3JFeHBlcmllbmNlAAIvMQAA
|
|
||||||
+EOF1
|
|
||||||
|
|
||||||
+ $amf_pkt[2] = decode_base64(<<EOF2);
|
|
||||||
+CgAAAAI=
|
|
||||||
+EOF2
|
|
||||||
+
|
|
||||||
+ $amf_pkt[3] = $amf0_formatter->format($metadata->{sessionId});
|
|
||||||
+
|
|
||||||
+ $amf_pkt[4] = decode_base64(<<EOF3);
|
|
||||||
+EQpjY2NvbS5icmlnaHRjb3ZlLmV4cGVyaWVuY2UuVmlld2VyRXhwZXJpZW5jZVJlcXVlc3QhY29u
|
|
||||||
+dGVudE92ZXJyaWRlcwdVUkwZZXhwZXJpZW5jZUlkEVRUTFRva2VuE3BsYXllcktleRlkZWxpdmVy
|
|
||||||
+eVR5cGUJAwEKgQNTY29tLmJyaWdodGNvdmUuZXhwZXJpZW5jZS5Db250ZW50T3ZlcnJpZGUXY29u
|
|
||||||
+dGVudFR5cGUTY29udGVudElkGWNvbnRlbnRSZWZJZBtmZWF0dXJlZFJlZklkG2NvbnRlbnRSZWZJ
|
|
||||||
+ZHMVZmVhdHVyZWRJZBVjb250ZW50SWRzDXRhcmdldAQABX/////gAAAA
|
|
||||||
+EOF3
|
|
||||||
+
|
|
||||||
+ $amf_pkt[5] = $amf3_formatter->format($metadata->{videoplayer});
|
|
||||||
+
|
|
||||||
+ $amf_pkt[6] = decode_base64(<<EOF4);
|
|
||||||
+AQEFf////+AAAAABBhd2aWRlb1BsYXllcg==
|
|
||||||
+EOF4
|
|
||||||
+
|
|
||||||
+ $amf_pkt[7] = $amf3_formatter->format($base_url);
|
|
||||||
+
|
|
||||||
+ $amf_pkt[8] = decode_base64(<<EOF5);
|
|
||||||
+BUI4gZvSwQAABgEGAQV/////4AAAAA==
|
|
||||||
+EOF5
|
|
||||||
+
|
|
||||||
+
|
|
||||||
+ $amf_pkt[1] = pack('n', length(join('',@amf_pkt[2..8])));
|
|
||||||
+
|
|
||||||
+ my $data = join('',@amf_pkt[0..8]);
|
|
||||||
+
|
|
||||||
+# my $packet = Data::AMF::Packet->deserialize($data);
|
|
||||||
+
|
|
||||||
+# if (defined $player_id) {
|
|
||||||
+# $packet->messages->[0]->{value}->[0] = "$player_id";
|
|
||||||
+# }
|
|
||||||
+
|
|
||||||
+# if (ref $metadata) {
|
|
||||||
+# for(keys %$metadata) {
|
|
||||||
+# $packet->messages->[0]->{value}->[1]->{$_} = "$metadata->{$_}";
|
|
||||||
+# }
|
|
||||||
+# }
|
|
||||||
+
|
|
||||||
+# my $data = $packet->serialize;
|
|
||||||
+
|
|
||||||
$browser->post(
|
|
||||||
- "http://c.brightcove.com/services/amfgateway",
|
|
||||||
+ "http://c.brightcove.com/services/messagebroker/amf?playerid=$player_id",
|
|
||||||
Content_Type => "application/x-amf",
|
|
||||||
Content => $data
|
|
||||||
);
|
|
||||||
@@ -99,46 +130,59 @@ EOF
|
|
||||||
die "Failed to post to Brightcove AMF gateway"
|
|
||||||
unless $browser->response->is_success;
|
|
||||||
|
|
||||||
- $packet = Data::AMF::Packet->deserialize($browser->content);
|
|
||||||
+ my $packet = Data::AMF::Packet->deserialize($browser->content);
|
|
||||||
|
|
||||||
if($self->debug) {
|
|
||||||
require Data::Dumper;
|
|
||||||
debug Data::Dumper::Dumper($packet);
|
|
||||||
}
|
|
||||||
|
|
||||||
- if(ref $packet->messages->[0]->{value} ne 'ARRAY') {
|
|
||||||
+# renditions Array contains the rtmpe URL.
|
|
||||||
+ if ( ref $packet->messages->[0]->{value}->{programmedContent}->{videoPlayer}->{mediaDTO}->{renditions} ne 'ARRAY') {
|
|
||||||
die "Unexpected data from AMF gateway";
|
|
||||||
}
|
|
||||||
|
|
||||||
my @found;
|
|
||||||
- for (@{$packet->messages->[0]->{value}}) {
|
|
||||||
- if ($_->{data}->{videoDTO}) {
|
|
||||||
- push @found, $_->{data}->{videoDTO};
|
|
||||||
+ for (@{$packet->messages->[0]->{value}->{programmedContent}->{videoPlayer}->{mediaDTO}->{renditions}}) {
|
|
||||||
+ if ($_->{defaultURL}) {
|
|
||||||
+ push @found, $_;
|
|
||||||
}
|
|
||||||
- if ($_->{data}->{videoDTOs}) {
|
|
||||||
- push @found, @{$_->{data}->{videoDTOs}};
|
|
||||||
- }
|
|
||||||
}
|
|
||||||
|
|
||||||
+# other information returned in message.
|
|
||||||
+ my $mediaId = $packet->messages->[0]->{value}->{programmedContent}->{videoPlayer}->{mediaId};
|
|
||||||
+ my $seasonnumber = $packet->messages->[0]->{value}->{programmedContent}->{videoPlayer}->{mediaDTO}->{customFields}->{seasonnumber};
|
|
||||||
+ my $episodenumber = $packet->messages->[0]->{value}->{programmedContent}->{videoPlayer}->{mediaDTO}->{customFields}->{episodenumber};
|
|
||||||
+ my $show = ($page_url =~ m!/shows/([^/]+)/!i)[0];
|
|
||||||
+ my $episode = ($page_url =~ m!/episodes/([^/]+)!i)[0];
|
|
||||||
+ my $filehead = $show . "_Series" . $seasonnumber;
|
|
||||||
+ if ( $show ne $episode ) {
|
|
||||||
+ $filehead = $filehead . "_Episode" . $episodenumber . "_" . $episode;
|
|
||||||
+ }
|
|
||||||
+ my $encode_rate = $encode_rates->{$prefs->{quality}};
|
|
||||||
+ if (! defined $encode_rate ) {
|
|
||||||
+ $encode_rate = $prefs->{quality};
|
|
||||||
+ }
|
|
||||||
+
|
|
||||||
my @rtmpdump_commands;
|
|
||||||
|
|
||||||
for my $d (@found) {
|
|
||||||
- next if $metadata->{videoId} && $d->{id} != $metadata->{videoId};
|
|
||||||
|
|
||||||
- my $host = ($d->{FLVFullLengthURL} =~ m!rtmp://(.*?)/!)[0];
|
|
||||||
- my $file = ($d->{FLVFullLengthURL} =~ m!&([a-z0-9:]+/.*?)(?:&|$)!)[0];
|
|
||||||
- my $app = ($d->{FLVFullLengthURL} =~ m!//.*?/(.*?)/&!)[0];
|
|
||||||
- my $filename = ($d->{FLVFullLengthURL} =~ m!&.*?/([^/&]+)(?:&|$)!)[0];
|
|
||||||
+ my $rate = ($d->{defaultURL} =~ /H264-(\d+)-16x9/i)[0];
|
|
||||||
+ next if $encode_rate != $rate;
|
|
||||||
+ my $host = ($d->{defaultURL} =~ m!rtmpe://(.*?)/!)[0];
|
|
||||||
+ my $file = ($d->{defaultURL} =~ /^[^&]+&(.*)$/)[0];
|
|
||||||
+ my $app = ($d->{defaultURL} =~ m!//.*?/(.*?)/&!)[0];
|
|
||||||
+ my $filename = $filehead . "_" . $rate;
|
|
||||||
|
|
||||||
- $app .= "?videoId=$d->{id}&lineUpId=$d->{lineupId}&pubId=$d->{publisherId}&playerId=$player_id&playerTag=&affiliateId=";
|
|
||||||
+ $app .= "?videoId=$mediaId&lineUpId=&pubId=$metadata->{publisherId}&playerId=$player_id&affiliateId=";
|
|
||||||
|
|
||||||
my $args = {
|
|
||||||
app => $app,
|
|
||||||
pageUrl => $page_url,
|
|
||||||
- swfUrl => "http://admin.brightcove.com/viewer/federated/f_012.swf?bn=590&pubId=$d->{publisherId}",
|
|
||||||
- tcUrl => "rtmp://$host:1935/$app",
|
|
||||||
- auth => ($d->{FLVFullLengthURL} =~ /^[^&]+&(.*)$/)[0],
|
|
||||||
- rtmp => "rtmp://$host/$app",
|
|
||||||
+ swfVfy => "http://admin.brightcove.com/viewer/us1.24.04.08.2011-01-14072625/connection/ExternalConnection_2.swf",
|
|
||||||
+ tcUrl => "rtmpe://$host:1935/$app",
|
|
||||||
+ rtmp => "$d->{defaultURL}",
|
|
||||||
playpath => $file,
|
|
||||||
flv => "$filename.flv",
|
|
||||||
};
|
|
||||||
@@ -150,10 +194,10 @@ EOF
|
|
||||||
|
|
||||||
# In some cases, Brightcove doesn't use RTMP streaming - the file is
|
|
||||||
# downloaded via HTTP.
|
|
||||||
- if (!$d->{FLVFullLengthStreamed}) {
|
|
||||||
- info "Brightcove HTTP download detected";
|
|
||||||
- return ($d->{FLVFullLengthURL}, $args->{flv});
|
|
||||||
- }
|
|
||||||
+# if (!$d->{FLVFullLengthStreamed}) {
|
|
||||||
+# info "Brightcove HTTP download detected";
|
|
||||||
+# return ($d->{}, $args->{flv});
|
|
||||||
+# }
|
|
||||||
|
|
||||||
push @rtmpdump_commands, $args;
|
|
||||||
}
|
|
@ -1,57 +0,0 @@
|
|||||||
$OpenBSD: patch-lib_FlashVideo_Site_Itv_pm,v 1.1 2011/03/07 23:50:09 sthen Exp $
|
|
||||||
--- lib/FlashVideo/Site/Itv.pm.orig Tue Nov 30 14:34:17 2010
|
|
||||||
+++ lib/FlashVideo/Site/Itv.pm Thu Mar 3 12:32:06 2011
|
|
||||||
@@ -5,8 +5,21 @@ use strict;
|
|
||||||
use FlashVideo::Utils;
|
|
||||||
use HTML::Entities;
|
|
||||||
|
|
||||||
+my $resolutions = {
|
|
||||||
+ "16x9" => {
|
|
||||||
+ "400" => [412, 232],
|
|
||||||
+ "600" => [512, 288],
|
|
||||||
+ "800" => [640, 360],
|
|
||||||
+ },
|
|
||||||
+ "4x3" => {
|
|
||||||
+ "400" => [320, 240],
|
|
||||||
+ "600" => [384, 288],
|
|
||||||
+ "800" => [480, 360],
|
|
||||||
+ },
|
|
||||||
+};
|
|
||||||
+
|
|
||||||
sub find_video {
|
|
||||||
- my ($self, $browser, $page_url) = @_;
|
|
||||||
+ my ($self, $browser, $page_url, $prefs) = @_;
|
|
||||||
|
|
||||||
my($id) = $browser->uri =~ /Filter=(\d+)/;
|
|
||||||
die "No id (filter) found in URL\n" unless $id;
|
|
||||||
@@ -33,8 +46,10 @@ sub find_video {
|
|
||||||
<itv:RevenueScienceValue>scc=true; svisit=1; sc4=Other</itv:RevenueScienceValue>
|
|
||||||
</tem:userInfo>
|
|
||||||
<tem:siteInfo>
|
|
||||||
+ <itv:AdvertisingRestriction>None</itv:AdvertisingRestriction>
|
|
||||||
+ <itv:AdvertisingSite>ITV</itv:AdvertisingSite>
|
|
||||||
<itv:Area>ITVPLAYER.VIDEO</itv:Area>
|
|
||||||
- <itv:Platform>Web</itv:Platform>
|
|
||||||
+ <itv:Platform>DotCom</itv:Platform>
|
|
||||||
<itv:Site>ItvCom</itv:Site>
|
|
||||||
</tem:siteInfo>
|
|
||||||
</tem:GetPlaylist>
|
|
||||||
@@ -47,8 +62,17 @@ EOF
|
|
||||||
die "Unable to find <Video> in XML" unless $browser->content =~ m{<Video timecode[^>]+>(.*?)</Video>}s;
|
|
||||||
my $video = $1;
|
|
||||||
|
|
||||||
+ # Parse list of availible formats and lookup their resolutions
|
|
||||||
+ my(@formats);
|
|
||||||
+ while ($video =~ m/(mp4:[^\]]+([0-9]{3})_(16x9|4x3).mp4)/gi)
|
|
||||||
+ {
|
|
||||||
+ push @formats, { playpath => $1, resolution => $resolutions->{$3}->{$2}};
|
|
||||||
+ }
|
|
||||||
+
|
|
||||||
+ my $format = $prefs->quality->choose(@formats);
|
|
||||||
+
|
|
||||||
my $rtmp = decode_entities($video =~ /base="(rtmp[^"]+)/);
|
|
||||||
- my($playpath) = $video =~ /(mp4:[^\]]+)/;
|
|
||||||
+ my($playpath) = $format->{"playpath"};
|
|
||||||
my($flv) = $playpath =~ m{/([^/]+)$};
|
|
||||||
|
|
||||||
return {
|
|
@ -1,4 +1,4 @@
|
|||||||
@comment $OpenBSD: PLIST,v 1.2 2010/12/02 21:49:28 sthen Exp $
|
@comment $OpenBSD: PLIST,v 1.3 2011/07/12 13:02:28 sthen Exp $
|
||||||
bin/get_flash_videos
|
bin/get_flash_videos
|
||||||
${P5SITE}/FlashVideo/
|
${P5SITE}/FlashVideo/
|
||||||
${P5SITE}/FlashVideo/Downloader.pm
|
${P5SITE}/FlashVideo/Downloader.pm
|
||||||
@ -12,7 +12,9 @@ ${P5SITE}/FlashVideo/Site.pm
|
|||||||
${P5SITE}/FlashVideo/Site/4od.pm
|
${P5SITE}/FlashVideo/Site/4od.pm
|
||||||
${P5SITE}/FlashVideo/Site/5min.pm
|
${P5SITE}/FlashVideo/Site/5min.pm
|
||||||
${P5SITE}/FlashVideo/Site/Abc.pm
|
${P5SITE}/FlashVideo/Site/Abc.pm
|
||||||
|
${P5SITE}/FlashVideo/Site/Abclocal.pm
|
||||||
${P5SITE}/FlashVideo/Site/About.pm
|
${P5SITE}/FlashVideo/Site/About.pm
|
||||||
|
${P5SITE}/FlashVideo/Site/Adultswim.pm
|
||||||
${P5SITE}/FlashVideo/Site/Amazon.pm
|
${P5SITE}/FlashVideo/Site/Amazon.pm
|
||||||
${P5SITE}/FlashVideo/Site/Aniboom.pm
|
${P5SITE}/FlashVideo/Site/Aniboom.pm
|
||||||
${P5SITE}/FlashVideo/Site/Apple.pm
|
${P5SITE}/FlashVideo/Site/Apple.pm
|
||||||
@ -24,9 +26,12 @@ ${P5SITE}/FlashVideo/Site/Break.pm
|
|||||||
${P5SITE}/FlashVideo/Site/Brightcove.pm
|
${P5SITE}/FlashVideo/Site/Brightcove.pm
|
||||||
${P5SITE}/FlashVideo/Site/Cartoonnetwork.pm
|
${P5SITE}/FlashVideo/Site/Cartoonnetwork.pm
|
||||||
${P5SITE}/FlashVideo/Site/Cbs.pm
|
${P5SITE}/FlashVideo/Site/Cbs.pm
|
||||||
|
${P5SITE}/FlashVideo/Site/Cbsnews.pm
|
||||||
|
${P5SITE}/FlashVideo/Site/Cnet.pm
|
||||||
${P5SITE}/FlashVideo/Site/Collegehumor.pm
|
${P5SITE}/FlashVideo/Site/Collegehumor.pm
|
||||||
${P5SITE}/FlashVideo/Site/Ctv.pm
|
${P5SITE}/FlashVideo/Site/Ctv.pm
|
||||||
${P5SITE}/FlashVideo/Site/Dailymotion.pm
|
${P5SITE}/FlashVideo/Site/Dailymotion.pm
|
||||||
|
${P5SITE}/FlashVideo/Site/Daum.pm
|
||||||
${P5SITE}/FlashVideo/Site/Ehow.pm
|
${P5SITE}/FlashVideo/Site/Ehow.pm
|
||||||
${P5SITE}/FlashVideo/Site/Expertvillage.pm
|
${P5SITE}/FlashVideo/Site/Expertvillage.pm
|
||||||
${P5SITE}/FlashVideo/Site/Flickr.pm
|
${P5SITE}/FlashVideo/Site/Flickr.pm
|
||||||
@ -35,12 +40,14 @@ ${P5SITE}/FlashVideo/Site/Fora.pm
|
|||||||
${P5SITE}/FlashVideo/Site/Freevideo.pm
|
${P5SITE}/FlashVideo/Site/Freevideo.pm
|
||||||
${P5SITE}/FlashVideo/Site/Gamespot.pm
|
${P5SITE}/FlashVideo/Site/Gamespot.pm
|
||||||
${P5SITE}/FlashVideo/Site/Gawker.pm
|
${P5SITE}/FlashVideo/Site/Gawker.pm
|
||||||
|
${P5SITE}/FlashVideo/Site/Globaltv.pm
|
||||||
${P5SITE}/FlashVideo/Site/Google.pm
|
${P5SITE}/FlashVideo/Site/Google.pm
|
||||||
${P5SITE}/FlashVideo/Site/Googlevideosearch.pm
|
${P5SITE}/FlashVideo/Site/Googlevideosearch.pm
|
||||||
${P5SITE}/FlashVideo/Site/Grindtv.pm
|
${P5SITE}/FlashVideo/Site/Grindtv.pm
|
||||||
${P5SITE}/FlashVideo/Site/Ima.pm
|
${P5SITE}/FlashVideo/Site/Ima.pm
|
||||||
${P5SITE}/FlashVideo/Site/Itv.pm
|
${P5SITE}/FlashVideo/Site/Itv.pm
|
||||||
${P5SITE}/FlashVideo/Site/Joemonster.pm
|
${P5SITE}/FlashVideo/Site/Joemonster.pm
|
||||||
|
${P5SITE}/FlashVideo/Site/Kidswb.pm
|
||||||
${P5SITE}/FlashVideo/Site/Last.pm
|
${P5SITE}/FlashVideo/Site/Last.pm
|
||||||
${P5SITE}/FlashVideo/Site/Liveleak.pm
|
${P5SITE}/FlashVideo/Site/Liveleak.pm
|
||||||
${P5SITE}/FlashVideo/Site/Megaporn.pm
|
${P5SITE}/FlashVideo/Site/Megaporn.pm
|
||||||
@ -56,14 +63,20 @@ ${P5SITE}/FlashVideo/Site/Mylifetime.pm
|
|||||||
${P5SITE}/FlashVideo/Site/Myvideo.pm
|
${P5SITE}/FlashVideo/Site/Myvideo.pm
|
||||||
${P5SITE}/FlashVideo/Site/Nbc.pm
|
${P5SITE}/FlashVideo/Site/Nbc.pm
|
||||||
${P5SITE}/FlashVideo/Site/Nfb.pm
|
${P5SITE}/FlashVideo/Site/Nfb.pm
|
||||||
|
${P5SITE}/FlashVideo/Site/Nick.pm
|
||||||
${P5SITE}/FlashVideo/Site/Nicovideo.pm
|
${P5SITE}/FlashVideo/Site/Nicovideo.pm
|
||||||
${P5SITE}/FlashVideo/Site/Pbs.pm
|
${P5SITE}/FlashVideo/Site/Pbs.pm
|
||||||
${P5SITE}/FlashVideo/Site/Pennyarcade.pm
|
${P5SITE}/FlashVideo/Site/Pennyarcade.pm
|
||||||
${P5SITE}/FlashVideo/Site/Redbull.pm
|
${P5SITE}/FlashVideo/Site/Redbull.pm
|
||||||
${P5SITE}/FlashVideo/Site/Redtube.pm
|
${P5SITE}/FlashVideo/Site/Redtube.pm
|
||||||
${P5SITE}/FlashVideo/Site/Ringtv.pm
|
${P5SITE}/FlashVideo/Site/Ringtv.pm
|
||||||
|
${P5SITE}/FlashVideo/Site/Sapo.pm
|
||||||
|
${P5SITE}/FlashVideo/Site/Sbs.pm
|
||||||
|
${P5SITE}/FlashVideo/Site/Scivee.pm
|
||||||
${P5SITE}/FlashVideo/Site/Seesaw.pm
|
${P5SITE}/FlashVideo/Site/Seesaw.pm
|
||||||
${P5SITE}/FlashVideo/Site/Sevenload.pm
|
${P5SITE}/FlashVideo/Site/Sevenload.pm
|
||||||
|
${P5SITE}/FlashVideo/Site/Slashcontrol.pm
|
||||||
|
${P5SITE}/FlashVideo/Site/Spiegel.pm
|
||||||
${P5SITE}/FlashVideo/Site/Spike.pm
|
${P5SITE}/FlashVideo/Site/Spike.pm
|
||||||
${P5SITE}/FlashVideo/Site/Stagevu.pm
|
${P5SITE}/FlashVideo/Site/Stagevu.pm
|
||||||
${P5SITE}/FlashVideo/Site/Starwars.pm
|
${P5SITE}/FlashVideo/Site/Starwars.pm
|
||||||
@ -73,23 +86,28 @@ ${P5SITE}/FlashVideo/Site/Tbs.pm
|
|||||||
${P5SITE}/FlashVideo/Site/Techcast.pm
|
${P5SITE}/FlashVideo/Site/Techcast.pm
|
||||||
${P5SITE}/FlashVideo/Site/Ted.pm
|
${P5SITE}/FlashVideo/Site/Ted.pm
|
||||||
${P5SITE}/FlashVideo/Site/Theonion.pm
|
${P5SITE}/FlashVideo/Site/Theonion.pm
|
||||||
|
${P5SITE}/FlashVideo/Site/Thirteen.pm
|
||||||
${P5SITE}/FlashVideo/Site/Todaysbigthing.pm
|
${P5SITE}/FlashVideo/Site/Todaysbigthing.pm
|
||||||
${P5SITE}/FlashVideo/Site/Tou.pm
|
${P5SITE}/FlashVideo/Site/Tou.pm
|
||||||
${P5SITE}/FlashVideo/Site/Traileraddict.pm
|
${P5SITE}/FlashVideo/Site/Traileraddict.pm
|
||||||
${P5SITE}/FlashVideo/Site/Truveo.pm
|
${P5SITE}/FlashVideo/Site/Truveo.pm
|
||||||
${P5SITE}/FlashVideo/Site/Tudou.pm
|
${P5SITE}/FlashVideo/Site/Tudou.pm
|
||||||
|
${P5SITE}/FlashVideo/Site/Tv.pm
|
||||||
${P5SITE}/FlashVideo/Site/Tva.pm
|
${P5SITE}/FlashVideo/Site/Tva.pm
|
||||||
${P5SITE}/FlashVideo/Site/Ustream.pm
|
${P5SITE}/FlashVideo/Site/Ustream.pm
|
||||||
${P5SITE}/FlashVideo/Site/Videojug.pm
|
${P5SITE}/FlashVideo/Site/Videojug.pm
|
||||||
${P5SITE}/FlashVideo/Site/Videolectures.pm
|
${P5SITE}/FlashVideo/Site/Videolectures.pm
|
||||||
${P5SITE}/FlashVideo/Site/Vimeo.pm
|
${P5SITE}/FlashVideo/Site/Vimeo.pm
|
||||||
|
${P5SITE}/FlashVideo/Site/Vrak.pm
|
||||||
${P5SITE}/FlashVideo/Site/Wat.pm
|
${P5SITE}/FlashVideo/Site/Wat.pm
|
||||||
${P5SITE}/FlashVideo/Site/Xhamster.pm
|
${P5SITE}/FlashVideo/Site/Xhamster.pm
|
||||||
${P5SITE}/FlashVideo/Site/Xnxx.pm
|
${P5SITE}/FlashVideo/Site/Xnxx.pm
|
||||||
${P5SITE}/FlashVideo/Site/Xvideos.pm
|
${P5SITE}/FlashVideo/Site/Xvideos.pm
|
||||||
${P5SITE}/FlashVideo/Site/Youku.pm
|
${P5SITE}/FlashVideo/Site/Youku.pm
|
||||||
|
${P5SITE}/FlashVideo/Site/Youtu.pm
|
||||||
${P5SITE}/FlashVideo/Site/Youtube.pm
|
${P5SITE}/FlashVideo/Site/Youtube.pm
|
||||||
${P5SITE}/FlashVideo/Site/Youtubenocookie.pm
|
${P5SITE}/FlashVideo/Site/Youtubenocookie.pm
|
||||||
|
${P5SITE}/FlashVideo/Site/Zshare.pm
|
||||||
${P5SITE}/FlashVideo/URLFinder.pm
|
${P5SITE}/FlashVideo/URLFinder.pm
|
||||||
${P5SITE}/FlashVideo/Utils.pm
|
${P5SITE}/FlashVideo/Utils.pm
|
||||||
${P5SITE}/FlashVideo/VideoPreferences/
|
${P5SITE}/FlashVideo/VideoPreferences/
|
||||||
|
Loading…
Reference in New Issue
Block a user