+ while ($tag = $p->get_tag('div', 'meta', 'script')) {
+ if ('meta' eq $tag->[0]) {
+ if ('title' eq $tag->[1]->{'name'}) {
+ $metadata->{'TITLE'} = $tag->[1]->{'content'};
+ $self->debug('Title found: %s', $metadata->{'TITLE'});
+ }
+ } elsif ('script' eq $tag->[0]) {
+ $e = $p->get_text();
+ $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;
+ }
+ }
+
+ $self->debug('URL found: %s', $metadata->{'DLURL'});
+ }
+ } elsif ('div' eq $tag->[0]) {
+ if (exists($tag->[1]->{'class'}) and ('errorBox' eq $tag->[1]->{'class'})) {
+ $self->error("Could not get video data for youtube %s: %s",
+ $metadata->{'ID'}, $p->get_trimmed_text());
+ return undef;
+ }