Diff for /loncom/publisher/lonrights.pm between versions 1.16 and 1.17

version 1.16, 2005/02/18 23:15:54 version 1.17, 2005/04/07 06:56:27
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'};    my $target = $env{'form.grade_target'};
   if ($target eq 'meta') {    if ($target eq 'meta') {
       &Apache::loncommon::content_type($r,'text/html');        &Apache::loncommon::content_type($r,'text/html');
       $r->send_http_header;        $r->send_http_header;
       $ENV{'request.uri'}=$r->uri;        $env{'request.uri'}=$r->uri;
       my $file = &Apache::lonnet::filelocation("",$r->uri);        my $file = &Apache::lonnet::filelocation("",$r->uri);
       my $content=&Apache::lonnet::getfile($file);        my $content=&Apache::lonnet::getfile($file);
       my $result=&Apache::lonxml::xmlparse(undef,'meta',$content);        my $result=&Apache::lonxml::xmlparse(undef,'meta',$content);
Line 69  sub handler { Line 69  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 95  sub handler { Line 95  sub handler {
                   $rulehash{'course'}=~s/\W//g;                    $rulehash{'course'}=~s/\W//g;
                   $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 112  sub handler { Line 112  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>1)) {                    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 249  ENDSTARTTABLE Line 249  ENDSTARTTABLE
           my ($rdom,$rcourse,$rsec)=split(/[\/\_]/,$realm);            my ($rdom,$rcourse,$rsec)=split(/[\/\_]/,$realm);
 # 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 {

Removed from v.1.16  
changed lines
  Added in v.1.17


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