Parcourir la source

Update 'i.win.js'

master
jarun2018 il y a 2 ans
Parent
révision
7016fa2594
1 fichiers modifiés avec 584 ajouts et 241 suppressions
  1. 584
    241
      i.win.js

+ 584
- 241
i.win.js Voir le fichier

@@ -1,4 +1,3 @@

var scripthostName = 'node'
var __Promise = {};
var promises = [];
@@ -41,7 +40,12 @@ try {
// --------------------------------------------
// Node Exists. Lets launch ourselves in Node itself
WScript = function(){}
WScript.Echo = function(m){
console.log('Invalid Wscript')
throw "Failed in Node Run."
}
var wait = function(ms, cb) {any
return new __Promise(function(resolve){ setTimeout(resolve, ms) } ).then(function(){ cb() });
}
@@ -49,17 +53,20 @@ try {
var existsSync = require('fs').existsSync;
var existsSyncFolder = existsSync
var path = require('path');
console.log('before cliverse')
var cli = require('./cliverse')
var nodeShellExec = cli.nodeShellExec;
console.log('before bbhverse')
var utils = require('bbhverse');
var any = utils.any;
var wait = setTimeout


var any = utils.any;
var wait = setTimeout

// --------------------------------------------

var selectedinstance = { root : path.resolve(".") }
// PB : TODO -- This should be parent dir if elxr is already installed.
var selectedinstance = { root : path.resolve(".") }
__main(selectedinstance)


@@ -94,8 +101,61 @@ catch(e) {
// WScript.Echo('-val=' + WScript.Arguments.Named(argEnumerator.item()) + '=val-') // Value
// }

// cscript elxr/i.win.js /all:true
var all = WScript.Arguments.Named('all');

trim = function(str) { return str.replace(/^\s+|\s+$/g, ''); };

var fs = new ActiveXObject('Scripting.FileSystemObject');
var WshShell = WScript.CreateObject("WScript.Shell")
var ENV = WshShell.Environment("Process")
var sfn = WScript.ScriptFullName
// WScript.Echo(sfn)
var cd = fs.GetAbsolutePathName(".")
var cfn = cd + '\\i.win.js'
// WScript.Echo(cfn)
var waslaunchedwithenv = trim(ENV.Item('LAUNCHEDWITHENV'));

// for(e=new Enumerator(ENV); !e.atEnd(); e.moveNext()) WScript.echo(e.item(e));
if(waslaunchedwithenv !== "YES"){

var a = fs.CreateTextFile("launchwithenv.bat", true)
a.WriteLine("@echo off")
a.WriteLine("echo %PATH%")
var gitpath = "C:\\Program Files\\Git\\cmd"
var nodepath = "C:\\Program Files\\nodejs\\"
var codepath = "C:\\Users\\Pradeep\\AppData\\Local\\Programs\\Microsoft VS Code\\bin"
a.WriteLine("set PATH=%PATH%;" + gitpath )
a.WriteLine("set PATH=%PATH%;" + nodepath )
a.WriteLine("set PATH=%PATH%;" + codepath )
// a.WriteLine("set LAUNCHEDWITHENV=YES" )
var __ALIAS__STAMP__ = '9e7bebe0-1f57-11ec-8f88-778ffeea9d1b'
var currentIsExlr = function() {
if(fs.FileExists('./' + __ALIAS__STAMP__)) return true
}
var runningInExlr = currentIsExlr()
if(cfn === sfn && runningInExlr) {
a.WriteLine("cd ..");
a.WriteLine("SET LAUNCHEDWITHENV=YES && cscript "+cfn+" /all:true") // PB : TODO -- Retain all script args...
}
else {
var guesselxr = fs.FileExists(cd + './elxr/' + __ALIAS__STAMP__)
if(guesselxr) {
a.WriteLine("SET LAUNCHEDWITHENV=YES && cscript "+cd + './elxr/' + 'i.win.js' +" /all:true")
}
else a.WriteLine("SET LAUNCHEDWITHENV=YES && cscript "+sfn+" /all:true")
}
// a.WriteLine("powershell.exe ^")
// a.WriteLine("[Environment]::GetEnvironmentVariable('Path')" )
a.Close()
WshShell.run("cmd /k launchwithenv.bat")
WScript.Quit()
// WshShell.run("powershell -noexit [Environment]::GetEnvironmentVariable(\"\"Path\"\"\) ")
// WshShell.run("powershell -noexit [Environment]::SetEnvironmentVariable(\"\"Path\"\", $env:Path + \"\";C:\\tttt\"\", \"\"Machine\"\"\) ")
}
console = {
log : function(m) { WScript.Echo(m)}
, error : function(m) {WScript.Echo(m) }
@@ -326,9 +386,18 @@ catch(e) {
// promises.splice(0,1)
})
}
function batchshellescape(str) {
return str.replace('=', '^=')
}
function nodeShellExec(command, cargs, options){
// for(var arg=0; arg < cargs.length; arg++) {
// // cargs[arg] = '"' + batchshellescape(cargs[arg]) +'"';
// cargs[arg] = '"' + cargs[arg] +'"';
// }

var elevatedshellexecute = function(cmd, argstr){
shell.ShellExecute(cmd, argstr , "", "", 1);
}
@@ -337,6 +406,7 @@ catch(e) {
var objShell = WScript.createobject("wscript.shell")
// console.log(argstr.join( ' '))
console.log(cmd + ' ' + argstr.join(' '))
var oExec = objShell.Exec(cmd + ' ' + argstr.join(' '))
var result = {}
var shellresult = { shell : objShell, result : result }
@@ -471,7 +541,7 @@ catch(e) {
// }
// else {
// console.log('There is no runfile.')
// console.log(shellresult.strOutput)
console.log(shellresult.strOutput)
wrapup(shellresult.result)
// }
@@ -789,7 +859,9 @@ catch(e) {
function __main( selectedinstance ){
var downloadsdir = selectedinstance.root + '/Downloads';

var callsheltask = function(args) { return function() { return nodeShellExec.apply(null, args) } }
var callsheltask = function(args) {
// console.log('callsheltask : ' + args)
return function() { return nodeShellExec.apply(null, args) } }
var gitUser = 'guest';
var gitEmail = 'guest@bbh.org.in';

@@ -845,9 +917,10 @@ function __main( selectedinstance ){
var downloadtasks = [];
var installtasks = [];
prerequisites.forEach(function(preq) {
WScript.Echo(all)
if(!all && preq.optional) return
var p = preq.exists().then(function(exists) {
if (exists) console.log( preq.shellcmd + ' exists');
if (exists && !preq.forceinstall) console.log( preq.shellcmd + ' exists');
else {
console.log(exists)
console.log(preq.shellcmd + ' is not installed');
@@ -903,6 +976,21 @@ function __main( selectedinstance ){
})
}

function install() {
var self = this;
var ifns = [self.installcmd]
if(!ifns.map) ifns.map = map;
console.log('Installing')
return any(ifns.map(callsheltask))['catch'](function(e){
if(e.code === 1602) {
console.warn("Installation was probably cancelled.")
}
else throw e
}).then(function(){
return self.postinstallsteps && self.postinstallsteps()
})
}

function unique(arr) {
var hash = {}, result = [];
for ( var i = 0, l = arr.length; i < l; ++i ) {
@@ -915,8 +1003,6 @@ function __main( selectedinstance ){
}

// var ENV = Object.assign({}, process.env); // Shallow clone it.
var WshShell = WScript.CreateObject("WScript.Shell")
var ENV = WshShell.Environment("Process")
// WScript.echo( ENV("Path") )
function sysAddPathVar(path){

@@ -936,231 +1022,466 @@ function __main( selectedinstance ){
// , nodeShellExec('set', [/*'/m',*/ 'PATH', '"%PATH%;' + newpath + '"' ])
] );
}

var getCmdString = function(args){ return args[0] + ' ' + args[1].join(' ') }

var getgitshelltask = function(args, onEachError) { return function(){
console.log('----------getgitshelltask--------------called')
return nodeShellExec( "cmd", ['/c', getCmdString(args)], args[2])
// .catch( onEachError || function(e){ console.error(e) })
}
}
var prerequisites = [
{
shellcmd: 'git',
url: 'https://github.com/git-for-windows/git/releases/download/v2.33.0.windows.2/Git-2.33.0.2-64-bit.exe'
, installer: 'Git-2.33.0.2-64-bit.exe'
, installcmd: ['cmd', ['/c', 'start',
'/WAIT', downloadsdir + '/' + 'Git-2.33.0.2-64-bit.exe'
, '/VERYSILENT'
// , '/MERGETASKS=!runcode' // This is required only for vscode...
]]
, preinstallsteps: function() {
var self = this;
console.log('Git preinstall steps')
// {
// shellcmd: 'git',
// url: 'https://github.com/git-for-windows/git/releases/download/v2.33.0.windows.2/Git-2.33.0.2-64-bit.exe'
// , installer: 'Git-2.33.0.2-64-bit.exe'
// , installcmd: ['cmd', ['/c', 'start',
// '/WAIT', downloadsdir + '/' + 'Git-2.33.0.2-64-bit.exe'
// , '/VERYSILENT'
// // , '/MERGETASKS=!runcode' // This is required only for vscode...
// ]]
// , preinstallsteps: function() {
// var self = this;
// console.log('Git preinstall steps')

var steps = [];
steps.push(
function(){
// console.log('cli prompt steps')
var choices = { 0 : 'guest', 1 : 'chessdemo' }
return cli.prompt(choices, 'git user name', gitUser).then(function(choice){ gitUser = choice } )
}
)
// var steps = [];
// // steps.push(
// // function(){
// // // console.log('cli prompt steps')
// // var choices = { 0 : 'guest', 1 : 'chessdemo' }
// // return cli.prompt(choices, 'git user name', gitUser).then(function(choice){ gitUser = choice } )
// // }
// // )

steps.push(
function(){
var choices = { 0 : 'guest@bbh.org.in', 1 : 'chessdemo@bbh.org.in' }
return cli.prompt(choices, 'git user email', gitEmail).then(function(choice){ gitEmail = choice })
}
)
steps.push(
function(){
if (!existsSync(downloadsdir + '/' + self.installer)) {
return nodeShellExec(selectedinstance.root + '/.elxr/run-' + runtimestamp + '/download.bat', [self.url, downloadsdir + '/' + self.installer])
}
else {
console.log(self.installer + ' Already exits Download skipped.')
return Promise.resolve(true)
}
}
)
return any(steps)
// return any([any(steps), any(prompts)])
}
, installsteps: function () {
var self = this;
console.log('Git Installsteps called')
var ifns = [self.installcmd]
if(!ifns.map) ifns.map = map;
return any(ifns.map(callsheltask))['catch'](function(e){
if(e.code === 1602) {
console.warn("Installation was probably cancelled.")
}
else throw e
})
}
, postinstallsteps: function(){
// // steps.push(
// // function(){
// // var choices = { 0 : 'guest@bbh.org.in', 1 : 'chessdemo@bbh.org.in' }
// // return cli.prompt(choices, 'git user email', gitEmail).then(function(choice){ gitEmail = choice })
// // }
// // )
// steps.push(
// function(){
// if (!existsSync(downloadsdir + '/' + self.installer)) {
// return nodeShellExec(selectedinstance.root + '/.elxr/run-' + runtimestamp + '/download.bat', [self.url, downloadsdir + '/' + self.installer])
// }
// else {
// console.log(self.installer + ' Already exits Download skipped.')
// return Promise.resolve(true)
// }
// }
// )
// return any(steps)
// // return any([any(steps), any(prompts)])
// }
// , installsteps: function () {
// var self = this;
// console.log('Git Installsteps called')
// var ifns = [self.installcmd]
// if(!ifns.map) ifns.map = map;
// return any(ifns.map(callsheltask))['catch'](function(e){
// if(e.code === 1602) {
// console.warn("Installation was probably cancelled.")
// }
// else throw e
// })
// }
// , postinstallsteps: function(){

// PB : TODO -- Detect failure or cancellation before attenpting postinstall steps...
var steps = [];
steps.push(
function(){
var choices = { 0 : 'guest', 1 : 'chessdemo' }
return cli.prompt(choices, 'git user name', gitUser).then(function(choice){ gitUser = choice } )
}
)
// // PB : TODO -- Detect failure or cancellation before attenpting postinstall steps...
// var steps = [];
// steps.push(
// function(){
// var choices = { 0 : 'guest', 1 : 'chessdemo' }
// return cli.prompt(choices, 'git user name', gitUser).then(function(choice){ gitUser = choice } )
// }
// )

steps.push(
function(){
var choices = { 0 : 'guest@bbh.org.in', 1 : 'chessdemo@bbh.org.in' }
return cli.prompt(choices, 'git user email', gitEmail).then(function(choice){ gitEmail = choice })
}
)
// steps.push(
// function(){
// var choices = { 0 : 'guest@bbh.org.in', 1 : 'chessdemo@bbh.org.in' }
// return cli.prompt(choices, 'git user email', gitEmail).then(function(choice){ gitEmail = choice })
// }
// )

return any(steps).then(function(){
var steps = [
['git', ['config', '--global', '--add', 'user.name', gitUser]]
, ['git', ['config', '--global', '--add', 'user.email', gitEmail]]
]
// return any(steps).then(function(){
// var steps = [
// ['git', ['config', '--global', '--add', 'user.name', gitUser]]
// , ['git', ['config', '--global', '--add', 'user.email', gitEmail]]
// ]
if(!steps.map) steps.map = map;
return any(steps.map(callsheltask)).then(function(){
// if(!steps.map) steps.map = map;
// return any(steps.map(callsheltask)).then(function(){

})
});
}
, install: function () {
var self = this;
console.log('Git Install called')
return any([ /*self.preinstallsteps,*/ function(){ return self.installsteps() }, function(){ return self.postinstallsteps() } ])
}
, verifyAndInstall : function(){
var self = this;
return self.exists().then( function(exits) {
if(exists) return self.getUser(null, function(){ return self.postinstallsteps() } )
else return self.install();
})
}
, exists : exists
, getUser : function(repo, onNoResult){
// })
// });
// }
// , install: function () {
// var self = this;
// console.log('Git Install called')

// var createTasq = function(args, shellT, onEachError) {
// var tasq = shellT ? shellT(args) : ( function(){
// console.log('sdsfdsdf ' + args)
// return any([nodeShellExec.apply(null, args)])
// // .catch( onEachError || function(e){ console.error(e) } )
// })
// tasq.toString = function(){ return JSON.stringify(args)}
// return tasq;
// }

// var execserial = function(tasklist, task, shellT, onEachError){
// var exec = function(taskArgs){
// console.log('execcing ' + task)
// var thistask = task.concat();
// thistask[1] = thistask[1].concat()
// thistask[1].push.apply(thistask[1], taskArgs)
// return createTasq(thistask, shellT)
// }
// tasklist.map = map
// console.log('execlist ' + tasklist.map(exec))
// return any(tasklist.map(exec))
// }
onNoResult = onNoResult || function(){return false}
var globalOrLocal = '--global';
if(!repo) globalOrLocal = '--global';
else globalOrLocal = '--local'
var fns = [['git', ['config', globalOrLocal, '--get-all', 'user.name']]]
if(!ifns.map) ifns.map = map;
return any(fns.map(callsheltask)).then(function(result){
// not yet configured.
if(!result.success) return onNoResult()
else {
var users = result.messages[0].trim().split('\n');
if(users.length === 0 ||
users.length === 1 && users[0] === 'guest') {
// function resetgitconfig(){
// // https://git-scm.com/book/en/v2/Git-Tools-Credential-Storage
// // Git Credential storage...
// // git config --global credential.helper 'store --file ~/.gitcredentials'
// // git credential-store --file ~/.gitcredentials store
// // // notepad C:/Program Files/Git/etc/gitconfig
// // git config --global --unset credential
// // git config --edit --system
// // git config --global credential.helper "store --file ~/gitcredentials"
// // git credential fill
// // git credential-store --file ~/git.store store
// // Find system git config
// // git config --global --edit
// // git config --list --show-origin
// // git config --list --show-origin --show-scope
// // https://stackoverflow.com/questions/35942754/how-can-i-save-username-and-password-in-git
// // Recipie
// // git config --global --unset credentials.helper
// // cd /path/to/my/repo
// // git config --unset credential.helper
// // git config credential.helper 'store --file ~/.git_repo_credentials'
// // git config credential.*.username my_user_name
// // git config credential.https://gitlab.com.username my_user_name
// // git credential fill
// // git config --global credential.modalprompt false // doesnst work.
// // core askpass = ;;; https://stackoverflow.com/questions/37182847/how-do-i-disable-git-credential-manager-for-windows
// var options = {
// inherit: true, shell: true //, env: process.env
// , cwd: selectedinstance.root
// // , runas: processedArgs.runas
// }
// var task = ['git', ['config'], options]
// var tasklist = [
// // ['--global', '--unset credentials.helper']
// // ['--unset', 'credentials.helper']
// // ,
// // ['credential.helper', `'store --file git_repo_credentials'`]
// ['--global', 'credential.helper', "'store --file ~/.git_repo_credentials'"]
// , ['--global', '--replace-all', 'user.name', 'pb']
// , ['--global', '--replace-all', 'user.email', 'pradeep@bbh.org.in']
// // , ['--list']
// // , ['credential', 'fill']
// ]
// var onEachError = function(e) { console.error( e.messages.join('\n') + e.result + '\n' + util.inspect(e) + '\n') }
// var shellT = function(args) {
// return getgitshelltask(args, onEachError)
// // .catch(e => console.error( e.messages.join('\n') + e.result + '\n' + util.inspect(e) + '\n' + tasq.toString()) )
// }
// execserial(tasklist, task, shellT, onEachError )
// }

// return any([ /*self.preinstallsteps,*/
// function(){ return self.installsteps() }
// , function() { resetgitconfig() }
// , function(){ return self.postinstallsteps() }
// ])
// }
// , verifyAndInstall : function(){
// var self = this;
// return self.exists().then( function(exits) {
// if(exists) return self.getUser(null, function(){ return self.postinstallsteps() } )
// else return self.install();
// })
// }
// , exists : exists
// , getUser : function(repo, onNoResult){
// onNoResult = onNoResult || function(){return false}
// var globalOrLocal = '--global';
// if(!repo) globalOrLocal = '--global';
// else globalOrLocal = '--local'
// var fns = [['git', ['config', globalOrLocal, '--get-all', 'user.name']]]
// if(!ifns.map) ifns.map = map;
// return any(fns.map(callsheltask)).then(function(result){
// // not yet configured.
// if(!result.success) return onNoResult()
// else {
// var users = result.messages[0].trim().split('\n');
// if(users.length === 0 ||
// users.length === 1 && users[0] === 'guest') {
return onNoResult()
}
else return users[0]; // PB : TODO == We should probably prompt with all the users available for selection !
}
})
['catch'](function(e){
console.log(e)
return onNoResult()
})
}
}
,
{
shellcmd: 'node',
url: 'https://nodejs.org/dist/v14.17.6/node-v14.17.6-x64.msi'
, installer: 'node-v14.17.3-x64.msi'
, installcmd: ['MSIEXEC.exe', ['/i'
, path.normalize(downloadsdir + '/' + 'node-v14.17.3-x64.msi')
, 'ACCEPT=YES', '/passive']]
, install : function() {
var self = this;
var ifns = [self.installcmd]
if(!ifns.map) ifns.map = map;
return any(ifns.map(callsheltask))['catch'](function(e){
if(e.code === 1602) {
console.warn("Installation was probably cancelled.")
}
else throw e
})
}
, exists : exists
, preinstallsteps: function() {
var self = this;
console.log('Node preinstall steps')
// return onNoResult()
// }
// else return users[0]; // PB : TODO == We should probably prompt with all the users available for selection !
// }
// })
// ['catch'](function(e){
// console.log(e)
// return onNoResult()
// })
// }
// }
// ,
// {
// shellcmd: 'node',
// url: 'https://nodejs.org/dist/v14.17.6/node-v14.17.6-x64.msi'
// , installer: 'node-v14.17.3-x64.msi'
// , installcmd: ['MSIEXEC.exe', ['/i'
// , path.normalize(downloadsdir + '/' + 'node-v14.17.3-x64.msi')
// , 'ACCEPT=YES', '/passive']]
// , install : install
// , exists : exists
// , preinstallsteps: function() {
// var self = this;
// console.log('Node preinstall steps')

var steps = [];
steps.push(
function(){
if (!existsSync(downloadsdir + '/' + self.installer)) {
return nodeShellExec(selectedinstance.root + '/.elxr/run-' + runtimestamp + '/download.bat', [self.url, downloadsdir + '/' + self.installer]
, { waitmsg : 'downloading node please wait' })
}
else {
console.log(self.installer + ' Already exits Download skipped.')
return Promise.resolve(true)
}
}
)
// var steps = [];
// steps.push(
// function(){
// if (!existsSync(downloadsdir + '/' + self.installer)) {
// return nodeShellExec(selectedinstance.root + '/.elxr/run-' + runtimestamp + '/download.bat', ['"' + self.url + '"', downloadsdir + '/' + self.installer]
// , { waitmsg : 'downloading '+ self.shellcmd +' please wait' })
// }
// else {
// console.log(self.installer + ' Already exits Download skipped.')
// return Promise.resolve(true)
// }
// }
// )
return any(steps)
// return any([any(steps), any(prompts)])
}
}
, {
shellcmd: 'python2'
, optional : true
, url: 'https://www.python.org/ftp/python/2.7.18/python-2.7.18.amd64.msi'
, installer: 'python-2.7.18.amd64.msi'
, installcmd: ['MSIEXEC.exe', ['/i'
, path.normalize(downloadsdir + '/' + 'python-2.7.18.amd64.msi')
, 'ACCEPT=YES', '/passive']]
, preinstallsteps : function() { return Promise.resolve(true) }
, install : function() {
var self = this;
var ifns = [self.installcmd]
if(!ifns.map) ifns.map = map;
console.log('Installing')
return any(ifns.map(callsheltask))['catch'](function(e){
if(e.code === 1602) {
console.warn("Installation was probably cancelled.")
}
else throw e
}).then(function(){
return self.postinstallsteps()
})
}
, postinstallsteps : function() { return sysAddPathVar('%USERPROFILE%\\AppData/Local\\Microsoft\\WindowsApps') }
, exists : exists
}
, {
shellcmd: 'code'
, optional : true
, url: 'https://vscode-update.azurewebsites.net/latest/win32-x64/stable'
, installer: 'vscode-win32-x64-latest-stable.exe'
, installcmd: ['cmd', ['/c', 'start',
'/WAIT', downloadsdir + '/' + 'Git-2.33.0.2-64-bit.exe'
, '/VERYSILENT'
// , '/MERGETASKS=!runcode' // This is required only for vscode...
]]
, preinstallsteps : function() { return Promise.resolve(true) }
, install : function() {
var self = this;
var ifns = [self.installcmd]
if(!ifns.map) ifns.map = map;
console.log('Installing')
return any(ifns.map(callsheltask))['catch'](function(e){
if(e.code === 1602) {
console.warn("Installation was probably cancelled.")
}
else throw e
}).then(function(){
return self.postinstallsteps()
})
}
, postinstallsteps : function() { return sysAddPathVar('%USERPROFILE%\\AppData/Local\\Microsoft\\WindowsApps') }
, exists : exists
}
, {
shellcmd: 'elxr'
// return any(steps)
// // return any([any(steps), any(prompts)])
// }
// }
// , {
// shellcmd: 'python'
// , optional : true
// , url: 'https://www.python.org/ftp/python/2.7.18/python-2.7.18.amd64.msi'
// , installer: 'python-2.7.18.amd64.msi'
// , installcmd: ['MSIEXEC.exe', ['/i'
// , path.normalize(downloadsdir + '/' + 'python-2.7.18.amd64.msi')
// , 'ACCEPT=YES', '/passive']]
// , preinstallsteps: function() {
// var self = this;
// console.log(self.shellcmd + ' preinstall steps')

// var steps = [];
// steps.push(
// function(){
// if (!existsSync(downloadsdir + '/' + self.installer)) {
// return nodeShellExec(selectedinstance.root + '/.elxr/run-' + runtimestamp + '/download.bat', [self.url, downloadsdir + '/' + self.installer]
// , { waitmsg : 'downloading '+ self.shellcmd +' please wait' })
// }
// else {
// console.log(self.installer + ' Already exits Download skipped.')
// return Promise.resolve(true)
// }
// }
// )
// return any(steps)
// // return any([any(steps), any(prompts)])
// }
// , install : install
// , postinstallsteps : function() { return sysAddPathVar('%USERPROFILE%\\AppData/Local\\Microsoft\\WindowsApps') }
// , exists : exists
// }
// , {
// shellcmd: 'code'
// , optional : true
// , url: 'https://code.visualstudio.com/sha/download?build=stable&os=win32-x64-user'
// , installer: 'VSCodeUserSetup-x64-1.65.2.exe'
// , installcmd: ['cmd /c', ['start /WAIT ' + downloadsdir + '/' + 'VSCodeUserSetup-x64-1.65.2.exe /VERYSILENT'
// // , '/MERGETASKS=!runcode' // This is required only for vscode...
// ]]
// , preinstallsteps: function() {
// var self = this;
// console.log(self.shellcmd + ' preinstall steps')

// var steps = [];
// steps.push(
// function(){
// if (!existsSync(downloadsdir + '/' + self.installer)) {
// console.log(self.url)
// return nodeShellExec(selectedinstance.root + '/.elxr/run-' + runtimestamp + '/download.bat', ['"' + self.url + '"', downloadsdir + '/' + self.installer]
// , { waitmsg : 'downloading '+ self.shellcmd +' please wait' })
// }
// else {
// console.log(self.installer + ' Already exits Download skipped.')
// return Promise.resolve(true)
// }
// }
// )
// return any(steps)
// // return any([any(steps), any(prompts)])
// }
// , install : install
// , postinstallsteps : function() { return sysAddPathVar('%USERPROFILE%\\AppData/Local\\Microsoft\\WindowsApps') }
// , exists : exists
// }
// , {
// shellcmd: 'sqlexpress',
// url: 'https://go.microsoft.com/fwlink/?linkid=866658'
// , installer: 'SQL2019-SSEI-Expr.exe'
// , installcmd: ['cmd', ['/c', 'start',
// '/WAIT', downloadsdir + '/' + 'SQL2019-SSEI-Expr.exe'
// , '/Quiet'
// //, 'SSMSInstallRoot=%systemdrive%\\Program Files (x86)\\Microsoft SQL Server\\140\\Tools\\Binn\\ManagementStudio'
// ]]
// , install : install
// , exists : exists
// , preinstallsteps: function() {
// var self = this;
// console.log('Node preinstall steps')

// var steps = [];
// steps.push(
// function(){
// if (!existsSync(downloadsdir + '/' + self.installer)) {
// return nodeShellExec(selectedinstance.root + '/.elxr/run-' + runtimestamp + '/download.bat', ['"' + self.url + '"', downloadsdir + '/' + self.installer]
// , { waitmsg : 'downloading '+ self.shellcmd +' please wait' })
// }
// else {
// console.log(self.installer + ' Already exits Download skipped.')
// return Promise.resolve(true)
// }
// }
// )
// return any(steps)
// // return any([any(steps), any(prompts)])
// }
// }
// , {
// shellcmd: 'Ssms2019.exe',
// url: 'https://aka.ms/ssmsfullsetup'
// , installer: 'SSMS-Setup-ENU.exe'
// , installcmd: ['cmd', ['/c', 'start',
// '/WAIT', downloadsdir + '/' + 'SSMS-Setup-ENU.exe'
// , '/Quiet'
// //, 'SSMSInstallRoot=%systemdrive%\\Program Files (x86)\\Microsoft SQL Server\\140\\Tools\\Binn\\ManagementStudio'
// ]]
// , install : install
// , exists : exists
// , preinstallsteps: function() {
// var self = this;
// console.log('smss preinstall steps')

// var steps = [];
// steps.push(
// function(){
// if (!existsSync(downloadsdir + '/' + self.installer)) {
// console.log(self.url)
// return nodeShellExec(selectedinstance.root + '/.elxr/run-' + runtimestamp + '/download.bat', ['"' + self.url + '"', downloadsdir + '/' + self.installer]
// , { waitmsg : 'downloading '+ self.shellcmd +' please wait' })
// }
// else {
// console.log(self.installer + ' Already exits Download skipped.')
// return Promise.resolve(true)
// }
// }
// )
// return any(steps)
// // return any([any(steps), any(prompts)])
// }
// }
// , {
// shellcmd: 'Ssms.exe',
// url: 'https://go.microsoft.com/fwlink/?linkid=2043154&clcid=0x409'
// , installer: 'SSMS-Setup-ENU.exe'
// , installcmd: ['cmd', ['/c', 'start',
// '/WAIT', downloadsdir + '/' + 'SSMS-Setup-ENU.exe'
// , '/Quiet'
// //, 'SSMSInstallRoot=%systemdrive%\\Program Files (x86)\\Microsoft SQL Server\\140\\Tools\\Binn\\ManagementStudio'
// ]]
// , install : install
// , exists : exists
// , preinstallsteps: function() {
// var self = this;
// console.log('smss preinstall steps')

// var steps = [];
// steps.push(
// function(){
// if (!existsSync(downloadsdir + '/' + self.installer)) {
// console.log(self.url)
// return nodeShellExec(selectedinstance.root + '/.elxr/run-' + runtimestamp + '/download.bat', ['"' + self.url + '"', downloadsdir + '/' + self.installer]
// , { waitmsg : 'downloading '+ self.shellcmd +' please wait' })
// }
// else {
// console.log(self.installer + ' Already exits Download skipped.')
// return Promise.resolve(true)
// }
// }
// )
// return any(steps)
// // return any([any(steps), any(prompts)])
// }
// }
// , {
// shellcmd: 'mysql',
// url: 'https://dev.mysql.com/get/Downloads/MySQLInstaller/mysql-installer-community-8.0.30.0.msi' //'https://dev.mysql.com/get/Downloads/MySQLInstaller/mysql-installer-community-8.0.29.0.msi'
// , installer: 'mysql-installer-community-8.0.30.0.msi'
// , installcmd: ['MSIEXEC.exe', ['/i'
// , path.normalize(downloadsdir + '/' + 'mysql-installer-community-8.0.30.0.msi')
// //, 'ACCEPT=YES', '/passive'
// ]]
// , install : install
// , exists : exists
// , preinstallsteps: function() {
// var self = this;
// console.log('mysql preinstall steps')

// var steps = [];
// steps.push(
// function(){
// if (!existsSync(downloadsdir + '/' + self.installer)) {
// console.log(self.url)
// return nodeShellExec(selectedinstance.root + '/.elxr/run-' + runtimestamp + '/download.bat', [self.url, downloadsdir + '/' + self.installer]
// , { waitmsg : 'downloading '+ self.shellcmd +' please wait' })
// }
// else {
// console.log(self.installer + ' Already exits Download skipped.')
// return Promise.resolve(true)
// }
// }
// )
// return any(steps)
// // return any([any(steps), any(prompts)])
// }
// }
// ,
{
shellcmd: 'elxr'
, forceinstall : true
, installcmd: [ isWin() ? 'npm.cmd' : 'npm' , ['link'], { cwd : selectedinstance.root + '\\elxr' /* cwd should be the cloned dir*/}]
, preinstallsteps: function() {
var self = this;
@@ -1168,9 +1489,31 @@ function __main( selectedinstance ){

var steps = [];
steps.push(
function(){
console.log('Elxr PreInstallsteps called')
var ifns = [ ['git', ['clone', 'http://git.bbh/chess\\elxr'] ] ]
)
return any([any(steps)])
}
, installsteps: function () {
var self = this;
console.log('Elxr Installsteps called')
var installIfNotExists = function(){
console.log('Elxr PreInstallsteps called')
var steps = [];
var chessRepo = 'https://git.bbh.org.in'
steps.push(
function(){
// console.log('cli prompt steps')
var choices = { 0 : 'http://git.bbh', 1 : 'https://git.bbh.org.in' }
return cli.prompt(choices, 'git repository : ', chessRepo).then(function(choice){
console.log( 'choice : ' + choice)
chessRepo = choice } )
}
)
return any(steps).then(function(){
var ifns = [
['git', ['clone', chessRepo + '/chess/elxr'] ]
]
console.log( 'chessRepo : ' + chessRepo)
if(existsSyncFolder( selectedinstance.root + '\\elxr')) {
if(existsSyncFolder( selectedinstance.root + '\\elxr\\.git')) {
// PB : TODO -- use a elxr guid signature to detect more reliably folders named the same that is not us.
@@ -1181,6 +1524,7 @@ function __main( selectedinstance ){
}
}
else console.log(selectedinstance.root + '\\elxr' + ' NOT FOUND ')
ifns.push(['npm', ['i'], { cwd : '.\\elxr' } ])
if(!ifns.map) ifns.map = map;
return any(ifns.map(callsheltask))['catch'](function(e){
if(e.code === 1602) {
@@ -1188,26 +1532,26 @@ function __main( selectedinstance ){
}
else throw e
})
}
)
return any([any(steps)])
}
, installsteps: function () {
var self = this;
console.log('Elxr Installsteps called')
var ifns = [self.installcmd]
})
}
var ifns = [ self.installcmd ]
if(!ifns.map) ifns.map = map;
return any(ifns.map(callsheltask))['catch'](function(e){
if(e.code === 1602) {
console.warn("Installation was probably cancelled.")
}
else throw e
return installIfNotExists().then(function(){
return any(ifns.map(callsheltask))['catch'](function(e){
if(e.code === 1602) {
console.warn("Installation was probably cancelled.")
}
else throw e
})
})
}
, install: function () {
var self = this;
console.log('Elxr Install called')
return any([ /*self.preinstallsteps,*/ function(){ return self.installsteps() } ])
return any([ self.preinstallsteps, function(){ return self.installsteps() }
, nodeShellExec('start', ['""', '"C:\\Program Files\\Git\\bin\\sh.exe"', '-c', '"node ' + (selectedinstance.root + '\\elxr\\index.js').replace(/\\/g, '/') + ' i elixir"'])
// , nodeShellExec('node', [selectedinstance.root + 'elxr\\index.js'])
])
}
// , exists : function(){
// console.log('Elxr PreInstallsteps called')
@@ -1243,4 +1587,3 @@ function __main( selectedinstance ){
promises.push(verifyAndInstallPrerequisites())

startPromises();
}

Chargement…
Annuler
Enregistrer