');
+
my $rolesdump=&Apache::lonnet::reply(
"dump:$ccdomain:$ccuname:roles",$uhome);
unless ($rolesdump eq 'con_lost') {
@@ -125,23 +291,29 @@ ENDENHEAD
my ($trole,$tend,$tstart)=split(/_/,$role);
my $bgcol='ffffff';
my $allows=0;
- if ($area=~/^\/(\w+)\/(\d\w+)\/(\w+)/) {
+ if ($area=~/^\/(\w+)\/(\d\w+)/) {
my %coursedata=&Apache::lonnet::coursedescription($1.'_'.$2);
- $area='Course: '.
- $coursedata{'description'}.' Section/Group: '.$3;
+ my $carea='Course: '.$coursedata{'description'};
$inccourses{$1.'_'.$2}=1;
- if (&Apache::lonnet::allowed('c'.$trole,$1.'_'.$2)) {
+ if (&Apache::lonnet::allowed('c'.$trole,$1.'/'.$2)) {
$allows=1;
}
$bgcol=$1.'_'.$2;
$bgcol=~s/[^8-9b-e]//g;
$bgcol=substr($bgcol.$bgcol.$bgcol.'ffffff',0,6);
+ if ($area=~/^\/(\w+)\/(\d\w+)\/(\w+)/) {
+ $carea.=' Section/Group: '.$3;
+ }
+ $area=$carea;
} else {
- if ($1) {
- $incdomains{$1}=1;
+ if ($area=~/^\/(\w+)\//) {
if (&Apache::lonnet::allowed('c'.$trole,$1)) {
$allows=1;
}
+ } else {
+ if (&Apache::lonnet::allowed('c'.$trole,'/')) {
+ $allows=1;
+ }
}
}
@@ -167,22 +339,163 @@ ENDENHEAD
} split(/&/,$rolesdump);
$r->print('');
}
+ my $currentauth=&Apache::lonnet::queryauthenticate($ccuname,$ccdomain);
+ if ($currentauth=~/^krb4:/) {
+ $currentauth=~/^krb4:(.*)/;
+ my $krbdefdom2=$1;
+ $loginscript=~s/vf\.krbdom\.value='.*?';/vf.krbdom.value='$krbdefdom2';/;
+ }
+ # minor script hack here
+# $loginscript=~s/login\[3\]/login\[4\]/; # loc
+# $loginscript=~s/login\[2\]/login\[3\]/; # fsys
+# $loginscript=~s/login\[1\]/login\[2\]/; # int
+# $loginscript=~s/login\[0\]/login\[1\]/; # krb4
+
+ unless ($currentauth=~/^krb4:/ or
+ $currentauth=~/^unix:/ or
+ $currentauth=~/^internal:/ or
+ $currentauth=~/^localauth:/
+ ) {
+ $r->print(<
+$loginscript
+ERROR:
+This user has an unrecognized authentication scheme ($currentauth).
+Please specify login data below.
+
Login Data
+$generalrule
+$authformkrb
+$authformint
+$authformfsys
+$authformloc
+END
+ }
+ else {
+ my $authformcurrent='';
+ my $authformother='';
+ if ($currentauth=~/^krb4:/) {
+ $authformcurrent=$authformkrb;
+ $authformother=$authformint.$authformfsys.$authformloc;
+ # embarrassing script hack here
+ $loginscript=~s/login\[3\]/login\[4\]/; # loc
+ $loginscript=~s/login\[2\]/login\[3\]/; # fsys
+ $loginscript=~s/login\[1\]/login\[2\]/; # int
+ $loginscript=~s/login\[0\]/login\[1\]/; # krb4
+ }
+ elsif ($currentauth=~/^internal:/) {
+ $authformcurrent=$authformint;
+ $authformother=$authformkrb.$authformfsys.$authformloc;
+ # embarrassing script hack here
+ $loginscript=~s/login\[3\]/login\[4\]/; # loc
+ $loginscript=~s/login\[2\]/login\[3\]/; # fsys
+ $loginscript=~s/login\[1\]/login\[1\]/; # int
+ $loginscript=~s/login\[0\]/login\[2\]/; # krb4
+ }
+ elsif ($currentauth=~/^unix:/) {
+ $authformcurrent=$authformfsys;
+ $authformother=$authformkrb.$authformint.$authformloc;
+ # embarrassing script hack here
+ $loginscript=~s/login\[3\]/login\[4\]/; # loc
+ $loginscript=~s/login\[1\]/login\[3\]/; # int
+ $loginscript=~s/login\[2\]/login\[1\]/; # fsys
+ $loginscript=~s/login\[0\]/login\[2\]/; # krb4
+ }
+ elsif ($currentauth=~/^localauth:/) {
+ $authformcurrent=$authformloc;
+ $authformother=$authformkrb.$authformint.$authformfsys;
+ # embarrassing script hack here
+ $loginscript=~s/login\[3\]/login\[loc\]/; # loc
+ $loginscript=~s/login\[2\]/login\[4\]/; # fsys
+ $loginscript=~s/login\[1\]/login\[3\]/; # int
+ $loginscript=~s/login\[0\]/login\[2\]/; # krb4
+ $loginscript=~s/login\[loc\]/login\[1\]/; # loc
+ }
+ $authformcurrent=<
+
+
* * * WARNING * * *
+
* * * WARNING * * *
+
+
$authformcurrent
+
Changing this value will overwrite existing authentication for the user; you should notify the user of this change.
+
+END
+ $r->print(<
+$loginscript
+
Change Current Login Data
+$generalrule
+$authformnop
+$authformcurrent
+
Enter New Login Data
+$authformother
+END
+ }
+ }
+ $r->print('
Add Roles
');
+#
+# Co-Author
+#
+
+ if (&Apache::lonnet::allowed('cca',$ENV{'user.domain'})) {
+ my $cuname=$ENV{'user.name'};
+ my $cudom=$ENV{'user.domain'};
+ $r->print(<Construction Space
+
');
map {
my $thiscourse=$_;
+ my $protectedcourse=$_;
+ $thiscourse=~s:_:/:g;
my %coursedata=&Apache::lonnet::coursedescription($thiscourse);
my $area=$coursedata{'description'};
my $bgcol=$thiscourse;
@@ -191,28 +504,183 @@ ENDENHEAD
map {
if (&Apache::lonnet::allowed('c'.$_,$thiscourse)) {
my $plrole=&Apache::lonnet::plaintext($_);
- $r->print(<print("
-
+
$plrole
$area
-
-
+
");
+ if ($_ ne 'cc') {
+ $r->print("");
+ } else { $r->print(" "); }
+ $r->print(<Set Start Date
-
+"javascript:pjump('date_start','Start Date $plrole',document.cu.start_$protectedcourse\_$_.value,'start_$protectedcourse\_$_','cu.pres','dateset')">Set Start Date
+"javascript:pjump('date_end','End Date $plrole',document.cu.end_$protectedcourse\_$_.value,'end_$protectedcourse\_$_','cu.pres','dateset')">Set End Date