assetexec.js 1.4 KB

1234567891011121314151617181920212223242526272829303132333435363738394041424344454647
  1. const {AssetGuard} = require('./assetguard.js')
  2. const tracker = new AssetGuard(process.argv[2], process.argv[3])
  3. console.log('AssetExec Started')
  4. // Temporary for debug purposes.
  5. process.on('unhandledRejection', r => console.log(r))
  6. tracker.on('assetVal', (data) => {
  7. process.send({task: 0, total: data.total, value: data.acc, content: 'validateAssets'})
  8. })
  9. tracker.on('totaldlprogress', (data) => {
  10. process.send({task: 0, total: data.total, value: data.acc, percent: parseInt((data.acc/data.total)*100), content: 'dl'})
  11. })
  12. tracker.on('dlcomplete', () => {
  13. process.send({task: 1, content: 'dl'})
  14. })
  15. tracker.on('jExtracted', (jPath) => {
  16. process.send({task: 2, content: 'dl', jPath})
  17. })
  18. process.on('message', (msg) => {
  19. if(msg.task === 0){
  20. const func = msg.content
  21. let nS = tracker[func]
  22. let iS = AssetGuard[func]
  23. if(typeof nS === 'function' || typeof iS === 'function'){
  24. const f = typeof nS === 'function' ? nS : iS
  25. const res = f.apply(f === nS ? tracker : null, msg.argsArr)
  26. if(res instanceof Promise){
  27. res.then((v) => {
  28. process.send({result: v, content: msg.content})
  29. })
  30. } else {
  31. process.send({result: res, content: msg.content})
  32. }
  33. }
  34. }
  35. })
  36. process.on('disconnect', () => {
  37. console.log('AssetExec Disconnected')
  38. process.exit(0)
  39. })