Diff for /loncom/publisher/lonrights.pm between versions 1.8 and 1.22

version 1.8, 2003/03/27 20:56:30 version 1.22, 2007/05/02 01:34:23
Line 32  package Apache::lonrights; Line 32  package Apache::lonrights;
   
 use strict;  use strict;
 use Apache::Constants qw(:common :http);  use Apache::Constants qw(:common :http);
 use Apache::lonnet();  use Apache::lonnet;
 use Apache::loncommon();  use Apache::loncommon();
 use HTML::LCParser;  use HTML::LCParser;
 use Apache::File;  use Apache::File;
   use Apache::lonlocal;
   
 sub handler {  sub handler {
   
   my $r=shift;    my $r=shift;
   $r->content_type('text/html');    my $target = $env{'form.grade_target'};
     if ($target eq 'meta') {
         &Apache::loncommon::content_type($r,'text/html');
         $r->send_http_header;
         $env{'request.uri'}=$r->uri;
         my $file = &Apache::lonnet::filelocation("",$r->uri);
         my $content=&Apache::lonnet::getfile($file);
         my $result=&Apache::lonxml::xmlparse(undef,'meta',$content);
         $r->print($result);
         return OK;
     }
     &Apache::loncommon::content_type($r,'text/html');
   $r->send_http_header;    $r->send_http_header;
   
   $r->print(    my $js = &Apache::loncommon::coursebrowser_javascript();
      '<html><head><title>LON-CAPA Custom Distribution Rights</title>'.  
    &Apache::loncommon::coursebrowser_javascript().'</head>');  
   
   $r->print(&Apache::loncommon::bodytag('Custom Distribution Rights'));    $r->print(&Apache::loncommon::start_page('Custom Distribution Rights',$js));
   $r->rflush();    $r->rflush();
   
   my $uri=$r->uri;    my $uri=$r->uri;
Line 57  sub handler { Line 67  sub handler {
   
 # ============================================================ Modify and store  # ============================================================ Modify and store
   if ($constructmode) {    if ($constructmode) {
       if ($ENV{'form.store'}) {        if ($env{'form.store'}) {
   my @newrules=();    my @newrules=();
           undef @newrules;            undef @newrules;
 # read rules from form  # read rules from form
           foreach (keys %ENV) {            foreach (keys %env) {
       if ($_=~/^form\.effect\_(\d+)$/) {        if ($_=~/^form\.effect\_(\d+)$/) {
   my $number=$1;    my $number=$1;
                   my %rulehash=();                    my %rulehash=();
                   foreach ('effect','domain','course','section','role') {                    foreach ('effect','domain','course','section','role') {
       $rulehash{$_}=$ENV{'form.'.$_.'_'.$number};        $rulehash{$_}=$env{'form.'.$_.'_'.$number};
                   }                    }
                   if ($rulehash{'role'} eq 'au') {                    if ($rulehash{'role'} eq 'au') {
       $rulehash{'course'}='';        $rulehash{'course'}='';
Line 79  sub handler { Line 89  sub handler {
           ($rulehash{'effect'} eq 'allow')) {            ($rulehash{'effect'} eq 'allow')) {
       $rulehash{'effect'}='deny';        $rulehash{'effect'}='deny';
                   }                    }
                   $rulehash{'domain'}=~s/\W//g;                    $rulehash{'domain'} = &LONCAPA::clean_domain($rulehash{'domain'});
                   $rulehash{'course'}=~s/\W//g;    $rulehash{'course'} = &LONCAPA::clean_courseid($rulehash{'course'});
                   $rulehash{'section'}=~s/\W//g;                    $rulehash{'section'}=~s/\W//g;
                   unless ($rulehash{'domain'}) {                     unless ($rulehash{'domain'}) { 
                      $rulehash{'domain'}=$ENV{'user.domain'};                        $rulehash{'domain'}=$env{'user.domain'}; 
                   }                    }
                   my $realm='';                    my $realm='';
                   if ($number) {                    if ($number) {
Line 100  sub handler { Line 110  sub handler {
               }                }
           }            }
 # edit actions?  # edit actions?
           foreach (keys %ENV) {            foreach (keys %env) {
       if ($_=~/^form\.action\_(\d+)$/) {        if ($_=~/^form\.action\_(\d+)$/) {
                   my $number=$1;                    my $number=$1;
   if ($ENV{$_} eq 'delete') { $newrules[$number]=''; }    if ($env{$_} eq 'delete') { $newrules[$number]=''; }
                   if (($ENV{$_} eq 'moveup') && ($number>2)) {                    if (($env{$_} eq 'moveup') && ($number>1)) {
       my $buffer=$newrules[$number];        my $buffer=$newrules[$number];
                       $newrules[$number]=$newrules[$number-1];                        $newrules[$number]=$newrules[$number-1];
                       $newrules[$number-1]=$buffer;                        $newrules[$number-1]=$buffer;
                   }                    }
                   if (($ENV{$_} eq 'movedown') && ($number<$#newrules)) {                    if (($env{$_} eq 'movedown') && ($number<$#newrules)) {
       my $buffer=$newrules[$number];        my $buffer=$newrules[$number];
                       $newrules[$number]=$newrules[$number+1];                        $newrules[$number]=$newrules[$number+1];
                       $newrules[$number+1]=$buffer;                        $newrules[$number+1]=$buffer;
                   }                    }
                   if ($ENV{$_} eq 'insertabove') {                    if ($env{$_} eq 'insertabove') {
       for (my $i=$#newrules;$i>=$number;$i--) {        for (my $i=$#newrules;$i>=$number;$i--) {
   $newrules[$i+1]=$newrules[$i];    $newrules[$i+1]=$newrules[$i];
                       }                        }
                       $newrules[$number]='deny';                        $newrules[$number]='deny';
                   }                    }
                   if ($ENV{$_} eq 'insertbelow') {                    if ($env{$_} eq 'insertbelow') {
        for (my $i=$#newrules;$i>$number;$i--) {         for (my $i=$#newrules;$i>$number;$i--) {
   $newrules[$i+1]=$newrules[$i];    $newrules[$i+1]=$newrules[$i];
                       }                        }
Line 161  sub handler { Line 171  sub handler {
   my $parser=HTML::LCParser->new(\$contents);    my $parser=HTML::LCParser->new(\$contents);
   my $token;    my $token;
   my $rulecounter=0;    my $rulecounter=0;
   my $colzero=($constructmode?'Edit action':'Rule');    my $colzero=&mt($constructmode?'Edit action':'Rule');
     my %lt=&Apache::lonlocal::texthash('ef' => 'Effect',
        'do' => 'Domain',
        'co' => 'Course',
        'se' => 'Section',
        'ro' => 'Role');
 # ---------------------------------------------------------- Start table output  # ---------------------------------------------------------- Start table output
   $r->print(<<ENDSTARTTABLE);    $r->print(<<ENDSTARTTABLE);
 <table border="2">  <table border="2">
     <tr><th>$colzero</th><th>Effect</th><th>Domain</th><th>Course</th>      <tr><th>$colzero</th><th>$lt{'ef'}</th><th>$lt{'do'}</th><th>$lt{'co'}</th>
 <th>Section</th><th>Role</th></tr>  <th>$lt{'se'}</th><th>$lt{'ro'}</th></tr>
 ENDSTARTTABLE  ENDSTARTTABLE
 # --------------------------------------------------------------------- Default  # --------------------------------------------------------------------- Default
 # Fast forward to first rule  # Fast forward to first rule
Line 193  ENDSTARTTABLE Line 208  ENDSTARTTABLE
   }    }
   $r->print('</td><td colspan="4">Default');    $r->print('</td><td colspan="4">Default');
   if (($token->[2]->{'realm'}) || ($token->[2]->{'role'})) {    if (($token->[2]->{'realm'}) || ($token->[2]->{'role'})) {
       $r->print(' - <font color="red">Error! No default set.</font>');        $r->print(' - <font color="red">'.&mt('Error! No default set.').
    '</font>');
   }    }
   $r->print('</td></tr>');    $r->print('</td></tr>');
 # Additional roles  # Additional roles
Line 227  ENDSTARTTABLE Line 243  ENDSTARTTABLE
   $r->print('</td><td>');    $r->print('</td><td>');
 # ---- realm  # ---- realm
           my $realm=$token->[2]->{'realm'};            my $realm=$token->[2]->{'realm'};
           $realm=~s/^\W//;  
           my ($rdom,$rcourse,$rsec)=split(/[\/\_]/,$realm);            my ($rdom,$rcourse,$rsec)=split(/[\/\_]/,$realm);
     $rdom = &LONCAPA::clean_domain($rdom);
     $rcourse = &LONCAPA::clean_courseid($rcourse);
 # realm domain  # realm domain
           if ($constructmode) {            if ($constructmode) {
               unless ($rdom) { $rdom=$ENV{'user.domain'}; }                unless ($rdom) { $rdom=$env{'user.domain'}; }
               $r->print(&Apache::loncommon::select_dom_form($rdom,                $r->print(&Apache::loncommon::select_dom_form($rdom,
                                                       'domain_'.$rulecounter));                                                        'domain_'.$rulecounter));
           } else {            } else {
Line 246  ENDSTARTTABLE Line 263  ENDSTARTTABLE
               $r->print($rcourse);                $r->print($rcourse);
           }            }
   
           $r->print('</td><td rowspan="2">');            $r->print('</td><td>');
 # realm section  # realm section
           if ($constructmode) {            if ($constructmode) {
              $r->print('<input input type="text" size="5" name="section_'.               $r->print('<input input type="text" size="5" name="section_'.
Line 270  ENDSTARTTABLE Line 287  ENDSTARTTABLE
               $r->print(&Apache::lonnet::plaintext($token->[2]->{'role'}));                $r->print(&Apache::lonnet::plaintext($token->[2]->{'role'}));
           }            }
 # course selection link  # course selection link
           $r->print('</td></tr><tr><td colspan="2" align="right">');            $r->print('</td></tr><tr><td colspan="3" align="right">');
           if ($rcourse) {            if ($rcourse) {
       my %descript=        my %descript=
                  &Apache::lonnet::coursedescription($rdom.'_'.$rcourse);                   &Apache::lonnet::coursedescription($rdom.'_'.$rcourse,
       {'one_time' => 1});
               $r->print($descript{'description'}.'&nbsp;&nbsp;&nbsp;');                $r->print($descript{'description'}.'&nbsp;&nbsp;&nbsp;');
           }            }
           $r->print(&Apache::loncommon::selectcourse_link('rules',    if ($constructmode) {
     'course_'.$rulecounter,'domain_'.$rulecounter));        $r->print(&Apache::loncommon::selectcourse_link('rules',
           'course_'.$rulecounter,'domain_'.$rulecounter));
     }
 # close row  # close row
           $r->print('</td></tr>');            $r->print('</td></tr>');
      }                                              }                                       
Line 285  ENDSTARTTABLE Line 305  ENDSTARTTABLE
   $r->print('</table>');    $r->print('</table>');
 # ------------------------------------------------------------ End table output  # ------------------------------------------------------------ End table output
   if ($constructmode) {     if ($constructmode) { 
      $r->print('<input type="submit" name="store" value="Store" /></form>');        $r->print('<input type="submit" name="store" value="'.&mt('Save').'" /></form>'); 
   }    }
   $r->print('</body></html>');    $r->print(&Apache::loncommon::end_page());
   return OK;      return OK;  
 }  }
   

Removed from v.1.8  
changed lines
  Added in v.1.22


FreeBSD-CVSweb <freebsd-cvsweb@FreeBSD.org>