--- comics/fetch.pl.new 2018/02/06 14:31:06 1.24
+++ comics/fetch.pl.new 2020/06/10 21:32:52 1.29
@@ -2,6 +2,21 @@
###############################################################################
# $Log: fetch.pl.new,v $
+# Revision 1.29 2020/06/10 21:32:52 nick
+# Centered page
+#
+# Revision 1.28 2020/06/10 21:14:31 nick
+# Updated for w3 validation.
+#
+# Revision 1.27 2019/04/15 12:50:23 nick
+# The script was unable to handle html '&' and convert it, so I added that. I probably should see if there's a library or something that handles all those automagically but I just tossed a regex in there for now that does the trick.
+#
+# Revision 1.26 2018/04/22 14:03:54 nick
+# Changed the default for Sunday comics that was causing issues with some comics.
+#
+# Revision 1.25 2018/02/12 13:30:58 nick
+# Added an easier to compare date string to determine if the status json file was updated today and report if it wasn't.
+#
# Revision 1.24 2018/02/06 14:31:06 nick
# A status report is now generated in JSON that can easily be scanned so that
# I can be alerted when there are failures that I miss if I don't read the
@@ -53,7 +68,7 @@ use Date::Calc qw/Date_to_Text_Long Toda
##
## Some default values
##
-my $ver = '$Id: fetch.pl.new,v 1.24 2018/02/06 14:31:06 nick Exp $';
+my $ver = '$Id: fetch.pl.new,v 1.29 2020/06/10 21:32:52 nick Exp $';
my $comicFile = "comics.conf";
my $comicConfigVer = "Unknown";
my $reportFile = "/home/httpd/html/daily/comics/status_report.json";
@@ -83,7 +98,7 @@ foreach my $comic ( sort keys %comics )
## Skip if this is Sunday and the comic is weekdays only
next if ( $comic =~ m/config/ );
if (($dates{'wday'} eq "Sunday") &&
- ($comics{$comic}{'sunday'} == 0)) {
+ ($comics{$comic}{'not_sunday'} == 1)) {
print "Skipping '$comic'; Weekdays only.\n";
next;
}
@@ -94,7 +109,7 @@ foreach my $comic ( sort keys %comics )
print "Skipping '$comic' ($comics{$comic}{'sunday_only'}); Sunday only.\n";
next
}
-
+
$comics{$comic}{'error'} = &downloadComic ( \%comics, $comic, \%dates );
&writeComic ( \%comics, $comic, \%dates );
@@ -183,7 +198,7 @@ sub readComicConfig ($$) {
$comicConfig{$res[0]}{'mode'} = $res[3];
$comicConfig{$res[0]}{'fullName'} = $res[4];
$comicConfig{$res[0]}{'ext'} = $res[5];
- $comicConfig{$res[0]}{'sunday'} = sprintf("%d", $res[6] || 1);
+ $comicConfig{$res[0]}{'not_sunday'} = sprintf("%d", $res[6] || 0);
$comicConfig{$res[0]}{'sunday_only'} = sprintf("%d", $res[7] || 0);
$comicConfig{$res[0]}{'remove_newlines'} = sprintf("%d", $res[8] || 0);
$comicConfig{$res[0]}{'error'} = 0;
@@ -202,7 +217,10 @@ sub readComicConfig ($$) {
sub writeStatusReportJSON ($$) {
my ( $comicsRef, $filename ) = @_;
my %comics = %$comicsRef;
- my %json = ('date' => $DATE, 'comics' => []);
+ my $shortDate = sprintf("%d%02d%02d", (localtime)[5] + 1900,
+ (localtime)[4] + 1,
+ (localtime)[3]);
+ my %json = ('date' => $shortDate, 'comics' => ());
my $totalErrors = 0;
foreach my $comic (sort keys %comics) {
@@ -211,13 +229,13 @@ sub writeStatusReportJSON ($$) {
my %error = ('comicName' => "$comics{$comic}{'fullName'}",
'error' => "$comics{$comic}{'error'}",
'status' => "Error");
- push $json{'comics'}, \%error;
+ push @{$json{'comics'}}, \%error;
$totalErrors += 1;
} else {
my %status = ('comicName' => "$comics{$comic}{'fullName'}",
'error' => 0,
'status' => "Successfull");
- push $json{'comics'}, \%status;
+ push @{$json{'comics'}}, \%status;
}
}
$json{'totalErrors'} = $totalErrors;
@@ -235,6 +253,7 @@ sub writeComic ($$) {
my $indexFile = $indexDir . "/index-" . $date->{'year2'} .
$date->{'mon2'} . $date->{'day2'} . "-" .
$sd . ".html";
+ $comics->{$comic}{'fullName'} =~ s/&/&/g;
my $content = <
+Generated on: $sysDate
-Version: $ver
-Config Version: $comicConfigVer
-CVS: http://demandred.dyndns.org/cgi-bin/cvsweb/comics/
-
+Version: $ver
+Config Version: $comicConfigVer
+CVS: http://demandred.dyndns.org/cgi-bin/cvsweb/comics/
+
-
-
|
@@ -342,19 +359,15 @@ sub writeTitle ($$) {
- - + +