Built motion from commit eddce310.|2.6.12
[motion2.git] / server / components / import / cm / csv.js
index 708479b..8099802 100644 (file)
@@ -15,4 +15,4 @@
 // * treaties. The SOFTWARE PRODUCT is licensed, not sold.                        *
 // *                                                                       *
 // *************************************************************************
-var _0x0011=['toString','from','cm_contacts','where','deletedAt\x20IS\x20NULL','phone\x20IS\x20NOT\x20NULL','phone\x20NOT\x20IN\x20(?)','ListId\x20=\x20?','id\x20IN\x20?','calleridnum','cm_hopper_final','\x20=\x20?','fromQuery','str','cm_hopper_black','VoiceQueue','outbound','dialCheckDuplicateType','Lists','get','always','query','VoiceQueueId','onlyIfOpen','sequelize','all','findAll','CmList','CampaignId','Campaign','BlackLists','cmContact,\x20%s,\x20%s','finally','contact:csv_','resume','resolve','emit','unlinkSync','Unable\x20to\x20delete\x20temp\x20file:','info','createReadStream','duplicate','pause','CSV\x20parse\x20error','Error\x20executing\x20contact\x20csv\x20import:','lodash','squel','papaparse','ioredis','../../../mysqldb','redis','defaults','localhost','socket.io-emitter','../../../api/cmContact/cmContact.socket','register','argv','undefined','null','Missing\x20filepath\x20parameter!','zipObject','split','Missing\x20ListId\x20parameter!','Missing\x20socket_timestamp\x20parameter!','error','contact','index','test','isNil','length','map','errors','message','hasOwnProperty','data','firstName','phone','phone\x20not\x20specified!','birthDate','YYYY-MM-DD','isValid','birthDate\x20format\x20is\x20invalid,\x20YYYY-MM-DD\x20format\x20is\x20supported!','email','email\x20format\x20is\x20not\x20valid!','find','Duplicate\x20Contact','CmContact','create','keys','then','push','pick','catch','Error\x20while\x20creating\x20contact:\x20','stringify','cmContact','checkHopper','inspect','insert','into','cm_hopper','ContactId','ListId','createdAt','updatedAt','select','field','NOW()','scheduledAt'];(function(_0x4c8d22,_0x178328){var _0x58bfa8=function(_0x989fbe){while(--_0x989fbe){_0x4c8d22['push'](_0x4c8d22['shift']());}};_0x58bfa8(++_0x178328);}(_0x0011,0x107));var _0x1001=function(_0x160c73,_0x2ee678){_0x160c73=_0x160c73-0x0;var _0xd9302=_0x0011[_0x160c73];return _0xd9302;};'use strict';var BPromise=require('bluebird');var util=require('util');var _=require(_0x1001('0x0'));var fs=require('fs');var squel=require(_0x1001('0x1'));var Papa=require(_0x1001('0x2'));var Redis=require(_0x1001('0x3'));var db=require(_0x1001('0x4'))['db'];var config=require('../../../config/environment');var logger=require('../../../config/logger')('api');config[_0x1001('0x5')]=_[_0x1001('0x6')](config[_0x1001('0x5')],{'host':_0x1001('0x7'),'port':0x18eb});var socket=require(_0x1001('0x8'))(new Redis(config[_0x1001('0x5')]));require(_0x1001('0x9'))[_0x1001('0xa')](socket);try{if(!process['argv'][0x2]||process[_0x1001('0xb')][0x2]===_0x1001('0xc')||process[_0x1001('0xb')][0x2]===_0x1001('0xd')){throw new Error(_0x1001('0xe'));}var FILEPATH=process['argv'][0x2];if(!process[_0x1001('0xb')][0x3]||process['argv'][0x3]===_0x1001('0xc')||process['argv'][0x3]==='null'||!process[_0x1001('0xb')][0x4]||process[_0x1001('0xb')][0x4]===_0x1001('0xc')||process['argv'][0x4]===_0x1001('0xd')){throw new Error('Missing\x20binding\x20parameters!');}var FIELDS=_[_0x1001('0xf')](process[_0x1001('0xb')][0x3]['split'](','),process[_0x1001('0xb')][0x4][_0x1001('0x10')](','));if(!process[_0x1001('0xb')][0x5]||process[_0x1001('0xb')][0x5]==='undefined'||process[_0x1001('0xb')][0x5]===_0x1001('0xd')){throw new Error(_0x1001('0x11'));}var LISTID=process[_0x1001('0xb')][0x5];var COMPANYID=process[_0x1001('0xb')][0x6]&&process[_0x1001('0xb')][0x6]!==_0x1001('0xc')&&process[_0x1001('0xb')][0x6]!==_0x1001('0xd')?process[_0x1001('0xb')][0x6]:null;var DUPLICATES=process[_0x1001('0xb')][0x7]&&process[_0x1001('0xb')][0x7]!==_0x1001('0xc')&&process[_0x1001('0xb')][0x7]!==_0x1001('0xd')?process['argv'][0x7]:null;if(!process[_0x1001('0xb')][0x8]||process['argv'][0x8]==='undefined'||process[_0x1001('0xb')][0x8]===_0x1001('0xd')){throw new Error(_0x1001('0x12'));}var SOCKET_TIMESTAMP=process[_0x1001('0xb')][0x8];}catch(_0x3c6b3f){logger[_0x1001('0x13')](_0x3c6b3f);endCsv();}var total=0x0;var pTotal=0x0;var success=0x0;var errors=0x0;var duplicates=0x0;var rows=[];var hopperContacts='';var promises=[];var index=0x0;var alreadyInvalid=![];function handleCheckRowError(_0x3b99ad,_0x33dfc7,_0xe0620c,_0x1c03f7){var _0x7b42e2={'message':_0x33dfc7};_0x7b42e2[_0x3b99ad]=!![];if(_0xe0620c){_0x7b42e2[_0x1001('0x14')]=_0xe0620c;}if(_0x1c03f7){_0x7b42e2[_0x1001('0x15')]=_0x1c03f7;}return _0x7b42e2;}function isEmail(_0x3611a4){return/^([^\x00-\x20\x22\x28\x29\x2c\x2e\x3a-\x3c\x3e\x40\x5b-\x5d\x7f-\xff]+|\x22([^\x0d\x22\x5c\x80-\xff]|\x5c[\x00-\x7f])*\x22)(\x2e([^\x00-\x20\x22\x28\x29\x2c\x2e\x3a-\x3c\x3e\x40\x5b-\x5d\x7f-\xff]+|\x22([^\x0d\x22\x5c\x80-\xff]|\x5c[\x00-\x7f])*\x22))*\x40([^\x00-\x20\x22\x28\x29\x2c\x2e\x3a-\x3c\x3e\x40\x5b-\x5d\x7f-\xff]+|\x5b([^\x0d\x5b-\x5d\x80-\xff]|\x5c[\x00-\x7f])*\x5d)(\x2e([^\x00-\x20\x22\x28\x29\x2c\x2e\x3a-\x3c\x3e\x40\x5b-\x5d\x7f-\xff]+|\x5b([^\x0d\x5b-\x5d\x80-\xff]|\x5c[\x00-\x7f])*\x5d))*$/[_0x1001('0x16')](_0x3611a4);}function checkRow(_0x35bf1e,_0x1cc82e,_0xc70e75){return new BPromise(function(_0x1a9e84,_0x59b4a6){if(_[_0x1001('0x17')](_0x35bf1e)){return _0x59b4a6(handleCheckRowError(_0x1001('0x13'),'The\x20row\x20is\x20empty\x20or\x20the\x20number\x20of\x20parameters\x20does\x20not\x20match\x20the\x20columns!',null,_0xc70e75));}if(_0x35bf1e['errors']&&_0x35bf1e['errors'][_0x1001('0x18')]){var _0x12a10d=_[_0x1001('0x19')](_0x35bf1e[_0x1001('0x1a')],_0x1001('0x1b'))['join'](';');return _0x59b4a6(handleCheckRowError('error',_0x12a10d,null,_0xc70e75));}var _0x30793d={};for(var _0x484546 in FIELDS){if(FIELDS[_0x1001('0x1c')](_0x484546)&&FIELDS[_0x484546]){_0x30793d[_0x484546]=_0x35bf1e[_0x1001('0x1d')][0x0][FIELDS[_0x484546]]||_0x35bf1e[_0x1001('0x1d')][0x0]['\ufeff'+FIELDS[_0x484546]];}}if(!_0x30793d[_0x1001('0x1e')]){return _0x59b4a6(handleCheckRowError('error','firstName\x20not\x20specified!',null,_0xc70e75));}if(!_0x30793d[_0x1001('0x1f')]){return _0x59b4a6(handleCheckRowError('error',_0x1001('0x20'),null,_0xc70e75));}if(_0x30793d[_0x1001('0x21')]){var _0x3e8efc=moment(_0x30793d[_0x1001('0x21')],_0x1001('0x22'));if(!_0x3e8efc[_0x1001('0x23')]()){return _0x59b4a6(handleCheckRowError('error',_0x1001('0x24'),null,_0xc70e75));}}if(_0x30793d[_0x1001('0x25')]){if(!isEmail(_0x30793d[_0x1001('0x25')])){return _0x59b4a6(handleCheckRowError(_0x1001('0x13'),_0x1001('0x26'),null,_0xc70e75));}}_0x30793d['ListId']=LISTID;_0x30793d['CompanyId']=COMPANYID||undefined;if(DUPLICATES&&DUPLICATES[_0x1001('0x18')]&&_0x1cc82e){var _0x13a10d={};for(var _0x35bdf6=0x0,_0xd96054=DUPLICATES[_0x1001('0x18')];_0x35bdf6<_0xd96054;_0x35bdf6+=0x1){_0x13a10d[DUPLICATES[_0x35bdf6]]=_0x30793d[DUPLICATES[_0x35bdf6]];}var _0x31e805=_[_0x1001('0x27')](_0x1cc82e,_0x13a10d);if(_0x31e805){return _0x59b4a6(handleCheckRowError('duplicate',_0x1001('0x28'),_0x31e805,_0xc70e75));}}return db[_0x1001('0x29')][_0x1001('0x2a')](_0x30793d,{'raw':!![],'hooks':![],'fields':_[_0x1001('0x2b')](_0x30793d)})[_0x1001('0x2c')](function(_0x44309e){if(DUPLICATES&&DUPLICATES[_0x1001('0x18')]&&_0x1cc82e){_0x1cc82e[_0x1001('0x2d')](_[_0x1001('0x2e')](_0x30793d,DUPLICATES));}hopperContacts+=(hopperContacts?',':'')+_0x44309e['id'];return _0x1a9e84();})[_0x1001('0x2f')](function(_0x514f30){return _0x59b4a6(handleCheckRowError(_0x1001('0x13'),_0x1001('0x30')+(_0x514f30[_0x1001('0x1b')]||JSON[_0x1001('0x31')](_0x514f30)),null,_0xc70e75));});});}function checkHopper(){function _0x457336(){return function(_0x53d236){logger[_0x1001('0x13')](_0x1001('0x32'),_0x1001('0x33'),util[_0x1001('0x34')](_0x53d236,{'showHidden':![],'depth':null}));};}var _0x1c781e=function(_0x46b658,_0x597bb6){var _0x3d75e0=squel[_0x1001('0x35')]()[_0x1001('0x36')](_0x1001('0x37'))['fromQuery']([_0x1001('0x1f'),'scheduledAt',_0x1001('0x38'),_0x1001('0x39'),_0x597bb6,_0x1001('0x3a'),_0x1001('0x3b')],squel[_0x1001('0x3c')]()[_0x1001('0x3d')](_0x1001('0x1f'),'phone')[_0x1001('0x3d')](_0x1001('0x3e'),_0x1001('0x3f'))[_0x1001('0x3d')]('id',_0x1001('0x38'))['field'](LISTID[_0x1001('0x40')](),_0x1001('0x39'))['field'](_0x46b658['id'][_0x1001('0x40')](),_0x597bb6)[_0x1001('0x3d')](_0x1001('0x3e'),_0x1001('0x3a'))[_0x1001('0x3d')](_0x1001('0x3e'),_0x1001('0x3b'))[_0x1001('0x41')](_0x1001('0x42'))[_0x1001('0x43')](_0x1001('0x44'))['where']('ListId\x20=\x20?',LISTID[_0x1001('0x40')]())['where'](_0x1001('0x45'))[_0x1001('0x43')](_0x1001('0x46'),squel['select']()[_0x1001('0x3d')](_0x1001('0x1f'))[_0x1001('0x41')](_0x1001('0x37'))[_0x1001('0x43')](_0x597bb6+'\x20=\x20?',_0x46b658['id'][_0x1001('0x40')]())))['toString']();return _0x3d75e0;};var _0x1abad1=function(_0x4f7485,_0x2e4261){var _0x540c83=squel[_0x1001('0x35')]()[_0x1001('0x36')](_0x1001('0x37'))['fromQuery']([_0x1001('0x1f'),_0x1001('0x3f'),_0x1001('0x38'),_0x1001('0x39'),_0x2e4261,_0x1001('0x3a'),_0x1001('0x3b')],squel['select']()[_0x1001('0x3d')](_0x1001('0x1f'),_0x1001('0x1f'))['field'](_0x1001('0x3e'),_0x1001('0x3f'))[_0x1001('0x3d')]('id',_0x1001('0x38'))[_0x1001('0x3d')](LISTID[_0x1001('0x40')](),_0x1001('0x39'))[_0x1001('0x3d')](_0x4f7485['id'][_0x1001('0x40')](),_0x2e4261)['field'](_0x1001('0x3e'),_0x1001('0x3a'))[_0x1001('0x3d')]('NOW()',_0x1001('0x3b'))[_0x1001('0x41')](_0x1001('0x42'))[_0x1001('0x43')]('deletedAt\x20IS\x20NULL')[_0x1001('0x43')](_0x1001('0x47'),LISTID[_0x1001('0x40')]())[_0x1001('0x43')](_0x1001('0x48'),squel['str'](hopperContacts))[_0x1001('0x43')](_0x1001('0x45'))[_0x1001('0x43')](_0x1001('0x46'),squel[_0x1001('0x3c')]()[_0x1001('0x3d')](_0x1001('0x49'))[_0x1001('0x41')](_0x1001('0x4a'))['where'](_0x2e4261+_0x1001('0x4b'),_0x4f7485['id']['toString']()))[_0x1001('0x43')](_0x1001('0x46'),squel['select']()[_0x1001('0x3d')]('phone')[_0x1001('0x41')](_0x1001('0x37'))[_0x1001('0x43')](_0x2e4261+'\x20=\x20?',_0x4f7485['id']['toString']())))[_0x1001('0x40')]();return _0x540c83;};function _0x116e10(_0x9c7581,_0x65109a){var _0x43a6bc=squel['insert']()[_0x1001('0x36')](_0x1001('0x37'))[_0x1001('0x4c')](['phone',_0x1001('0x3f'),_0x1001('0x38'),_0x1001('0x39'),_0x65109a,_0x1001('0x3a'),_0x1001('0x3b')],squel[_0x1001('0x3c')]()[_0x1001('0x3d')](_0x1001('0x1f'),_0x1001('0x1f'))[_0x1001('0x3d')](_0x1001('0x3e'),_0x1001('0x3f'))[_0x1001('0x3d')]('id',_0x1001('0x38'))[_0x1001('0x3d')](LISTID[_0x1001('0x40')](),_0x1001('0x39'))['field'](_0x9c7581['id'][_0x1001('0x40')](),_0x65109a)[_0x1001('0x3d')](_0x1001('0x3e'),_0x1001('0x3a'))[_0x1001('0x3d')](_0x1001('0x3e'),_0x1001('0x3b'))[_0x1001('0x41')](_0x1001('0x42'))[_0x1001('0x43')](_0x1001('0x44'))[_0x1001('0x43')](_0x1001('0x47'),LISTID[_0x1001('0x40')]())['where']('id\x20IN\x20?',squel[_0x1001('0x4d')](hopperContacts))[_0x1001('0x43')](_0x1001('0x45')))[_0x1001('0x40')]();return _0x43a6bc;}function _0x542419(_0x39f407,_0x4a983f){var _0xb29846=squel['insert']()[_0x1001('0x36')](_0x1001('0x4e'))[_0x1001('0x4c')](['phone',_0x1001('0x38'),_0x1001('0x39'),_0x4a983f,_0x1001('0x3a'),_0x1001('0x3b')],squel[_0x1001('0x3c')]()[_0x1001('0x3d')](_0x1001('0x1f'),'phone')[_0x1001('0x3d')]('id',_0x1001('0x38'))[_0x1001('0x3d')](LISTID[_0x1001('0x40')](),_0x1001('0x39'))['field'](_0x39f407['id'][_0x1001('0x40')](),_0x4a983f)[_0x1001('0x3d')](_0x1001('0x3e'),'createdAt')['field'](_0x1001('0x3e'),_0x1001('0x3b'))[_0x1001('0x41')](_0x1001('0x42'))[_0x1001('0x43')]('deletedAt\x20IS\x20NULL')[_0x1001('0x43')](_0x1001('0x47'),LISTID['toString']())['where'](_0x1001('0x48'),squel[_0x1001('0x4d')](hopperContacts))[_0x1001('0x43')](_0x1001('0x45')))[_0x1001('0x40')]();return _0xb29846;}return db[_0x1001('0x4f')]['findAll']({'where':{'type':_0x1001('0x50')},'attributes':['id',_0x1001('0x51')],'include':[{'model':db['CmList'],'as':_0x1001('0x52'),'where':{'id':LISTID}}]})[_0x1001('0x2c')](function(_0x5972ee){var _0x51f2d8=[];if(_0x5972ee){var _0xa89c48;for(var _0x177b33=0x0,_0x1acdad;_0x177b33<_0x5972ee[_0x1001('0x18')];_0x177b33+=0x1){_0x1acdad=_0x5972ee[_0x177b33][_0x1001('0x53')]({'plain':!![]});switch(_0x1acdad[_0x1001('0x51')]){case _0x1001('0x54'):_0x51f2d8[_0x1001('0x2d')](db['sequelize'][_0x1001('0x55')](_0x1abad1(_0x1acdad,_0x1001('0x56')))[_0x1001('0x2c')](function(){})[_0x1001('0x2f')](_0x457336()));break;case _0x1001('0x57'):_0x51f2d8[_0x1001('0x2d')](db[_0x1001('0x58')][_0x1001('0x55')](_0x1c781e(_0x1acdad,_0x1001('0x56')))[_0x1001('0x2c')](function(){})[_0x1001('0x2f')](_0x457336()));break;default:_0x51f2d8['push'](db[_0x1001('0x58')][_0x1001('0x55')](_0x116e10(_0x1acdad,_0x1001('0x56')))['then'](function(){})[_0x1001('0x2f')](_0x457336()));}}}return _0x51f2d8;})[_0x1001('0x59')]()[_0x1001('0x2c')](function(){return db[_0x1001('0x4f')][_0x1001('0x5a')]({'where':{'type':_0x1001('0x50')},'attributes':['id'],'include':[{'model':db[_0x1001('0x5b')],'as':'BlackLists','where':{'id':LISTID}}]})[_0x1001('0x2c')](function(_0x2a2588){var _0x1c529c=[];if(_0x2a2588){var _0x29342a;for(var _0x31e594=0x0,_0x3b51f0;_0x31e594<_0x2a2588[_0x1001('0x18')];_0x31e594+=0x1){_0x3b51f0=_0x2a2588[_0x31e594][_0x1001('0x53')]({'plain':!![]});_0x1c529c[_0x1001('0x2d')](db['sequelize'][_0x1001('0x55')](_0x542419(_0x3b51f0,_0x1001('0x56')))[_0x1001('0x2c')](function(){})[_0x1001('0x2f')](_0x457336()));}}return _0x1c529c;})['all']();})[_0x1001('0x2c')](function(){return db['Campaign'][_0x1001('0x5a')]({'attributes':['id','dialCheckDuplicateType'],'include':[{'model':db['CmList'],'as':'Lists','where':{'id':LISTID}}]})[_0x1001('0x2c')](function(_0x28a9d1){var _0x1c1cfa=[];if(_0x28a9d1){for(var _0x5aefb8=0x0,_0x1e5d67;_0x5aefb8<_0x28a9d1['length'];_0x5aefb8+=0x1){_0x1e5d67=_0x28a9d1[_0x5aefb8][_0x1001('0x53')]({'plain':!![]});switch(_0x1e5d67[_0x1001('0x51')]){case _0x1001('0x54'):_0x1c1cfa['push'](db[_0x1001('0x58')]['query'](_0x1abad1(_0x1e5d67,_0x1001('0x5c')))[_0x1001('0x2c')](function(){})[_0x1001('0x2f')](_0x457336()));break;case _0x1001('0x57'):_0x1c1cfa[_0x1001('0x2d')](db[_0x1001('0x58')][_0x1001('0x55')](_0x1c781e(_0x1e5d67,_0x1001('0x5c')))[_0x1001('0x2c')](function(){})[_0x1001('0x2f')](_0x457336()));break;default:_0x1c1cfa[_0x1001('0x2d')](db[_0x1001('0x58')][_0x1001('0x55')](_0x116e10(_0x1e5d67,_0x1001('0x5c')))[_0x1001('0x2c')](function(){})[_0x1001('0x2f')](_0x457336()));}}}return _0x1c1cfa;})[_0x1001('0x59')]();})[_0x1001('0x2c')](function(){return db[_0x1001('0x5d')][_0x1001('0x5a')]({'attributes':['id'],'include':[{'model':db[_0x1001('0x5b')],'as':_0x1001('0x5e'),'where':{'id':LISTID}}]})['then'](function(_0x10e9f0){var _0x12c49b=[];if(_0x10e9f0){for(var _0x4d830e=0x0,_0x119a37;_0x4d830e<_0x10e9f0[_0x1001('0x18')];_0x4d830e+=0x1){_0x119a37=_0x10e9f0[_0x4d830e][_0x1001('0x53')]({'plain':!![]});_0x12c49b[_0x1001('0x2d')](db['sequelize'][_0x1001('0x55')](_0x542419(_0x119a37,_0x1001('0x5c')))[_0x1001('0x2c')](function(){})[_0x1001('0x2f')](_0x457336()));}}return _0x12c49b;})[_0x1001('0x59')]();})['catch'](function(_0x57bb5b){logger[_0x1001('0x13')](_0x1001('0x5f'),'generalCheckHopper',_0x57bb5b['message']);});}var processPromises=function(_0xfa8514){return BPromise[_0x1001('0x59')](promises)['then'](function(_0x2c03e3){})[_0x1001('0x2f')](function(_0x30cf62){logger[_0x1001('0x13')]('Error\x20processing\x20rows\x20block:',JSON[_0x1001('0x31')](_0x30cf62));})[_0x1001('0x60')](function(){socket['emit'](_0x1001('0x61')+SOCKET_TIMESTAMP,{'success':success,'errors':errors,'duplicates':duplicates,'rows':rows});promises=[];success=0x0;errors=0x0;duplicates=0x0;rows=[];if(_0xfa8514){return _0xfa8514[_0x1001('0x62')]();}});};var endCsv=function(){return BPromise[_0x1001('0x63')]()[_0x1001('0x2c')](function(){if(hopperContacts){return checkHopper();}})['then'](function(){socket[_0x1001('0x64')](_0x1001('0x61')+SOCKET_TIMESTAMP,{'finished':!![],'success':success,'errors':errors,'duplicates':duplicates,'rows':rows});try{fs[_0x1001('0x65')](FILEPATH);}catch(_0x7bed27){logger[_0x1001('0x13')](_0x1001('0x66'),JSON[_0x1001('0x31')](_0x7bed27));}finally{process['exit'](0x0);}});};process['on']('SIGINT',function(){logger[_0x1001('0x67')]('CSV\x20import\x20process\x20stopped!');endCsv();});function main(){return BPromise[_0x1001('0x63')]()['then'](function(){if(DUPLICATES){DUPLICATES=DUPLICATES[_0x1001('0x10')](',');return db[_0x1001('0x29')][_0x1001('0x5a')]({'where':{'ListId':LISTID},'attributes':DUPLICATES,'raw':!![]});}})[_0x1001('0x2c')](function(_0x7c9694){var _0x264465=fs[_0x1001('0x68')](FILEPATH,{'highWaterMark':0xf*0x400*0x400});Papa['parse'](_0x264465,{'header':!![],'skipEmptyLines':!![],'step':function(_0x386fc7,_0x285099){total+=0x1;var _0x195af9=total;promises[_0x1001('0x2d')](checkRow(_0x386fc7,_0x7c9694,_0x195af9)[_0x1001('0x2c')](function(){success+=0x1;})[_0x1001('0x2f')](function(_0x6c391){if(_0x6c391[_0x1001('0x13')]){errors+=0x1;delete _0x6c391[_0x1001('0x13')];}else if(_0x6c391[_0x1001('0x69')]){duplicates+=0x1;delete _0x6c391[_0x1001('0x69')];}rows[_0x1001('0x2d')](_0x6c391);}));if(total%0xc8===0x0){_0x285099[_0x1001('0x6a')]();return processPromises(_0x285099);}},'complete':function(){return processPromises()['then'](function(){logger['info']('CSV\x20parsed\x20correctly!');endCsv();});},'error':function(_0x37395c,_0xd1d167){logger['info'](_0x1001('0x6b'),JSON[_0x1001('0x31')](_0x37395c));endCsv();}});})[_0x1001('0x2f')](function(_0x45f7dd){logger[_0x1001('0x13')](_0x1001('0x6c'),JSON[_0x1001('0x31')](_0x45f7dd));});}main();
\ No newline at end of file
+var _0x1cfb=['../../../api/cmContact/cmContact.socket','register','argv','undefined','Missing\x20filepath\x20parameter!','null','Missing\x20binding\x20parameters!','Missing\x20ListId\x20parameter!','Missing\x20socket_timestamp\x20parameter!','error','contact','index','test','isNil','errors','length','map','message','join','hasOwnProperty','data','firstName','firstName\x20not\x20specified!','phone\x20not\x20specified!','birthDate','YYYY-MM-DD','isValid','birthDate\x20format\x20is\x20invalid,\x20YYYY-MM-DD\x20format\x20is\x20supported!','email','email\x20format\x20is\x20not\x20valid!','ListId','CompanyId','find','duplicate','Duplicate\x20Contact','CmContact','create','keys','then','pick','catch','Error\x20while\x20creating\x20contact:\x20','stringify','checkHopper','inspect','insert','into','cm_hopper','phone','scheduledAt','ContactId','createdAt','updatedAt','select','field','toString','NOW()','where','deletedAt\x20IS\x20NULL','phone\x20IS\x20NOT\x20NULL','from','fromQuery','cm_contacts','ListId\x20=\x20?','id\x20IN\x20?','str','phone\x20NOT\x20IN\x20(?)','calleridnum','cm_hopper_final','\x20=\x20?','cm_hopper_black','VoiceQueue','findAll','outbound','dialCheckDuplicateType','CmList','Lists','always','push','sequelize','query','VoiceQueueId','all','get','onlyIfOpen','CampaignId','Campaign','BlackLists','cmContact,\x20%s,\x20%s','generalCheckHopper','Error\x20processing\x20rows\x20block:','emit','resume','resolve','unlinkSync','exit','SIGINT','info','CSV\x20import\x20process\x20stopped!','split','pause','CSV\x20parsed\x20correctly!','Error\x20executing\x20contact\x20csv\x20import:','lodash','squel','ioredis','../../../mysqldb','../../../config/environment','../../../config/logger','redis','defaults','localhost'];(function(_0x515784,_0x4c79a3){var _0x1fb287=function(_0x5f226a){while(--_0x5f226a){_0x515784['push'](_0x515784['shift']());}};_0x1fb287(++_0x4c79a3);}(_0x1cfb,0xd7));var _0xb1cf=function(_0x1b68ff,_0x5e68a2){_0x1b68ff=_0x1b68ff-0x0;var _0x4b3b07=_0x1cfb[_0x1b68ff];return _0x4b3b07;};'use strict';var BPromise=require('bluebird');var util=require('util');var _=require(_0xb1cf('0x0'));var fs=require('fs');var squel=require(_0xb1cf('0x1'));var Papa=require('papaparse');var Redis=require(_0xb1cf('0x2'));var db=require(_0xb1cf('0x3'))['db'];var config=require(_0xb1cf('0x4'));var logger=require(_0xb1cf('0x5'))('api');config[_0xb1cf('0x6')]=_[_0xb1cf('0x7')](config[_0xb1cf('0x6')],{'host':_0xb1cf('0x8'),'port':0x18eb});var socket=require('socket.io-emitter')(new Redis(config['redis']));require(_0xb1cf('0x9'))[_0xb1cf('0xa')](socket);try{if(!process['argv'][0x2]||process[_0xb1cf('0xb')][0x2]===_0xb1cf('0xc')||process[_0xb1cf('0xb')][0x2]==='null'){throw new Error(_0xb1cf('0xd'));}var FILEPATH=process[_0xb1cf('0xb')][0x2];if(!process['argv'][0x3]||process[_0xb1cf('0xb')][0x3]===_0xb1cf('0xc')||process[_0xb1cf('0xb')][0x3]===_0xb1cf('0xe')||!process['argv'][0x4]||process[_0xb1cf('0xb')][0x4]==='undefined'||process['argv'][0x4]===_0xb1cf('0xe')){throw new Error(_0xb1cf('0xf'));}var FIELDS=_['zipObject'](process[_0xb1cf('0xb')][0x3]['split'](','),process[_0xb1cf('0xb')][0x4]['split'](','));if(!process['argv'][0x5]||process['argv'][0x5]===_0xb1cf('0xc')||process[_0xb1cf('0xb')][0x5]===_0xb1cf('0xe')){throw new Error(_0xb1cf('0x10'));}var LISTID=process[_0xb1cf('0xb')][0x5];var COMPANYID=process[_0xb1cf('0xb')][0x6]&&process['argv'][0x6]!==_0xb1cf('0xc')&&process[_0xb1cf('0xb')][0x6]!==_0xb1cf('0xe')?process[_0xb1cf('0xb')][0x6]:null;var DUPLICATES=process['argv'][0x7]&&process[_0xb1cf('0xb')][0x7]!==_0xb1cf('0xc')&&process[_0xb1cf('0xb')][0x7]!==_0xb1cf('0xe')?process['argv'][0x7]:null;if(!process[_0xb1cf('0xb')][0x8]||process[_0xb1cf('0xb')][0x8]===_0xb1cf('0xc')||process[_0xb1cf('0xb')][0x8]==='null'){throw new Error(_0xb1cf('0x11'));}var SOCKET_TIMESTAMP=process[_0xb1cf('0xb')][0x8];}catch(_0x7bf429){logger[_0xb1cf('0x12')](_0x7bf429);endCsv();}var total=0x0;var pTotal=0x0;var success=0x0;var errors=0x0;var duplicates=0x0;var rows=[];var hopperContacts='';var promises=[];var index=0x0;var alreadyInvalid=![];function handleCheckRowError(_0x41a8c6,_0x242c27,_0x4b8574,_0x20cc37){var _0x25f3ca={'message':_0x242c27};_0x25f3ca[_0x41a8c6]=!![];if(_0x4b8574){_0x25f3ca[_0xb1cf('0x13')]=_0x4b8574;}if(_0x20cc37){_0x25f3ca[_0xb1cf('0x14')]=_0x20cc37;}return _0x25f3ca;}function isEmail(_0x57fd31){return/^([^\x00-\x20\x22\x28\x29\x2c\x2e\x3a-\x3c\x3e\x40\x5b-\x5d\x7f-\xff]+|\x22([^\x0d\x22\x5c\x80-\xff]|\x5c[\x00-\x7f])*\x22)(\x2e([^\x00-\x20\x22\x28\x29\x2c\x2e\x3a-\x3c\x3e\x40\x5b-\x5d\x7f-\xff]+|\x22([^\x0d\x22\x5c\x80-\xff]|\x5c[\x00-\x7f])*\x22))*\x40([^\x00-\x20\x22\x28\x29\x2c\x2e\x3a-\x3c\x3e\x40\x5b-\x5d\x7f-\xff]+|\x5b([^\x0d\x5b-\x5d\x80-\xff]|\x5c[\x00-\x7f])*\x5d)(\x2e([^\x00-\x20\x22\x28\x29\x2c\x2e\x3a-\x3c\x3e\x40\x5b-\x5d\x7f-\xff]+|\x5b([^\x0d\x5b-\x5d\x80-\xff]|\x5c[\x00-\x7f])*\x5d))*$/[_0xb1cf('0x15')](_0x57fd31);}function checkRow(_0x1b00b5,_0x5dfea9,_0x5191a0){return new BPromise(function(_0x52b5f0,_0x71e33c){if(_[_0xb1cf('0x16')](_0x1b00b5)){return _0x71e33c(handleCheckRowError('error','The\x20row\x20is\x20empty\x20or\x20the\x20number\x20of\x20parameters\x20does\x20not\x20match\x20the\x20columns!',null,_0x5191a0));}if(_0x1b00b5[_0xb1cf('0x17')]&&_0x1b00b5[_0xb1cf('0x17')][_0xb1cf('0x18')]){var _0x5252a4=_[_0xb1cf('0x19')](_0x1b00b5[_0xb1cf('0x17')],_0xb1cf('0x1a'))[_0xb1cf('0x1b')](';');return _0x71e33c(handleCheckRowError('error',_0x5252a4,null,_0x5191a0));}var _0x91a4c3={};for(var _0x5107d4 in FIELDS){if(FIELDS[_0xb1cf('0x1c')](_0x5107d4)&&FIELDS[_0x5107d4]){_0x91a4c3[_0x5107d4]=_0x1b00b5[_0xb1cf('0x1d')][0x0][FIELDS[_0x5107d4]]||_0x1b00b5[_0xb1cf('0x1d')][0x0]['\ufeff'+FIELDS[_0x5107d4]];}}if(!_0x91a4c3[_0xb1cf('0x1e')]){return _0x71e33c(handleCheckRowError('error',_0xb1cf('0x1f'),null,_0x5191a0));}if(!_0x91a4c3['phone']){return _0x71e33c(handleCheckRowError(_0xb1cf('0x12'),_0xb1cf('0x20'),null,_0x5191a0));}if(_0x91a4c3[_0xb1cf('0x21')]){var _0x5a32fe=moment(_0x91a4c3[_0xb1cf('0x21')],_0xb1cf('0x22'));if(!_0x5a32fe[_0xb1cf('0x23')]()){return _0x71e33c(handleCheckRowError('error',_0xb1cf('0x24'),null,_0x5191a0));}}if(_0x91a4c3[_0xb1cf('0x25')]){if(!isEmail(_0x91a4c3[_0xb1cf('0x25')])){return _0x71e33c(handleCheckRowError('error',_0xb1cf('0x26'),null,_0x5191a0));}}_0x91a4c3[_0xb1cf('0x27')]=LISTID;_0x91a4c3[_0xb1cf('0x28')]=COMPANYID||undefined;if(DUPLICATES&&DUPLICATES[_0xb1cf('0x18')]&&_0x5dfea9){var _0x5b5d9={};for(var _0x4f9ec7=0x0,_0x214f7e=DUPLICATES['length'];_0x4f9ec7<_0x214f7e;_0x4f9ec7+=0x1){_0x5b5d9[DUPLICATES[_0x4f9ec7]]=_0x91a4c3[DUPLICATES[_0x4f9ec7]];}var _0x49a7fd=_[_0xb1cf('0x29')](_0x5dfea9,_0x5b5d9);if(_0x49a7fd){return _0x71e33c(handleCheckRowError(_0xb1cf('0x2a'),_0xb1cf('0x2b'),_0x49a7fd,_0x5191a0));}}return db[_0xb1cf('0x2c')][_0xb1cf('0x2d')](_0x91a4c3,{'raw':!![],'hooks':![],'fields':_[_0xb1cf('0x2e')](_0x91a4c3)})[_0xb1cf('0x2f')](function(_0x2a32e2){if(DUPLICATES&&DUPLICATES['length']&&_0x5dfea9){_0x5dfea9['push'](_[_0xb1cf('0x30')](_0x91a4c3,DUPLICATES));}hopperContacts+=(hopperContacts?',':'')+_0x2a32e2['id'];return _0x52b5f0();})[_0xb1cf('0x31')](function(_0x43aa00){return _0x71e33c(handleCheckRowError(_0xb1cf('0x12'),_0xb1cf('0x32')+(_0x43aa00[_0xb1cf('0x1a')]||JSON[_0xb1cf('0x33')](_0x43aa00)),null,_0x5191a0));});});}function checkHopper(){function _0x3053af(){return function(_0x7015bb){logger['error']('cmContact',_0xb1cf('0x34'),util[_0xb1cf('0x35')](_0x7015bb,{'showHidden':![],'depth':null}));};}var _0x451a22=function(_0x503c56,_0x12ee28){var _0x44b08c=squel[_0xb1cf('0x36')]()[_0xb1cf('0x37')](_0xb1cf('0x38'))['fromQuery']([_0xb1cf('0x39'),_0xb1cf('0x3a'),_0xb1cf('0x3b'),_0xb1cf('0x27'),_0x12ee28,_0xb1cf('0x3c'),_0xb1cf('0x3d')],squel[_0xb1cf('0x3e')]()[_0xb1cf('0x3f')](_0xb1cf('0x39'),_0xb1cf('0x39'))[_0xb1cf('0x3f')]('NOW()',_0xb1cf('0x3a'))['field']('id',_0xb1cf('0x3b'))[_0xb1cf('0x3f')](LISTID[_0xb1cf('0x40')](),_0xb1cf('0x27'))[_0xb1cf('0x3f')](_0x503c56['id'][_0xb1cf('0x40')](),_0x12ee28)[_0xb1cf('0x3f')](_0xb1cf('0x41'),'createdAt')[_0xb1cf('0x3f')](_0xb1cf('0x41'),_0xb1cf('0x3d'))['from']('cm_contacts')[_0xb1cf('0x42')](_0xb1cf('0x43'))[_0xb1cf('0x42')]('ListId\x20=\x20?',LISTID[_0xb1cf('0x40')]())[_0xb1cf('0x42')](_0xb1cf('0x44'))[_0xb1cf('0x42')]('phone\x20NOT\x20IN\x20(?)',squel[_0xb1cf('0x3e')]()[_0xb1cf('0x3f')]('phone')[_0xb1cf('0x45')]('cm_hopper')['where'](_0x12ee28+'\x20=\x20?',_0x503c56['id'][_0xb1cf('0x40')]())))[_0xb1cf('0x40')]();return _0x44b08c;};var _0x153108=function(_0x4f77c1,_0x515887){var _0x490684=squel[_0xb1cf('0x36')]()[_0xb1cf('0x37')](_0xb1cf('0x38'))[_0xb1cf('0x46')]([_0xb1cf('0x39'),'scheduledAt',_0xb1cf('0x3b'),_0xb1cf('0x27'),_0x515887,_0xb1cf('0x3c'),_0xb1cf('0x3d')],squel[_0xb1cf('0x3e')]()[_0xb1cf('0x3f')](_0xb1cf('0x39'),_0xb1cf('0x39'))[_0xb1cf('0x3f')](_0xb1cf('0x41'),_0xb1cf('0x3a'))[_0xb1cf('0x3f')]('id',_0xb1cf('0x3b'))[_0xb1cf('0x3f')](LISTID['toString'](),_0xb1cf('0x27'))[_0xb1cf('0x3f')](_0x4f77c1['id'][_0xb1cf('0x40')](),_0x515887)[_0xb1cf('0x3f')](_0xb1cf('0x41'),'createdAt')[_0xb1cf('0x3f')](_0xb1cf('0x41'),_0xb1cf('0x3d'))[_0xb1cf('0x45')](_0xb1cf('0x47'))[_0xb1cf('0x42')](_0xb1cf('0x43'))[_0xb1cf('0x42')](_0xb1cf('0x48'),LISTID[_0xb1cf('0x40')]())[_0xb1cf('0x42')](_0xb1cf('0x49'),squel[_0xb1cf('0x4a')](hopperContacts))[_0xb1cf('0x42')](_0xb1cf('0x44'))[_0xb1cf('0x42')](_0xb1cf('0x4b'),squel['select']()[_0xb1cf('0x3f')](_0xb1cf('0x4c'))['from'](_0xb1cf('0x4d'))[_0xb1cf('0x42')](_0x515887+_0xb1cf('0x4e'),_0x4f77c1['id']['toString']()))[_0xb1cf('0x42')](_0xb1cf('0x4b'),squel['select']()[_0xb1cf('0x3f')](_0xb1cf('0x39'))['from']('cm_hopper')[_0xb1cf('0x42')](_0x515887+_0xb1cf('0x4e'),_0x4f77c1['id'][_0xb1cf('0x40')]())))[_0xb1cf('0x40')]();return _0x490684;};function _0x262b54(_0xe85674,_0x10e526){var _0xdc7d0=squel[_0xb1cf('0x36')]()[_0xb1cf('0x37')](_0xb1cf('0x38'))['fromQuery'](['phone',_0xb1cf('0x3a'),_0xb1cf('0x3b'),'ListId',_0x10e526,'createdAt',_0xb1cf('0x3d')],squel['select']()['field'](_0xb1cf('0x39'),'phone')['field'](_0xb1cf('0x41'),_0xb1cf('0x3a'))[_0xb1cf('0x3f')]('id',_0xb1cf('0x3b'))['field'](LISTID[_0xb1cf('0x40')](),_0xb1cf('0x27'))['field'](_0xe85674['id'][_0xb1cf('0x40')](),_0x10e526)[_0xb1cf('0x3f')](_0xb1cf('0x41'),_0xb1cf('0x3c'))['field'](_0xb1cf('0x41'),_0xb1cf('0x3d'))[_0xb1cf('0x45')](_0xb1cf('0x47'))[_0xb1cf('0x42')](_0xb1cf('0x43'))['where'](_0xb1cf('0x48'),LISTID['toString']())[_0xb1cf('0x42')](_0xb1cf('0x49'),squel[_0xb1cf('0x4a')](hopperContacts))['where'](_0xb1cf('0x44')))[_0xb1cf('0x40')]();return _0xdc7d0;}function _0x2c2362(_0x38351e,_0x59fa5c){var _0x5ed1fc=squel['insert']()[_0xb1cf('0x37')](_0xb1cf('0x4f'))[_0xb1cf('0x46')]([_0xb1cf('0x39'),_0xb1cf('0x3b'),'ListId',_0x59fa5c,_0xb1cf('0x3c'),_0xb1cf('0x3d')],squel['select']()[_0xb1cf('0x3f')](_0xb1cf('0x39'),_0xb1cf('0x39'))[_0xb1cf('0x3f')]('id','ContactId')[_0xb1cf('0x3f')](LISTID[_0xb1cf('0x40')](),_0xb1cf('0x27'))['field'](_0x38351e['id'][_0xb1cf('0x40')](),_0x59fa5c)['field'](_0xb1cf('0x41'),'createdAt')[_0xb1cf('0x3f')]('NOW()',_0xb1cf('0x3d'))[_0xb1cf('0x45')](_0xb1cf('0x47'))[_0xb1cf('0x42')](_0xb1cf('0x43'))['where']('ListId\x20=\x20?',LISTID['toString']())[_0xb1cf('0x42')](_0xb1cf('0x49'),squel[_0xb1cf('0x4a')](hopperContacts))[_0xb1cf('0x42')](_0xb1cf('0x44')))[_0xb1cf('0x40')]();return _0x5ed1fc;}return db[_0xb1cf('0x50')][_0xb1cf('0x51')]({'where':{'type':_0xb1cf('0x52')},'attributes':['id',_0xb1cf('0x53')],'include':[{'model':db[_0xb1cf('0x54')],'as':_0xb1cf('0x55'),'where':{'id':LISTID}}]})[_0xb1cf('0x2f')](function(_0x3af313){var _0x393a47=[];if(_0x3af313){var _0x17a9ee;for(var _0x43a2a=0x0,_0xcdb601;_0x43a2a<_0x3af313[_0xb1cf('0x18')];_0x43a2a+=0x1){_0xcdb601=_0x3af313[_0x43a2a]['get']({'plain':!![]});switch(_0xcdb601[_0xb1cf('0x53')]){case _0xb1cf('0x56'):_0x393a47[_0xb1cf('0x57')](db[_0xb1cf('0x58')][_0xb1cf('0x59')](_0x153108(_0xcdb601,_0xb1cf('0x5a')))[_0xb1cf('0x2f')](function(){})[_0xb1cf('0x31')](_0x3053af()));break;case'onlyIfOpen':_0x393a47[_0xb1cf('0x57')](db[_0xb1cf('0x58')][_0xb1cf('0x59')](_0x451a22(_0xcdb601,'VoiceQueueId'))['then'](function(){})[_0xb1cf('0x31')](_0x3053af()));break;default:_0x393a47[_0xb1cf('0x57')](db[_0xb1cf('0x58')][_0xb1cf('0x59')](_0x262b54(_0xcdb601,_0xb1cf('0x5a')))[_0xb1cf('0x2f')](function(){})[_0xb1cf('0x31')](_0x3053af()));}}}return _0x393a47;})[_0xb1cf('0x5b')]()[_0xb1cf('0x2f')](function(){return db[_0xb1cf('0x50')]['findAll']({'where':{'type':'outbound'},'attributes':['id'],'include':[{'model':db[_0xb1cf('0x54')],'as':'BlackLists','where':{'id':LISTID}}]})[_0xb1cf('0x2f')](function(_0x17b3bf){var _0x5a9d69=[];if(_0x17b3bf){var _0x34c49f;for(var _0x43af28=0x0,_0x4bad47;_0x43af28<_0x17b3bf[_0xb1cf('0x18')];_0x43af28+=0x1){_0x4bad47=_0x17b3bf[_0x43af28][_0xb1cf('0x5c')]({'plain':!![]});_0x5a9d69['push'](db[_0xb1cf('0x58')][_0xb1cf('0x59')](_0x2c2362(_0x4bad47,'VoiceQueueId'))[_0xb1cf('0x2f')](function(){})[_0xb1cf('0x31')](_0x3053af()));}}return _0x5a9d69;})[_0xb1cf('0x5b')]();})[_0xb1cf('0x2f')](function(){return db['Campaign'][_0xb1cf('0x51')]({'attributes':['id',_0xb1cf('0x53')],'include':[{'model':db['CmList'],'as':_0xb1cf('0x55'),'where':{'id':LISTID}}]})['then'](function(_0xb5cdf8){var _0x337136=[];if(_0xb5cdf8){for(var _0x366636=0x0,_0x79ff2;_0x366636<_0xb5cdf8[_0xb1cf('0x18')];_0x366636+=0x1){_0x79ff2=_0xb5cdf8[_0x366636]['get']({'plain':!![]});switch(_0x79ff2['dialCheckDuplicateType']){case'always':_0x337136[_0xb1cf('0x57')](db[_0xb1cf('0x58')][_0xb1cf('0x59')](_0x153108(_0x79ff2,'CampaignId'))[_0xb1cf('0x2f')](function(){})['catch'](_0x3053af()));break;case _0xb1cf('0x5d'):_0x337136[_0xb1cf('0x57')](db[_0xb1cf('0x58')][_0xb1cf('0x59')](_0x451a22(_0x79ff2,_0xb1cf('0x5e')))[_0xb1cf('0x2f')](function(){})['catch'](_0x3053af()));break;default:_0x337136[_0xb1cf('0x57')](db[_0xb1cf('0x58')][_0xb1cf('0x59')](_0x262b54(_0x79ff2,_0xb1cf('0x5e')))[_0xb1cf('0x2f')](function(){})[_0xb1cf('0x31')](_0x3053af()));}}}return _0x337136;})[_0xb1cf('0x5b')]();})[_0xb1cf('0x2f')](function(){return db[_0xb1cf('0x5f')][_0xb1cf('0x51')]({'attributes':['id'],'include':[{'model':db[_0xb1cf('0x54')],'as':_0xb1cf('0x60'),'where':{'id':LISTID}}]})[_0xb1cf('0x2f')](function(_0x462877){var _0x2e162d=[];if(_0x462877){for(var _0x1313c9=0x0,_0xe5f9ff;_0x1313c9<_0x462877[_0xb1cf('0x18')];_0x1313c9+=0x1){_0xe5f9ff=_0x462877[_0x1313c9][_0xb1cf('0x5c')]({'plain':!![]});_0x2e162d[_0xb1cf('0x57')](db[_0xb1cf('0x58')][_0xb1cf('0x59')](_0x2c2362(_0xe5f9ff,_0xb1cf('0x5e')))['then'](function(){})[_0xb1cf('0x31')](_0x3053af()));}}return _0x2e162d;})['all']();})[_0xb1cf('0x31')](function(_0x55b04a){logger[_0xb1cf('0x12')](_0xb1cf('0x61'),_0xb1cf('0x62'),_0x55b04a[_0xb1cf('0x1a')]);});}var processPromises=function(_0x4ca966){return BPromise[_0xb1cf('0x5b')](promises)['then'](function(_0x13e332){})[_0xb1cf('0x31')](function(_0x1ec54a){logger['error'](_0xb1cf('0x63'),JSON[_0xb1cf('0x33')](_0x1ec54a));})['finally'](function(){socket[_0xb1cf('0x64')]('contact:csv_'+SOCKET_TIMESTAMP,{'success':success,'errors':errors,'duplicates':duplicates,'rows':rows});promises=[];success=0x0;errors=0x0;duplicates=0x0;rows=[];if(_0x4ca966){return _0x4ca966[_0xb1cf('0x65')]();}});};var endCsv=function(){return BPromise[_0xb1cf('0x66')]()[_0xb1cf('0x2f')](function(){if(hopperContacts){return checkHopper();}})['then'](function(){socket['emit']('contact:csv_'+SOCKET_TIMESTAMP,{'finished':!![],'success':success,'errors':errors,'duplicates':duplicates,'rows':rows});try{fs[_0xb1cf('0x67')](FILEPATH);}catch(_0x30f4ac){logger[_0xb1cf('0x12')]('Unable\x20to\x20delete\x20temp\x20file:',JSON[_0xb1cf('0x33')](_0x30f4ac));}finally{process[_0xb1cf('0x68')](0x0);}});};process['on'](_0xb1cf('0x69'),function(){logger[_0xb1cf('0x6a')](_0xb1cf('0x6b'));endCsv();});function main(){return BPromise[_0xb1cf('0x66')]()['then'](function(){if(DUPLICATES){DUPLICATES=DUPLICATES[_0xb1cf('0x6c')](',');return db[_0xb1cf('0x2c')][_0xb1cf('0x51')]({'where':{'ListId':LISTID},'attributes':DUPLICATES,'raw':!![]});}})['then'](function(_0x2cb3ec){var _0x28ad26=fs['createReadStream'](FILEPATH,{'highWaterMark':0xf*0x400*0x400});Papa['parse'](_0x28ad26,{'header':!![],'skipEmptyLines':!![],'step':function(_0x532658,_0x254755){total+=0x1;var _0x34621f=total;promises[_0xb1cf('0x57')](checkRow(_0x532658,_0x2cb3ec,_0x34621f)['then'](function(){success+=0x1;})['catch'](function(_0x2b62b4){if(_0x2b62b4[_0xb1cf('0x12')]){errors+=0x1;delete _0x2b62b4[_0xb1cf('0x12')];}else if(_0x2b62b4[_0xb1cf('0x2a')]){duplicates+=0x1;delete _0x2b62b4[_0xb1cf('0x2a')];}rows[_0xb1cf('0x57')](_0x2b62b4);}));if(total%0xc8===0x0){_0x254755[_0xb1cf('0x6d')]();return processPromises(_0x254755);}},'complete':function(){return processPromises()[_0xb1cf('0x2f')](function(){logger[_0xb1cf('0x6a')](_0xb1cf('0x6e'));endCsv();});},'error':function(_0x1a3601,_0x5b2e17){logger[_0xb1cf('0x6a')]('CSV\x20parse\x20error',JSON[_0xb1cf('0x33')](_0x1a3601));endCsv();}});})['catch'](function(_0x25b063){logger[_0xb1cf('0x12')](_0xb1cf('0x6f'),JSON[_0xb1cf('0x33')](_0x25b063));});}main();
\ No newline at end of file