You can not select more than 25 topics
Topics must start with a letter or number, can include dashes ('-') and can be up to 35 characters long.
846 lines
25 KiB
846 lines
25 KiB
6 months ago
|
#!/usr/bin/perl
|
||
|
#
|
||
|
# $Id: tdef.pl,v 1.11 2006/05/22 16:06:41 psims Exp $
|
||
|
#
|
||
|
# Source File: tdef.pl
|
||
|
|
||
|
# Get config
|
||
|
use CGI qw/:standard/;
|
||
|
|
||
|
require 'sitecfg.pl';
|
||
|
require 'ui.pl';
|
||
|
require 'sbalib.pl';
|
||
|
|
||
|
use POSIX;
|
||
|
|
||
|
if ( ! &go() ) {
|
||
|
&logger::logerr("Unable to successfully serve page");
|
||
|
}
|
||
|
|
||
|
sub go {
|
||
|
&app_initialize;
|
||
|
print "Content-Type: text/html\n\n";
|
||
|
if (&get_session($FORM{'tid'})) {
|
||
|
&LanguageSupportInit();
|
||
|
|
||
|
### DED 8/27/02 Preview CFA
|
||
|
if (($FORM{'cfa'} ne '') && ($FORM{'preview'} eq "Preview")) {
|
||
|
&preview_cfa();
|
||
|
return;
|
||
|
}
|
||
|
my ($ok, $msg) = &setAvailableDatetimes( \%FORM );
|
||
|
$FORM{'respmsg'} = "";
|
||
|
if ( ! $ok ) {
|
||
|
$FORM{'respmsg'} = &errorformat($msg);
|
||
|
$FORM{'savechanges'} = 'N';
|
||
|
$FORM{'frm'} = 1;
|
||
|
}
|
||
|
if ($FORM{'tstid'} eq '') { $FORM{'tstid'} = $FORM{'id'}; }
|
||
|
if ($FORM{'id'} eq '') { $FORM{'id'} = $FORM{'tstid'}; }
|
||
|
if ($FORM{'UploadImages'} ne '') {
|
||
|
&log_entry($SESSION{'clid'}, $SESSION{'uid'}, "2", "Test Image Upload $FORM{'tstid'}");
|
||
|
&show_upload_form;
|
||
|
return 1;
|
||
|
} else {
|
||
|
if ($FORM{'savechanges'} eq 'Y' ) {
|
||
|
|
||
|
if ( defined($FORM{'newtest'}) && ($FORM{'newtest'} eq 'Y') && &is_duplicate_test_id($FORM{'tstid'}, $SESSION{'clid'})) {
|
||
|
|
||
|
#
|
||
|
# Disallow duplicates on new test defns ...
|
||
|
#
|
||
|
$msg = GetLanguageElement($SESSION{lang}, 552);
|
||
|
$msg .= qq{ "$FORM{'tstid'}" (};
|
||
|
$msg .= GetLanguageElement($SESSION{lang}, 553);
|
||
|
$msg .= qq{ "$FORM{'desc'}") };
|
||
|
$msg .= GetLanguageElement($SESSION{lang}, 554);
|
||
|
$FORM{'respmsg'} .= &errorformat($msg);
|
||
|
&logger::loguerr($msg);
|
||
|
|
||
|
} elsif ( defined($FORM{'newtest'}) &&
|
||
|
($FORM{'newtest'} eq 'Y') &&
|
||
|
$FORM{'tstid'} =~ /\s/ ) {
|
||
|
|
||
|
#
|
||
|
# Disallow spaces in new test IDs ...
|
||
|
#
|
||
|
$msg = GetLanguageElement($SESSION{lang}, 555);
|
||
|
$FORM{'respmsg'} .= &errorformat($msg);
|
||
|
&logger::loguerr($msg);
|
||
|
|
||
|
} else {
|
||
|
if ($FORM{'flags'} ne '' || $FORM{'group'} ne '' || $FORM{'tstalwrotip'} ne '') {
|
||
|
@flags = split(/\./, $FORM{'flags'});
|
||
|
$flags[4] = $FORM{'group'};
|
||
|
$flags[5] = $FORM{'tstalwrotip'};
|
||
|
$FORM{'flags'} = join('.',@flags);
|
||
|
}
|
||
|
### DED 6/22/04 For Custom fields
|
||
|
### Not yet implemented
|
||
|
#$FORM{'showsubj'} .= ".$FORM{'showques1'}.$FORM{'lblques1'}.$FORM{'showques2'}.$FORM{'lblques2'}";
|
||
|
|
||
|
&put_test_profile($SESSION{'clid'}, $FORM{'id'}, \%FORM, $FORM{newtest});
|
||
|
if ($FORM{'seq'} eq 'std') {
|
||
|
&put_test_saskmatrix($SESSION{'clid'}, $FORM{'id'}, \%FORM);
|
||
|
}
|
||
|
|
||
|
&put_test_logo($SESSION{'clid'},$FORM{'id'}, \%UPLOADED_FILES);
|
||
|
&log_entry($SESSION{'clid'}, $SESSION{'uid'}, "3", "Saved Test Definition $FORM{'id'}");
|
||
|
if ($FORM{'newtest'} eq 'Y') {
|
||
|
&log_entry($SESSION{'clid'}, $SESSION{'uid'}, "2", "Question File Created $FORM{'id'}");
|
||
|
&create_question_file($SESSION{'clid'}, $FORM{'id'});
|
||
|
$FORM{'newtest'} = "N";
|
||
|
}
|
||
|
$FORM{'frm'} = 1;
|
||
|
# $FORM{'respmsg'} .= GetLanguageElement($SESSION{lang}, 556);
|
||
|
|
||
|
#
|
||
|
# Create an Instance of this test?
|
||
|
#
|
||
|
if ( ($FORM{instanceit} eq 'Y' || $FORM{instanceit} eq 'on') ) {
|
||
|
|
||
|
$FORM{instancename} = strip_blanks($FORM{instancename});
|
||
|
$FORM{desc} = $FORM{instancedesc};
|
||
|
my ($rc, $msg) = &instance_test($SESSION{'clid'}, $FORM{'tstid'}, $FORM{instancename}, \%FORM);
|
||
|
if ( ! $rc ) {
|
||
|
|
||
|
&logger::logerr("&instance_test($SESSION{'clid'}, $FORM{'tstid'}, $FORM{instancename}) FAILED;");
|
||
|
#hkh bug#157 delete any new files due to incomplete cloning
|
||
|
} else {
|
||
|
log_entry($SESSION{'clid'}, $SESSION{'uid'}, "2",
|
||
|
"Created an Instance of test '$FORM{instancename}' from test/survey '$FORM{'tstid'}'");
|
||
|
}
|
||
|
$FORM{'respmsg'} .= $msg;
|
||
|
}
|
||
|
|
||
|
#
|
||
|
# Clone this test?
|
||
|
#
|
||
|
if ( ($FORM{cloneit} eq 'Y' || $FORM{cloneit} eq 'on') ) {
|
||
|
|
||
|
$FORM{clonename} = strip_blanks($FORM{clonename});
|
||
|
$FORM{desc} = $FORM{clonedesc};
|
||
|
my ($rc, $msg) = &clone_test($SESSION{'clid'}, $FORM{'tstid'}, $FORM{clonename}, \%FORM);
|
||
|
if ( ! $rc ) {
|
||
|
|
||
|
&logger::logerr("&clone_test($SESSION{'clid'}, $FORM{'tstid'}, $FORM{clonename}) FAILED;");
|
||
|
#hkh bug#157 delete any new files due to incomplete cloning
|
||
|
} else {
|
||
|
log_entry($SESSION{'clid'}, $SESSION{'uid'}, "2",
|
||
|
"Cloned test/survey '$FORM{clonename}' from test/survey '$FORM{'tstid'}'");
|
||
|
}
|
||
|
$FORM{'respmsg'} .= $msg;
|
||
|
}
|
||
|
}
|
||
|
$TEST{'reload'}="Y";
|
||
|
} else {
|
||
|
$FORM{'respmsg'} .= GetLanguageElement($SESSION{lang}, 557);
|
||
|
}
|
||
|
|
||
|
push @templates, (tdefund, tdef, tdefstd, tdefadp);
|
||
|
|
||
|
if ($FORM{'newtest'} ne 'Y') {
|
||
|
&get_test_profile($SESSION{'clid'}, $FORM{'tstid'});
|
||
|
if ($FORM{'frm'} eq 0) {
|
||
|
$FORM{'frm'} = ($TEST{'seq'} eq 'std') ? 2 : 3;
|
||
|
}
|
||
|
# added for subject area support
|
||
|
}
|
||
|
$SUBJAREA{'subjskillcgt'}=&get_subjskill_cntgrdtbl($SESSION{'clid'}, $FORM{'tstid'}, "");
|
||
|
# FIXME: This needs to go thru the language support facilities.
|
||
|
if ($FORM{'respmsg'} eq "") {
|
||
|
$FORM{'respmsg'} .= GetLanguageElement($SESSION{lang}, 556);
|
||
|
}
|
||
|
print $FORM{respmsg} if ( $FORM{respmsg} );
|
||
|
&get_client_profile($SESSION{'clid'});
|
||
|
&show_template($templates[$FORM{'frm'}]);
|
||
|
return 1;
|
||
|
}
|
||
|
}
|
||
|
}
|
||
|
|
||
|
|
||
|
sub setAvailableDatetimes {
|
||
|
my ($form) = @_;
|
||
|
|
||
|
$form->{availonminute} ||= $UI{DEFAULT_AVAILON_MIN};
|
||
|
$form->{availonhour} ||= $UI{DEFAULT_AVAILON_HR};
|
||
|
$form->{availthruminute} ||= $UI{DEFAULT_AVAILTHRU_MIN};
|
||
|
$form->{availthruhour} ||= $UI{DEFAULT_AVAILTHRU_HR};
|
||
|
|
||
|
|
||
|
if ( ! defined($form->{availonminute}) ||
|
||
|
! defined($form->{availonhour}) ||
|
||
|
! defined($form->{availonpmoffset}) ||
|
||
|
! defined($form->{availthruminute}) ||
|
||
|
! defined($form->{availthruhour}) ||
|
||
|
! defined($form->{availthrupmoffset}) ) {
|
||
|
logger::logerr("One of the 'availon...' or 'availthru...' form fields is undefined...aborting setAvailableDatetimes()");
|
||
|
return (0, GetLanguageElement($SESSION{lang}, 565));
|
||
|
}
|
||
|
|
||
|
if ( $form->{availonminute} !~ /^\d+$/ ) {
|
||
|
logger::logerr("form field 'availonminute' is not of the expected integer format...aborting setAvailableDatetimes(). availonminute = $form->{availonminute}");
|
||
|
return (0, GetLanguageElement($SESSION{lang}, 565));
|
||
|
}
|
||
|
|
||
|
if ( $form->{availonhour} !~ /^\d+$/ ) {
|
||
|
logger::logerr("form field 'availonhour' is not of the expected integer format...aborting setAvailableDatetimes()");
|
||
|
return (0, GetLanguageElement($SESSION{lang}, 565));
|
||
|
}
|
||
|
|
||
|
$form->{availonpmoffset} ||= 0;
|
||
|
$form->{availthrupmoffset} ||= 0;
|
||
|
if ( $form->{availonpmoffset} !~ /^\d+$/ ) {
|
||
|
logger::logerr("form field 'availonpmoffset' [$form->{availonpmoffset}] is not of the expected integer format...aborting setAvailableDatetimes()");
|
||
|
return (0, GetLanguageElement($SESSION{lang}, 565));
|
||
|
}
|
||
|
|
||
|
if ( $form->{availthruminute} !~ /^\d+$/ ) {
|
||
|
logger::logerr("form field 'availthruminute' is not of the expected integer format...aborting setAvailableDatetimes()");
|
||
|
return (0, GetLanguageElement($SESSION{lang}, 565));
|
||
|
}
|
||
|
|
||
|
if ( $form->{availthruhour} !~ /^\d+$/ ) {
|
||
|
logger::logerr("form field 'availthruhour' is not of the expected integer format...aborting setAvailableDatetimes()");
|
||
|
return (0, GetLanguageElement($SESSION{lang}, 565));
|
||
|
}
|
||
|
|
||
|
if ( $form->{availthrupmoffset} !~ /^\d+$/ ) {
|
||
|
logger::logerr("form field 'availthrupmoffset' is not of the expected integer format...aborting setAvailableDatetimes()");
|
||
|
return (0, GetLanguageElement($SESSION{lang}, 565));
|
||
|
}
|
||
|
|
||
|
if ( $form->{availonhour} < 12 ) {
|
||
|
$form->{availonhour} += $form->{availonpmoffset};
|
||
|
} elsif ( $form->{availonpmoffset} == 0 ) {
|
||
|
$form->{availonhour} -= 12;
|
||
|
}
|
||
|
|
||
|
if ( $form->{availthruhour} < 12 ) {
|
||
|
$form->{availthruhour} += $form->{availthrupmoffset};
|
||
|
} elsif ( $form->{availthrupmoffset} == 0 ) {
|
||
|
$form->{availthruhour} -= 12;
|
||
|
}
|
||
|
|
||
|
$form->{availon} = sprintf("%02d/%02d/%04d-%02d:%02d",
|
||
|
$form->{availonmonth},
|
||
|
$form->{availonday},
|
||
|
$form->{availonyear},
|
||
|
$form->{availonhour},
|
||
|
$form->{availonminute});
|
||
|
|
||
|
$form->{availthru} = sprintf("%02d/%02d/%04d-%02d:%02d",
|
||
|
$form->{availthrumonth},
|
||
|
$form->{availthruday},
|
||
|
$form->{availthruyear},
|
||
|
$form->{availthruhour},
|
||
|
$form->{availthruminute});
|
||
|
|
||
|
my $on = POSIX::strftime("%s", 0, $form->{availonminute},
|
||
|
$form->{availonhour},
|
||
|
$form->{availonday},
|
||
|
$form->{availonmonth} - 1,
|
||
|
$form->{availonyear} - 1900);
|
||
|
|
||
|
my $to = POSIX::strftime("%s", 0, $form->{availthruminute},
|
||
|
$form->{availthruhour},
|
||
|
$form->{availthruday},
|
||
|
$form->{availthrumonth} - 1,
|
||
|
$form->{availthruyear} - 1900);
|
||
|
|
||
|
if ( ! valid_date( $form->{availonyear},
|
||
|
$form->{availonmonth},
|
||
|
$form->{availonday}) ) {
|
||
|
&logger::loguerr("Bogus availability start date/time: [$form->{availon}]");
|
||
|
return (0, GetLanguageElement($SESSION{lang}, 577));
|
||
|
}
|
||
|
|
||
|
if ( ! valid_date( $form->{availthruyear},
|
||
|
$form->{availthrumonth},
|
||
|
$form->{availthruday}) ) {
|
||
|
&logger::loguerr("Bogus availability end date/time: [$form->{availthru}]");
|
||
|
return (0, GetLanguageElement($SESSION{lang}, 577));
|
||
|
}
|
||
|
|
||
|
if ( $to <= $on ) {
|
||
|
&logger::loguerr("Test/survey starting time ($form->{availon}) later than ending time ($form->{availthru})");
|
||
|
return (0, GetLanguageElement($SESSION{lang}, 576));
|
||
|
}
|
||
|
|
||
|
|
||
|
return (1, "");
|
||
|
}
|
||
|
|
||
|
sub valid_test_id_syntax( $ ) {
|
||
|
my ($testid) = @_;
|
||
|
|
||
|
# No spaces allowed in test names...
|
||
|
if ( $testid =~ /\s/ ) {
|
||
|
return (0, GetLanguageElement($SESSION{lang}, 555)); #No spaces
|
||
|
}
|
||
|
|
||
|
if ( $testid !~ /\S/ ) {
|
||
|
return (0, GetLanguageElement($SESSION{lang}, 567)); #At least 1 char
|
||
|
}
|
||
|
|
||
|
return (1, GetLanguageElement($SESSION{lang}, 566)); #OK
|
||
|
}
|
||
|
|
||
|
# Return 1 if the test already exists, 0 if it does not.
|
||
|
sub is_duplicate_test_id {
|
||
|
($id,$clid) = @_;
|
||
|
|
||
|
# FIXME: Handle undefined test ID/description
|
||
|
|
||
|
@test_list = &get_test_list($clid);
|
||
|
|
||
|
foreach ( @test_list ) {
|
||
|
|
||
|
($this_id, $this_desc) = split(/&/, $_);
|
||
|
if ( $this_id eq $id ) {
|
||
|
return 1;
|
||
|
}
|
||
|
}
|
||
|
|
||
|
return 0;
|
||
|
}
|
||
|
|
||
|
#
|
||
|
# Copy/duplicate the test $tstid and name the new cloned test $newtestid for
|
||
|
# client $clid.
|
||
|
#
|
||
|
sub instance_test( $ $ $ $ ) {
|
||
|
my ($clid, $oldtestid, $newtestid, $params) = @_;
|
||
|
|
||
|
my ($rc, $msg) = valid_test_id_syntax($newtestid);
|
||
|
if ( ! $rc ) {
|
||
|
&logger::loguerr("Invalid test ID syntax: '$newtestid'");
|
||
|
return (0, errorformat($msg));
|
||
|
}
|
||
|
|
||
|
if ( &is_duplicate_test_id($newtestid, $SESSION{'clid'}) ) {
|
||
|
&logger::loguerr("The test ID '$newtestid' already exists and cannot serve as a test ID for a new instance test for client '$clid'.");
|
||
|
my $msg = GetLanguageElement($SESSION{lang}, 936);
|
||
|
$msg .= " ".GetLanguageElement($SESSION{lang}, 564);
|
||
|
$msg .= " ".GetLanguageElement($SESSION{lang}, 552);
|
||
|
$msg .= qq{ "$newtestid" };
|
||
|
$msg .= GetLanguageElement($SESSION{lang}, 554);
|
||
|
return (0, errorformat($msg));
|
||
|
}
|
||
|
|
||
|
if ( ! $params || ref($params) ne 'HASH' ) {
|
||
|
&logger::logerr("Missing new test parameters for Instance test ID '$newtestid', client '$clid'.");
|
||
|
return 0;
|
||
|
my $msg = GetLanguageElement($SESSION{lang}, 936);
|
||
|
$msg .= " ".GetLanguageElement($SESSION{lang}, 564);
|
||
|
$msg .= " ".GetLanguageElement($SESSION{lang}, 565);
|
||
|
return (0, errorformat($msg));
|
||
|
}
|
||
|
|
||
|
|
||
|
my $newtest = 'Y';
|
||
|
|
||
|
if ( ! &put_test_profile($clid, $newtestid, $params, $newtest, $oldtestid) ) {
|
||
|
&logger::logerr("put_test_profile($clid,$newtestid,$params,$newtest) FAILED");
|
||
|
my $msg = GetLanguageElement($SESSION{lang}, 936);
|
||
|
return (0, errorformat($msg));
|
||
|
}
|
||
|
if ( ! &link_question_file($clid, $oldtestid, $newtestid) ) {
|
||
|
&remove_created_test_file($clid, $newtestid);
|
||
|
&logger::logerr("link_question_file($clid, $oldtestid, $newtestid) FAILED");
|
||
|
my $msg = GetLanguageElement($SESSION{lang}, 937);
|
||
|
return (0, errorformat($msg));
|
||
|
}
|
||
|
|
||
|
if ( ! &link_sbacustom_files($clid, $oldtestid, $newtestid) ) {
|
||
|
&remove_created_test_file($clid, $newtestid);
|
||
|
&remove_created_question_file($clid, $newtestid);
|
||
|
&logger::logerr("link_sbacustom_files($clid, $oldtestid, $newtestid) FAILED");
|
||
|
my $msg = GetLanguageElement($SESSION{lang}, 938);
|
||
|
return (0, errorformat($msg));
|
||
|
}
|
||
|
|
||
|
if ( ! &link_test_logos($clid, $oldtestid, $newtestid) ) {
|
||
|
&remove_created_test_file($clid, $newtestid);
|
||
|
&remove_created_question_file($clid, $newtestid);
|
||
|
&remove_created_sbacustom_files($clid, $newtestid);
|
||
|
&logger::logerr("link_test_logos($clid, $oldtestid, $newtestid) FAILED");
|
||
|
my $msg = GetLanguageElement($SESSION{lang}, 939);
|
||
|
return (0, errorformat($msg));
|
||
|
}
|
||
|
|
||
|
my $msg = GetLanguageElement($SESSION{lang}, 940);
|
||
|
$msg .= "'$oldtestid'";
|
||
|
$msg .= GetLanguageElement($SESSION{lang}, 569);
|
||
|
$msg .= "'$newtestid'";
|
||
|
|
||
|
return (1, okformat($msg));
|
||
|
}
|
||
|
|
||
|
sub link_test_logos {
|
||
|
my ($clid, $srctestid, $newtestid) = @_;
|
||
|
|
||
|
if ( ! opendir(DIR, $testgraphic) ) {
|
||
|
&logger::logerr("Unable to opendir $testgraphic: $!");
|
||
|
return 0;
|
||
|
}
|
||
|
@filenames = readdir(DIR);
|
||
|
closedir(DIR);
|
||
|
|
||
|
# my $regex = "^$clid".'\.'."$srctestid".'(.*)$';
|
||
|
|
||
|
foreach my $srcfile ( @filenames ) {
|
||
|
|
||
|
if ( $srcfile =~ /^$clid.$srctestid.0(.*)$/ ) {
|
||
|
my $newfile = join($pathsep, $testgraphic, "$clid.$newtestid.0$1");
|
||
|
my $oldfile = join($pathsep, $testgraphic, $srcfile);
|
||
|
if (! symlink($oldfile, $newfile)) {
|
||
|
&remove_created_logo_files($clid, $newtestid);
|
||
|
return 0;
|
||
|
}
|
||
|
|
||
|
}
|
||
|
}
|
||
|
|
||
|
return 1;
|
||
|
}
|
||
|
|
||
|
sub link_question_file {
|
||
|
my ($clid, $oldtestid, $newtestid) = @_;
|
||
|
my $oldfile = join($pathsep, $questionroot, "$oldtestid.$clid");
|
||
|
my $newfile = join($pathsep, $questionroot, "$newtestid.$clid");
|
||
|
if (! symlink($oldfile, $newfile)) {
|
||
|
&remove_created_question_file($clid, $newtestid);
|
||
|
return 0;
|
||
|
}
|
||
|
return 1;
|
||
|
}
|
||
|
|
||
|
sub link_sbacustom_files {
|
||
|
my ($clid, $oldtestid, $newtestid) = @_;
|
||
|
if ( ! opendir(DIR, $questionroot) ) {
|
||
|
&logger::logerr("Unable to opendir $questionroot: $!");
|
||
|
return 0;
|
||
|
}
|
||
|
@filenames = readdir(DIR);
|
||
|
closedir(DIR);
|
||
|
|
||
|
#my $regex = "^$oldtestid".'\.'."$clid".'\.'.'(.*)$';
|
||
|
foreach my $srcfile ( @filenames ) {
|
||
|
|
||
|
if ( $srcfile =~ /^$oldtestid\.$clid\.(.*)$/ ) {
|
||
|
my $newfile = join($pathsep, $questionroot, "$newtestid.$clid.$1");
|
||
|
my $oldfile = join($pathsep, $questionroot, $srcfile);
|
||
|
if ( ! symlink($oldfile, $newfile)) {
|
||
|
&remove_created_sbacustom_files($clid, $newtestid);
|
||
|
return 0;
|
||
|
}
|
||
|
}
|
||
|
}
|
||
|
|
||
|
return 1;
|
||
|
}
|
||
|
|
||
|
#
|
||
|
# Copy/duplicate the test $tstid and name the new cloned test $newtestid for
|
||
|
# client $clid.
|
||
|
#
|
||
|
sub clone_test( $ $ $ $ ) {
|
||
|
my ($clid, $oldtestid, $newtestid, $params) = @_;
|
||
|
|
||
|
my ($rc, $msg) = valid_test_id_syntax($newtestid);
|
||
|
if ( ! $rc ) {
|
||
|
&logger::loguerr("Invalid test ID syntax: '$newtestid'");
|
||
|
return (0, errorformat($msg));
|
||
|
}
|
||
|
|
||
|
if ( &is_duplicate_test_id($newtestid, $SESSION{'clid'}) ) {
|
||
|
&logger::loguerr("The test ID '$newtestid' already exists and cannot serve as a test ID for a newly cloned test for client '$clid'.");
|
||
|
my $msg = GetLanguageElement($SESSION{lang}, 563);
|
||
|
$msg .= " ".GetLanguageElement($SESSION{lang}, 564);
|
||
|
$msg .= " ".GetLanguageElement($SESSION{lang}, 552);
|
||
|
$msg .= qq{ "$newtestid" };
|
||
|
$msg .= GetLanguageElement($SESSION{lang}, 554);
|
||
|
return (0, errorformat($msg));
|
||
|
}
|
||
|
|
||
|
if ( ! $params || ref($params) ne 'HASH' ) {
|
||
|
&logger::logerr("Missing new test parameters for clone test ID '$newtestid', client '$clid'.");
|
||
|
return 0;
|
||
|
my $msg = GetLanguageElement($SESSION{lang}, 563);
|
||
|
$msg .= " ".GetLanguageElement($SESSION{lang}, 564);
|
||
|
$msg .= " ".GetLanguageElement($SESSION{lang}, 565);
|
||
|
return (0, errorformat($msg));
|
||
|
}
|
||
|
|
||
|
|
||
|
my $newtest = 'Y';
|
||
|
|
||
|
if ( ! &put_test_profile($clid, $newtestid, $params, $newtest) ) {
|
||
|
&logger::logerr("put_test_profile($clid,$newtestid,$params,$newtest) FAILED");
|
||
|
my $msg = GetLanguageElement($SESSION{lang}, 563);
|
||
|
return (0, errorformat($msg));
|
||
|
}
|
||
|
|
||
|
if ( ! &clone_question_file($clid, $oldtestid, $newtestid) ) {
|
||
|
&remove_created_test_file($clid, $newtestid);
|
||
|
&logger::logerr("clone_question_file($clid, $oldtestid, $newtestid) FAILED");
|
||
|
my $msg = GetLanguageElement($SESSION{lang}, 731);
|
||
|
return (0, errorformat($msg));
|
||
|
}
|
||
|
|
||
|
# hkh 01/04 clone mtx & custom files
|
||
|
if ( ! &clone_sbacustom_files($clid, $oldtestid, $newtestid) ) {
|
||
|
&remove_created_test_file($clid, $newtestid);
|
||
|
&remove_created_question_file($clid, $newtestid);
|
||
|
&logger::logerr("clone_sbacustom_files($clid, $oldtestid, $newtestid) FAILED");
|
||
|
my $msg = GetLanguageElement($SESSION{lang}, 733);
|
||
|
return (0, errorformat($msg));
|
||
|
}
|
||
|
|
||
|
if ( ! &clone_test_logos($clid, $oldtestid, $newtestid) ) {
|
||
|
&remove_created_test_file($clid, $newtestid);
|
||
|
&remove_created_question_file($clid, $newtestid);
|
||
|
&remove_created_sbacustom_files($clid, $newtestid);
|
||
|
&logger::logerr("clone_test_logos($clid, $oldtestid, $newtestid) FAILED");
|
||
|
my $msg = GetLanguageElement($SESSION{lang}, 734);
|
||
|
return (0, errorformat($msg));
|
||
|
}
|
||
|
|
||
|
my $msg = GetLanguageElement($SESSION{lang}, 568);
|
||
|
$msg .= "'$oldtestid'";
|
||
|
$msg .= GetLanguageElement($SESSION{lang}, 569);
|
||
|
$msg .= "'$newtestid'";
|
||
|
|
||
|
return (1, okformat($msg));
|
||
|
}
|
||
|
|
||
|
|
||
|
sub reassignifduplicate {
|
||
|
$vid = $_[1];
|
||
|
@vtrecs = &get_test_list($_[0]);
|
||
|
while (&test_exists($vid)) {
|
||
|
$vid++;
|
||
|
}
|
||
|
return $vid;
|
||
|
}
|
||
|
|
||
|
sub put_test_logo {
|
||
|
my ($clid, $testid) = @_;
|
||
|
my $upfile;
|
||
|
my $msg;
|
||
|
my $chmodok;
|
||
|
my $testimg = upload('testimg');
|
||
|
my @fileparts = split(/\./, param('testimg'));
|
||
|
my $test_logo_ext = $fileparts[$#fileparts];
|
||
|
@fileparts = ();
|
||
|
if ($SYSTEM{'supportedimagemedia'} =~ /$test_logo_ext/i ) {
|
||
|
@suexts = split(/\;/, $SYSTEM{'supportedimagemedia'});
|
||
|
# remove any old logos for this test
|
||
|
foreach $suext (@suexts) {
|
||
|
$prefile = join($pathsep, $pubroot, "graphic", "$clid.$testid");
|
||
|
$existingfile=&file_exists_with_extension($prefile, $suext);
|
||
|
if ($existingfile ne '') {
|
||
|
$cnt = unlink $existingfile;
|
||
|
}
|
||
|
}
|
||
|
# write the uploaded file
|
||
|
$upfile = join($pathsep, $pubroot, "graphic", "$clid.$testid.$test_logo_ext");
|
||
|
open (OUTFILE, ">$upfile") or $msg="failed";
|
||
|
if ($msg ne "failed") {
|
||
|
binmode(OUTFILE);
|
||
|
while ($bytesread=read($testimg,$buffer,1024)) {
|
||
|
print OUTFILE $buffer;
|
||
|
}
|
||
|
close OUTFILE;
|
||
|
$chmodok = chmod 0666, $upfile;
|
||
|
}
|
||
|
}
|
||
|
}
|
||
|
|
||
|
|
||
|
sub clone_test_logos {
|
||
|
my ($clid, $srctestid, $newtestid) = @_;
|
||
|
|
||
|
if ( ! opendir(DIR, $testgraphic) ) {
|
||
|
&logger::logerr("Unable to opendir $testgraphic: $!");
|
||
|
return 0;
|
||
|
}
|
||
|
@filenames = readdir(DIR);
|
||
|
closedir(DIR);
|
||
|
|
||
|
# my $regex = "^$clid".'\.'."$srctestid".'(.*)$';
|
||
|
|
||
|
foreach my $srcfile ( @filenames ) {
|
||
|
|
||
|
if ( $srcfile =~ /^$clid.$srctestid.0(.*)$/ ) {
|
||
|
my $newfile = join($pathsep, $testgraphic, "$clid.$newtestid.0$1");
|
||
|
my $oldfile = join($pathsep, $testgraphic, $srcfile);
|
||
|
#hkh bug#58 cpbin("$oldfile", "$newfile", 1);
|
||
|
if (! &get_io_file($oldfile, $newfile)) {
|
||
|
&remove_created_logo_files($clid, $newtestid);
|
||
|
return 0;
|
||
|
}
|
||
|
|
||
|
# if ( ! cpbin("$oldfile", "$newfile") ) {
|
||
|
# &logger::logerr("cpbin($oldfile, $newfile) FAILED");
|
||
|
# if ( scalar(@copied) ) {
|
||
|
# &logger::logwarn("DUE cpbin() FAILURE, THERE ARE NOW ORPHANED IMAGE FILES IN $testgraphic: @copied");
|
||
|
# NOTE: We *could* delete the files we just copied,
|
||
|
# NOTE: but that just seems like a bad idea given
|
||
|
# NOTE: we could end-up deleting some original
|
||
|
# NOTE: graphics files accidentally if they were
|
||
|
# NOTE: already there and thus caused cpbin() to fail.
|
||
|
# }
|
||
|
# return 0;
|
||
|
# } else {
|
||
|
# push( @copied, $newfile );
|
||
|
# }
|
||
|
}
|
||
|
}
|
||
|
|
||
|
return 1;
|
||
|
}
|
||
|
|
||
|
sub remove_created_test_file {
|
||
|
my ($clid, $newtestid) = @_;
|
||
|
@trecs = &get_test_list($clid);
|
||
|
foreach $trec (@trecs) {
|
||
|
chop ($trec);
|
||
|
($id, $trash) = split(/\&/, $trec);
|
||
|
if ($newtestid ne $id) {
|
||
|
push @newtests, $trec;
|
||
|
}
|
||
|
}
|
||
|
@trecs = @newtests;
|
||
|
&save_test_list($clid);
|
||
|
}
|
||
|
|
||
|
#hkh bug#157 delete new logofiles if clonning is not successful
|
||
|
sub remove_created_logo_files {
|
||
|
my ($clid, $newtestid) = @_;
|
||
|
opendir(DIR, $testgraphic);
|
||
|
@filenames = readdir(DIR);
|
||
|
closedir(DIR);
|
||
|
foreach my $srcfile ( @filenames ) {
|
||
|
if ( $srcfile =~ /^$clid.$newtestid.0(.*)$/ ) {
|
||
|
$ulinkfile = join($pathsep, $testgraphic, $srcfile);
|
||
|
$cnt = unlink $ulinkfile;
|
||
|
}
|
||
|
}
|
||
|
}
|
||
|
|
||
|
sub test_exists {
|
||
|
foreach $vtrec (@vtrecs) {
|
||
|
($vid, $vmore) = split(/&/, $vtrec);
|
||
|
if ($vid eq $_[0]) {
|
||
|
return 1;
|
||
|
}
|
||
|
}
|
||
|
return 0;
|
||
|
}
|
||
|
|
||
|
sub create_question_file {
|
||
|
my ($clid, $testid) = @_;
|
||
|
@lines = &get_question_list("default", "std");
|
||
|
$trash = join($pathsep, $questionroot, "$testid.$clid");
|
||
|
open (TMPFILE, ">$trash");
|
||
|
foreach $line (@lines) {
|
||
|
print TMPFILE "$line";
|
||
|
}
|
||
|
close TMPFILE;
|
||
|
$chmodok = chmod 0666, $trash;
|
||
|
}
|
||
|
|
||
|
|
||
|
sub clone_question_file {
|
||
|
my ($clid, $oldtestid, $newtestid) = @_;
|
||
|
@lines = &get_question_list($oldtestid, $clid);
|
||
|
$new_question_file = join($pathsep, $questionroot, "$newtestid.$clid");
|
||
|
if ( ! open (TMPFILE, ">$new_question_file") ) {
|
||
|
&logger::logerr("Unable to write to $new_question_file: $!");
|
||
|
return undef;
|
||
|
}
|
||
|
$line1 = '0';
|
||
|
foreach $line (@lines) {
|
||
|
#hkh bug#19 if oldtestid is diff. from question-id, replace q-id with newtestid
|
||
|
if ($line1 eq '0') {
|
||
|
$line1 = '1';
|
||
|
print TMPFILE "$line";
|
||
|
} else {
|
||
|
@fields = split /&/, $line;
|
||
|
$_ = shift(@fields);
|
||
|
s/.*\./$newtestid./;
|
||
|
unshift(@fields, $_);
|
||
|
$line = join "&", @fields;
|
||
|
#hkh bug#19 $line =~ s/^$oldtestid/$newtestid/;
|
||
|
print TMPFILE "$line";
|
||
|
}
|
||
|
}
|
||
|
close TMPFILE;
|
||
|
$chmodok = chmod 0666, $new_question_file;
|
||
|
}
|
||
|
|
||
|
sub remove_created_question_file {
|
||
|
my ($clid, $newtestid) = @_;
|
||
|
$ulinkfile = join($pathsep, $questionroot, "$newtestid.$clid");
|
||
|
$cnt = unlink $ulinkfile;
|
||
|
}
|
||
|
|
||
|
# hkh 01/04
|
||
|
sub clone_sbacustom_files {
|
||
|
my ($clid, $oldtestid, $newtestid) = @_;
|
||
|
if ( ! opendir(DIR, $questionroot) ) {
|
||
|
&logger::logerr("Unable to opendir $questionroot: $!");
|
||
|
return 0;
|
||
|
}
|
||
|
@filenames = readdir(DIR);
|
||
|
closedir(DIR);
|
||
|
|
||
|
#my $regex = "^$oldtestid".'\.'."$clid".'\.'.'(.*)$';
|
||
|
foreach my $srcfile ( @filenames ) {
|
||
|
|
||
|
if ( $srcfile =~ /^$oldtestid\.$clid\.(.*)$/ ) {
|
||
|
my $newfile = join($pathsep, $questionroot, "$newtestid.$clid.$1");
|
||
|
my $oldfile = join($pathsep, $questionroot, $srcfile);
|
||
|
#hkh bug#58 cpbin("$oldfile", "$newfile", 1)
|
||
|
if ( ! &get_io_file($oldfile, $newfile)) {
|
||
|
&remove_created_sbacustom_files($clid, $newtestid);
|
||
|
return 0;
|
||
|
}
|
||
|
}
|
||
|
}
|
||
|
|
||
|
return 1;
|
||
|
}
|
||
|
|
||
|
sub remove_created_sbacustom_files {
|
||
|
my ($clid, $newtestid) = @_;
|
||
|
opendir(DIR, $questionroot);
|
||
|
@filenames = readdir(DIR);
|
||
|
closedir(DIR);
|
||
|
foreach my $srcfile ( @filenames ) {
|
||
|
if ( $srcfile =~ /^$newtestid.$clid.(.*)$/ ) {
|
||
|
$ulinkfile = join($pathsep, $questionroot, $srcfile);
|
||
|
$cnt = unlink $ulinkfile;
|
||
|
}
|
||
|
}
|
||
|
|
||
|
}
|
||
|
|
||
|
sub show_upload_form {
|
||
|
$iShownCount=0;
|
||
|
$qreclist = "";
|
||
|
&get_test_profile($SESSION{'clid'}, $FORM{'tstid'});
|
||
|
&show_template("uploadpagehdr");
|
||
|
print "<FORM METHOD=POST ACTION=\"$PATHS{'cgiroot'}/upimages.pl\" enctype=\"multipart/form-data\">\n";
|
||
|
print "<input type=hidden name=tid value=\"$SESSION{'tid'}\">\n";
|
||
|
print "<input type=hidden name=clid value=\"$SESSION{'clid'}\">\n";
|
||
|
print "<TABLE cellpadding=0 cellspacing=0 border=1 width=\"100%\">\n";
|
||
|
print "<TR>\n";
|
||
|
print "<TD align=\"left\"><Font Size=1>\n";
|
||
|
print "Upload Image\n";
|
||
|
print "</font></TD>\n";
|
||
|
print "<TD align=\"left\"><Font Size=1>\n";
|
||
|
print "\ \n";
|
||
|
print "</font></TD>\n";
|
||
|
print "<TD align=\"left\"><Font Size=1>\n";
|
||
|
print "Question\n";
|
||
|
print "</font></TD>\n";
|
||
|
print "</TR>\n";
|
||
|
@qrecs = &get_question_list($FORM{'tstid'}, $SESSION{'clid'});
|
||
|
$bFirst = 1;
|
||
|
foreach $qrec (@qrecs) {
|
||
|
chop ($qrec);
|
||
|
if ($bFirst) {
|
||
|
@flds = split(/&/, $qrec);
|
||
|
$bFirst = 0;
|
||
|
$i = 0;
|
||
|
foreach $fld (@flds) {
|
||
|
if ($fld eq 'qim') {
|
||
|
$iqim = $i;
|
||
|
} else {
|
||
|
if ($fld eq 'id') {
|
||
|
$iid = $i;
|
||
|
} else {
|
||
|
if ($fld eq 'qtx') {
|
||
|
$iqtx = $i;
|
||
|
}
|
||
|
}
|
||
|
}
|
||
|
$i++;
|
||
|
}
|
||
|
} else {
|
||
|
@flds = split(/&/, $qrec);
|
||
|
if ($flds[$iqim] ne '0') {
|
||
|
$iShownCount++;
|
||
|
print "<TR>\n";
|
||
|
print "<TD align=\"left\"><Font Size=1>\n";
|
||
|
print "<INPUT TYPE=FILE NAME=\"$SESSION{'clid'}.$flds[$iid]\" MAXLENGTH=120 SIZE=20> \n";
|
||
|
$qreclist .= "$flds[$iid]::";
|
||
|
print "</font></TD>\n";
|
||
|
print "<TD align=\"left\"><Font Size=1>\n";
|
||
|
print "\ $flds[$iid]:\ \n";
|
||
|
print "</font></TD>\n";
|
||
|
print "<TD align=\"left\"><Font Size=1>\n";
|
||
|
print "$flds[$iqtx]\n";
|
||
|
print "</font></TD>\n";
|
||
|
print "</TR>\n";
|
||
|
}
|
||
|
}
|
||
|
}
|
||
|
$qreclist = substr($qreclist,0,-2);
|
||
|
unless ($iShownCount) {
|
||
|
print "<TR>\n";
|
||
|
print "<TD colspan=\"3\" align=\"left\">\n";
|
||
|
print "No questions were tagged as having images.\n";
|
||
|
print "</TD>\n";
|
||
|
print "</TR>\n";
|
||
|
}
|
||
|
print "<TR>\n";
|
||
|
print "<TD colspan=\"3\" align=\"center\">\n";
|
||
|
print "<INPUT TYPE=HIDDEN NAME=\"path\" VALUE=\"$testgraphic\">\n";
|
||
|
print "<INPUT TYPE=HIDDEN NAME=\"fieldlist\" VALUE=\"$qreclist\">\n";
|
||
|
print "<INPUT TYPE=SUBMIT VALUE=\"$xlatphrase[512]\">\n";
|
||
|
print "</TD>\n";
|
||
|
print "</TR>\n";
|
||
|
print "</TABLE>\n";
|
||
|
print "</FORM>\n";
|
||
|
print "</BODY>\n</HTML>\n";
|
||
|
}
|
||
|
|
||
|
sub preview_cfa {
|
||
|
print "
|
||
|
<HTML>
|
||
|
<HEAD>
|
||
|
<!-- Based on agreement.htt,v 1.2 2002/02/14 21:02:55 ed Exp $ -->
|
||
|
<TITLE>Confidentiality Agreement</TITLE>
|
||
|
</HEAD>
|
||
|
<BODY BGCOLOR=\"#FFFFFF\" TEXT=\"#000000\" LINK=\"#0000FF\" VLINK=\"#800080\">
|
||
|
<TABLE CELLSPACING=0 CELLPADDING=0 BORDER=0 width=\"100%\">
|
||
|
<TR>
|
||
|
<td align=\"left\">
|
||
|
<FONT SIZE=4>
|
||
|
<BR>
|
||
|
</FONT>
|
||
|
</td>
|
||
|
</TR>
|
||
|
<TR>
|
||
|
<td align=\"left\">
|
||
|
$FORM{'cfa'} <BR>
|
||
|
<BR>
|
||
|
</td>
|
||
|
</TR>
|
||
|
<TR>
|
||
|
<td align=\"center\">
|
||
|
<INPUT TYPE=BUTTON NAME=submit VALUE=\"$xlatphrase[487]\" onClick=window.close()>
|
||
|
<INPUT TYPE=BUTTON NAME=submit VALUE=\"$xlatphrase[488]\" onClick=window.close()>
|
||
|
</form>
|
||
|
</td>
|
||
|
</TR>
|
||
|
</TABLE>
|
||
|
</BODY>
|
||
|
</HTML>\n";
|
||
|
}
|