mirror of
				https://github.com/Ylianst/MeshCentral.git
				synced 2025-03-09 15:40:18 +00:00 
			
		
		
		
	Fixed open descriptor issue with agentupdate on linux/freebsd
This commit is contained in:
		
							parent
							
								
									e2201b1d9f
								
							
						
					
					
						commit
						fe9baf0e8f
					
				
					 2 changed files with 194 additions and 6 deletions
				
			
		|  | @ -3760,7 +3760,87 @@ function sendAgentMessage(msg, icon) { | |||
|     sendAgentMessage.messages[sendAgentMessage.nextid++] = { msg: msg, icon: icon }; | ||||
|     require('MeshAgent').SendCommand({ action: 'sessions', type: 'msg', value: sendAgentMessage.messages }); | ||||
| } | ||||
| function getOpenDescriptors() | ||||
| { | ||||
|     switch (process.platform) | ||||
|     { | ||||
|         case "freebsd": | ||||
|             var child = require('child_process').execFile('/bin/sh', ['sh']); | ||||
|             child.stdout.str = ''; child.stdout.on('data', function (c) { this.str += c.toString(); }); | ||||
|             child.stderr.on('data', function (c) { }); | ||||
| 
 | ||||
|             child.stdin.write("procstat -f " + process.pid + " | tr '\\n' '`' | awk -F'`' '"); | ||||
|             child.stdin.write('{'); | ||||
|             child.stdin.write('   DEL="";'); | ||||
|             child.stdin.write('   printf "[";'); | ||||
|             child.stdin.write('   for(i=1;i<NF;++i)'); | ||||
|             child.stdin.write('   {'); | ||||
|             child.stdin.write('      A=split($i,B," ");'); | ||||
|             child.stdin.write('      if(B[3] ~ /^[0-9]/)'); | ||||
|             child.stdin.write('      {'); | ||||
|             child.stdin.write('         printf "%s%s", DEL, B[3];'); | ||||
|             child.stdin.write('         DEL=",";'); | ||||
|             child.stdin.write('      }'); | ||||
|             child.stdin.write('   }'); | ||||
|             child.stdin.write('   printf "]";'); | ||||
|             child.stdin.write("}'"); | ||||
| 
 | ||||
|             child.stdin.write('\nexit\n'); | ||||
|             child.waitExit(); | ||||
| 
 | ||||
|             try | ||||
|             { | ||||
|                 return (JSON.parse(child.stdout.str.trim())); | ||||
|             } | ||||
|             catch (e) | ||||
|             { | ||||
|                 return ([]); | ||||
|             } | ||||
|             break; | ||||
|         case "linux": | ||||
|             var child = require('child_process').execFile('/bin/sh', ['sh']); | ||||
|             child.stdout.str = ''; child.stdout.on('data', function (c) { this.str += c.toString(); }); | ||||
|             child.stderr.on('data', function (c) { }); | ||||
| 
 | ||||
|             child.stdin.write("ls /proc/" + process.pid + "/fd | tr '\\n' '`' | awk -F'`' '"); | ||||
|             child.stdin.write('{'); | ||||
|             child.stdin.write('   printf "[";'); | ||||
|             child.stdin.write('   DEL="";'); | ||||
|             child.stdin.write('   for(i=1;i<NF;++i)'); | ||||
|             child.stdin.write('   {'); | ||||
|             child.stdin.write('      printf "%s%s",DEL,$i;'); | ||||
|             child.stdin.write('      DEL=",";'); | ||||
|             child.stdin.write('   }'); | ||||
|             child.stdin.write('   printf "]";'); | ||||
|             child.stdin.write("}'"); | ||||
|             child.stdin.write('\nexit\n'); | ||||
|             child.waitExit(); | ||||
| 
 | ||||
|             try | ||||
|             { | ||||
|                 return (JSON.parse(child.stdout.str.trim())); | ||||
|             } | ||||
|             catch (e) | ||||
|             { | ||||
|                 return ([]); | ||||
|             } | ||||
|             break; | ||||
|         default: | ||||
|             return ([]); | ||||
|     } | ||||
| } | ||||
| function closeDescriptors(libc, descriptors) | ||||
| { | ||||
|     var fd = null; | ||||
|     while (descriptors.length > 0) | ||||
|     { | ||||
|         fd = descriptors.pop(); | ||||
|         if (fd > 2) | ||||
|         { | ||||
|             libc.close(fd); | ||||
|         } | ||||
|     } | ||||
| } | ||||
| function linux_execv(name, agentfilename, sessionid) { | ||||
|     var libs = require('monitor-info').getLibInfo('libc'); | ||||
|     var libc = null; | ||||
|  | @ -3778,6 +3858,7 @@ function linux_execv(name, agentfilename, sessionid) { | |||
|     if (libc != null) { | ||||
|         try { | ||||
|             libc.CreateMethod('execv'); | ||||
|             libc.CreateMethod('close'); | ||||
|         } | ||||
|         catch (e) { | ||||
|             libc = null; | ||||
|  | @ -3803,7 +3884,7 @@ function linux_execv(name, agentfilename, sessionid) { | |||
| 
 | ||||
|     var i; | ||||
|     var args; | ||||
|     var argarr = []; | ||||
|     var argarr = [process.execPath]; | ||||
|     var path = require('_GenericMarshal').CreateVariable(process.execPath); | ||||
| 
 | ||||
|     if (require('MeshAgent').getStartupOptions != null) { | ||||
|  | @ -3819,6 +3900,9 @@ function linux_execv(name, agentfilename, sessionid) { | |||
|         arg.pointerBuffer().copy(args.toBuffer(), i * require('_GenericMarshal').PointerSize); | ||||
|     } | ||||
| 
 | ||||
|     var descriptors = getOpenDescriptors(); | ||||
|     closeDescriptors(libc, descriptors); | ||||
| 
 | ||||
|     libc.execv(path, args); | ||||
|     if (sessionid != null) { sendConsoleText('Self Update failed because execv() failed', sessionid) } | ||||
|     sendAgentMessage('Self Update failed because execv() failed', 3); | ||||
|  | @ -3849,6 +3933,7 @@ function bsd_execv(name, agentfilename, sessionid) { | |||
|     try { | ||||
|         libc = require('_GenericMarshal').CreateNativeProxy(child.stdout.str.trim()); | ||||
|         libc.CreateMethod('execv'); | ||||
|         libc.CreateMethod('close'); | ||||
|     } | ||||
|     catch (e) { | ||||
|         if (sessionid != null) { sendConsoleText('Self Update failed: ' + e.toString(), sessionid) } | ||||
|  | @ -3858,7 +3943,7 @@ function bsd_execv(name, agentfilename, sessionid) { | |||
| 
 | ||||
|     var i; | ||||
|     var path = require('_GenericMarshal').CreateVariable(process.execPath); | ||||
|     var argarr = []; | ||||
|     var argarr = [process.execPath]; | ||||
|     var args; | ||||
|     var options = require('MeshAgent').getStartupOptions(); | ||||
|     for (i in options) { | ||||
|  | @ -3871,6 +3956,10 @@ function bsd_execv(name, agentfilename, sessionid) { | |||
|     } | ||||
| 
 | ||||
|     if (sessionid != null) { sendConsoleText('Restarting service via execv()', sessionid) } | ||||
| 
 | ||||
|     var descriptors = getOpenDescriptors(); | ||||
|     closeDescriptors(libc, descriptors); | ||||
| 
 | ||||
|     libc.execv(path, args); | ||||
|     if (sessionid != null) { sendConsoleText('Self Update failed because execv() failed', sessionid) } | ||||
|     sendAgentMessage('Self Update failed because execv() failed', 3); | ||||
|  |  | |||
		Loading…
	
	Add table
		Add a link
		
	
		Reference in a new issue