blob: fec911d0e19c9b2c59e397ddbe0d365e9d9a7f36 (
plain)
1
2
3
4
5
6
7
8
9
10
11
12
13
14
15
16
17
18
19
20
21
22
23
24
25
26
27
28
29
30
31
32
33
34
35
36
37
38
39
40
41
42
43
44
45
46
47
48
49
50
51
52
53
54
55
56
57
58
59
60
61
62
63
64
65
66
67
68
69
70
71
72
73
74
75
76
77
78
79
80
81
82
83
84
85
86
87
|
#!/usr/bin/perl -w
#
#
# rhautoimport
#
# Copyright (C) 2009-2016 Christian Pointner <equinox@helsinki.at>
#
# This file is part of rhautoimport.
#
# rhautoimport 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
# any later version.
#
# rhautoimport 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.
#
# You should have received a copy of the GNU General Public License
# along with rhautoimport. If not, see <http://www.gnu.org/licenses/>.
#
use strict;
use XML::Feed;
use XML::Feed::Entry;
use XML::Feed::Content;
use XML::Feed::Enclosure;
use File::Fetch;
use HTML::Entities;
$XML::Feed::MULTIPLE_ENCLOSURES=1;
binmode(STDIN, ":utf8");
binmode(STDOUT, ":utf8");
binmode(STDERR, ":utf8");
if(@ARGV == 0) {
print "You have to supply a Series ID\n";
exit 1;
}
my $RSS_URL = "http://cba.fro.at/seriesrss/$ARGV[0]?c=Kfs2IoV2Wmd&limit=10000";
print "Fetching files form '$RSS_URL'\n";
my $feed = XML::Feed->parse(URI->new($RSS_URL))
or die "Error fetching feed: " . XML::Feed->errstr;
my $i = 1;
for my $entry ($feed->entries) {
if($entry->enclosure) {
my $sum_title = decode_entities($entry->title);
my $sum_text = decode_entities($entry->content->body);
my $j = 1;
for my $enclosure ($entry->enclosure) {
if($enclosure->type eq "audio/mpeg" || $enclosure->type eq "audio/ogg") {
print "$i/$j: (" . $enclosure->type . ", " . $enclosure->length . ") " . $enclosure->url . "\n";
my $url = $enclosure->url;
if($url =~ /^(.*)_cut(\.[^\.]+)$/) {
$url = $1 . $2;
}
# if($i <= 100) {
# print" --> skipping " . $url . "\n";
# last;
# }
my $ff = File::Fetch->new(uri => $url);
print " --> downloading " . $url . " (" . $enclosure->length . " Bytes) .. ";
my $file = $ff->fetch() or die $ff->error;
print "ok\n";
my $notefile = $file . "_notes";
unlink($notefile);
open(my $fhs, '>', $notefile);
binmode($fhs, ":utf8");
print $fhs $sum_title . "\n\n" . $sum_text . "\n";
close($fhs);
last;
}
$j++;
}
print "\n";
$i++;
}
}
|