--- loncom/interface/lonsupportreq.pm 2006/09/01 21:07:11 1.37
+++ loncom/interface/lonsupportreq.pm 2017/10/13 19:59:11 1.92
@@ -1,5 +1,7 @@
+# The LearningOnline Network with CAPA
+# Helpdesk request form
#
-# $Id: lonsupportreq.pm,v 1.37 2006/09/01 21:07:11 raeburn Exp $
+# $Id: lonsupportreq.pm,v 1.92 2017/10/13 19:59:11 raeburn Exp $
#
# Copyright Michigan State University Board of Trustees
#
@@ -27,18 +29,17 @@
package Apache::lonsupportreq;
use strict;
-use lib qw(/home/httpd/lib/perl);
-use MIME::Types;
-use MIME::Lite;
use CGI::Cookie();
use Apache::Constants qw(:common);
use Apache::loncommon();
+use Apache::lonhtmlcommon;
use Apache::lonnet;
use Apache::lonlocal;
use Apache::lonacc();
-use lib '/home/httpd/lib/perl/';
-use LONCAPA;
-
+use Apache::lonauth();
+use Apache::courseclassifier;
+use LONCAPA qw(:DEFAULT :match);
+use HTML::Entities;
sub handler {
my ($r) = @_;
@@ -48,121 +49,114 @@ sub handler {
if ($r->header_only) {
return OK;
}
+ if ($r->uri eq '/adm/helpdesk') {
+ &Apache::lonlocal::get_language_handle($r);
+ }
+
&Apache::loncommon::get_unprocessed_cgi($ENV{'QUERY_STRING'},['origurl','function']);
if ($r->uri eq '/adm/helpdesk') {
&Apache::lonacc::get_posted_cgi($r);
}
- my $function = $env{'form.function'};
- my $origurl = &unescape($env{'form.origurl'});
- my $action = $env{'form.action'};
+ my $function;
+ if ($env{'form.function'}) {
+ if (($env{'form.function'} eq 'norole') ||
+ ($env{'form.function'} eq 'student') ||
+ ($env{'form.function'} eq 'admin') ||
+ ($env{'form.function'} eq 'author')) {
+ $function = $env{'form.function'};
+ }
+ }
+ my $origurl = $env{'form.origurl'};
+ $origurl =~ s{^https?://}{};
+ $origurl =~ s/(`)//g;
+ $origurl =~ s/\$/\(\$\)/g;
+ my $command = $env{'form.command'};
- if ($action eq 'process') {
+ if ($command eq 'process') {
&print_request_receipt($r,$origurl,$function);
} else {
&print_request_form($r,$origurl,$function);
}
return OK;
}
-
+
sub print_request_form {
my ($r,$origurl,$function) = @_;
- my ($os,$browser,$bversion,$uhost,$uname,$udom,$uhome,$urole,$usec,$email,$cid,$cdom,$cnum,$ctitle,$ccode,$sectionlist,$lastname,$firstname,$server,$formname);
- my $tablecolor = &Apache::loncommon::designparm($function.'.tabbg');
- if (($tablecolor eq '') || ($tablecolor eq '#FFFFFF')) {
- $tablecolor = '#EEEE99';
- }
+ my ($os,$browser,$bversion,$uname,$udom,$uhome,$urole,$usec,$email,$cid,
+ $cdom,$cnum,$ctitle,$ccode,$sectionlist,$lastname,$firstname,$server,
+ $formname,$public,$homeserver,$knownuser,$captcha_form,$captcha_error,
+ $captcha,$recaptcha_version,$extra_validations,%groupid);
+ $function = &Apache::loncommon::get_users_function() if (!$function);
$ccode = '';
$os = $env{'browser.os'};
$browser = $env{'browser.type'};
$bversion = $env{'browser.version'};
- $uhost = $env{'request.host'};
- $uname = $env{'user.name'};
- $udom = $env{'user.domain'};
- $uhome = $env{'user.home'};
- $urole = $env{'request.role'};
- $usec = $env{'request.course.sec'};
- $cid = $env{'request.course.id'};
- $formname = 'logproblem';
- if ($origurl =~ m-^http://-) {
- $server = $origurl;
+ if (($env{'user.name'} eq 'public') && ($env{'user.domain'} eq 'public')) {
+ $public = 1;
} else {
- $server = 'http://'.$ENV{'SERVER_NAME'}.$origurl;
- }
- my $scripttag = (<<'END');
-function validate() {
- if (validmail(document.logproblem.email) == false) {
- alert("The e-mail address you entered: "+document.logproblem.email.value+" is not a valid e-mail address.");
- return;
- }
- document.logproblem.submit();
-}
-
-function validmail(field) {
- var str = field.value;
- if (window.RegExp) {
- var reg1str = "(@.*@)|(\\.\\.)|(@\\.)|(\\.@)|(^\\.)";
- var reg2str = "^.+\\@(\\[?)[a-zA-Z0-9\\-\\.]+\\.([a-zA-Z]{2,3}|[0-9]{1,3})(\\]?)$"; //"
- var reg1 = new RegExp(reg1str);
- var reg2 = new RegExp(reg2str);
- if (!reg1.test(str) && reg2.test(str)) {
- return true;
- }
- return false;
- }
- else
- {
- if(str.indexOf("@") >= 0) {
- return true;
+ if (($env{'user.name'} ne '') && ($env{'user.domain'} ne '')) {
+ $homeserver = &Apache::lonnet::homeserver($env{'user.name'},
+ $env{'user.domain'});
+ if ($homeserver eq 'no_host') {
+ undef($homeserver);
+ } else {
+ $uname = $env{'user.name'};
+ $udom = $env{'user.domain'};
+ }
}
- return false;
}
-}
-END
-
- if ($cid =~ m/_/) {
- ($cdom,$cnum) = split/_/,$cid;
+ if (($env{'user.name'} =~ /^$match_username$/) &&
+ ($env{'user.domain'} =~ /^$match_domain$/) && (!$public)) {
+ $knownuser = 1;
+ } else {
+ my $lonhost = $r->dir_config('lonHostID');
+ ($captcha_form,$captcha_error,$captcha,$recaptcha_version) =
+ &Apache::loncommon::captcha_display('login',$lonhost);
+ }
+ &Apache::loncommon::get_unprocessed_cgi($ENV{'QUERY_STRING'},['codedom',
+ 'useremail','useraccount']);
+
+ if ($homeserver) {
+ $uhome = $env{'user.home'};
+ $urole = $env{'request.role'};
+ $usec = $env{'request.course.sec'};
+ $cid = $env{'request.course.id'};
+ }
+ if ($cid) {
+ $cdom = $env{'course.'.$cid.'.domain'};
+ $cnum = $env{'course.'.$cid.'.num'};
}
if ($cdom && $cnum) {
my %csettings = &Apache::lonnet::get('environment',['description','internal.coursecode','internal.sectionnums'],$cdom,$cnum);
$ctitle = $csettings{'description'};
$ccode = $csettings{'internal.coursecode'};
$sectionlist = $csettings{'internal.sectionnums'};
+ my @sections = split(/,/,$sectionlist);
+ foreach my $section (@sections) {
+ my ($sec,$grp) = split(/:/,$section);
+ $groupid{$sec} = $grp;
+ }
}
- if ($env{'environment.critnotification'}) {
- $email = $env{'environment.critnotification'};
- }
- if (!$email && $env{'environment.notification'}) {
- $email = $env{'environment.notification'};
- }
- if ($env{'environment.lastname'}) {
- $lastname = $env{'environment.lastname'};
- }
- if ($env{'environment.firstname'}) {
- $firstname = $env{'environment.firstname'};
- }
- my @sections = split/,/,$sectionlist;
- my %groupid = ();
- foreach (@sections) {
- my ($sec,$grp) = split/:/,$_;
- $groupid{$sec} = $grp;
- }
- my $codedom = $Apache::lonnet::perlvar{'lonDefDomain'};
- &Apache::loncommon::get_unprocessed_cgi($ENV{'QUERY_STRING'},['codedom']);
- if (exists($env{'form.codedom'})) {
- $codedom = $env{'form.codedom'};
- }
- my $details_title;
- if ($codedom) {
- $details_title = '
('.$codedom.')';
+
+ $formname = 'logproblem';
+ my $codedom = &get_domain();
+ my %helpform;
+ my %domconfig =
+ &Apache::lonnet::get_dom('configuration',['contacts'],$codedom);
+ if (ref($domconfig{'contacts'}) eq 'HASH') {
+ if (ref($domconfig{'contacts'}{'helpform'}) eq 'HASH') {
+ %helpform = %{$domconfig{'contacts'}{'helpform'}};
+ }
}
- my %coursecodes = ();
- my %codes = ();
- my @codetitles = ();
- my %cat_titles = ();
- my %cat_order = ();
- my %idlist = ();
- my %idnums = ();
- my %idlist_titles = ();
+
+ my %coursecodes;
+ my %codes;
+ my @codetitles;
+ my %cat_titles;
+ my %cat_order;
+ my %idlist;
+ my %idnums;
+ my %idlist_titles;
my $caller = 'global';
my $totcodes = 0;
my $format_reply;
@@ -172,265 +166,317 @@ function initialize_codes() {
return;
}
|;
- if ($cdom) {
- $codedom = $cdom;
- }
- if ($cnum) {
- $coursecodes{$cnum} = $ccode;
- if ($ccode eq '') {
- $totcodes = &retrieve_instcodes(\%coursecodes,$codedom,$totcodes);
- } else {
- $coursecodes{$cnum} = $ccode;
- $caller = $cnum;
- $totcodes ++;
- }
- } else {
- $totcodes = &retrieve_instcodes(\%coursecodes,$codedom,$totcodes);
- }
- if ($totcodes > 0) {
- if ($ccode eq '') {
+ unless ($helpform{'course'} eq 'no') {
+ $totcodes = &Apache::courseclassifier::retrieve_instcodes(\%coursecodes,$codedom);
+ if ($totcodes > 0) {
$format_reply = &Apache::lonnet::auto_instcode_format($caller,$codedom,\%coursecodes,\%codes,\@codetitles,\%cat_titles,\%cat_order);
if ($format_reply eq 'ok') {
my $numtypes = @codetitles;
- &build_code_selections(\%codes,\@codetitles,\%cat_titles,\%cat_order,\%idlist,\%idnums,\%idlist_titles);
- &javascript_code_selections($formname,$numtypes,\%cat_titles,\$jscript,\%idlist,\%idnums,\%idlist_titles,\@codetitles);
+ &Apache::courseclassifier::build_code_selections(\%codes,\@codetitles,\%cat_titles,\%cat_order,\%idlist,\%idnums,\%idlist_titles);
+ my ($scripttext,$longtitles) = &Apache::courseclassifier::javascript_definitions(\@codetitles,\%idlist,\%idlist_titles,\%idnums,\%cat_titles);
+ my $longtitles_str = join('","',@{$longtitles});
+ my $allidlist = $idlist{$codetitles[0]};
+ my $knowncodes;
+ if (($ccode ne '') && ($cnum ne '')) {
+ my (%singlecodes,@singlecodetitles,%singlecat_titles,%singlecat_order);
+ my $crscode_reply = &Apache::lonnet::auto_instcode_format($cnum,$codedom,{ $cnum => $ccode },\%singlecodes,
+ \@singlecodetitles,\%singlecat_titles,\%singlecat_order);
+ if (ref($singlecodes{$cnum}) eq 'HASH') {
+ $knowncodes = $singlecodes{$cnum};
+ }
+ }
+ $jscript .= &Apache::courseclassifier::courseset_js_start($formname,$longtitles_str,$allidlist);
+ $jscript .= $scripttext;
+ $jscript .= &Apache::courseclassifier::javascript_code_selections($formname,\@codetitles,$knowncodes,$sectionlist);
$loaditems = '';
}
}
}
-
- my $js = '';
- my %add_entries = (topmargin => "0",
- marginheight => "0",
- onLoad =>"initialize_codes()",);
-
- my $start_page =
- &Apache::loncommon::start_page('Support Request',$js,
- { 'function' => $function,
- 'add_entries' => \%add_entries,
- 'only_body' => 1,});
- $r->print($start_page);
+ my %missing = &Apache::lonlocal::texthash(
+ username => 'You must include a name.',
+ phone => 'You must include a phone.',
+ );
+ &js_escape(\%missing);
+ if (keys(%helpform)) {
+ foreach my $key (keys(%helpform)) {
+ if (($helpform{$key} eq 'req') && ($missing{$key} ne '')) {
+ next if (($key eq 'username') && (($knownuser) ||
+ (($env{'user.name'} =~ /^$match_username$/) && (!$public))));
+ $extra_validations .= <<"END";
- if ($r->uri eq '/adm/helpdesk') {
- &print_header($r,$origurl);
+ if (document.$formname.$key.value == '') {
+ alert("$missing{$key}");
+ return;
}
- $r->print(<<"END");
-