version 1.126, 2021/02/01 01:24:09
|
version 1.130, 2024/07/10 02:47:53
|
Line 42 use IO::File;
|
Line 42 use IO::File;
|
use IO::Socket; |
use IO::Socket; |
use HTML::Entities; |
use HTML::Entities; |
use Getopt::Long; |
use Getopt::Long; |
use GDBM_File; |
use GDBM_File qw(GDBM_READER); |
use Storable qw(thaw); |
use Storable qw(thaw); |
use File::ReadBackwards; |
use File::ReadBackwards; |
use File::Copy; |
use File::Copy; |
Line 337 sub start_logging {
|
Line 337 sub start_logging {
|
<li><a href="#lonc">lonc</a></li> |
<li><a href="#lonc">lonc</a></li> |
<li><a href="#lonnet">lonnet</a></li> |
<li><a href="#lonnet">lonnet</a></li> |
<li><a href="#connections">Connections</a></li> |
<li><a href="#connections">Connections</a></li> |
|
<li><a href="#bashconf">bash readline config</a></li> |
<li><a href="#delayed">Delayed Messages</a></li> |
<li><a href="#delayed">Delayed Messages</a></li> |
<li><a href="#errcount">Error Count</a></li> |
<li><a href="#errcount">Error Count</a></li> |
</ol> |
</ol> |
Line 1491 sub read_serverhomeIDs {
|
Line 1492 sub read_serverhomeIDs {
|
return %server; |
return %server; |
} |
} |
|
|
|
sub check_bash_settings { |
|
my $distro = &LONCAPA::distro(); |
|
my ($check_bracketed_paste,$bracketed_warning); |
|
if ($distro =~ /^debian(\d+)$/) { |
|
if ($1 >= 12) { |
|
$check_bracketed_paste = 1; |
|
} |
|
} elsif ($distro =~ /^ubuntu(\d+)$/) { |
|
if ($1 >= 22) { |
|
$check_bracketed_paste = 1; |
|
} |
|
} elsif ($distro =~ /^(?:redhat|oracle|alma|rocky|centos-stream)(\d+)$/) { |
|
if ($1 >= 9) { |
|
$check_bracketed_paste = 1; |
|
} |
|
} elsif ($distro =~ /^fedora(\d+)/) { |
|
if ($1 >= 34) { |
|
$check_bracketed_paste = 1; |
|
} |
|
} |
|
if ($check_bracketed_paste) { |
|
if (open(PIPE,"bind -V 2>&1 | grep enable-bracketed-paste |")) { |
|
my $info = <PIPE>; |
|
chomp($info); |
|
my ($bracketed) = ($info =~ /^\Qenable-bracketed-paste\E\s+is\s+set\s+to\s+\W(on|off)\W$/); |
|
close(PIPE); |
|
if ($bracketed eq 'on') { |
|
$bracketed_warning = 1; |
|
} |
|
} else { |
|
print "Unable to check if bracketed paste is set to off for www user's shell\n"; |
|
} |
|
} |
|
return ($bracketed_warning,$check_bracketed_paste); |
|
} |
|
|
|
sub set_bracketed_paste_off { |
|
my $bash_www_cnf = '/home/www/.inputrc'; |
|
my $result; |
|
if (!-e $bash_www_cnf) { |
|
system("touch $bash_www_cnf"); |
|
if (open(my $cfh,'>',$bash_www_cnf)) { |
|
print $cfh "set enable-bracketed-paste off\n"; |
|
close($cfh); |
|
$result = "Updated $bash_www_cnf"; |
|
} else { |
|
$result = "Could not open $bash_www_cnf to add 'set enable-bracketed-paste to off'"; |
|
} |
|
my $wwwuid = getpwnam('www'); |
|
my $wwwgid = getgrnam('www'); |
|
if ($wwwuid!=$<) { |
|
chown($wwwuid,$wwwgid,$bash_www_cnf); |
|
} |
|
} else { |
|
my ($bracketed_paste_on,$bracketed_paste_off,@preserve); |
|
if (open(my $cfh,'<',$bash_www_cnf)) { |
|
while (my $line=<$cfh>) { |
|
chomp($line); |
|
if ($line =~ /^\s*set\s+enable\-bracketed\-paste\s+(off|on)\s*$/) { |
|
if ($1 eq 'off') { |
|
$bracketed_paste_off = 1; |
|
} else { |
|
$bracketed_paste_on = 1; |
|
} |
|
} else { |
|
push(@preserve,$line); |
|
} |
|
} |
|
close($cfh); |
|
if ($bracketed_paste_on || !$bracketed_paste_off) { |
|
if (open(my $cfh,'>',$bash_www_cnf)) { |
|
print $cfh "set enable-bracketed-paste off\n"; |
|
if (@preserve) { |
|
foreach my $entry (@preserve) { |
|
print $cfh "$entry\n"; |
|
} |
|
} |
|
close($cfh); |
|
$result = "Updated $bash_www_cnf"; |
|
} else { |
|
$result = "Could not open $bash_www_cnf to add 'set enable-bracketed-paste to off'"; |
|
} |
|
} else { |
|
$result = "No action needed; $bash_www_cnf already includes 'set enable-bracketed-paste to off'"; |
|
} |
|
} else { |
|
$result = "Could not open $bash_www_cnf to check if a value is included for 'enable-bracketed-paste'."; |
|
} |
|
} |
|
return $result; |
|
} |
|
|
sub send_mail { |
sub send_mail { |
my ($sysmail,$reportstatus) = @_; |
my ($sysmail,$reportstatus) = @_; |
my $defdom = $perlvar{'lonDefDomain'}; |
my $defdom = $perlvar{'lonDefDomain'}; |
Line 1595 sub main () {
|
Line 1688 sub main () {
|
my $wwwid=getpwnam('www'); |
my $wwwid=getpwnam('www'); |
if ($wwwid!=$<) { |
if ($wwwid!=$<) { |
print("User ID mismatch. This program must be run as user 'www'.\n"); |
print("User ID mismatch. This program must be run as user 'www'.\n"); |
my $emailto="$perlvar{'lonAdmEMail'},$perlvar{'lonSysEMail'}"; |
my $emailto="$perlvar{'lonAdmEMail'} $perlvar{'lonSysEMail'}"; |
my $subj="LON: $perlvar{'lonHostID'} User ID mismatch"; |
my $subj="LON: $perlvar{'lonHostID'} User ID mismatch"; |
system("echo 'User ID mismatch. loncron must be run as user www.' |". |
system("echo 'User ID mismatch. loncron must be run as user www.' |". |
" mail -s '$subj' $emailto > /dev/null"); |
" mail -s '$subj' $emailto > /dev/null"); |
Line 1687 sub main () {
|
Line 1780 sub main () {
|
&test_connections($fh); |
&test_connections($fh); |
} |
} |
if (!$justcheckdaemons && !$justcheckconnections && !$justreload && !$justiptables) { |
if (!$justcheckdaemons && !$justcheckconnections && !$justreload && !$justiptables) { |
|
my ($bracketed_warning,$check_bracketed_paste) = &check_bash_settings(); |
|
if ($check_bracketed_paste) { |
|
&log($fh,'<hr /><a name="bashconf" /><h2>bash readline config</h2><h3>Brackedted Paste</h3>'. |
|
'<p>Distros using bash readline library 8.1 or later need bracketed paste disabled for www, so R commands sent to lon daemon will be processed.</p>'); |
|
if ($bracketed_warning) { |
|
my $bash_update = &set_bracketed_paste_off(); |
|
if ($bash_update) { |
|
&log($fh,'<p>'.$bash_update.'</p>'."\n"); |
|
} |
|
} else { |
|
&log($fh,'<p>No action needed; /home/www/.inputrc already set.</p>'."\n"); |
|
} |
|
} else { |
|
&log($fh,'<hr /><a name="bashconf" /><h2>bash readline config</h2><h3>Bracketed Paste</h3>'. |
|
'<p>No action needed for distros using pre-8.1 bash readline library</p>'."\n"); |
|
} |
my $domconf = &get_domain_config(); |
my $domconf = &get_domain_config(); |
my ($threshold,$sysmail,$reportstatus,$weightsref,$exclusionsref) = |
my ($threshold,$sysmail,$reportstatus,$weightsref,$exclusionsref) = |
&get_permcount_settings($domconf); |
&get_permcount_settings($domconf); |