- if ($e =~ m|/watch_fullscreen\?(.+)\x27|) {
- my %args = map { split(/=/, $_, 2); } split(/&/, $1);
- $metadata->{'DLURL'} = sprintf('http://www.youtube.com/get_video.php?video_id=%s&t=%s',
- $metadata->{'ID'}, $args{'t'});
+ $self->debug("Found script: %s", $e);
+ if ($e =~ m|\x22fmt_url_map\x22\s*:\s*\x22([^\x22]+)\x22|) {
+ $self->debug("Found fmt_url_map: %s", $1);
+ my $urls = $1;
+ my %urls;
+
+ $urls =~ s/%([[:xdigit:]]{2})/chr(hex($1))/ge;
+ %urls = split(/[\|,]/, $urls);
+ $self->debug("Found quality levels [%s]", join(", ", keys(%urls)));
+
+ foreach (keys(%urls)) {
+ if ($_ == 35) {
+ $self->debug('Found flv,h264,large: %s', $urls{$_});
+ } elsif ($_ == 34) {
+ $self->debug('Found flv,h264: %s', $urls{$_});
+ } elsif ($_ == 22) {
+ $self->debug('Found mp4,h264,large: %s', $urls{$_});
+ } elsif ($_ == 18) {
+ $self->debug('Found mp4,h264: %s', $urls{$_});
+ } elsif ($_ == 5) {
+ $self->debug('Found flv,flv: %s', $urls{$_});
+ } else {
+ $self->error('Unknown tag %s: %s', $_, $urls{$_});
+ }
+ }
+
+ foreach (@{$preflist}) {
+ if (exists($urls{$_})) {
+ $self->debug("Selected URL with quality level %s", $_);
+ $metadata->{'DLURL'} = $urls{$_};
+ last;
+ }
+ }
+