| @@ -11,8 +11,6 @@ var chalk = require('chalk') | |||
| const homedir = require('os').homedir(); | |||
| var ENV = Object.assign({}, process.env); // Shallow clone it. | |||
| function sysAddPathVar(path){ | |||
| // Object.assign({ | |||
| // inherit: true, shell: true, env: ENV, title: `${command} ${args}` | |||
| @@ -117,7 +115,23 @@ const existsFolderSync = existsSync; | |||
| const fs = require('fs') | |||
| const cliargs = utils.cliargs; | |||
| const processedArgs = cliargs(process.argv.slice(2)); | |||
| const processedArgs = cliargs(process.argv); | |||
| if(!processedArgs.wd){ | |||
| if(process.env.wd){ | |||
| } | |||
| else { | |||
| process.env.wd = process.cwd(); | |||
| if(process.cwd() === __dirname) { | |||
| // This script was launched in the same dir. | |||
| } | |||
| } | |||
| } | |||
| else process.env.wd = processedArgs.wd | |||
| var ENV = Object.assign({}, process.env); // Shallow clone it. | |||
| console.dir(processedArgs) | |||
| // PB : TODO -- defaults for valuless arguments if passed. | |||
| // Object.keys(processedArgs).forEach(a=>{ | |||
| @@ -590,7 +604,7 @@ var op = { | |||
| if (__isElevated) { | |||
| try { | |||
| op[processedArgs.label || processedArgs._[0] || 'undefined']() | |||
| op[processedArgs.label || processedArgs._[0] || 'undefined'](processedArgs) | |||
| } | |||
| catch (e) { | |||
| console.error('Error Invalid command : ' + e) | |||
| @@ -614,11 +628,16 @@ var op = { | |||
| console.log('result : ' + JSON.stringify(r)) | |||
| Object.keys(processedArgs).forEach((v) => { v != '_' ? namedArgs.push('--' + v + '=' + processedArgs[v]) : null; }) | |||
| // PB : TODO -- Convert all the cli args back to string. | |||
| var args = [`${selectedinstance.root}/.elxr/run-${runtimestamp}/windowselevate.hta`].concat(processedArgs._).concat(namedArgs.join(' ')); args.push('--runas=self'); | |||
| var args = [`${selectedinstance.root}/.elxr/run-${runtimestamp}/windowselevate.hta`].concat(processedArgs._) | |||
| namedArgs.length > 0 ? args = args.concat(namedArgs.join(' ')) : null; | |||
| args.push('--runas=self'); | |||
| // args.push('--nodepath=' + r.messages[r.messages.length - 1]) | |||
| // if (!processedArgs.node_env) args.push('--node_env=' + ENV.NODE_ENV) | |||
| // if (processedArgs.debug) args.push('--debug=true') // Enable to debug elevated.. | |||
| console.dir(processedArgs) | |||
| // console.dir(processedArgs._) | |||
| // console.dir(namedArgs.join(' ')) | |||
| console.dir(args) | |||
| // throw 'test' | |||
| return nodeShellExec('MSHTA', [`"${args.join('" "')}"`] | |||
| , { | |||
| @@ -2099,7 +2118,7 @@ var cmds = { | |||
| // sourecpathandfile should include name of file name | |||
| targetfilename = cmdopts.targetfilename || processedArgs._[1] | |||
| // console.log(processedArgs) | |||
| if(!targetfilename) Promise.reject('error no file provided for linking') | |||
| if(!targetfilename) return Promise.reject('error no file provided for linking') | |||
| targetdir = cmdopts.targetdir || process.env.wd | |||
| sourecpathandfile = cmdopts.sourecpathandfile || path.normalize(`../../node_modules/chess-server-lib/common/models/${targetfilename}`) | |||
| @@ -2742,10 +2761,35 @@ var __acquireData = function (selected, owner, clusternodename, datarepo, errHan | |||
| }) | |||
| } | |||
| var launchpath = path.normalize(process.cwd()) | |||
| var launchpath = path.resolve(path.normalize(process.env.wd)) | |||
| var thisscriptdir = path.normalize(__dirname); // PB : TODO -- Thisscriptdir could be dislocated when run as a standalone file... We need to detect this where and how we were run. | |||
| // The easisest would be to ask for a target directory and default to current dir.... | |||
| var instanceroot = path.normalize(thisscriptdir) === path.normalize(launchpath) ? path.normalize(thisscriptdir + '/..') : launchpath ; | |||
| // path.dirname(launchpath).split(path.sep).pop() | |||
| var parent = path.dirname(launchpath); | |||
| var pp = launchpath; | |||
| var instancediscoverytasks = []; | |||
| while(parent !== pp){ | |||
| instancediscoverytasks.push( | |||
| ((pa)=>{ | |||
| var p = pa; | |||
| return function(){ | |||
| return hasElxr(p).then((value)=>{ | |||
| if(value) return p | |||
| throw { value : false }; | |||
| }) | |||
| } | |||
| })(pp) | |||
| ) | |||
| pp = parent; | |||
| parent = path.dirname(parent); | |||
| } | |||
| var instanceroot = null | |||
| var detectInstanceRoot = any(instancediscoverytasks, true, true).then( ir => instanceroot = ir.pVal ).catch(()=>{ | |||
| instanceroot = path.normalize(thisscriptdir) === path.normalize(launchpath) ? path.normalize(thisscriptdir + '/..') : launchpath ; | |||
| }) | |||
| // PB : TODO -- Embed this in the build instead of inlining it. | |||
| // Also attepmt to load from ../chess-config/... | |||
| @@ -3280,101 +3324,6 @@ function ensureDirectoryExistence(filePath) { | |||
| var mainTasks = []; | |||
| function verifyAndInstallPrerequisites() { | |||
| fs.writeFileSync(ensureDirectoryExistence(path.normalize(`${selectedinstance.root}/${downloadsdir}/readme.txt`)), `${getVersion()} Your local downloads for this instance`) | |||
| // PB : TODO include and build from files... using rollup.. | |||
| var downloadbatch = | |||
| `::************************************************************************** | |||
| :Download_ <url> <File> | |||
| Powershell.exe ^ | |||
| $AllProtocols = [System.Net.SecurityProtocolType]'Ssl3,Tls,Tls11,Tls12'; ^ | |||
| [System.Net.ServicePointManager]::SecurityProtocol = $AllProtocols; ^ | |||
| (New-Object System.Net.WebClient).DownloadFile('%1','%2') | |||
| exit /b | |||
| ::**************************************************************************` | |||
| fs.writeFileSync(`${selectedinstance.root}/.elxr/run-${runtimestamp}/download.bat`, downloadbatch) | |||
| var windowselevate = | |||
| ` | |||
| <html><HTA:APPLICATION ID="windowselevate" icon="#"/> | |||
| <script language="vbscript"> | |||
| document.title = "elxr control panel" | |||
| self.ResizeTo 200,600 | |||
| Sub Window_Onload | |||
| self.MoveTo (screen.availWidth - (document.body.clientWidth + 40)),10 | |||
| End Sub | |||
| Set objShell = CreateObject("WScript.Shell") | |||
| Set objENV = objShell.Environment("Process") | |||
| dim NODE_ENV | |||
| NODE_ENV = objENV("NODE_ENV") | |||
| </script> | |||
| <script language="javascript"> | |||
| //WINDOWSTATE="minimize" SHOWINTASKBAR="no" SYSMENU="no" CAPTION="no" | |||
| // https://devblogs.microsoft.com/scripting/how-can-i-pass-command-line-variables-to-an-hta-when-it-starts/ | |||
| // alert(windowselevate.commandLine) | |||
| var args = windowselevate.commandLine.split('"').slice(3); | |||
| // alert(args) | |||
| var processedArgs = { _ : [] } | |||
| var namedArgs = []; | |||
| for(var item in args){ | |||
| if(args[item].charAt(0) === '-'){ | |||
| namedArgs.push(args[item]) | |||
| var split = args[item].split('='); | |||
| processedArgs[split[0].slice(2)] = split[1] || true; | |||
| } | |||
| else processedArgs._.push(args[item]); | |||
| } | |||
| // args = args.forEach(function(item){ }) | |||
| // alert('processedArgs._ : ' + processedArgs._); | |||
| // alert(processedArgs.runas); | |||
| // PB : TODO -- Convert all the cli args back to string. | |||
| var cargs = (processedArgs.debug ? '--inspect-brk=9228' : '') + ' elxr ' + processedArgs._.join(' ') + ' ' + namedArgs.join(' '); | |||
| // alert(cargs) | |||
| var shell = new ActiveXObject('shell.application'); | |||
| // alert('launching node privilged. ' + processedArgs['nodepath']) | |||
| // shell.ShellExecute('where', 'node', '', '', 10); | |||
| // shell.ShellExecute('cmd.exe', '/k notepad.exe', '', 'runas', 1); | |||
| // shell.ShellExecute('cmd.exe ', '/k node "' + cargs + '"', '', 'runas', 1); | |||
| shell.ShellExecute('node', cargs, '', 'runas', 1); | |||
| // shell.ShellExecute(processedArgs['nodepath'], cargs, '', 'runas', 1); | |||
| var fso = new ActiveXObject('Scripting.FileSystemObject'); | |||
| window.onload = function() { | |||
| document.body.style.backgroundColor = 'black'; | |||
| document.body.style.fontFamily = 'arial'; | |||
| var log = document.createElement('div'); | |||
| log.innerHTML='Please Wait'; | |||
| function l(msg){ log.innerHTML+= msg; }; | |||
| log.style.color = 'blue'; | |||
| log.style.width = '95%'; | |||
| log.id = 'log'; | |||
| document.body.appendChild(log); | |||
| l('<Br/>Current config : ') | |||
| l('<Br/>NODE_ENV = ' + NODE_ENV) | |||
| l('<Br/>cmd = ' + processedArgs._[0]) | |||
| processedArgs._[1] === 'use' ? l('<Br/>using = ' + processedArgs._[2]) : null; | |||
| l('<Br/><Br/>') | |||
| var timer = function(){ | |||
| l('.'); | |||
| if(fso.FileExists("run.done")) close(); | |||
| else window.setTimeout(timer, 1000); | |||
| }; | |||
| window.setTimeout(timer, 3000); | |||
| }; | |||
| </script> | |||
| </html> | |||
| ` | |||
| fs.writeFileSync(`${selectedinstance.root}/.elxr/run-${runtimestamp}/windowselevate.hta`, windowselevate) | |||
| var downloadtasks = []; | |||
| var installtasks = []; | |||
| prerequisites.forEach(preq => { | |||
| @@ -3958,6 +3907,111 @@ var maintask = () => { | |||
| } | |||
| var generateDependencies = function(){ | |||
| // PB : TODO -- Keep only the last n runs... | |||
| // Currently it retains 2*n when proc needs to be relaunched in elevated mode !!! | |||
| ensureDirectoryExistence(`${selectedinstance.root}/.elxr/run-${runtimestamp}/download.bat`) | |||
| fs.writeFileSync(ensureDirectoryExistence(path.normalize(`${selectedinstance.root}/${downloadsdir}/readme.txt`)), `${getVersion()} Your local downloads for this instance`) | |||
| // PB : TODO include and build from files... using rollup.. | |||
| var downloadbatch = | |||
| `::************************************************************************** | |||
| :Download_ <url> <File> | |||
| Powershell.exe ^ | |||
| $AllProtocols = [System.Net.SecurityProtocolType]'Ssl3,Tls,Tls11,Tls12'; ^ | |||
| [System.Net.ServicePointManager]::SecurityProtocol = $AllProtocols; ^ | |||
| (New-Object System.Net.WebClient).DownloadFile('%1','%2') | |||
| exit /b | |||
| ::**************************************************************************` | |||
| fs.writeFileSync(`${selectedinstance.root}/.elxr/run-${runtimestamp}/download.bat`, downloadbatch) | |||
| var windowselevate = | |||
| ` | |||
| <html><HTA:APPLICATION ID="windowselevate" icon="#"/> | |||
| <script language="vbscript"> | |||
| document.title = "elxr control panel" | |||
| self.ResizeTo 200,600 | |||
| Sub Window_Onload | |||
| self.MoveTo (screen.availWidth - (document.body.clientWidth + 40)),10 | |||
| End Sub | |||
| Set objShell = CreateObject("WScript.Shell") | |||
| Set objENV = objShell.Environment("Process") | |||
| dim NODE_ENV | |||
| NODE_ENV = objENV("NODE_ENV") | |||
| </script> | |||
| <script language="javascript"> | |||
| //WINDOWSTATE="minimize" SHOWINTASKBAR="no" SYSMENU="no" CAPTION="no" | |||
| // https://devblogs.microsoft.com/scripting/how-can-i-pass-command-line-variables-to-an-hta-when-it-starts/ | |||
| // alert(windowselevate.commandLine) | |||
| var args = windowselevate.commandLine.split('"').slice(3); | |||
| // alert(args) | |||
| var processedArgs = { _ : [] } | |||
| var namedArgs = []; | |||
| namedArgs.push('--wd=' + objENV('wd')) | |||
| // alert(namedArgs) | |||
| for(var item in args){ | |||
| if(args[item].charAt(0) === '-'){ | |||
| namedArgs.push(args[item]) | |||
| var split = args[item].split('='); | |||
| processedArgs[split[0].slice(2)] = split[1] || true; | |||
| } | |||
| else processedArgs._.push(args[item]); | |||
| } | |||
| // args = args.forEach(function(item){ }) | |||
| // alert('processedArgs._ : ' + processedArgs._); | |||
| // alert(processedArgs.runas); | |||
| // alert(objENV('wd')) | |||
| // PB : TODO -- Convert all the cli args back to string. | |||
| // __filename will sure we are launhed using the same entry point. | |||
| var cargs = (processedArgs.debug ? '--inspect-brk=9228' : '') + ' ${path.basename(__filename)} ' + processedArgs._.join(' ') + ' ' + namedArgs.join(' '); | |||
| // alert(cargs) | |||
| var shell = new ActiveXObject('shell.application'); | |||
| // alert('launching node privilged. ' + processedArgs['nodepath']) | |||
| // shell.ShellExecute('where', 'node', '', '', 10); | |||
| // shell.ShellExecute('cmd.exe', '/k notepad.exe', '', 'runas', 1); | |||
| // shell.ShellExecute('cmd.exe ', '/k node "' + cargs + '"', '', 'runas', 1); | |||
| shell.ShellExecute('node', cargs, '', 'runas', 1); | |||
| // shell.ShellExecute(processedArgs['nodepath'], cargs, '', 'runas', 1); | |||
| var fso = new ActiveXObject('Scripting.FileSystemObject'); | |||
| window.onload = function() { | |||
| document.body.style.backgroundColor = 'black'; | |||
| document.body.style.fontFamily = 'arial'; | |||
| var log = document.createElement('div'); | |||
| log.innerHTML='Please Wait'; | |||
| function l(msg){ log.innerHTML+= msg; }; | |||
| log.style.color = 'blue'; | |||
| log.style.width = '95%'; | |||
| log.id = 'log'; | |||
| document.body.appendChild(log); | |||
| l('<Br/>Current config : ') | |||
| l('<Br/>NODE_ENV = ' + NODE_ENV) | |||
| l('<Br/>cmd = ' + processedArgs._[0]) | |||
| processedArgs._[1] === 'use' ? l('<Br/>using = ' + processedArgs._[2]) : null; | |||
| l('<Br/><Br/>') | |||
| var timer = function(){ | |||
| l('.'); | |||
| if(fso.FileExists("run.done")) close(); | |||
| else window.setTimeout(timer, 1000); | |||
| }; | |||
| window.setTimeout(timer, 3000); | |||
| }; | |||
| </script> | |||
| </html> | |||
| ` | |||
| fs.writeFileSync(`${selectedinstance.root}/.elxr/run-${runtimestamp}/windowselevate.hta`, windowselevate) | |||
| } | |||
| var startElxr = function() { | |||
| const retaincount = 2 | |||
| var min = runtimestamp; | |||
| @@ -4029,6 +4083,7 @@ var startElxr = function() { | |||
| }) | |||
| .then(()=>{ | |||
| generateDependencies(); | |||
| if(noprerequisites[processedArgs._[0]] | |||
| || skipprereqs[processedArgs._[0]] | |||
| ) { | |||
| @@ -4060,24 +4115,22 @@ var startElxr = function() { | |||
| } | |||
| else return true | |||
| }) | |||
| if (!skipprerequisites && !__isElevated || processedArgs.forceprereqs && !__isElevated ) mainTasks.push(verifyAndInstallPrerequisites); | |||
| mainTasks.push(maintask) | |||
| return any(mainTasks); | |||
| } | |||
| else return true; | |||
| }) | |||
| .then(()=>{ | |||
| // PB : TODO -- Keep only the last n runs... | |||
| // Currently it retains 2*n when proc needs to be relaunched in elevated mode !!! | |||
| ensureDirectoryExistence(`${selectedinstance.root}/.elxr/run-${runtimestamp}/download.bat`) | |||
| if (!skipprerequisites && !__isElevated || processedArgs.forceprereqs && !__isElevated ) mainTasks.push(verifyAndInstallPrerequisites); | |||
| mainTasks.push(maintask) | |||
| return any(mainTasks); | |||
| }) | |||
| } | |||
| acquireElevationState().then(() => { | |||
| return startElxr() | |||
| detectInstanceRoot.then(()=>{ | |||
| return acquireElevationState().then(() => { | |||
| return startElxr() | |||
| }) | |||
| }) | |||
| // detect if alread installed -> Take no action. | |||