--- loncom/loncnew 2018/12/10 17:34:22 1.107 +++ loncom/loncnew 2024/06/14 18:49:41 1.110 @@ -2,7 +2,7 @@ # The LearningOnline Network with CAPA # lonc maintains the connections to remote computers # -# $Id: loncnew,v 1.107 2018/12/10 17:34:22 raeburn Exp $ +# $Id: loncnew,v 1.110 2024/06/14 18:49:41 raeburn Exp $ # # Copyright Michigan State University Board of Trustees # @@ -97,6 +97,8 @@ my $executable = $0; # Get the full my $RemoteHost; # Hostname of host child is talking to. my $RemoteHostId; # lonid of host child is talking to. my $RemoteDefHostId; # default lonhostID of host child is talking to. +my $RemoteLoncapaRev; # LON-CAPA version of host child is talking to, + # if 2.12.0 or newer, format: X.Y.Z my @all_host_ids; my $UnixSocketDir= $perlvar{'lonSockDir'}; my $IdleConnections = Stack->new(); # Set of idle connections @@ -613,7 +615,7 @@ sub CompleteTransaction { StartClientReply($Transaction, $data); } else { # Delete deferred transaction file. Log("SUCCESS", "A delayed transaction was completed"); - LogPerm("S:".$Socket->PeerLoncapaHim().":".$Transaction->getRequest()); + LogPerm("S:".$Transaction->getClient().":".$Transaction->getRequest()); unlink($Transaction->getFile()); } } @@ -671,7 +673,6 @@ Parameters: =item client The LondTransaction we are failing. - =cut @@ -1250,7 +1251,8 @@ sub MakeLondConnection { my $Connection = LondConnection->new(&GetServerHost(), &GetServerPort(), &GetHostId(), - &GetDefHostId()); + &GetDefHostId(), + &GetLoncapaRev()); if($Connection eq undef) { Log("CRITICAL","Failed to make a connection with lond."); @@ -1575,6 +1577,18 @@ sub GetDefHostId { =pod +=head2 GetLoncapaRev + +Returns the LON-CAPA version for the node whose lond we talk with. + +=cut + +sub GetLoncapaRev { + return $RemoteLoncapaRev; # Setup by the fork. +} + +=pod + =head2 GetServerPort Returns the lond port number. @@ -1836,7 +1850,7 @@ sub ChildProcess { # Create a new child for host passed in: sub CreateChild { - my ($host, $hostid, $defhostid) = @_; + my ($host, $hostid, $defhostid, $loncaparev) = @_; my $sigset = POSIX::SigSet->new(SIGINT); sigprocmask(SIG_BLOCK, $sigset); @@ -1852,6 +1866,7 @@ sub CreateChild { } else { # child. $RemoteHostId = $hostid; $RemoteDefHostId = $defhostid; + $RemoteLoncapaRev = $loncaparev; ShowStatus("Connected to ".$RemoteHost); $SIG{INT} = 'DEFAULT'; sigprocmask(SIG_UNBLOCK, $sigset); @@ -1917,9 +1932,13 @@ sub get_remote_hostname { &Debug(5,"Creating child for $data (parent_client_connection)"); (my $hostname,my $lonid,@all_host_ids) = split(':',$data); + my $remotelcrev; + if ((scalar(@all_host_ids) > 1) && ($all_host_ids[0] =~ /^\d+\.\d+\.[\w.]+$/)) { + $remotelcrev = shift(@all_host_ids); + } $ChildHost{$hostname}++; if ($ChildHost{$hostname} == 1) { - &CreateChild($hostname,$lonid,$all_host_ids[-1]); + &CreateChild($hostname,$lonid,$all_host_ids[-1],$remotelcrev); } else { &Log('WARNING',"Request for a second child on $hostname"); }