version 1.18, 2002/01/04 15:56:07
|
version 1.22, 2002/04/04 17:32:45
|
Line 129 sub record_sep {
|
Line 129 sub record_sep {
|
if ($ENV{'form.upfiletype'} eq 'xml') { |
if ($ENV{'form.upfiletype'} eq 'xml') { |
} elsif ($ENV{'form.upfiletype'} eq 'space') { |
} elsif ($ENV{'form.upfiletype'} eq 'space') { |
my $i=0; |
my $i=0; |
map { |
foreach (split(/\s+/,$record)) { |
my $field=$_; |
my $field=$_; |
$field=~s/^(\"|\')//; |
$field=~s/^(\"|\')//; |
$field=~s/(\"|\')$//; |
$field=~s/(\"|\')$//; |
$components{$i}=$field; |
$components{$i}=$field; |
$i++; |
$i++; |
} split(/\s+/,$record); |
} |
} elsif ($ENV{'form.upfiletype'} eq 'tab') { |
} elsif ($ENV{'form.upfiletype'} eq 'tab') { |
my $i=0; |
my $i=0; |
map { |
foreach (split(/\t+/,$record)) { |
my $field=$_; |
my $field=$_; |
$field=~s/^(\"|\')//; |
$field=~s/^(\"|\')//; |
$field=~s/(\"|\')$//; |
$field=~s/(\"|\')$//; |
$components{$i}=$field; |
$components{$i}=$field; |
$i++; |
$i++; |
} split(/\t+/,$record); |
} |
} else { |
} else { |
my @allfields=split(/\,/,$record); |
my @allfields=split(/\,/,$record); |
my $i=0; |
my $i=0; |
Line 173 sub dropstudent {
|
Line 173 sub dropstudent {
|
my ($udom,$unam,$courseid,$csec)=@_; |
my ($udom,$unam,$courseid,$csec)=@_; |
$courseid=~s/\_/\//g; |
$courseid=~s/\_/\//g; |
$courseid=~s/^(\w)/\/$1/; |
$courseid=~s/^(\w)/\/$1/; |
map { |
foreach (split(/\&/, |
|
&Apache::lonnet::reply('dump:'.$udom.':'.$unam.':roles', |
|
&Apache::lonnet::homeserver($unam,$udom)))) { |
my ($key,$value)=split(/\=/,$_); |
my ($key,$value)=split(/\=/,$_); |
$key=&Apache::lonnet::unescape($key); |
$key=&Apache::lonnet::unescape($key); |
if ($key=~/^$courseid(?:\/)*(\w+)*\_st$/) { |
if ($key=~/^$courseid(?:\/)*(\w+)*\_st$/) { |
Line 197 sub dropstudent {
|
Line 199 sub dropstudent {
|
} |
} |
} |
} |
} |
} |
} split(/\&/,&Apache::lonnet::reply('dump:'.$udom.':'.$unam.':roles', |
} |
&Apache::lonnet::homeserver($unam,$udom))); |
|
} |
} |
|
|
# ============================================================== Menu Phase One |
# ============================================================== Menu Phase One |
Line 252 sub menu_phase_two_upload {
|
Line 253 sub menu_phase_two_upload {
|
<input type=hidden name=upfiletype value=$ENV{'form.upfiletype'}> |
<input type=hidden name=upfiletype value=$ENV{'form.upfiletype'}> |
<hr> |
<hr> |
<h3>Identify fields</h3> |
<h3>Identify fields</h3> |
Total number of records found in file: $distotal |
Total number of records found in file: $distotal <hr /> |
|
Enter as many fields as you can. The system will inform you and bring you back |
|
to this page if the data selected is insufficient to run your class.<hr /> |
<script> |
<script> |
function verify(vf) { |
function verify(vf) { |
var founduname=0; |
var founduname=0; |
Line 434 ENDPICK
|
Line 437 ENDPICK
|
if ($total>=2) { |
if ($total>=2) { |
%sthree=&record_sep($records[2]); |
%sthree=&record_sep($records[2]); |
} |
} |
map { |
foreach (sort keys %sone) { |
$r->print('<tr><td><select name=f'.$i. |
$r->print('<tr><td><select name=f'.$i. |
' onChange="flip(this.form,'.$i.');">'); |
' onChange="flip(this.form,'.$i.');">'); |
map { |
foreach ('none: ','username:Username', |
my ($value,$display)=split(/\:/,$_); |
|
$r->print('<option value='.$value.'>'.$display. |
|
'</option>'); |
|
} ('none: ','username:Username', |
|
'names:Last Name, First Names', |
'names:Last Name, First Names', |
'fname:First Name','mname:Middle Names/Initials', |
'fname:First Name','mname:Middle Names/Initials', |
'lname:Last Name','gen:Generation', |
'lname:Last Name','gen:Generation', |
'id:ID/Student Number','sec:Group/Section', |
'id:ID/Student Number','sec:Group/Section', |
'ipwd:Initial Password'); |
'ipwd:Initial Password') { |
|
my ($value,$display)=split(/\:/,$_); |
|
$r->print('<option value='.$value.'>'.$display. |
|
'</option>'); |
|
} |
$r->print('</select></td><td>'); |
$r->print('</select></td><td>'); |
if (defined($sone{$_})) { |
if (defined($sone{$_})) { |
$r->print($sone{$_}."</br>\n"); |
$r->print($sone{$_}."</br>\n"); |
Line 459 ENDPICK
|
Line 462 ENDPICK
|
} |
} |
$r->print('</td></tr>'); |
$r->print('</td></tr>'); |
$i++; |
$i++; |
} sort keys %sone; |
} |
$i--; |
$i--; |
} |
} |
my $keyfields=join(',',sort keys %sone); |
my $keyfields=join(',',sort keys %sone); |
Line 505 LON-CAPA domain: <input type=text size=1
|
Line 508 LON-CAPA domain: <input type=text size=1
|
<h3>ID/Student Number</h3> |
<h3>ID/Student Number</h3> |
<input type=checkbox name=forceid value=yes> |
<input type=checkbox name=forceid value=yes> |
Disable ID/Student Number Safeguard and Force Change of Conflicting IDs |
Disable ID/Student Number Safeguard and Force Change of Conflicting IDs |
(only do if you know what you are doing) |
(only do if you know what you are doing)<p> |
<input type=button onClick="verify(this.form)" value="Update Courselist"><br> |
<input type=button onClick="verify(this.form)" value="Update Courselist"><br> |
Note: for large courses, this operation might be time consuming. |
Note: for large courses, this operation might be time consuming. |
ENDPICK |
ENDPICK |
Line 540 sub enroll_single_student {
|
Line 543 sub enroll_single_student {
|
$ENV{'form.cfirst'},$ENV{'form.cmiddle'}, |
$ENV{'form.cfirst'},$ENV{'form.cmiddle'}, |
$ENV{'form.clast'},$ENV{'form.cgen'}, |
$ENV{'form.clast'},$ENV{'form.cgen'}, |
$ENV{'form.csec'},$ENV{'form.enddate'}, |
$ENV{'form.csec'},$ENV{'form.enddate'}, |
$ENV{'form.startdate'})); |
$ENV{'form.startdate'},$ENV{'form.forceid'})); |
} else { |
} else { |
$r->print('Invalid login mode or password'); |
$r->print('Invalid login mode or password'); |
} |
} |
Line 752 Local Authentication with argument
|
Line 755 Local Authentication with argument
|
<h3>ID/Student Number</h3> |
<h3>ID/Student Number</h3> |
<input type=checkbox name=forceid value=yes> |
<input type=checkbox name=forceid value=yes> |
Disable ID/Student Number Safeguard and Force Change of Conflicting IDs |
Disable ID/Student Number Safeguard and Force Change of Conflicting IDs |
(only do if you know what you are doing) |
(only do if you know what you are doing)<p> |
<input type=button onClick="verify(this.form)" value="Enroll as student"><br> |
<input type=button onClick="verify(this.form)" value="Enroll as student"><br> |
<input type=hidden name=phase value=five> |
<input type=hidden name=phase value=five> |
ENDSENROLL |
ENDSENROLL |
Line 770 sub menu_phase_two_drop {
|
Line 773 sub menu_phase_two_drop {
|
my %currentlist=(); |
my %currentlist=(); |
my $now=time; |
my $now=time; |
unless ($classlst=~/^error\:/) { |
unless ($classlst=~/^error\:/) { |
map { |
foreach (split(/\&/,$classlst)) { |
my ($name,$value)=split(/\=/,$_); |
my ($name,$value)=split(/\=/,$_); |
my ($end,$start)=split(/\:/, |
my ($end,$start)=split(/\:/, |
&Apache::lonnet::unescape($value)); |
&Apache::lonnet::unescape($value)); |
Line 779 sub menu_phase_two_drop {
|
Line 782 sub menu_phase_two_drop {
|
if ($active) { |
if ($active) { |
$currentlist{&Apache::lonnet::unescape($name)}=1; |
$currentlist{&Apache::lonnet::unescape($name)}=1; |
} |
} |
} split(/\&/,$classlst); |
} |
# ----------------------------------------------------------- Print out choices |
# ----------------------------------------------------------- Print out choices |
&show_drop_list($r,%currentlist); |
&show_drop_list($r,%currentlist); |
} else { |
} else { |
Line 797 sub show_drop_list {
|
Line 800 sub show_drop_list {
|
|
|
$r->print('<input type=hidden name=phase value=four>'); |
$r->print('<input type=hidden name=phase value=four>'); |
$r->print('<table border=2>'); |
$r->print('<table border=2>'); |
map { |
foreach (sort keys %currentlist) { |
my ($sname,$sdom)=split(/\:/,$_); |
my ($sname,$sdom)=split(/\:/,$_); |
my %reply=&Apache::lonnet::idrget($sdom,$sname); |
my %reply=&Apache::lonnet::idrget($sdom,$sname); |
my $ssec=&Apache::lonnet::usection($sdom,$sname,$cid); |
my $ssec=&Apache::lonnet::usection($sdom,$sname,$cid); |
Line 815 sub show_drop_list {
|
Line 818 sub show_drop_list {
|
&Apache::lonnet::unescape($reply[1]). |
&Apache::lonnet::unescape($reply[1]). |
'</td><td>'. |
'</td><td>'. |
$ssec."</td></tr>\n"); |
$ssec."</td></tr>\n"); |
} sort keys %currentlist; |
} |
$r->print('</table><br>'); |
$r->print('</table><br>'); |
$r->print('<input type=submit value="Drop Students">'); |
$r->print('<input type=submit value="Drop Students">'); |
} |
} |
Line 863 sub upfile_drop_add {
|
Line 866 sub upfile_drop_add {
|
my %student=(); |
my %student=(); |
# ----------------------------------------------------------- Get new classlist |
# ----------------------------------------------------------- Get new classlist |
# --------------------------------------------------------- Enroll new students |
# --------------------------------------------------------- Enroll new students |
map { |
foreach (@studentdata) { |
my %entries=&record_sep($_); |
my %entries=&record_sep($_); |
|
|
unless (($entries{$fields{'username'}} eq '') || |
unless (($entries{$fields{'username'}} eq '') || |
Line 919 sub upfile_drop_add {
|
Line 922 sub upfile_drop_add {
|
&dropstudent($domain,$username,$cid,$sec); |
&dropstudent($domain,$username,$cid,$sec); |
my $reply=&Apache::lonnet::modifystudent( |
my $reply=&Apache::lonnet::modifystudent( |
$domain,$username,$id,$amode,$password, |
$domain,$username,$id,$amode,$password, |
$fname,$mname,$lname,$gen,$sec,$enddate,$startdate); |
$fname,$mname,$lname,$gen,$sec,$enddate,$startdate, |
|
$ENV{'form.forceid'}); |
unless ($reply eq 'ok') { |
unless ($reply eq 'ok') { |
$r->print( |
$r->print( |
"<p><b>Error enrolling $username: $reply</b><p>"); |
"<p><b>Error enrolling $username: $reply</b><p>"); |
Line 938 sub upfile_drop_add {
|
Line 942 sub upfile_drop_add {
|
} |
} |
} |
} |
} |
} |
} @studentdata; |
} |
$r->print('<p>Processed Students: '.$count); |
$r->print('<p>Processed Students: '.$count); |
# --------------------------------------------------------------- Drop students |
# --------------------------------------------------------------- Drop students |
if ($ENV{'form.fullup'} eq 'yes') { |
if ($ENV{'form.fullup'} eq 'yes') { |
Line 951 sub upfile_drop_add {
|
Line 955 sub upfile_drop_add {
|
my %currentlist=(); |
my %currentlist=(); |
my $now=time; |
my $now=time; |
unless ($classlst=~/^error\:/) { |
unless ($classlst=~/^error\:/) { |
map { |
foreach (split(/\&/,$classlst)) { |
my ($name,$value)=split(/\=/,$_); |
my ($name,$value)=split(/\=/,$_); |
my ($end,$start)=split(/\:/, |
my ($end,$start)=split(/\:/, |
&Apache::lonnet::unescape($value)); |
&Apache::lonnet::unescape($value)); |
Line 960 sub upfile_drop_add {
|
Line 964 sub upfile_drop_add {
|
if ($active) { |
if ($active) { |
$currentlist{&Apache::lonnet::unescape($name)}=1; |
$currentlist{&Apache::lonnet::unescape($name)}=1; |
} |
} |
} split(/\&/,$classlst); |
} |
# ------------------------------------------------ Now got up-to-date classlist |
# ------------------------------------------------ Now got up-to-date classlist |
map { |
foreach (@studentdata) { |
my %entries=&record_sep($_); |
my %entries=&record_sep($_); |
unless (($entries{$fields{'username'}} eq '') || |
unless (($entries{$fields{'username'}} eq '') || |
(!defined($entries{$fields{'username'}}))) { |
(!defined($entries{$fields{'username'}}))) { |
Line 970 sub upfile_drop_add {
|
Line 974 sub upfile_drop_add {
|
$entries{$fields{'username'}}.':'. |
$entries{$fields{'username'}}.':'. |
$domain}); |
$domain}); |
} |
} |
} @studentdata; |
} |
# ----------------------------------------------------------- Print out choices |
# ----------------------------------------------------------- Print out choices |
&show_drop_list($r,%currentlist); |
&show_drop_list($r,%currentlist); |
} else { |
} else { |
Line 989 sub upfile_drop_add {
|
Line 993 sub upfile_drop_add {
|
sub drop_student_list { |
sub drop_student_list { |
my $r=shift; |
my $r=shift; |
my $count=0; |
my $count=0; |
map { |
foreach (keys %ENV) { |
if ($_=~/^form\.drop\:/) { |
if ($_=~/^form\.drop\:/) { |
my ($dummy,$uname,$udom)=split(/\:/,$_); |
my ($dummy,$uname,$udom)=split(/\:/,$_); |
&dropstudent($udom,$uname,$ENV{'request.course.id'}); |
&dropstudent($udom,$uname,$ENV{'request.course.id'}); |
$r->print('Dropped '.$uname.' at '.$udom.'<br>'); |
$r->print('Dropped '.$uname.' at '.$udom.'<br>'); |
$count++; |
$count++; |
} |
} |
} keys %ENV; |
} |
$r->print('<p><b>Dropped '.$count.' student(s).</b>'); |
$r->print('<p><b>Dropped '.$count.' student(s).</b>'); |
$r->print('<p>Re-enrollment will re-activate data.'); |
$r->print('<p>Re-enrollment will re-activate data.'); |
} |
} |