version 1.574, 2022/02/25 09:38:47
|
version 1.583, 2024/12/27 02:32:56
|
Line 223 my %trust = (
|
Line 223 my %trust = (
|
courseidputhash => {remote => 1, domroles => 1, enroll => 1}, |
courseidputhash => {remote => 1, domroles => 1, enroll => 1}, |
courselastaccess => {remote => 1, domroles => 1, enroll => 1}, |
courselastaccess => {remote => 1, domroles => 1, enroll => 1}, |
coursesessions => {institutiononly => 1}, |
coursesessions => {institutiononly => 1}, |
|
crsfilefrompriv => {remote => 1, enroll => 1}, |
currentauth => {remote => 1, domroles => 1, enroll => 1}, |
currentauth => {remote => 1, domroles => 1, enroll => 1}, |
currentdump => {remote => 1, enroll => 1}, |
currentdump => {remote => 1, enroll => 1}, |
currentversion => {remote=> 1, content => 1}, |
currentversion => {remote=> 1, content => 1}, |
Line 259 my %trust = (
|
Line 260 my %trust = (
|
instidrules => {remote => 1, domroles => 1,}, |
instidrules => {remote => 1, domroles => 1,}, |
instrulecheck => {remote => 1, enroll => 1, reqcrs => 1, domroles => 1}, |
instrulecheck => {remote => 1, enroll => 1, reqcrs => 1, domroles => 1}, |
instselfcreatecheck => {institutiononly => 1}, |
instselfcreatecheck => {institutiononly => 1}, |
|
instunamemapcheck => {remote => 1,}, |
instuserrules => {remote => 1, enroll => 1, reqcrs => 1, domroles => 1}, |
instuserrules => {remote => 1, enroll => 1, reqcrs => 1, domroles => 1}, |
keys => {remote => 1,}, |
keys => {remote => 1,}, |
load => {anywhere => 1}, |
load => {anywhere => 1}, |
Line 305 my %trust = (
|
Line 307 my %trust = (
|
servertimezone => {remote => 1, enroll => 1}, |
servertimezone => {remote => 1, enroll => 1}, |
setannounce => {remote => 1, domroles => 1}, |
setannounce => {remote => 1, domroles => 1}, |
sethost => {anywhere => 1}, |
sethost => {anywhere => 1}, |
|
signlti => {remote => 1}, |
store => {remote => 1, enroll => 1, reqcrs => 1,}, |
store => {remote => 1, enroll => 1, reqcrs => 1,}, |
studentphoto => {remote => 1, enroll => 1}, |
studentphoto => {remote => 1, enroll => 1}, |
sub => {content => 1,}, |
sub => {content => 1,}, |
Line 312 my %trust = (
|
Line 315 my %trust = (
|
tmpget => {institutiononly => 1}, |
tmpget => {institutiononly => 1}, |
tmpput => {remote => 1, othcoau => 1}, |
tmpput => {remote => 1, othcoau => 1}, |
tokenauthuserfile => {anywhere => 1}, |
tokenauthuserfile => {anywhere => 1}, |
|
unamemaprules => {remote => 1,}, |
unsub => {content => 1,}, |
unsub => {content => 1,}, |
update => {shared => 1}, |
update => {shared => 1}, |
updatebalcookie => {institutiononly => 1}, |
updatebalcookie => {institutiononly => 1}, |
Line 863 sub PushFile {
|
Line 867 sub PushFile {
|
|
|
if($filename eq "host") { |
if($filename eq "host") { |
$contents = AdjustHostContents($contents); |
$contents = AdjustHostContents($contents); |
} elsif (($filename eq 'dns_host') || ($filename eq 'dns_domain') || |
} elsif (($filename eq 'dns_hosts') || ($filename eq 'dns_domain') || |
($filename eq 'loncapaCAcrl')) { |
($filename eq 'loncapaCAcrl')) { |
if ($contents eq '') { |
if ($contents eq '') { |
&logthis('<font color="red"> Pushfile: unable to install ' |
&logthis('<font color="red"> Pushfile: unable to install ' |
Line 1920 sub ls3_handler {
|
Line 1924 sub ls3_handler {
|
my $ulsout=''; |
my $ulsout=''; |
my $ulsfn; |
my $ulsfn; |
|
|
my ($crscheck,$toplevel,$currdom,$currnum,$skip); |
my ($crscheck,$toplevel,$currdom,$currnum,$skip,$privdir_for_course); |
unless ($islocal) { |
unless ($islocal) { |
my ($major,$minor) = split(/\./,$clientversion); |
my ($major,$minor) = split(/\./,$clientversion); |
if (($major < 2) || ($major == 2 && $minor < 12)) { |
if (($major < 2) || ($major == 2 && $minor < 12)) { |
$crscheck = 1; |
$crscheck = 1; |
} |
} |
|
if ($ulsdir =~ m{^/home/httpd/html/priv/($LONCAPA::match_domain)/($LONCAPA::match_courseid)}) { |
|
my ($currdom,$currnum) = ($1,$2); |
|
if (&LONCAPA::Lond::is_course($currdom,$currnum)) { |
|
$privdir_for_course = 1; |
|
} |
|
} |
} |
} |
if (-e $ulsdir) { |
if (-e $ulsdir) { |
if(-d $ulsdir) { |
if(-d $ulsdir) { |
unless (($getpropath) || ($getuserdir) || |
unless (($getpropath) || ($getuserdir) || |
($ulsdir =~ m{^/home/httpd/html/(res/$LONCAPA::match_domain|userfiles/)}) || |
($ulsdir =~ m{^/home/httpd/html/(res/$LONCAPA::match_domain|userfiles/)}) || |
($ulsdir =~ m{^/home/httpd/lonUsers/$LONCAPA::match_domain(?:/[\w\-.@]){3}/$LONCAPA::match_name/userfiles}) || |
($ulsdir =~ m{^/home/httpd/lonUsers/$LONCAPA::match_domain(?:/[\w\-.@]){3}/$LONCAPA::match_name/userfiles}) || |
(($ulsdir =~ m{^/home/httpd/html/priv/$LONCAPA::match_domain}) && ($islocal))) { |
(($ulsdir =~ m{^/home/httpd/html/priv/$LONCAPA::match_domain}) && ($islocal)) || |
|
($privdir_for_course)) { |
&Failure($client,"refused\n",$userinput); |
&Failure($client,"refused\n",$userinput); |
return 1; |
return 1; |
} |
} |
Line 2655 sub update_passwd_history {
|
Line 2666 sub update_passwd_history {
|
return; |
return; |
} |
} |
|
|
|
sub inst_unamemap_check { |
|
my ($cmd, $tail, $client) = @_; |
|
my $userinput = "$cmd:$tail"; |
|
my %rulecheck; |
|
my $outcome; |
|
my ($udom,$uname,@rules) = split(/:/,$tail); |
|
$udom = &unescape($udom); |
|
$uname = &unescape($uname); |
|
@rules = map {&unescape($_);} (@rules); |
|
eval { |
|
local($SIG{__DIE__})='DEFAULT'; |
|
$outcome = &localenroll::unamemap_check($udom,$uname,\@rules,\%rulecheck); |
|
}; |
|
if (!$@) { |
|
if ($outcome eq 'ok') { |
|
my $result=''; |
|
foreach my $key (keys(%rulecheck)) { |
|
$result.=&escape($key).'='.&Apache::lonnet::freeze_escape($rulecheck{$key}).'&'; |
|
} |
|
&Reply($client,\$result,$userinput); |
|
} else { |
|
&Reply($client,"error\n", $userinput); |
|
} |
|
} else { |
|
&Failure($client,"unknown_cmd\n",$userinput); |
|
} |
|
} |
|
®ister_handler("instunamemapcheck",\&inst_unamemap_check,0,1,0); |
|
|
|
|
# |
# |
# Determines if this is the home server for a user. The home server |
# Determines if this is the home server for a user. The home server |
# for a user will have his/her lon-capa passwd file. Therefore all we need |
# for a user will have his/her lon-capa passwd file. Therefore all we need |
Line 2784 sub devalidate_meta_cache {
|
Line 2825 sub devalidate_meta_cache {
|
} |
} |
|
|
# |
# |
|
# Copy a file from /home/httpd/html/priv/domain/coursenum/ |
|
# to /home/httpd/html/userfiles/domain/coursenum/priv |
|
# |
|
# Parameters: |
|
# $cmd - The command that got us here. |
|
# $tail - Tail of the command |
|
# : separated list of escaped values for |
|
# (a) relative path to a file in /priv/domain/coursenum |
|
# (b) coursenum |
|
# (c) domain |
|
# $client - File descriptor connected to client. |
|
# Returns |
|
# 0 - Requested to exit, caller should shut down. |
|
# 1 - Continue processing. |
|
# |
|
|
|
sub crs_filefrompriv_handler { |
|
my ($cmd, $tail, $client) = @_; |
|
my $userinput = "$cmd:$tail"; |
|
my ($path,$cnum,$cdom) = map { &unescape($_); } split(/:/,$tail); |
|
$path =~ s/\.{2,}//g; |
|
if (($path eq '') || ($path eq '.')) { |
|
&Failure($client, "not_found\n", "$cmd:$tail"); |
|
} else { |
|
$cdom = &LONCAPA::clean_domain($cdom); |
|
$cnum = &LONCAPA::clean_courseid($cnum); |
|
if (&LONCAPA::Lond::is_course($cdom,$cnum)) { |
|
my $toplevel = "/userfiles/$cdom/$cnum/priv"; |
|
my $toppath = $perlvar{'lonDocRoot'}.$toplevel; |
|
my $dest = $toppath.'/'.$path; |
|
my $desturl = $toplevel.'/'.$path; |
|
my $src = $perlvar{'lonDocRoot'}.'/priv/'.$cdom.'/'.$cnum.'/'.$path; |
|
my ($dest_mtime, $src_mtime); |
|
if (-e $dest) { |
|
($dest_mtime) = (stat($dest))[9]; |
|
} |
|
if (-e $src) { |
|
my $protocol = $Apache::lonnet::protocol{$perlvar{'lonHostID'}}; |
|
$protocol = 'http' if ($protocol ne 'https'); |
|
my $url = $protocol.'://'.&Apache::lonnet::hostname($perlvar{'lonHostID'}).$desturl; |
|
($src_mtime) = (stat($src))[9]; |
|
if ((-e $dest) && ($dest_mtime >= $src_mtime)) { |
|
my $result = &escape($url); |
|
&Reply($client,\$result,$userinput); |
|
} else { |
|
my $reldir = $toplevel; |
|
my ($subdir,$fname) = ($path =~ m{^(.+)/([^/]+)$}); |
|
if ($subdir eq '') { |
|
$fname = $path; |
|
} else { |
|
$reldir .= '/'.$subdir; |
|
} |
|
my $targetdir = $perlvar{'lonDocRoot'}; |
|
my $dirfail; |
|
foreach my $part (split(/\//,$reldir)) { |
|
$targetdir .= '/'.$part; |
|
if ((-e $targetdir)!=1) { |
|
unless (mkdir($targetdir,0755)) { |
|
$dirfail = 1; |
|
last; |
|
} |
|
} |
|
} |
|
if ($dirfail) { |
|
&Failure($client,"error: mkdir_failed\n", $userinput); |
|
} else { |
|
if (File::Copy::copy($src,$dest)) { |
|
my $result = &escape($url); |
|
&Reply($client,\$result,$userinput); |
|
} else { |
|
&Failure($client,"error: copy_failed\n", $userinput); |
|
} |
|
} |
|
} |
|
} else { |
|
&Failure($client,"error: not_found\n", $userinput); |
|
} |
|
} else { |
|
&Failure($client, "error: not_course\n", $userinput); |
|
} |
|
} |
|
return 1; |
|
} |
|
®ister_handler("crsfilefrompriv", \&crs_filefrompriv_handler, 0, 1, 0); |
|
|
|
# |
# Fetch a user file from a remote server to the user's home directory |
# Fetch a user file from a remote server to the user's home directory |
# userfiles subdir. |
# userfiles subdir. |
# Parameters: |
# Parameters: |
Line 5232 sub encrypted_get_domain_handler {
|
Line 5359 sub encrypted_get_domain_handler {
|
# 0 - Exit. |
# 0 - Exit. |
# Side effects: |
# Side effects: |
# The reply will contain an LTI itemID, if the signed LTI payload |
# The reply will contain an LTI itemID, if the signed LTI payload |
# could be verified using the consumer key and the shared secret |
# could be verified using the consumer key and the shared secret |
# available for that key (for the itemID) for either the course or domain, |
# available for that key (for the itemID) for either the course or domain, |
# depending on values for cnum and context. The reply is encrypted before |
# depending on values for cnum and context. The reply is encrypted before |
# being written to $client. |
# being written to $client. |
# |
# |
sub lti_handler { |
sub lti_handler { |
Line 5275 sub lti_handler {
|
Line 5402 sub lti_handler {
|
®ister_handler("lti", \<i_handler, 1, 1, 0); |
®ister_handler("lti", \<i_handler, 1, 1, 0); |
|
|
# |
# |
|
# Data for LTI payload (received encrypted) are unencrypted and |
|
# then signed with the appropriate key and secret, before re-encrypting |
|
# the signed payload which is sent to the client for unencryption by |
|
# the caller: lonnet::sign_lti()) before dispatch either to a web browser |
|
# (launch) or to a remote web service (roster, logout, or grade). |
|
# |
|
# Parameters: |
|
# $cmd - Command request keyword (signlti). |
|
# $tail - Tail of the command. This is a colon-separated list |
|
# consisting of the domain, coursenum (if for an External |
|
# Tool defined in a course), crsdef (true if defined in |
|
# a course), type (linkprot or lti) |
|
# context (launch, roster, logout, or grade), |
|
# escaped launch URL, numeric ID of external tool, |
|
# version number for encryption key (if tool's LTI secret was |
|
# encrypted before storing), a frozen hash of LTI launch |
|
# parameters, and a frozen hash of LTI information, |
|
# (e.g., method => 'HMAC-SHA1', |
|
# respfmt => 'to_authorization_header'). |
|
# $client - File descriptor open on the client. |
|
# Returns: |
|
# 1 - Continue processing. |
|
# 0 - Exit. |
|
# Side effects: |
|
# The reply will contain the LTI payload, as & separated key=value pairs, |
|
# where value is itself a frozen hash, if the required key and secret |
|
# for the specific tool ID are available. The payload data are retrieved from |
|
# a call to Lond::sign_lti_payload(), and the reply is encrypted before being |
|
# written to $client. |
|
# |
|
sub sign_lti_handler { |
|
my ($cmd, $tail, $client) = @_; |
|
|
|
my $userinput = "$cmd:$tail"; |
|
|
|
my ($cdom,$cnum,$crsdef,$type,$context,$escurl, |
|
$ltinum,$keynum,$paramsref,$inforef) = split(/:/,$tail); |
|
my $url = &unescape($escurl); |
|
my $params = &Apache::lonnet::thaw_unescape($paramsref); |
|
my $info = &Apache::lonnet::thaw_unescape($inforef); |
|
my $res = |
|
&LONCAPA::Lond::sign_lti_payload($cdom,$cnum,$crsdef,$type,$context,$url,$ltinum, |
|
$keynum,$perlvar{'lonVersion'},$params,$info); |
|
my $result; |
|
if (ref($res) eq 'HASH') { |
|
foreach my $key (keys(%{$res})) { |
|
$result .= &escape($key).'='.&Apache::lonnet::freeze_escape($res->{$key}).'&'; |
|
} |
|
$result =~ s/\&$//; |
|
} else { |
|
$result = $res; |
|
} |
|
if ($result =~ /^error:/) { |
|
&Failure($client, \$result, $userinput); |
|
} else { |
|
if ($cipher) { |
|
my $cmdlength=length($result); |
|
$result.=" "; |
|
my $encres=''; |
|
for (my $encidx=0;$encidx<=$cmdlength;$encidx+=8) { |
|
$encres.= unpack("H16", |
|
$cipher->encrypt(substr($result, |
|
$encidx, |
|
8))); |
|
} |
|
&Reply( $client,"enc:$cmdlength:$encres\n",$userinput); |
|
} else { |
|
&Failure( $client, "error:no_key\n",$userinput); |
|
} |
|
} |
|
return 1; |
|
} |
|
®ister_handler("signlti", \&sign_lti_handler, 1, 1, 0); |
|
|
|
# |
# Puts an id to a domains id database. |
# Puts an id to a domains id database. |
# |
# |
# Parameters: |
# Parameters: |
Line 6042 sub enrollment_enabled_handler {
|
Line 6244 sub enrollment_enabled_handler {
|
my ($cmd, $tail, $client) = @_; |
my ($cmd, $tail, $client) = @_; |
my $userinput = $cmd.":".$tail; # For logging purposes. |
my $userinput = $cmd.":".$tail; # For logging purposes. |
|
|
|
|
my ($cdom) = split(/:/, $tail, 2); # Domain we're asking about. |
my ($cdom) = split(/:/, $tail, 2); # Domain we're asking about. |
|
my $outcome; |
my $outcome = &localenroll::run($cdom); |
eval { |
|
local($SIG{__DIE__})='DEFAULT'; |
|
$outcome = &localenroll::run($cdom); |
|
}; |
&Reply($client, \$outcome, $userinput); |
&Reply($client, \$outcome, $userinput); |
|
|
return 1; |
return 1; |
} |
} |
®ister_handler("autorun", \&enrollment_enabled_handler, 0, 1, 0); |
®ister_handler("autorun", \&enrollment_enabled_handler, 0, 1, 0); |
Line 6080 sub validate_instcode_handler {
|
Line 6283 sub validate_instcode_handler {
|
my ($dom,$instcode,$owner) = split(/:/, $tail); |
my ($dom,$instcode,$owner) = split(/:/, $tail); |
$instcode = &unescape($instcode); |
$instcode = &unescape($instcode); |
$owner = &unescape($owner); |
$owner = &unescape($owner); |
my ($outcome,$description,$credits) = |
my ($outcome,$description,$credits); |
&localenroll::validate_instcode($dom,$instcode,$owner); |
eval { |
|
local($SIG{__DIE__})='DEFAULT'; |
|
($outcome,$description,$credits) = |
|
&localenroll::validate_instcode($dom,$instcode,$owner); |
|
}; |
my $result = &escape($outcome).'&'.&escape($description).'&'. |
my $result = &escape($outcome).'&'.&escape($description).'&'. |
&escape($credits); |
&escape($credits); |
&Reply($client, \$result, $userinput); |
&Reply($client, \$result, $userinput); |
Line 6115 sub validate_instcrosslist_handler {
|
Line 6322 sub validate_instcrosslist_handler {
|
$instcode = &unescape($instcode); |
$instcode = &unescape($instcode); |
$inst_xlist = &unescape($inst_xlist); |
$inst_xlist = &unescape($inst_xlist); |
$coowner = &unescape($coowner); |
$coowner = &unescape($coowner); |
my $outcome = &localenroll::validate_crosslist_access($dom,$instcode, |
my $outcome; |
$inst_xlist,$coowner); |
eval { |
&Reply($client, \$outcome, $userinput); |
local($SIG{__DIE__})='DEFAULT'; |
|
$outcome = &localenroll::validate_crosslist_access($dom,$instcode, |
|
$inst_xlist,$coowner); |
|
}; |
|
|
|
&Reply($client, \$outcome, $userinput); |
return 1; |
return 1; |
} |
} |
®ister_handler("autovalidateinstcrosslist", \&validate_instcrosslist_handler, 0, 1, 0); |
®ister_handler("autovalidateinstcrosslist", \&validate_instcrosslist_handler, 0, 1, 0); |
Line 6141 sub get_sections_handler {
|
Line 6352 sub get_sections_handler {
|
my $userinput = "$cmd:$tail"; |
my $userinput = "$cmd:$tail"; |
|
|
my ($coursecode, $cdom) = split(/:/, $tail); |
my ($coursecode, $cdom) = split(/:/, $tail); |
my @secs = &localenroll::get_sections($coursecode,$cdom); |
my $seclist; |
my $seclist = &escape(join(':',@secs)); |
eval { |
|
local($SIG{__DIE__})='DEFAULT'; |
|
my @secs = &localenroll::get_sections($coursecode,$cdom); |
|
$seclist = &escape(join(':',@secs)); |
|
}; |
&Reply($client, \$seclist, $userinput); |
&Reply($client, \$seclist, $userinput); |
|
|
|
|
return 1; |
return 1; |
} |
} |
®ister_handler("autogetsections", \&get_sections_handler, 0, 1, 0); |
®ister_handler("autogetsections", \&get_sections_handler, 0, 1, 0); |
Line 6166 sub get_sections_handler {
|
Line 6378 sub get_sections_handler {
|
# Returns: |
# Returns: |
# 1 - Processing should continue. |
# 1 - Processing should continue. |
# |
# |
|
|
sub validate_course_owner_handler { |
sub validate_course_owner_handler { |
my ($cmd, $tail, $client) = @_; |
my ($cmd, $tail, $client) = @_; |
my $userinput = "$cmd:$tail"; |
my $userinput = "$cmd:$tail"; |
Line 6173 sub validate_course_owner_handler {
|
Line 6386 sub validate_course_owner_handler {
|
|
|
$owner = &unescape($owner); |
$owner = &unescape($owner); |
$coowners = &unescape($coowners); |
$coowners = &unescape($coowners); |
my $outcome = &localenroll::new_course($inst_course_id,$owner,$cdom,$coowners); |
my $outcome; |
|
eval { |
|
local($SIG{__DIE__})='DEFAULT'; |
|
$outcome = &localenroll::new_course($inst_course_id,$owner,$cdom,$coowners); |
|
}; |
&Reply($client, \$outcome, $userinput); |
&Reply($client, \$outcome, $userinput); |
|
|
|
|
|
|
return 1; |
return 1; |
} |
} |
®ister_handler("autonewcourse", \&validate_course_owner_handler, 0, 1, 0); |
®ister_handler("autonewcourse", \&validate_course_owner_handler, 0, 1, 0); |
Line 6203 sub validate_course_section_handler {
|
Line 6417 sub validate_course_section_handler {
|
my ($cmd, $tail, $client) = @_; |
my ($cmd, $tail, $client) = @_; |
my $userinput = "$cmd:$tail"; |
my $userinput = "$cmd:$tail"; |
my ($inst_course_id, $cdom) = split(/:/, $tail); |
my ($inst_course_id, $cdom) = split(/:/, $tail); |
|
my $outcome; |
my $outcome=&localenroll::validate_courseID($inst_course_id,$cdom); |
eval { |
|
local($SIG{__DIE__})='DEFAULT'; |
|
$outcome=&localenroll::validate_courseID($inst_course_id,$cdom); |
|
}; |
&Reply($client, \$outcome, $userinput); |
&Reply($client, \$outcome, $userinput); |
|
|
|
|
return 1; |
return 1; |
} |
} |
®ister_handler("autovalidatecourse", \&validate_course_section_handler, 0, 1, 0); |
®ister_handler("autovalidatecourse", \&validate_course_section_handler, 0, 1, 0); |
Line 6241 sub validate_class_access_handler {
|
Line 6456 sub validate_class_access_handler {
|
$outcome=&localenroll::check_section($inst_class,$owners,$cdom); |
$outcome=&localenroll::check_section($inst_class,$owners,$cdom); |
}; |
}; |
&Reply($client,\$outcome, $userinput); |
&Reply($client,\$outcome, $userinput); |
|
|
return 1; |
return 1; |
} |
} |
®ister_handler("autovalidateclass_sec", \&validate_class_access_handler, 0, 1, 0); |
®ister_handler("autovalidateclass_sec", \&validate_class_access_handler, 0, 1, 0); |
Line 6374 sub create_auto_enroll_password_handler
|
Line 6588 sub create_auto_enroll_password_handler
|
my ($authparam, $cdom) = split(/:/, $userinput); |
my ($authparam, $cdom) = split(/:/, $userinput); |
|
|
my ($create_passwd,$authchk); |
my ($create_passwd,$authchk); |
($authparam, |
eval { |
$create_passwd, |
local($SIG{__DIE__})='DEFAULT'; |
$authchk) = &localenroll::create_password($authparam,$cdom); |
($authparam,$create_passwd,$create_passwd,$authchk) = |
|
&localenroll::create_password($authparam,$cdom); |
|
}; |
&Reply($client, &escape($authparam.':'.$create_passwd.':'.$authchk)."\n", |
&Reply($client, &escape($authparam.':'.$create_passwd.':'.$authchk)."\n", |
$userinput); |
$userinput); |
|
|
Line 6613 sub get_institutional_code_format_handle
|
Line 6828 sub get_institutional_code_format_handle
|
my ($key,$value) = split/=/,$_; |
my ($key,$value) = split/=/,$_; |
$instcodes{&unescape($key)} = &unescape($value); |
$instcodes{&unescape($key)} = &unescape($value); |
} |
} |
my $formatreply = &localenroll::instcode_format($cdom, |
my $formatreply; |
\%instcodes, |
eval { |
\%codes, |
local($SIG{__DIE__})='DEFAULT'; |
\@codetitles, |
$formatreply = &localenroll::instcode_format($cdom, |
\%cat_titles, |
\%instcodes, |
\%cat_order); |
\%codes, |
|
\@codetitles, |
|
\%cat_titles, |
|
\%cat_order); |
|
}; |
if ($formatreply eq 'ok') { |
if ($formatreply eq 'ok') { |
my $codes_str = &Apache::lonnet::hash2str(%codes); |
my $codes_str = &Apache::lonnet::hash2str(%codes); |
my $codetitles_str = &Apache::lonnet::array2str(@codetitles); |
my $codetitles_str = &Apache::lonnet::array2str(@codetitles); |
Line 6678 sub get_possible_instcodes_handler {
|
Line 6897 sub get_possible_instcodes_handler {
|
my $reply; |
my $reply; |
my $cdom = $tail; |
my $cdom = $tail; |
my (@codetitles,%cat_titles,%cat_order,@code_order); |
my (@codetitles,%cat_titles,%cat_order,@code_order); |
my $formatreply = &localenroll::possible_instcodes($cdom, |
my $formatreply; |
\@codetitles, |
eval { |
\%cat_titles, |
local($SIG{__DIE__})='DEFAULT'; |
\%cat_order, |
$formatreply = &localenroll::possible_instcodes($cdom, |
\@code_order); |
\@codetitles, |
|
\%cat_titles, |
|
\%cat_order, |
|
\@code_order); |
|
}; |
if ($formatreply eq 'ok') { |
if ($formatreply eq 'ok') { |
my $result = join('&',map {&escape($_);} (@codetitles)).':'; |
my $result = join('&',map {&escape($_);} (@codetitles)).':'; |
$result .= join('&',map {&escape($_);} (@code_order)).':'; |
$result .= join('&',map {&escape($_);} (@code_order)).':'; |
Line 6806 sub get_institutional_selfcreate_rules {
|
Line 7029 sub get_institutional_selfcreate_rules {
|
} |
} |
®ister_handler("instemailrules",\&get_institutional_selfcreate_rules,0,1,0); |
®ister_handler("instemailrules",\&get_institutional_selfcreate_rules,0,1,0); |
|
|
|
sub get_unamemap_rules { |
|
my ($cmd, $tail, $client) = @_; |
|
my $userinput = "$cmd:$tail"; |
|
my $dom = &unescape($tail); |
|
my (%rules_hash,@rules_order); |
|
my $outcome; |
|
eval { |
|
local($SIG{__DIE__})='DEFAULT'; |
|
$outcome = &localenroll::unamemap_rules($dom,\%rules_hash,\@rules_order); |
|
}; |
|
if (!$@) { |
|
if ($outcome eq 'ok') { |
|
my $result; |
|
foreach my $key (keys(%rules_hash)) { |
|
$result .= &escape($key).'='.&Apache::lonnet::freeze_escape($rules_hash{$key}).'&'; |
|
} |
|
$result =~ s/\&$//; |
|
$result .= ':'; |
|
if (@rules_order > 0) { |
|
foreach my $item (@rules_order) { |
|
$result .= &escape($item).'&'; |
|
} |
|
} |
|
$result =~ s/\&$//; |
|
&Reply($client,\$result,$userinput); |
|
} else { |
|
&Reply($client,"error\n", $userinput); |
|
} |
|
} else { |
|
&Failure($client,"unknown_cmd\n",$userinput); |
|
} |
|
} |
|
®ister_handler("unamemaprules",\&get_unamemap_rules,0,1,0); |
|
|
sub institutional_username_check { |
sub institutional_username_check { |
my ($cmd, $tail, $client) = @_; |
my ($cmd, $tail, $client) = @_; |
Line 7384 undef $perlvarref;
|
Line 7640 undef $perlvarref;
|
# ----------------------------- Make sure this process is running from user=www |
# ----------------------------- Make sure this process is running from user=www |
my $wwwid=getpwnam('www'); |
my $wwwid=getpwnam('www'); |
if ($wwwid!=$<) { |
if ($wwwid!=$<) { |
my $emailto="$perlvar{'lonAdmEMail'},$perlvar{'lonSysEMail'}"; |
my $emailto="$perlvar{'lonAdmEMail'} $perlvar{'lonSysEMail'}"; |
my $subj="LON: $currenthostid User ID mismatch"; |
my $subj="LON: $currenthostid User ID mismatch"; |
system("echo 'User ID mismatch. lond must be run as user www.' |". |
system("echo 'User ID mismatch. lond must be run as user www.' |". |
" mail -s '$subj' $emailto > /dev/null"); |
" mail -s '$subj' $emailto > /dev/null"); |
Line 8390 sub validate_user {
|
Line 8646 sub validate_user {
|
# |
# |
# Don't attempt authentication for username and password supplied |
# Don't attempt authentication for username and password supplied |
# for user without an account if uername contains @ to avoid |
# for user without an account if uername contains @ to avoid |
# call to &Authen::Krb5::parse_name() which will result in con_lost |
# call to &Authen::Krb5::parse_name() which will result in con_lost |
# |
# |
unless ($user =~ /\@/) { |
unless ($user =~ /\@/) { |
$howpwd = $domdefaults{'auth_def'}; |
$howpwd = $domdefaults{'auth_def'}; |
Line 8739 sub currentversion {
|
Line 8995 sub currentversion {
|
if (-e $ulsdir) { |
if (-e $ulsdir) { |
if(-d $ulsdir) { |
if(-d $ulsdir) { |
if (opendir(LSDIR,$ulsdir)) { |
if (opendir(LSDIR,$ulsdir)) { |
|
if (-e $fname) { |
|
$version=0; |
|
} |
my $ulsfn; |
my $ulsfn; |
while ($ulsfn=readdir(LSDIR)) { |
while ($ulsfn=readdir(LSDIR)) { |
# see if this is a regular file (ignore links produced earlier) |
# see if this is a regular file (ignore links produced earlier) |