2019-03-05 23:05:01 -05:00
|
|
|
let target = require('./assetguard')[process.argv[2]]
|
|
|
|
if(target == null){
|
|
|
|
process.send({context: 'error', data: null, error: 'Invalid class name'})
|
|
|
|
console.error('Invalid class name passed to argv[2], cannot continue.')
|
|
|
|
process.exit(1)
|
|
|
|
}
|
|
|
|
let tracker = new target(...(process.argv.splice(3)))
|
2018-01-18 23:45:50 -05:00
|
|
|
|
2019-03-05 23:05:01 -05:00
|
|
|
//const tracker = new AssetGuard(process.argv[2], process.argv[3])
|
2018-01-18 23:45:50 -05:00
|
|
|
console.log('AssetExec Started')
|
|
|
|
|
|
|
|
// Temporary for debug purposes.
|
|
|
|
process.on('unhandledRejection', r => console.log(r))
|
|
|
|
|
2020-04-12 03:44:20 +03:00
|
|
|
let percent = 0
|
2019-06-02 18:11:39 -04:00
|
|
|
function assignListeners(){
|
|
|
|
tracker.on('validate', (data) => {
|
|
|
|
process.send({context: 'validate', data})
|
|
|
|
})
|
|
|
|
tracker.on('progress', (data, acc, total) => {
|
2020-04-12 03:44:20 +03:00
|
|
|
const currPercent = parseInt((acc/total) * 100)
|
|
|
|
if (currPercent !== percent) {
|
|
|
|
percent = currPercent
|
|
|
|
process.send({context: 'progress', data, value: acc, total, percent})
|
|
|
|
}
|
2019-06-02 18:11:39 -04:00
|
|
|
})
|
|
|
|
tracker.on('complete', (data, ...args) => {
|
|
|
|
process.send({context: 'complete', data, args})
|
|
|
|
})
|
|
|
|
tracker.on('error', (data, error) => {
|
|
|
|
process.send({context: 'error', data, error})
|
|
|
|
})
|
|
|
|
}
|
|
|
|
|
|
|
|
assignListeners()
|
2018-05-06 21:45:20 -04:00
|
|
|
|
2018-01-18 23:45:50 -05:00
|
|
|
process.on('message', (msg) => {
|
2018-07-22 11:40:15 -04:00
|
|
|
if(msg.task === 'execute'){
|
|
|
|
const func = msg.function
|
2019-03-05 23:05:01 -05:00
|
|
|
let nS = tracker[func] // Nonstatic context
|
|
|
|
let iS = target[func] // Static context
|
2018-04-02 18:40:32 -04:00
|
|
|
if(typeof nS === 'function' || typeof iS === 'function'){
|
|
|
|
const f = typeof nS === 'function' ? nS : iS
|
|
|
|
const res = f.apply(f === nS ? tracker : null, msg.argsArr)
|
2018-01-18 23:45:50 -05:00
|
|
|
if(res instanceof Promise){
|
|
|
|
res.then((v) => {
|
2018-07-22 11:40:15 -04:00
|
|
|
process.send({result: v, context: func})
|
2018-05-08 06:34:16 -04:00
|
|
|
}).catch((err) => {
|
2019-02-18 06:31:01 -05:00
|
|
|
process.send({result: err.message || err, context: func})
|
2018-01-18 23:45:50 -05:00
|
|
|
})
|
|
|
|
} else {
|
2018-07-22 11:40:15 -04:00
|
|
|
process.send({result: res, context: func})
|
2018-01-18 23:45:50 -05:00
|
|
|
}
|
2019-06-02 18:11:39 -04:00
|
|
|
} else {
|
|
|
|
process.send({context: 'error', data: null, error: `Function ${func} not found on ${process.argv[2]}`})
|
|
|
|
}
|
|
|
|
} else if(msg.task === 'changeContext'){
|
|
|
|
target = require('./assetguard')[msg.class]
|
|
|
|
if(target == null){
|
|
|
|
process.send({context: 'error', data: null, error: `Invalid class ${msg.class}`})
|
|
|
|
} else {
|
|
|
|
tracker = new target(...(msg.args))
|
|
|
|
assignListeners()
|
2018-01-18 23:45:50 -05:00
|
|
|
}
|
|
|
|
}
|
|
|
|
})
|
|
|
|
|
|
|
|
process.on('disconnect', () => {
|
|
|
|
console.log('AssetExec Disconnected')
|
|
|
|
process.exit(0)
|
|
|
|
})
|