Diff for /loncom/publisher/lonrights.pm between versions 1.10 and 1.21

version 1.10, 2003/09/22 15:39:53 version 1.21, 2006/12/20 22:41:08
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;
Line 41  use Apache::lonlocal; Line 41  use Apache::lonlocal;
 sub handler {  sub handler {
   
   my $r=shift;    my $r=shift;
     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');    &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 58  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 80  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 101  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 163  sub handler { Line 172  sub handler {
   my $token;    my $token;
   my $rulecounter=0;    my $rulecounter=0;
   my $colzero=&mt($constructmode?'Edit action':'Rule');    my $colzero=&mt($constructmode?'Edit action':'Rule');
 my %lt=&Apache::loncommon::texthash('ef' => 'Effect',    my %lt=&Apache::lonlocal::texthash('ef' => 'Effect',
     'do' => 'Domain',       'do' => 'Domain',
     'co' => 'Course',       'co' => 'Course',
     'se' => 'Section/Group',       'se' => 'Section',
     'ro' => 'Role');       'ro' => 'Role');
 # ---------------------------------------------------------- Start table output  # ---------------------------------------------------------- Start table output
   $r->print(<<ENDSTARTTABLE);    $r->print(<<ENDSTARTTABLE);
 <table border="2">  <table border="2">
Line 234  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 280  ENDSTARTTABLE Line 290  ENDSTARTTABLE
           $r->print('</td></tr><tr><td colspan="3" 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 294  ENDSTARTTABLE Line 307  ENDSTARTTABLE
   if ($constructmode) {     if ($constructmode) { 
      $r->print('<input type="submit" name="store" value="'.&mt('Store').'" /></form>');        $r->print('<input type="submit" name="store" value="'.&mt('Store').'" /></form>'); 
   }    }
   $r->print('</body></html>');    $r->print(&Apache::loncommon::end_page());
   return OK;      return OK;  
 }  }
   

Removed from v.1.10  
changed lines
  Added in v.1.21


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