Further work on MHC interface
[tpope-extra.git] / perl / sctweb
index af6bdc68bedd206585efce73f0896c1e5ed222fa..7c6f23ea7280b08f616feed7c024eb97cb103072 100755 (executable)
@@ -2,6 +2,10 @@
 # $Id$
 # -*- perl -*- vim: ft=perl sw=4 sts=4
 
+# Brief usage instructions:
+# Create a ~/.sctwebrc that has SID=yourssn and PIN=yourpin
+# You'll need to change the url below if you go anywhere but Northwest Vista.
+
 use strict;
 use LWP::UserAgent;
 use HTML::TableExtract;
@@ -25,19 +29,34 @@ $ua->env_proxy;
 $ua->cookie_jar( {} );
 $ua->get("$url&tserve_tip_write=||WID&tserve_transconfig=astulog.cfg") or die "$!";
 $response = $ua->post("$url&tserve_trans_config=astulog.cfg", { tserve_tip_write => "%7C%7CWID%7CSID%7CPIN", SID => $opts{SID}, PIN => $opts{PIN} }) or die "$!";
-#print $response->content;
-#die "Site down.  Try again later.\n" if(length($response->content)<256);
 
 $response = $ua->get("$url&tserve_tip_write=||WID|SID|PIN|Term&tserve_trans_config=" . ("regterm.cfg"||"rgrdterm.cfg")); # Valid terms
 die $response->status_line unless $response->is_success;
 my @terms = grep {s/^<option value="([^"]*)">.*/$1/} (split( /\r\n/, $response->content));
 die "Site down. Try again later.\n" unless (@terms);
 
-sub do_schedule {
-    my @readheaders = ("Section ID/Title", "Instructor", "Days", "Time", "Start/EndDates", "Site/Building/Room");
-    my @showheaders = ("Section ID/Title", "Instructor", "Days", "Time", "Start/End\nDates", "Location");
-    my $te = new HTML::TableExtract( headers => [ @readheaders ] );
-    my (@terms, $row);
+sub capitalize {
+    local $_ = shift;
+    s/\b([A-Z])([A-Z]*)\b/$1\L$2/g;
+    s/\b(I)(i*)\b/$1\U$2/g;
+    s/\bUs\b/US/g;
+    s/ (And|For|Of|Or|The|To|With) / \l$1 /g;
+    s/\b(Ma?c)([a-z])/$1\u$2/g;
+    s/\b(Tcp\/Ip|Pc)\b/\U$&/g;
+    s/\bThru\b/Through/g;
+    s/\bAcct\b/Accounting/g;
+    s/\bAmer\b/American/g;
+    s/\bChem\b/Chemistry/g;
+    s/\bComp\b/Composition/g;
+    s/\bFed\b/Federal/g;
+    s/\bGen\b/General/g;
+    #s/\bGovt\b/Government/g;
+    s/\bLit\b/Literature/g;
+    s/\bPrin\b/Principles/g;
+    return $_;
+}
+sub get_schedule_terms {
+    my @terms;
     my @localtime=localtime();
     if ($localtime[4]<3) { # Through Mar 31
        @terms=((1900+$localtime[5])*10+2);
@@ -52,6 +71,55 @@ sub do_schedule {
     } else {
        @terms=((1900+$localtime[5])*10+1,(1901+$localtime[5])*10+2);
     }
+    return @terms;
+}
+
+sub do_mhc_schedule {
+    my @readheaders = ("Section ID/Title", "Days", "Time", "Start/EndDates", "Site/Building/Room");
+    my %days = (M => "Mon", T => "Tue", W => "Wed", R => "Thu", F => "Fri", S => "Sat");
+    my $te = new HTML::TableExtract( headers => [ @readheaders ] );
+    my (@terms, $row);
+    @terms = get_schedule_terms();
+    foreach(@ARGV || @terms) {
+       $response = $ua->get("$url&tserve_tip_write=||WID|SID|PIN|Term&tserve_trans_config=" . ($opts{cfg} || "rstusch" || "rgrades") . ".cfg&Term=".($_) );
+       die $response->status_line unless $response->is_success;
+       $te->parse($response->content);
+    }
+    print "# MHC school schedule\n";
+    print "# Autogenerated by sctweb ".localtime()."\n";
+    foreach $ts ($te->table_states) {
+       foreach $row ($ts->rows) {
+           map { s/\xa0//g; s/\n/-/g; $_} @$row;
+           $row->[0] =~ s/.*launchWebCT\("([^"]*)"\).*/$1/s;
+           $row->[0] =~ s/.*<BR>//g;
+           $row->[0] = capitalize($row->[0]);
+           $row->[1] =~ s/([MTWRFS])/ $days{$1}/g;
+           if($row->[2] =~ /^(\d\d):\d\d-(\d\d):\d\dPM$/) {
+               $row->[2] =~ s/^(\d\d)/$1+12/e
+               if($1 < $2);
+               $row->[2] =~ s/-(\d\d)/"-".($1+12)/e;
+               $row->[2] =~ s/PM$//;
+           } else { $row->[2] =~ s/AM$//; }
+           $row->[3] =~ s/(\d\d)-(\d\d)-(\d\d)/20$3$1$2/g;
+           $row->[4] =~ s/ON CAMPUS-//g;
+           $row->[4] =~ s/-/ /g;
+           print "\n";
+           print "X-SC-Subject: ", $row->[0], "\n";
+           print "X-SC-Category: School\n";
+           print "X-SC-Cond:", $row->[1], "\n"; # Space after colon not needed
+           print "X-SC-Time: ", $row->[2], "\n";
+           print "X-SC-Duration: ", $row->[3], "\n";
+           print "X-SC-Location: ", $row->[4], "\n";
+       }
+    }
+}
+
+sub do_html_schedule {
+    my @readheaders = ("Section ID/Title", "Instructor", "Days", "Time", "Start/EndDates", "Site/Building/Room");
+    my @showheaders = ("Section ID/Title", "Instructor", "Days", "Time", "Duration", "Location");
+    my $te = new HTML::TableExtract( headers => [ @readheaders ] );
+    my (@terms, $row);
+    @terms = get_schedule_terms();
     foreach(@ARGV || @terms) {
        $response = $ua->get("$url&tserve_tip_write=||WID|SID|PIN|Term&tserve_trans_config=" . ($opts{cfg} || "rstusch" || "rgrades") . ".cfg&Term=".($_) );
        die $response->status_line unless $response->is_success;
@@ -64,7 +132,8 @@ sub do_schedule {
        foreach $row ($ts->rows) {
            map { s/\xa0//g; s/\n/<br \/>/g; $_} @$row;
            $row->[0] =~ s/.*launchWebCT\("([^"]*)"\).*/$1/s;
-           $row->[0] =~ s/ <BR>/<br \/>/g;
+           $row->[0] =~ s/ <BR>(.*)/"<br \/>" . capitalize($1)/eg;
+           $row->[1] = capitalize($row->[1]);
            $row->[5] =~ s/ON CAMPUS<br \/>//g;
            $row->[5] =~ s/<br \/>/ /g;
            print '<tr><td>';
@@ -75,7 +144,7 @@ sub do_schedule {
     print "</table>\n";
 }
 
-sub do_grades {
+sub do_html_grades {
     my @readheaders = ("Section ID", "Course Title", "Grade", "Attempted  Hours", "Earned  Hours", "Quality  Hours", "Quality  Points", "GPA");
     my @showheaders = ("Section ID", "Course Title", "Grade", "Attempted<br>Hours", "Earned<br>Hours", "Quality<br>Hours", "Quality<br>Points", "GPA");
     my ($row, $lastrow);
@@ -94,8 +163,7 @@ sub do_grades {
     foreach $ts ($te->table_states) {
        foreach $row ($ts->rows) {
            map { s/\xa0//g; s/\n/<br \/>/g; $_} @$row;
-           #$row->[0] =~ s/.*launchWebCT\("([^"]*)"\).*/$1/s;
-           #$row->[0] =~ s/ <BR>/<br \/>/s;
+           $row->[1] = capitalize($row->[1]);
            $lastrow=$row;
            next if $row->[0] =~ /:/;
            print '<tr><td>';
@@ -103,18 +171,22 @@ sub do_grades {
            print "</td></tr>\n";
        }
     }
-    print '<tr><td colspan="3">', $lastrow->[0];
+    print '<tr><td colspan="2">', capitalize($lastrow->[0]);
     shift @$lastrow; shift @$lastrow;
+    print "</td><td>";
     print join('</td><td>', @$lastrow);
     print "</td></tr>\n";
     print "</table>\n";
 }
 
-if(defined($ARGV[0]) && $ARGV[0] eq "-g") {
+if (defined($ARGV[0]) && $ARGV[0] eq "-g") {
+    shift;
+    do_html_grades;
+} elsif (defined($ARGV[0]) && $ARGV[0] eq "-s") {
     shift;
-    do_grades;
+    do_html_schedule;
 } else {
-    do_schedule;
+    do_mhc_schedule;
 }
 
 $ua->get("$url&tserve_trans_config=alogout.cfg"); # Logout