[system] / trunk / webwork2 / lib / Apache / WeBWorK.pm Repository:
ViewVC logotype

View of /trunk/webwork2/lib/Apache/WeBWorK.pm

Parent Directory Parent Directory | Revision Log Revision Log


Revision 820 - (download) (as text) (annotate)
Fri Apr 25 05:10:08 2003 UTC (10 years, 1 month ago) by malsyned
File size: 5750 byte(s)
Added the instructor URL dispatching.
-dennis

    1 ################################################################################
    2 # WeBWorK mod_perl (c) 2000-2002 WeBWorK Project
    3 # $Id$
    4 ################################################################################
    5 
    6 package Apache::WeBWorK;
    7 
    8 =head1 NAME
    9 
   10 Apache::WeBWorK - The WeBWorK dispatcher module.
   11 
   12 =cut
   13 
   14 use strict;
   15 use warnings;
   16 use Apache::Constants qw(:common REDIRECT);
   17 use Apache::Request;
   18 use WeBWorK::Authen;
   19 use WeBWorK::Authz;
   20 use WeBWorK::ContentGenerator::Feedback;
   21 use WeBWorK::ContentGenerator::Login;
   22 use WeBWorK::ContentGenerator::Logout;
   23 use WeBWorK::ContentGenerator::Hardcopy;
   24 use WeBWorK::ContentGenerator::Options;
   25 use WeBWorK::ContentGenerator::Problem;
   26 use WeBWorK::ContentGenerator::ProblemSet;
   27 use WeBWorK::ContentGenerator::ProblemSets;
   28 use WeBWorK::ContentGenerator::Professor;
   29 use WeBWorK::ContentGenerator::Test;
   30 use WeBWorK::CourseEnvironment;
   31 use WeBWorK::DB;
   32 
   33 # This module should be installed as a Handler for the location selected for
   34 # WeBWorK on your webserver. Here is an example of a stanza that can be added
   35 # to your httpd.conf file to achieve this:
   36 #
   37 # <IfModule mod_perl.c>
   38 #   PerlFreshRestart On
   39 #   <Location /webwork>
   40 #     SetHandler perl-script
   41 #     PerlHandler Apache::WeBWorK
   42 #     PerlSetVar webwork_root /path/to/webwork-modperl
   43 #     <Perl>
   44 #       use lib '/path/to/webwork-modperl/lib';
   45 #       use lib '/path/to/webwork-modperl/pglib';
   46 #     </Perl>
   47 #   </Location>
   48 # </IfModule>
   49 
   50 sub handler() {
   51   my $r = Apache::Request->new(shift); # have to deal with unpredictable GET or POST data, and sift through it for the key.  So use Apache::Request
   52 
   53   # This stuff is pretty much copied out of the O'Reilly mod_perl book.
   54   # It's for figuring out the basepath.  I may change this up if I
   55   # find a better way to do it.
   56   my $path_info = $r->path_info || "";
   57   my $current_uri = $r->uri;
   58   my $args = $r->args;
   59 
   60   $current_uri =~ m/^(.*)$path_info/;
   61   my $urlRoot = $1;
   62 
   63   # If it's a valid WeBWorK URI, it ends in a /.  This is assumed
   64   # alllll over the place.
   65   unless (substr($current_uri,-1) eq '/') {
   66     $r->header_out(Location => "$current_uri/" . ($args ? "?$args" : ""));
   67     return REDIRECT;
   68     # *** any post data gets lost here -- fix that.
   69   }
   70 
   71   # Create the @components array, which contains the path specified in the URL
   72   my($junk, @components) = split "/", $path_info;
   73   my $webwork_root = $r->dir_config('webwork_root'); # From a PerlSetVar in httpd.conf
   74   my $course = shift @components;
   75 
   76   # Try to get the course environment.
   77   my $ce = eval {WeBWorK::CourseEnvironment->new($webwork_root, $urlRoot, $course);};
   78   if ($@) { # If there was an error getting the requested course
   79     # TODO: display an error page.  For now, 404 it.
   80     warn $@;
   81     return DECLINED;
   82   }
   83 
   84   # If no course was specified, redirect to the home URL
   85   unless (defined $course) {
   86     $r->header_out(Location => $ce->{webworkURLs}->{home});
   87     return REDIRECT;
   88   }
   89 
   90   # Freak out if the requested course doesn't exist.  For now, this is just a
   91   # check to see if the course directory exists.
   92   if (!-e $ce->{webworkDirs}->{courses} . "/$course") {
   93     warn "Course directory for $course not found at "
   94       . $ce->{webworkDirs}->{courses} . "/$course" ."\n";
   95     return DECLINED;
   96   }
   97 
   98   # Bring up a connection to the database (for Authen/Authz, and eventually
   99   # to be passed to content generators, when we clean this file up).
  100   my $db = WeBWorK::DB->new($ce);
  101 
  102   ### Begin dispatching ###
  103 
  104   # WeBWorK::Authen::verify erases the passwd field and sets the key field
  105   # if login is successful.
  106   if (!WeBWorK::Authen->new($r, $ce, $db)->verify) {
  107     return WeBWorK::ContentGenerator::Login->new($r, $ce, $db)->go;
  108   } else {
  109     # After we are authenticated, there are some things that need to be
  110     # sorted out, Authorization-wize, before we start dispatching to individual
  111     # content generators.
  112     my $user = $r->param("user");
  113     my $effectiveUser = $r->param("effectiveUser") || $user;
  114     my $su_authorized = WeBWorK::Authz->new($r, $ce, $db)->hasPermissions($user, "become_student", $effectiveUser);
  115     $effectiveUser = $user unless $su_authorized;
  116     $r->param("effectiveUser", $effectiveUser);
  117 
  118     my $arg = shift @components;
  119     if (!defined $arg) { # We want the list of problem sets
  120       return WeBWorK::ContentGenerator::ProblemSets->new($r, $ce, $db)->go;
  121     } elsif ($arg eq "hardcopy") {
  122       my $hardcopyArgument = shift @components;
  123       $hardcopyArgument = "" unless defined $hardcopyArgument;
  124       return WeBWorK::ContentGenerator::Hardcopy->new($r, $ce, $db)->go($hardcopyArgument);
  125     } elsif ($arg eq "instructor") {
  126       return WeBWorK::ContentGenerator::Instructor->new($r, $ce, $db)->go;
  127     } elsif ($arg eq "prof") {
  128       return WeBWorK::ContentGenerator::Professor->new($r, $ce, $db)->go;
  129     } elsif ($arg eq "options") {
  130       return WeBWorK::ContentGenerator::Options->new($r, $ce, $db)->go;
  131     } elsif ($arg eq "feedback") {
  132       return WeBWorK::ContentGenerator::Feedback->new($r, $ce, $db)->go;
  133     } elsif ($arg eq "logout") {
  134       return WeBWorK::ContentGenerator::Logout->new($r, $ce, $db)->go;
  135     } elsif ($arg eq "test") {
  136       return WeBWorK::ContentGenerator::Test->new($r, $ce, $db)->go;
  137     } else { # We've got the name of a problem set.
  138       my $problem_set = $arg;
  139       my $ps_arg = shift @components;
  140 
  141       if (!defined $ps_arg) {
  142         # list the problems in the problem set
  143         return WeBWorK::ContentGenerator::ProblemSet->new($r, $ce, $db)->go($problem_set);
  144       } else {
  145         # We've got the name of a problem
  146         my $problem = $ps_arg;
  147         return WeBWorK::ContentGenerator::Problem->new($r, $ce, $db)->go($problem_set, $problem);
  148       }
  149     }
  150 
  151   }
  152 
  153   # If the dispatcher doesn't know any modules that want to handle
  154   # the current path, it'll claim that the path does not exist by
  155   # declining the request.
  156   return DECLINED;
  157 }
  158 
  159 1;

aubreyja at gmail dot com
ViewVC Help
Powered by ViewVC 1.0.9