version 1.18, 2002/01/04 15:56:07
|
version 1.24, 2002/04/15 23:37:37
|
Line 52
|
Line 52
|
package Apache::londropadd; |
package Apache::londropadd; |
|
|
use strict; |
use strict; |
use Apache::lonnet; |
use Apache::lonnet(); |
|
use Apache::loncommon(); |
use Apache::Constants qw(:common :http REDIRECT); |
use Apache::Constants qw(:common :http REDIRECT); |
|
|
# ================================================================ Print header |
# ================================================================ Print header |
Line 73 action="/adm/dropadd" name="studentform"
|
Line 74 action="/adm/dropadd" name="studentform"
|
ENDHEAD |
ENDHEAD |
} |
} |
|
|
# ========================================================= Store uploaded file |
|
# needs $ENV{'form.upfile'} |
|
# return $datatoken to be put into hidden field |
|
|
|
sub upfile_store { |
|
my $r=shift; |
|
$ENV{'form.upfile'}=~s/\r/\n/gs; |
|
$ENV{'form.upfile'}=~s/\f/\n/gs; |
|
$ENV{'form.upfile'}=~s/\n+/\n/gs; |
|
$ENV{'form.upfile'}=~s/\n+$//gs; |
|
|
|
my $datatoken=$ENV{'user.name'}.'_'.$ENV{'user.domain'}. |
|
'_enroll_'.$ENV{'request.course.id'}.'_'.time.'_'.$$; |
|
{ |
|
my $fh=Apache::File->new('>'.$r->dir_config('lonDaemons'). |
|
'/tmp/'.$datatoken.'.tmp'); |
|
print $fh $ENV{'form.upfile'}; |
|
} |
|
return $datatoken; |
|
} |
|
|
|
# ================================================= Load uploaded file from tmp |
|
# needs $ENV{'form.datatoken'} |
|
# sets $ENV{'form.upfile'} |
|
|
|
sub load_tmp_file { |
|
my $r=shift; |
|
my @studentdata=(); |
|
{ |
|
my $fh; |
|
if ($fh=Apache::File->new($r->dir_config('lonDaemons'). |
|
'/tmp/'.$ENV{'form.datatoken'}.'.tmp')) { |
|
@studentdata=<$fh>; |
|
} |
|
} |
|
$ENV{'form.upfile'}=join('',@studentdata); |
|
} |
|
|
|
# ========================================= Separate uploaded file into records |
|
# returns array of records |
|
|
|
sub upfile_record_sep { |
|
if ($ENV{'form.upfiletype'} eq 'xml') { |
|
} else { |
|
return split(/\n/,$ENV{'form.upfile'}); |
|
} |
|
} |
|
|
|
# =============================================== Separate a record into fields |
|
|
|
sub record_sep { |
|
my $record=shift; |
|
my %components=(); |
|
if ($ENV{'form.upfiletype'} eq 'xml') { |
|
} elsif ($ENV{'form.upfiletype'} eq 'space') { |
|
my $i=0; |
|
map { |
|
my $field=$_; |
|
$field=~s/^(\"|\')//; |
|
$field=~s/(\"|\')$//; |
|
$components{$i}=$field; |
|
$i++; |
|
} split(/\s+/,$record); |
|
} elsif ($ENV{'form.upfiletype'} eq 'tab') { |
|
my $i=0; |
|
map { |
|
my $field=$_; |
|
$field=~s/^(\"|\')//; |
|
$field=~s/(\"|\')$//; |
|
$components{$i}=$field; |
|
$i++; |
|
} split(/\t+/,$record); |
|
} else { |
|
my @allfields=split(/\,/,$record); |
|
my $i=0; |
|
my $j; |
|
for ($j=0;$j<=$#allfields;$j++) { |
|
my $field=$allfields[$j]; |
|
if ($field=~/^\s*(\"|\')/) { |
|
my $delimiter=$1; |
|
while (($field!~/$delimiter$/) && ($j<$#allfields)) { |
|
$j++; |
|
$field.=','.$allfields[$j]; |
|
} |
|
$field=~s/^\s*$delimiter//; |
|
$field=~s/$delimiter\s*$//; |
|
} |
|
$components{$i}=$field; |
|
$i++; |
|
} |
|
} |
|
return %components; |
|
} |
|
|
|
# =========== Drop student from all sections of a course, except optional $csec |
# =========== Drop student from all sections of a course, except optional $csec |
|
|
sub dropstudent { |
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 106 sub dropstudent {
|
} |
} |
} |
} |
} |
} |
} split(/\&/,&Apache::lonnet::reply('dump:'.$udom.':'.$unam.':roles', |
} |
&Apache::lonnet::homeserver($unam,$udom))); |
|
} |
} |
|
|
# ============================================================== Menu Phase One |
# ============================================================== Menu Phase One |
|
|
sub menu_phase_one { |
sub menu_phase_one { |
my $r=shift; |
my $r=shift; |
|
my $upfile_select=&Apache::loncommon::upfile_select_html(); |
$r->print(<<ENDUPFORM); |
$r->print(<<ENDUPFORM); |
<input type=hidden name=phase value=two> |
<input type=hidden name=phase value=two> |
<hr> |
<hr> |
<h3>Upload a courselist</h3> |
<h3>Upload a courselist</h3> |
<input type=file name=upfile size=50> |
$upfile_select |
<br>Type: <select name=upfiletype> |
|
<option value=csv>CSV (comma separated values, spreadsheet)</option> |
|
<option value=space>Space separated</option> |
|
<option value=tab>Tabulator separated</option> |
|
<option value=xml>HTML/XML</option> |
|
</select> |
|
<p><input type=submit name=fileupload value="Upload Courselist"> |
<p><input type=submit name=fileupload value="Upload Courselist"> |
<hr> |
<hr> |
<h3>Enroll a single student</h3> |
<h3>Enroll a single student</h3> |
Line 226 sub menu_phase_one {
|
Line 129 sub menu_phase_one {
|
ENDUPFORM |
ENDUPFORM |
} |
} |
|
|
# ======================================================= Menu Phase Two Upload |
|
|
|
sub menu_phase_two_upload { |
|
my $r=shift; |
|
|
|
my $datatoken=&upfile_store($r); |
|
|
|
my @records=&upfile_record_sep(); |
|
my $total=$#records; |
|
my $distotal=$total+1; |
|
|
|
$ENV{'SERVER_NAME'}=~/(\w+\.\w+)$/; |
|
my $krbdefdom=$1; |
|
$krbdefdom=~tr/a-z/A-Z/; |
|
|
|
my $today=time; |
|
my $halfyear=$today+15552000; |
|
|
|
my $defdom=$r->dir_config('lonDefDomain'); |
|
|
|
|
sub phase_two_header { |
|
my ($r,$datatoken,$distotal,$krbdefdom)=@_; |
|
my $javascript; |
|
if ($ENV{'form.upfile_associate'} eq 'reverse') { |
|
$javascript=&phase_two_javascript_reverse_associate(); |
|
} else { |
|
$javascript=&phase_two_javascript_forward_associate(); |
|
} |
|
my $javascript_validations=&javascript_validations($krbdefdom); |
$r->print(<<ENDPICK); |
$r->print(<<ENDPICK); |
<input type=hidden name=phase value=three> |
|
<input type=hidden name=datatoken value="$datatoken"> |
|
<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 /> |
|
<input type="submit" name="associate" value="Reverse Association" /> |
|
<input type="hidden" name="phase" value="three" /> |
|
<input type="hidden" name="datatoken" value="$datatoken" /> |
|
<input type="hidden" name="fileupload" value="$ENV{'form.fileupload'}" /> |
|
<input type="hidden" name="upfiletype" value="$ENV{'form.upfiletype'}" /> |
|
<input type="hidden" name="upfile_associate" value="$ENV{'form.upfile_associate'}" /> |
|
<hr /> |
<script> |
<script> |
function verify(vf) { |
$javascript |
var founduname=0; |
|
var foundpwd=0; |
$javascript_validations |
var foundname=0; |
</script> |
var foundid=0; |
ENDPICK |
var foundsec=0; |
} |
|
|
|
sub javascript_validations { |
|
my ($krbdefdom)=@_; |
|
return (<<ENDPICK); |
|
function verify_message (vf,founduname,foundpwd,foundname,foundid,foundsec) { |
var foundatype=0; |
var foundatype=0; |
var tw; |
|
var message=''; |
var message=''; |
for (i=0;i<=vf.nfields.value;i++) { |
|
tw=eval('vf.f'+i+'.selectedIndex'); |
|
if (tw==1) { founduname=1; } |
|
if ((tw>=2) && (tw<=6)) { foundname=1; } |
|
if (tw==7) { foundid=1; } |
|
if (tw==8) { foundsec=1; } |
|
if (tw==9) { foundpwd=1; } |
|
} |
|
if (founduname==0) { |
if (founduname==0) { |
alert('You need to specify at least the username field'); |
alert('You need to specify at least the username field'); |
return; |
return; |
Line 321 function verify(vf) {
|
Line 216 function verify(vf) {
|
} else { |
} else { |
pclose(); |
pclose(); |
vf.submit(); |
vf.submit(); |
} |
} |
} |
|
|
|
function flip(vf,tf) { |
|
var nw=eval('vf.f'+tf+'.selectedIndex'); |
|
var i; |
|
for (i=0;i<=vf.nfields.value;i++) { |
|
if ((i!=tf) && (eval('vf.f'+i+'.selectedIndex')==nw)) { |
|
eval('vf.f'+i+'.selectedIndex=0;') |
|
} |
|
} |
|
if (nw==2) { |
|
for (i=0;i<=vf.nfields.value;i++) { |
|
if ((eval('vf.f'+i+'.selectedIndex')>=3) && |
|
(eval('vf.f'+i+'.selectedIndex')<=6)) { |
|
eval('vf.f'+i+'.selectedIndex=0;') |
|
} |
|
} |
|
} |
|
if ((nw>=3) && (nw<=6)) { |
|
for (i=0;i<=vf.nfields.value;i++) { |
|
if (eval('vf.f'+i+'.selectedIndex')==2) { |
|
eval('vf.f'+i+'.selectedIndex=0;') |
|
} |
|
} |
|
} |
|
if (nw==9) { |
|
vf.login[1].checked=true; |
|
vf.intpwd.value=''; |
|
vf.krbdom.value=''; |
|
vf.locarg.value=''; |
|
} |
|
|
|
} |
|
|
|
function clearpwd(vf) { |
|
var i; |
|
for (i=0;i<=vf.nfields.value;i++) { |
|
if (eval('vf.f'+i+'.selectedIndex')==9) { |
|
eval('vf.f'+i+'.selectedIndex=0;') |
|
} |
|
} |
|
} |
} |
|
|
function setkrb(vf) { |
function setkrb(vf) { |
Line 371 function setkrb(vf) {
|
Line 225 function setkrb(vf) {
|
vf.login[0].checked=true; |
vf.login[0].checked=true; |
vf.krbdom.value=vf.krbdom.value.toUpperCase(); |
vf.krbdom.value=vf.krbdom.value.toUpperCase(); |
vf.intpwd.value=''; |
vf.intpwd.value=''; |
|
vf.locarg.value=''; |
} |
} |
} |
} |
|
|
Line 379 function setint(vf) {
|
Line 234 function setint(vf) {
|
clearpwd(vf); |
clearpwd(vf); |
vf.login[1].checked=true; |
vf.login[1].checked=true; |
vf.krbdom.value=''; |
vf.krbdom.value=''; |
|
vf.locarg.value=''; |
|
} |
|
} |
|
|
|
function setloc(vf) { |
|
if (vf.locarg.value!='') { |
|
vf.login[2].checked=true; |
|
vf.krbdom.value=''; |
|
vf.intpwd.value=''; |
} |
} |
} |
} |
|
|
Line 386 function clickkrb(vf) {
|
Line 250 function clickkrb(vf) {
|
vf.krbdom.value='$krbdefdom'; |
vf.krbdom.value='$krbdefdom'; |
clearpwd(vf); |
clearpwd(vf); |
vf.intpwd.value=''; |
vf.intpwd.value=''; |
|
vf.locarg.value=''; |
} |
} |
|
|
function clickint(vf) { |
function clickint(vf) { |
vf.krbdom.value=''; |
vf.krbdom.value=''; |
|
vf.locarg.value=''; |
|
} |
|
|
|
function clickloc(vf) { |
|
vf.krbdom.value=''; |
|
vf.intpwd.value=''; |
} |
} |
|
|
function pclose() { |
function pclose() { |
Line 419 function clickint(vf) {
|
Line 290 function clickint(vf) {
|
pclose(); |
pclose(); |
} |
} |
|
|
</script> |
|
<table border=2><tr><th>Field</th><th>Samples</th></tr> |
|
ENDPICK |
ENDPICK |
my %sone; my %stwo; my %sthree; |
} |
my $i=0; |
|
|
|
if ($total>=0) { |
sub phase_two_javascript_forward_associate { |
%sone=&record_sep($records[0]); |
return(<<ENDPICK); |
if ($total>=1) { |
function verify(vf) { |
%stwo=&record_sep($records[1]); |
var founduname=0; |
|
var foundpwd=0; |
} |
var foundname=0; |
if ($total>=2) { |
var foundid=0; |
%sthree=&record_sep($records[2]); |
var foundsec=0; |
} |
var tw; |
map { |
for (i=0;i<=vf.nfields.value;i++) { |
$r->print('<tr><td><select name=f'.$i. |
tw=eval('vf.f'+i+'.selectedIndex'); |
' onChange="flip(this.form,'.$i.');">'); |
if (tw==1) { founduname=1; } |
map { |
if ((tw>=2) && (tw<=6)) { foundname=1; } |
my ($value,$display)=split(/\:/,$_); |
if (tw==7) { foundid=1; } |
$r->print('<option value='.$value.'>'.$display. |
if (tw==8) { foundsec=1; } |
'</option>'); |
if (tw==9) { foundpwd=1; } |
} ('none: ','username:Username', |
} |
'names:Last Name, First Names', |
verify_message(vf,founduname,foundpwd,foundname,foundid,foundsec); |
'fname:First Name','mname:Middle Names/Initials', |
} |
'lname:Last Name','gen:Generation', |
|
'id:ID/Student Number','sec:Group/Section', |
|
'ipwd:Initial Password'); |
function flip(vf,tf) { |
$r->print('</select></td><td>'); |
var nw=eval('vf.f'+tf+'.selectedIndex'); |
if (defined($sone{$_})) { |
var i; |
$r->print($sone{$_}."</br>\n"); |
for (i=0;i<=vf.nfields.value;i++) { |
} |
if ((i!=tf) && (eval('vf.f'+i+'.selectedIndex')==nw)) { |
if (defined($stwo{$_})) { |
eval('vf.f'+i+'.selectedIndex=0;') |
$r->print($stwo{$_}."</br>\n"); |
} |
} |
} |
if (defined($sthree{$_})) { |
if (tf==1 && nw!=0) { |
$r->print($sthree{$_}."</br>\n"); |
for (i=2;i<=5;i++) { |
} |
eval('vf.f'+i+'.selectedIndex=0;') |
$r->print('</td></tr>'); |
} |
$i++; |
} |
} sort keys %sone; |
if (nw==2) { |
$i--; |
for (i=0;i<=vf.nfields.value;i++) { |
} |
if ((eval('vf.f'+i+'.selectedIndex')>=3) && |
my $keyfields=join(',',sort keys %sone); |
(eval('vf.f'+i+'.selectedIndex')<=6)) { |
$r->print(<<ENDPICK); |
eval('vf.f'+i+'.selectedIndex=0;') |
|
} |
|
} |
|
} |
|
if ((nw>=3) && (nw<=6)) { |
|
for (i=0;i<=vf.nfields.value;i++) { |
|
if (eval('vf.f'+i+'.selectedIndex')==2) { |
|
eval('vf.f'+i+'.selectedIndex=0;') |
|
} |
|
} |
|
} |
|
if (nw==9) { |
|
vf.login[1].checked=true; |
|
vf.intpwd.value=''; |
|
vf.krbdom.value=''; |
|
vf.locarg.value=''; |
|
} |
|
} |
|
|
|
function clearpwd(vf) { |
|
var i; |
|
for (i=0;i<=vf.nfields.value;i++) { |
|
if (eval('vf.f'+i+'.selectedIndex')==9) { |
|
eval('vf.f'+i+'.selectedIndex=0;') |
|
} |
|
} |
|
} |
|
|
|
ENDPICK |
|
} |
|
|
|
sub phase_two_javascript_reverse_associate { |
|
return(<<ENDPICK); |
|
function verify(vf) { |
|
var founduname=0; |
|
var foundpwd=0; |
|
var foundname=0; |
|
var foundid=0; |
|
var foundsec=0; |
|
var tw; |
|
for (i=0;i<=vf.nfields.value;i++) { |
|
tw=eval('vf.f'+i+'.selectedIndex'); |
|
if (i==0 && tw!=0) { founduname=1; } |
|
if (((i>=1) && (i<=5)) && tw!=0 ) { foundname=1; } |
|
if (i==6 && tw!=0) { foundid=1; } |
|
if (i==7 && tw!=0) { foundsec=1; } |
|
if (i==8 && tw!=0) { foundpwd=1; } |
|
} |
|
verify_message(vf,founduname,foundpwd,foundname,foundid,foundsec); |
|
} |
|
|
|
function flip(vf,tf) { |
|
var nw=eval('vf.f'+tf+'.selectedIndex'); |
|
var i; |
|
// picked the all one one name field, reset the other name ones to blank |
|
if (tf==1 && nw!=0) { |
|
for (i=2;i<=5;i++) { |
|
eval('vf.f'+i+'.selectedIndex=0;') |
|
} |
|
} |
|
//picked one of the piecewise name fields, reset the all in |
|
//one field to blank |
|
if ((tf>=2) && (tf<=5) && (nw!=0)) { |
|
eval('vf.f1.selectedIndex=0;') |
|
} |
|
// intial password specified, pick internal authentication |
|
if (tf==8 && nw!=0) { |
|
vf.login[1].checked=true; |
|
vf.intpwd.value=''; |
|
vf.krbdom.value=''; |
|
vf.locarg.value=''; |
|
} |
|
} |
|
|
|
function clearpwd(vf) { |
|
var i; |
|
if (eval('vf.f8.selectedIndex')!=0) { |
|
eval('vf.f8.selectedIndex=0;') |
|
} |
|
} |
|
ENDPICK |
|
} |
|
|
|
sub phase_two_end { |
|
my ($r,$i,$keyfields,$defdom,$today,$halfyear)=@_; |
|
$r->print(<<ENDPICK); |
</table> |
</table> |
<input type=hidden name=nfields value=$i> |
<input type=hidden name=nfields value=$i> |
<input type=hidden name=keyfields value="$keyfields"> |
<input type=hidden name=keyfields value="$keyfields"> |
Line 505 LON-CAPA domain: <input type=text size=1
|
Line 458 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 |
} |
} |
|
|
|
# ======================================================= Menu Phase Two Upload |
|
|
|
sub menu_phase_two_upload { |
|
my $r=shift; |
|
|
|
my $datatoken; |
|
if (!$ENV{'form.datatoken'}) { |
|
$datatoken=&Apache::loncommon::upfile_store($r); |
|
} else { |
|
$datatoken=$ENV{'form.datatoken'}; |
|
&Apache::loncommon::load_tmp_file($r); |
|
} |
|
my @records=&Apache::loncommon::upfile_record_sep(); |
|
my $total=$#records; |
|
my $distotal=$total+1; |
|
|
|
$ENV{'SERVER_NAME'}=~/(\w+\.\w+)$/; |
|
my $krbdefdom=$1; |
|
$krbdefdom=~tr/a-z/A-Z/; |
|
|
|
my $today=time; |
|
my $halfyear=$today+15552000; |
|
|
|
my $defdom=$r->dir_config('lonDefDomain'); |
|
|
|
&phase_two_header($r,$datatoken,$distotal,$krbdefdom); |
|
|
|
my $i; |
|
my $keyfields; |
|
if ($total>=0) { |
|
my @d=(['username','Username'],['names','Last Name, First Names'], |
|
['fname','First Name'],['mname','Middle Names/Initials'], |
|
['lname','Last Name'],['gen','Generation'], |
|
['id','ID/Student Number'],['sec','Group/Section'], |
|
['ipwd','Initial Password']); |
|
if ($ENV{'form.upfile_associate'} eq 'reverse') { |
|
&Apache::loncommon::csv_print_samples($r,\@records); |
|
$i=&Apache::loncommon::csv_print_select_table($r,\@records,\@d); |
|
foreach (@d) { $keyfields.=$_->[0].','; } |
|
chop($keyfields); |
|
} else { |
|
unshift(@d,['none','']); |
|
$i=&Apache::loncommon::csv_samples_select_table($r,\@records,\@d); |
|
my %sone=&Apache::loncommon::record_sep($records[0]); |
|
$keyfields=join(',',sort(keys(%sone))); |
|
} |
|
} |
|
|
|
|
|
&phase_two_end($r,$i,$keyfields,$defdom,$today,$halfyear); |
|
} |
|
|
# ======================================================= Enroll single student |
# ======================================================= Enroll single student |
|
|
sub enroll_single_student { |
sub enroll_single_student { |
Line 540 sub enroll_single_student {
|
Line 545 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 562 sub menu_phase_two_enroll {
|
Line 567 sub menu_phase_two_enroll {
|
my $halfyear=$today+15552000; |
my $halfyear=$today+15552000; |
|
|
my $defdom=$r->dir_config('lonDefDomain'); |
my $defdom=$r->dir_config('lonDefDomain'); |
|
my $javascript_validations=&javascript_validations($krbdefdom); |
$r->print(<<ENDSENROLL); |
$r->print(<<ENDSENROLL); |
<script> |
<script> |
function verify(vf) { |
function verify(vf) { |
Line 571 function verify(vf) {
|
Line 576 function verify(vf) {
|
var foundname=0; |
var foundname=0; |
var foundid=0; |
var foundid=0; |
var foundsec=0; |
var foundsec=0; |
var foundatype=0; |
|
var tw; |
var tw; |
var message=''; |
|
if ((typeof(vf.cuname.value)!="undefined") && (vf.cuname.value!='') && |
if ((typeof(vf.cuname.value)!="undefined") && (vf.cuname.value!='') && |
(typeof(vf.cdomain.value)!="undefined") && (vf.cdomain.value!='')) { |
(typeof(vf.cdomain.value)!="undefined") && (vf.cdomain.value!='')) { |
founduname=1; |
founduname=1; |
Line 592 function verify(vf) {
|
Line 595 function verify(vf) {
|
alert('You need to specify at least the username and domain fields'); |
alert('You need to specify at least the username and domain fields'); |
return; |
return; |
} |
} |
if (vf.login[0].checked) { |
verify_message(vf,founduname,foundpwd,foundname,foundid,foundsec); |
foundatype=1; |
|
if (vf.krbdom.value=='') { |
|
alert('You need to specify the Kerberos domain'); |
|
return; |
|
} |
|
} |
|
if (vf.login[1].checked) { |
|
foundatype=1; |
|
if ((vf.intpwd.value=='') && (foundpwd==0)) { |
|
alert('You need to specify the initial password'); |
|
return; |
|
} |
|
} |
|
if (vf.login[2].checked) { |
|
foundatype=1; |
|
//An argument is not required |
|
} |
|
if (foundatype==0) { |
|
alert('You need to set the login type'); |
|
return; |
|
} |
|
if (foundname==0) { message='No first and last name specified. '; } |
|
if (foundid==0) { message+='No ID or student number field specified. '; } |
|
if (foundsec==0) { message+='No section or group field specified. '; } |
|
if (vf.startdate.value=='') { |
|
message+='No starting date set. '; |
|
} |
|
if (vf.enddate.value=='') { |
|
message+='No ending date set. '; |
|
} |
|
if ((vf.enddate.value!='') && (vf.startdate.value!='')) { |
|
if (Math.round(vf.enddate.value)<Math.round(vf.startdate.value)) { |
|
alert('Ending date is before starting date'); |
|
return; |
|
} |
|
} |
|
if (message!='') { |
|
message+='Continue enrollment?'; |
|
if (confirm(message)) { |
|
pclose(); |
|
vf.submit(); |
|
} |
|
} else { |
|
pclose(); |
|
vf.submit(); |
|
} |
|
} |
|
|
|
function setkrb(vf) { |
|
if (vf.krbdom.value!='') { |
|
vf.login[0].checked=true; |
|
vf.krbdom.value=vf.krbdom.value.toUpperCase(); |
|
vf.intpwd.value=''; |
|
vf.locarg.value=''; |
|
} |
|
} |
|
|
|
function setint(vf) { |
|
if (vf.intpwd.value!='') { |
|
vf.login[1].checked=true; |
|
vf.krbdom.value=''; |
|
vf.locarg.value=''; |
|
} |
|
} |
} |
|
|
function setloc(vf) { |
$javascript_validations |
if (vf.locarg.value!='') { |
|
vf.login[2].checked=true; |
|
vf.krbdom.value=''; |
|
vf.intpwd.value=''; |
|
} |
|
} |
|
|
|
function clickkrb(vf) { |
function clearpwd(vf) { |
vf.krbdom.value='$krbdefdom'; |
//nothing else needs clearing |
vf.intpwd.value=''; |
|
vf.locarg.value=''; |
|
} |
|
|
|
function clickint(vf) { |
|
vf.krbdom.value=''; |
|
vf.locarg.value=''; |
|
} |
|
|
|
function clickloc(vf) { |
|
vf.krbdom.value=''; |
|
vf.intpwd.value=''; |
|
} |
} |
|
|
function pclose() { |
|
parmwin=window.open("/adm/rat/empty.html","LONCAPAparms", |
|
"height=350,width=350,scrollbars=no,menubar=no"); |
|
parmwin.close(); |
|
} |
|
|
|
function pjump(type,dis,value,marker,ret,call) { |
|
parmwin=window.open("/adm/rat/parameter.html?type="+escape(type) |
|
+"&value="+escape(value)+"&marker="+escape(marker) |
|
+"&return="+escape(ret) |
|
+"&call="+escape(call)+"&name="+escape(dis),"LONCAPAparms", |
|
"height=350,width=350,scrollbars=no,menubar=no"); |
|
|
|
} |
|
|
|
function dateset() { |
|
if (document.studentform.pres_marker.value=='end') { |
|
document.studentform.enddate.value= |
|
document.studentform.pres_value.value; |
|
} |
|
if (document.studentform.pres_marker.value=='start') { |
|
document.studentform.startdate.value= |
|
document.studentform.pres_value.value; |
|
} |
|
pclose(); |
|
} |
|
|
|
</script> |
</script> |
<h3>Personal Data</h3> |
<h3>Personal Data</h3> |
First Name: <input type=text name=cfirst size=15><br> |
First Name: <input type=text name=cfirst size=15><br> |
Line 752 Local Authentication with argument
|
Line 647 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 665 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 674 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 692 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 710 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 825 sub show_drop_list {
|
Line 720 sub show_drop_list {
|
sub upfile_drop_add { |
sub upfile_drop_add { |
my $r=shift; |
my $r=shift; |
|
|
&load_tmp_file($r); |
&Apache::loncommon::load_tmp_file($r); |
my @studentdata=&upfile_record_sep(); |
my @studentdata=&Apache::loncommon::upfile_record_sep(); |
|
|
my @keyfields=split(/\,/,$ENV{'form.keyfields'}); |
my @keyfields=split(/\,/,$ENV{'form.keyfields'}); |
my $cid=$ENV{'request.course.id'}; |
my $cid=$ENV{'request.course.id'}; |
|
|
my %fields=(); |
my %fields=(); |
for (my $i=0;$i<=$ENV{'form.nfields'};$i++) { |
for (my $i=0;$i<=$ENV{'form.nfields'};$i++) { |
$fields{$ENV{'form.f'.$i}}=$keyfields[$i]; |
if ($ENV{'form.upfile_associate'} eq 'reverse') { |
|
if ($ENV{'form.f'.$i} ne 'none') { |
|
$fields{$keyfields[$i]}=$ENV{'form.f'.$i}; |
|
} |
|
} else { |
|
$fields{$ENV{'form.f'.$i}}=$keyfields[$i]; |
|
} |
} |
} |
my $startdate=$ENV{'form.startdate'}; |
my $startdate=$ENV{'form.startdate'}; |
my $enddate=$ENV{'form.enddate'}; |
my $enddate=$ENV{'form.enddate'}; |
Line 863 sub upfile_drop_add {
|
Line 763 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=&Apache::loncommon::record_sep($_); |
|
|
unless (($entries{$fields{'username'}} eq '') || |
unless (($entries{$fields{'username'}} eq '') || |
(!defined($entries{$fields{'username'}}))) { |
(!defined($entries{$fields{'username'}}))) { |
Line 919 sub upfile_drop_add {
|
Line 819 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 839 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 852 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 861 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=&Apache::loncommon::record_sep($_); |
unless (($entries{$fields{'username'}} eq '') || |
unless (($entries{$fields{'username'}} eq '') || |
(!defined($entries{$fields{'username'}}))) { |
(!defined($entries{$fields{'username'}}))) { |
delete($currentlist{ |
delete($currentlist{ |
$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 890 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.'); |
} |
} |
Line 1005 sub drop_student_list {
|
Line 906 sub drop_student_list {
|
|
|
sub handler { |
sub handler { |
my $r=shift; |
my $r=shift; |
|
$Apache::lonxml::debug=1; |
if ($r->header_only) { |
if ($r->header_only) { |
$r->content_type('text/html'); |
$r->content_type('text/html'); |
$r->send_http_header; |
$r->send_http_header; |
Line 1027 sub handler {
|
Line 928 sub handler {
|
&menu_phase_one($r); |
&menu_phase_one($r); |
} |
} |
# ------------------------------------------------------------------- Phase two |
# ------------------------------------------------------------------- Phase two |
|
|
|
if ($ENV{'form.associate'} eq 'Reverse Association') { |
|
$ENV{'form.phase'} = 'two'; |
|
if ( $ENV{'form.upfile_associate'} ne 'reverse' ) { |
|
$ENV{'form.upfile_associate'} = 'reverse'; |
|
} else { |
|
$ENV{'form.upfile_associate'} = 'forward'; |
|
} |
|
} |
if ($ENV{'form.phase'} eq 'two') { |
if ($ENV{'form.phase'} eq 'two') { |
if ($ENV{'form.fileupload'}) { |
if ($ENV{'form.fileupload'}) { |
&menu_phase_two_upload($r); |
&menu_phase_two_upload($r); |
Line 1050 sub handler {
|
Line 960 sub handler {
|
if ($ENV{'form.phase'} eq 'four') { |
if ($ENV{'form.phase'} eq 'four') { |
&drop_student_list($r); |
&drop_student_list($r); |
} |
} |
# ------------------------------------------------------------------ Phase four |
# ------------------------------------------------------------------ Phase five |
if ($ENV{'form.phase'} eq 'five') { |
if ($ENV{'form.phase'} eq 'five') { |
&enroll_single_student($r); |
&enroll_single_student($r); |
} |
} |
Line 1068 sub handler {
|
Line 978 sub handler {
|
1; |
1; |
__END__ |
__END__ |
|
|
|
|
|
|
|
|