Built motion from commit 639a1a7f.|2.6.19
[motion2.git] / server / components / import / cm / csv.js
index 861eb11..be79485 100644 (file)
@@ -15,4 +15,4 @@
 // * treaties. The SOFTWARE PRODUCT is licensed, not sold.                        *
 // *                                                                       *
 // *************************************************************************
-var _0x72f8=['catch','sequelize','all','outbound','BlackLists','CampaignId','findAll','Error\x20processing\x20rows\x20block:','finally','contact:csv_','resume','resolve','unlinkSync','Unable\x20to\x20delete\x20temp\x20file:','info','CSV\x20import\x20process\x20stopped!','CmContact','parse','duplicate','pause','Error\x20executing\x20contact\x20csv\x20import:','bluebird','util','lodash','squel','papaparse','ioredis','../../../mysqldb','api','redis','defaults','localhost','../../../api/cmContact/cmContact.socket','register','argv','undefined','null','Missing\x20filepath\x20parameter!','Missing\x20binding\x20parameters!','zipObject','split','Missing\x20ListId\x20parameter!','error','contact','index','test','errors','length','map','message','hasOwnProperty','data','firstName','firstName\x20not\x20specified!','phone','birthDate','isValid','birthDate\x20format\x20is\x20invalid,\x20YYYY-MM-DD\x20format\x20is\x20supported!','email','ListId','CompanyId','Duplicate\x20Contact','create','keys','then','push','pick','stringify','cmContact','checkHopper','inspect','insert','scheduledAt','ContactId','updatedAt','select','field','createdAt','NOW()','from','cm_contacts','where','deletedAt\x20IS\x20NULL','ListId\x20=\x20?','toString','phone\x20IS\x20NOT\x20NULL','phone\x20NOT\x20IN\x20(?)','cm_hopper','\x20=\x20?','fromQuery','str','calleridnum','into','id\x20IN\x20?','cm_hopper_black','VoiceQueue','dialCheckDuplicateType','CmList','Lists','get','always','query','VoiceQueueId'];(function(_0x36fe55,_0x75f5d){var _0x2701e4=function(_0xce9362){while(--_0xce9362){_0x36fe55['push'](_0x36fe55['shift']());}};_0x2701e4(++_0x75f5d);}(_0x72f8,0xe3));var _0x872f=function(_0x367e5b,_0x5721e4){_0x367e5b=_0x367e5b-0x0;var _0x4b909e=_0x72f8[_0x367e5b];return _0x4b909e;};'use strict';var BPromise=require(_0x872f('0x0'));var util=require(_0x872f('0x1'));var _=require(_0x872f('0x2'));var fs=require('fs');var squel=require(_0x872f('0x3'));var Papa=require(_0x872f('0x4'));var Redis=require(_0x872f('0x5'));var db=require(_0x872f('0x6'))['db'];var config=require('../../../config/environment');var logger=require('../../../config/logger')(_0x872f('0x7'));config[_0x872f('0x8')]=_[_0x872f('0x9')](config[_0x872f('0x8')],{'host':_0x872f('0xa'),'port':0x18eb});var socket=require('socket.io-emitter')(new Redis(config['redis']));require(_0x872f('0xb'))[_0x872f('0xc')](socket);try{if(!process[_0x872f('0xd')][0x2]||process['argv'][0x2]===_0x872f('0xe')||process['argv'][0x2]===_0x872f('0xf')){throw new Error(_0x872f('0x10'));}var FILEPATH=process[_0x872f('0xd')][0x2];if(!process[_0x872f('0xd')][0x3]||process[_0x872f('0xd')][0x3]===_0x872f('0xe')||process[_0x872f('0xd')][0x3]===_0x872f('0xf')||!process[_0x872f('0xd')][0x4]||process['argv'][0x4]===_0x872f('0xe')||process['argv'][0x4]===_0x872f('0xf')){throw new Error(_0x872f('0x11'));}var FIELDS=_[_0x872f('0x12')](process['argv'][0x3]['split'](','),process[_0x872f('0xd')][0x4][_0x872f('0x13')](','));if(!process['argv'][0x5]||process['argv'][0x5]===_0x872f('0xe')||process[_0x872f('0xd')][0x5]===_0x872f('0xf')){throw new Error(_0x872f('0x14'));}var LISTID=process[_0x872f('0xd')][0x5];var COMPANYID=process[_0x872f('0xd')][0x6]&&process[_0x872f('0xd')][0x6]!==_0x872f('0xe')&&process['argv'][0x6]!==_0x872f('0xf')?process['argv'][0x6]:null;var DUPLICATES=process[_0x872f('0xd')][0x7]&&process[_0x872f('0xd')][0x7]!==_0x872f('0xe')&&process[_0x872f('0xd')][0x7]!==_0x872f('0xf')?process[_0x872f('0xd')][0x7]:null;if(!process[_0x872f('0xd')][0x8]||process['argv'][0x8]===_0x872f('0xe')||process[_0x872f('0xd')][0x8]==='null'){throw new Error('Missing\x20socket_timestamp\x20parameter!');}var SOCKET_TIMESTAMP=process['argv'][0x8];}catch(_0x4435a1){logger[_0x872f('0x15')](_0x4435a1);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(_0x11cc31,_0xc564e8,_0x300470,_0x433c22){var _0x3cac31={'message':_0xc564e8};_0x3cac31[_0x11cc31]=!![];if(_0x300470){_0x3cac31[_0x872f('0x16')]=_0x300470;}if(_0x433c22){_0x3cac31[_0x872f('0x17')]=_0x433c22;}return _0x3cac31;}function isEmail(_0x52dc4f){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))*$/[_0x872f('0x18')](_0x52dc4f);}function checkRow(_0x5f1fb2,_0x3e557b,_0x22c244){return new BPromise(function(_0xec3405,_0x16ca9e){if(_['isNil'](_0x5f1fb2)){return _0x16ca9e(handleCheckRowError(_0x872f('0x15'),'The\x20row\x20is\x20empty\x20or\x20the\x20number\x20of\x20parameters\x20does\x20not\x20match\x20the\x20columns!',null,_0x22c244));}if(_0x5f1fb2['errors']&&_0x5f1fb2[_0x872f('0x19')][_0x872f('0x1a')]){var _0x40dd64=_[_0x872f('0x1b')](_0x5f1fb2[_0x872f('0x19')],_0x872f('0x1c'))['join'](';');return _0x16ca9e(handleCheckRowError(_0x872f('0x15'),_0x40dd64,null,_0x22c244));}var _0x11fa75={};for(var _0x3e5833 in FIELDS){if(FIELDS[_0x872f('0x1d')](_0x3e5833)&&FIELDS[_0x3e5833]){_0x11fa75[_0x3e5833]=_0x5f1fb2[_0x872f('0x1e')][0x0][FIELDS[_0x3e5833]]||_0x5f1fb2[_0x872f('0x1e')][0x0]['\ufeff'+FIELDS[_0x3e5833]];}}if(!_0x11fa75[_0x872f('0x1f')]){return _0x16ca9e(handleCheckRowError('error',_0x872f('0x20'),null,_0x22c244));}if(!_0x11fa75[_0x872f('0x21')]){return _0x16ca9e(handleCheckRowError(_0x872f('0x15'),'phone\x20not\x20specified!',null,_0x22c244));}if(_0x11fa75['birthDate']){var _0x46c01b=moment(_0x11fa75[_0x872f('0x22')],'YYYY-MM-DD');if(!_0x46c01b[_0x872f('0x23')]()){return _0x16ca9e(handleCheckRowError(_0x872f('0x15'),_0x872f('0x24'),null,_0x22c244));}}if(_0x11fa75[_0x872f('0x25')]){if(!isEmail(_0x11fa75[_0x872f('0x25')])){return _0x16ca9e(handleCheckRowError(_0x872f('0x15'),'email\x20format\x20is\x20not\x20valid!',null,_0x22c244));}}_0x11fa75[_0x872f('0x26')]=LISTID;_0x11fa75[_0x872f('0x27')]=COMPANYID||undefined;if(DUPLICATES&&DUPLICATES[_0x872f('0x1a')]&&_0x3e557b){var _0x11dc65={};for(var _0x12c0d3=0x0,_0x17c0fb=DUPLICATES['length'];_0x12c0d3<_0x17c0fb;_0x12c0d3+=0x1){_0x11dc65[DUPLICATES[_0x12c0d3]]=_0x11fa75[DUPLICATES[_0x12c0d3]];}var _0xefb780=_['find'](_0x3e557b,_0x11dc65);if(_0xefb780){return _0x16ca9e(handleCheckRowError('duplicate',_0x872f('0x28'),_0xefb780,_0x22c244));}}return db['CmContact'][_0x872f('0x29')](_0x11fa75,{'raw':!![],'hooks':![],'fields':_[_0x872f('0x2a')](_0x11fa75)})[_0x872f('0x2b')](function(_0x2d616c){if(DUPLICATES&&DUPLICATES[_0x872f('0x1a')]&&_0x3e557b){_0x3e557b[_0x872f('0x2c')](_[_0x872f('0x2d')](_0x11fa75,DUPLICATES));}hopperContacts+=(hopperContacts?',':'')+_0x2d616c['id'];return _0xec3405();})['catch'](function(_0x544441){return _0x16ca9e(handleCheckRowError(_0x872f('0x15'),'Error\x20while\x20creating\x20contact:\x20'+(_0x544441[_0x872f('0x1c')]||JSON[_0x872f('0x2e')](_0x544441)),null,_0x22c244));});});}function checkHopper(){function _0x2d377d(){return function(_0x18ed95){logger[_0x872f('0x15')](_0x872f('0x2f'),_0x872f('0x30'),util[_0x872f('0x31')](_0x18ed95,{'showHidden':![],'depth':null}));};}var _0x2de6c5=function(_0x16bdad,_0x56d883){var _0x1672ea=squel[_0x872f('0x32')]()['into']('cm_hopper')['fromQuery']([_0x872f('0x21'),_0x872f('0x33'),_0x872f('0x34'),_0x872f('0x26'),_0x56d883,'createdAt',_0x872f('0x35')],squel[_0x872f('0x36')]()['field'](_0x872f('0x21'),_0x872f('0x21'))['field']('NOW()',_0x872f('0x33'))[_0x872f('0x37')]('id',_0x872f('0x34'))['field'](LISTID['toString'](),_0x872f('0x26'))[_0x872f('0x37')](_0x16bdad['id']['toString'](),_0x56d883)[_0x872f('0x37')]('NOW()',_0x872f('0x38'))[_0x872f('0x37')](_0x872f('0x39'),_0x872f('0x35'))[_0x872f('0x3a')](_0x872f('0x3b'))[_0x872f('0x3c')](_0x872f('0x3d'))[_0x872f('0x3c')](_0x872f('0x3e'),LISTID[_0x872f('0x3f')]())[_0x872f('0x3c')](_0x872f('0x40'))['where'](_0x872f('0x41'),squel[_0x872f('0x36')]()['field'](_0x872f('0x21'))['from'](_0x872f('0x42'))[_0x872f('0x3c')](_0x56d883+_0x872f('0x43'),_0x16bdad['id'][_0x872f('0x3f')]())))['toString']();return _0x1672ea;};var _0x1cdcc5=function(_0x54796b,_0x16eb13){var _0x1547b7=squel[_0x872f('0x32')]()['into'](_0x872f('0x42'))[_0x872f('0x44')]([_0x872f('0x21'),_0x872f('0x33'),_0x872f('0x34'),_0x872f('0x26'),_0x16eb13,_0x872f('0x38'),_0x872f('0x35')],squel[_0x872f('0x36')]()[_0x872f('0x37')](_0x872f('0x21'),_0x872f('0x21'))[_0x872f('0x37')](_0x872f('0x39'),'scheduledAt')['field']('id',_0x872f('0x34'))['field'](LISTID[_0x872f('0x3f')](),_0x872f('0x26'))[_0x872f('0x37')](_0x54796b['id'][_0x872f('0x3f')](),_0x16eb13)[_0x872f('0x37')]('NOW()',_0x872f('0x38'))[_0x872f('0x37')]('NOW()',_0x872f('0x35'))[_0x872f('0x3a')]('cm_contacts')[_0x872f('0x3c')](_0x872f('0x3d'))['where'](_0x872f('0x3e'),LISTID['toString']())[_0x872f('0x3c')]('id\x20IN\x20?',squel[_0x872f('0x45')](hopperContacts))[_0x872f('0x3c')](_0x872f('0x40'))[_0x872f('0x3c')](_0x872f('0x41'),squel['select']()[_0x872f('0x37')](_0x872f('0x46'))[_0x872f('0x3a')]('cm_hopper_final')['where'](_0x16eb13+_0x872f('0x43'),_0x54796b['id'][_0x872f('0x3f')]()))[_0x872f('0x3c')]('phone\x20NOT\x20IN\x20(?)',squel[_0x872f('0x36')]()['field'](_0x872f('0x21'))[_0x872f('0x3a')](_0x872f('0x42'))['where'](_0x16eb13+_0x872f('0x43'),_0x54796b['id'][_0x872f('0x3f')]())))['toString']();return _0x1547b7;};function _0x19f996(_0x1fdcf4,_0x25a06c){var _0x1a0cc0=squel['insert']()[_0x872f('0x47')](_0x872f('0x42'))[_0x872f('0x44')]([_0x872f('0x21'),_0x872f('0x33'),'ContactId','ListId',_0x25a06c,_0x872f('0x38'),_0x872f('0x35')],squel[_0x872f('0x36')]()[_0x872f('0x37')](_0x872f('0x21'),'phone')[_0x872f('0x37')]('NOW()',_0x872f('0x33'))['field']('id','ContactId')[_0x872f('0x37')](LISTID[_0x872f('0x3f')](),'ListId')['field'](_0x1fdcf4['id'][_0x872f('0x3f')](),_0x25a06c)[_0x872f('0x37')](_0x872f('0x39'),_0x872f('0x38'))[_0x872f('0x37')](_0x872f('0x39'),_0x872f('0x35'))[_0x872f('0x3a')]('cm_contacts')['where']('deletedAt\x20IS\x20NULL')[_0x872f('0x3c')](_0x872f('0x3e'),LISTID['toString']())[_0x872f('0x3c')](_0x872f('0x48'),squel['str'](hopperContacts))[_0x872f('0x3c')](_0x872f('0x40')))[_0x872f('0x3f')]();return _0x1a0cc0;}function _0x5b297e(_0x528c14,_0x327376){var _0x4f3d98=squel['insert']()[_0x872f('0x47')](_0x872f('0x49'))[_0x872f('0x44')]([_0x872f('0x21'),'ContactId','ListId',_0x327376,_0x872f('0x38'),_0x872f('0x35')],squel[_0x872f('0x36')]()[_0x872f('0x37')](_0x872f('0x21'),_0x872f('0x21'))[_0x872f('0x37')]('id',_0x872f('0x34'))[_0x872f('0x37')](LISTID[_0x872f('0x3f')](),'ListId')[_0x872f('0x37')](_0x528c14['id']['toString'](),_0x327376)[_0x872f('0x37')](_0x872f('0x39'),_0x872f('0x38'))['field'](_0x872f('0x39'),'updatedAt')[_0x872f('0x3a')](_0x872f('0x3b'))[_0x872f('0x3c')](_0x872f('0x3d'))['where'](_0x872f('0x3e'),LISTID['toString']())[_0x872f('0x3c')](_0x872f('0x48'),squel[_0x872f('0x45')](hopperContacts))[_0x872f('0x3c')](_0x872f('0x40')))[_0x872f('0x3f')]();return _0x4f3d98;}return db[_0x872f('0x4a')]['findAll']({'where':{'type':'outbound'},'attributes':['id',_0x872f('0x4b')],'include':[{'model':db[_0x872f('0x4c')],'as':_0x872f('0x4d'),'where':{'id':LISTID}}]})[_0x872f('0x2b')](function(_0xbca2b0){var _0x389d14=[];if(_0xbca2b0){var _0x437f23;for(var _0x53d5bd=0x0,_0x1be5df;_0x53d5bd<_0xbca2b0[_0x872f('0x1a')];_0x53d5bd+=0x1){_0x1be5df=_0xbca2b0[_0x53d5bd][_0x872f('0x4e')]({'plain':!![]});switch(_0x1be5df['dialCheckDuplicateType']){case _0x872f('0x4f'):_0x389d14[_0x872f('0x2c')](db['sequelize'][_0x872f('0x50')](_0x1cdcc5(_0x1be5df,_0x872f('0x51')))[_0x872f('0x2b')](function(){})[_0x872f('0x52')](_0x2d377d()));break;case'onlyIfOpen':_0x389d14[_0x872f('0x2c')](db[_0x872f('0x53')][_0x872f('0x50')](_0x2de6c5(_0x1be5df,'VoiceQueueId'))['then'](function(){})['catch'](_0x2d377d()));break;default:_0x389d14['push'](db[_0x872f('0x53')][_0x872f('0x50')](_0x19f996(_0x1be5df,_0x872f('0x51')))[_0x872f('0x2b')](function(){})[_0x872f('0x52')](_0x2d377d()));}}}return _0x389d14;})[_0x872f('0x54')]()[_0x872f('0x2b')](function(){return db[_0x872f('0x4a')]['findAll']({'where':{'type':_0x872f('0x55')},'attributes':['id'],'include':[{'model':db[_0x872f('0x4c')],'as':_0x872f('0x56'),'where':{'id':LISTID}}]})[_0x872f('0x2b')](function(_0xfc9ff3){var _0x1e5129=[];if(_0xfc9ff3){var _0x266f60;for(var _0x106826=0x0,_0x10282c;_0x106826<_0xfc9ff3[_0x872f('0x1a')];_0x106826+=0x1){_0x10282c=_0xfc9ff3[_0x106826]['get']({'plain':!![]});_0x1e5129['push'](db[_0x872f('0x53')][_0x872f('0x50')](_0x5b297e(_0x10282c,_0x872f('0x51')))[_0x872f('0x2b')](function(){})[_0x872f('0x52')](_0x2d377d()));}}return _0x1e5129;})[_0x872f('0x54')]();})[_0x872f('0x2b')](function(){return db['Campaign']['findAll']({'attributes':['id',_0x872f('0x4b')],'include':[{'model':db[_0x872f('0x4c')],'as':_0x872f('0x4d'),'where':{'id':LISTID}}]})[_0x872f('0x2b')](function(_0xc3e011){var _0x43f387=[];if(_0xc3e011){for(var _0x54b5a3=0x0,_0x2284d2;_0x54b5a3<_0xc3e011[_0x872f('0x1a')];_0x54b5a3+=0x1){_0x2284d2=_0xc3e011[_0x54b5a3][_0x872f('0x4e')]({'plain':!![]});switch(_0x2284d2[_0x872f('0x4b')]){case _0x872f('0x4f'):_0x43f387['push'](db[_0x872f('0x53')][_0x872f('0x50')](_0x1cdcc5(_0x2284d2,_0x872f('0x57')))[_0x872f('0x2b')](function(){})[_0x872f('0x52')](_0x2d377d()));break;case'onlyIfOpen':_0x43f387[_0x872f('0x2c')](db[_0x872f('0x53')][_0x872f('0x50')](_0x2de6c5(_0x2284d2,_0x872f('0x57')))['then'](function(){})['catch'](_0x2d377d()));break;default:_0x43f387[_0x872f('0x2c')](db[_0x872f('0x53')]['query'](_0x19f996(_0x2284d2,_0x872f('0x57')))[_0x872f('0x2b')](function(){})[_0x872f('0x52')](_0x2d377d()));}}}return _0x43f387;})['all']();})['then'](function(){return db['Campaign'][_0x872f('0x58')]({'attributes':['id'],'include':[{'model':db[_0x872f('0x4c')],'as':_0x872f('0x56'),'where':{'id':LISTID}}]})[_0x872f('0x2b')](function(_0xdf9d31){var _0x205cc3=[];if(_0xdf9d31){for(var _0x2db836=0x0,_0x370037;_0x2db836<_0xdf9d31[_0x872f('0x1a')];_0x2db836+=0x1){_0x370037=_0xdf9d31[_0x2db836][_0x872f('0x4e')]({'plain':!![]});_0x205cc3[_0x872f('0x2c')](db[_0x872f('0x53')]['query'](_0x5b297e(_0x370037,_0x872f('0x57')))[_0x872f('0x2b')](function(){})[_0x872f('0x52')](_0x2d377d()));}}return _0x205cc3;})[_0x872f('0x54')]();})[_0x872f('0x52')](function(_0x294f51){logger[_0x872f('0x15')]('cmContact,\x20%s,\x20%s','generalCheckHopper',_0x294f51[_0x872f('0x1c')]);});}var processPromises=function(_0x477735){return BPromise[_0x872f('0x54')](promises)[_0x872f('0x2b')](function(_0x34c245){})[_0x872f('0x52')](function(_0x26c2e6){logger['error'](_0x872f('0x59'),JSON[_0x872f('0x2e')](_0x26c2e6));})[_0x872f('0x5a')](function(){socket['emit'](_0x872f('0x5b')+SOCKET_TIMESTAMP,{'success':success,'errors':errors,'duplicates':duplicates,'rows':rows});promises=[];success=0x0;errors=0x0;duplicates=0x0;rows=[];if(_0x477735){return _0x477735[_0x872f('0x5c')]();}});};var endCsv=function(){return BPromise[_0x872f('0x5d')]()[_0x872f('0x2b')](function(){if(hopperContacts){return checkHopper();}})[_0x872f('0x2b')](function(){socket['emit']('contact:csv_'+SOCKET_TIMESTAMP,{'finished':!![],'success':success,'errors':errors,'duplicates':duplicates,'rows':rows});try{fs[_0x872f('0x5e')](FILEPATH);}catch(_0x35c0fe){logger[_0x872f('0x15')](_0x872f('0x5f'),JSON['stringify'](_0x35c0fe));}finally{process['exit'](0x0);}});};process['on']('SIGINT',function(){logger[_0x872f('0x60')](_0x872f('0x61'));endCsv();});function main(){return BPromise['resolve']()['then'](function(){if(DUPLICATES){DUPLICATES=DUPLICATES[_0x872f('0x13')](',');return db[_0x872f('0x62')]['findAll']({'where':{'ListId':LISTID},'attributes':DUPLICATES,'raw':!![]});}})[_0x872f('0x2b')](function(_0x506077){var _0x5f122b=fs['createReadStream'](FILEPATH,{'highWaterMark':0xf*0x400*0x400});Papa[_0x872f('0x63')](_0x5f122b,{'header':!![],'skipEmptyLines':!![],'step':function(_0x4cdf04,_0x28e6c9){total+=0x1;var _0x18e924=total;promises[_0x872f('0x2c')](checkRow(_0x4cdf04,_0x506077,_0x18e924)['then'](function(){success+=0x1;})[_0x872f('0x52')](function(_0x4eafd0){if(_0x4eafd0[_0x872f('0x15')]){errors+=0x1;delete _0x4eafd0['error'];}else if(_0x4eafd0[_0x872f('0x64')]){duplicates+=0x1;delete _0x4eafd0[_0x872f('0x64')];}rows[_0x872f('0x2c')](_0x4eafd0);}));if(total%0xc8===0x0){_0x28e6c9[_0x872f('0x65')]();return processPromises(_0x28e6c9);}},'complete':function(){return processPromises()['then'](function(){logger[_0x872f('0x60')]('CSV\x20parsed\x20correctly!');endCsv();});},'error':function(_0x2c01f8,_0x1cdc0d){logger[_0x872f('0x60')]('CSV\x20parse\x20error',JSON[_0x872f('0x2e')](_0x2c01f8));endCsv();}});})[_0x872f('0x52')](function(_0xd98351){logger['error'](_0x872f('0x66'),JSON['stringify'](_0xd98351));});}main();
\ No newline at end of file
+var _0xbaca=['updatedAt','field','NOW()','toString','createdAt','from','cm_contacts','where','deletedAt\x20IS\x20NULL','ListId\x20=\x20?','phone\x20IS\x20NOT\x20NULL','select','id\x20IN\x20?','str','phone\x20NOT\x20IN\x20(?)','calleridnum','\x20=\x20?','insert','cm_hopper_black','VoiceQueue','outbound','CmList','dialCheckDuplicateType','always','query','VoiceQueueId','catch','onlyIfOpen','sequelize','all','findAll','BlackLists','Lists','get','CampaignId','cmContact,\x20%s,\x20%s','generalCheckHopper','message','finally','contact:csv_','resume','resolve','emit','unlinkSync','Unable\x20to\x20delete\x20temp\x20file:','SIGINT','info','CSV\x20import\x20process\x20stopped!','CmContact','pause','CSV\x20parsed\x20correctly!','CSV\x20parse\x20error','lodash','papaparse','ioredis','../../../mysqldb','../../../config/environment','api','localhost','redis','../../../api/cmContact/cmContact.socket','undefined','argv','null','zipObject','split','Missing\x20ListId\x20parameter!','Missing\x20socket_timestamp\x20parameter!','error','contact','isNil','The\x20row\x20is\x20empty\x20or\x20the\x20number\x20of\x20parameters\x20does\x20not\x20match\x20the\x20columns!','length','errors','hasOwnProperty','data','firstName','firstName\x20not\x20specified!','phone','phone\x20not\x20specified!','birthDate','YYYY-MM-DD','birthDate\x20format\x20is\x20invalid,\x20YYYY-MM-DD\x20format\x20is\x20supported!','email','ListId','CompanyId','duplicate','Duplicate\x20Contact','then','push','Error\x20while\x20creating\x20contact:\x20','stringify','cmContact','checkHopper','into','cm_hopper','fromQuery','scheduledAt','ContactId'];(function(_0x1c8943,_0x3b52e9){var _0x1e3862=function(_0x5b6f2a){while(--_0x5b6f2a){_0x1c8943['push'](_0x1c8943['shift']());}};_0x1e3862(++_0x3b52e9);}(_0xbaca,0x15d));var _0xabac=function(_0x5b644e,_0x2e5e07){_0x5b644e=_0x5b644e-0x0;var _0x49c6bf=_0xbaca[_0x5b644e];return _0x49c6bf;};'use strict';var BPromise=require('bluebird');var util=require('util');var _=require(_0xabac('0x0'));var fs=require('fs');var squel=require('squel');var Papa=require(_0xabac('0x1'));var Redis=require(_0xabac('0x2'));var db=require(_0xabac('0x3'))['db'];var config=require(_0xabac('0x4'));var logger=require('../../../config/logger')(_0xabac('0x5'));config['redis']=_['defaults'](config['redis'],{'host':_0xabac('0x6'),'port':0x18eb});var socket=require('socket.io-emitter')(new Redis(config[_0xabac('0x7')]));require(_0xabac('0x8'))['register'](socket);try{if(!process['argv'][0x2]||process['argv'][0x2]===_0xabac('0x9')||process[_0xabac('0xa')][0x2]===_0xabac('0xb')){throw new Error('Missing\x20filepath\x20parameter!');}var FILEPATH=process[_0xabac('0xa')][0x2];if(!process[_0xabac('0xa')][0x3]||process[_0xabac('0xa')][0x3]===_0xabac('0x9')||process[_0xabac('0xa')][0x3]===_0xabac('0xb')||!process['argv'][0x4]||process['argv'][0x4]==='undefined'||process[_0xabac('0xa')][0x4]===_0xabac('0xb')){throw new Error('Missing\x20binding\x20parameters!');}var FIELDS=_[_0xabac('0xc')](process[_0xabac('0xa')][0x3][_0xabac('0xd')](','),process['argv'][0x4][_0xabac('0xd')](','));if(!process['argv'][0x5]||process['argv'][0x5]===_0xabac('0x9')||process[_0xabac('0xa')][0x5]===_0xabac('0xb')){throw new Error(_0xabac('0xe'));}var LISTID=process[_0xabac('0xa')][0x5];var COMPANYID=process[_0xabac('0xa')][0x6]&&process[_0xabac('0xa')][0x6]!==_0xabac('0x9')&&process['argv'][0x6]!=='null'?process['argv'][0x6]:null;var DUPLICATES=process[_0xabac('0xa')][0x7]&&process[_0xabac('0xa')][0x7]!=='undefined'&&process[_0xabac('0xa')][0x7]!=='null'?process[_0xabac('0xa')][0x7]:null;if(!process[_0xabac('0xa')][0x8]||process[_0xabac('0xa')][0x8]==='undefined'||process[_0xabac('0xa')][0x8]===_0xabac('0xb')){throw new Error(_0xabac('0xf'));}var SOCKET_TIMESTAMP=process[_0xabac('0xa')][0x8];}catch(_0x4bdcd1){logger[_0xabac('0x10')](_0x4bdcd1);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(_0x347248,_0x33016b,_0x3babec,_0x327692){var _0x5ecfa0={'message':_0x33016b};_0x5ecfa0[_0x347248]=!![];if(_0x3babec){_0x5ecfa0[_0xabac('0x11')]=_0x3babec;}if(_0x327692){_0x5ecfa0['index']=_0x327692;}return _0x5ecfa0;}function isEmail(_0x3399fe){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))*$/['test'](_0x3399fe);}function checkRow(_0x1c6580,_0x461917,_0x6f26f7){return new BPromise(function(_0x5581b6,_0xf2082b){if(_[_0xabac('0x12')](_0x1c6580)){return _0xf2082b(handleCheckRowError('error',_0xabac('0x13'),null,_0x6f26f7));}if(_0x1c6580['errors']&&_0x1c6580['errors'][_0xabac('0x14')]){var _0xb051eb=_['map'](_0x1c6580[_0xabac('0x15')],'message')['join'](';');return _0xf2082b(handleCheckRowError(_0xabac('0x10'),_0xb051eb,null,_0x6f26f7));}var _0x2d6cfa={};for(var _0x32b1a3 in FIELDS){if(FIELDS[_0xabac('0x16')](_0x32b1a3)&&FIELDS[_0x32b1a3]){_0x2d6cfa[_0x32b1a3]=_0x1c6580[_0xabac('0x17')][0x0][FIELDS[_0x32b1a3]]||_0x1c6580['data'][0x0]['\ufeff'+FIELDS[_0x32b1a3]];}}if(!_0x2d6cfa[_0xabac('0x18')]){return _0xf2082b(handleCheckRowError(_0xabac('0x10'),_0xabac('0x19'),null,_0x6f26f7));}if(!_0x2d6cfa[_0xabac('0x1a')]){return _0xf2082b(handleCheckRowError('error',_0xabac('0x1b'),null,_0x6f26f7));}if(_0x2d6cfa['birthDate']){var _0x286baa=moment(_0x2d6cfa[_0xabac('0x1c')],_0xabac('0x1d'));if(!_0x286baa['isValid']()){return _0xf2082b(handleCheckRowError(_0xabac('0x10'),_0xabac('0x1e'),null,_0x6f26f7));}}if(_0x2d6cfa['email']){if(!isEmail(_0x2d6cfa[_0xabac('0x1f')])){return _0xf2082b(handleCheckRowError(_0xabac('0x10'),'email\x20format\x20is\x20not\x20valid!',null,_0x6f26f7));}}_0x2d6cfa[_0xabac('0x20')]=LISTID;_0x2d6cfa[_0xabac('0x21')]=COMPANYID||undefined;if(DUPLICATES&&DUPLICATES[_0xabac('0x14')]&&_0x461917){var _0x4cc1b1={};for(var _0xd490cc=0x0,_0x1f8b10=DUPLICATES[_0xabac('0x14')];_0xd490cc<_0x1f8b10;_0xd490cc+=0x1){_0x4cc1b1[DUPLICATES[_0xd490cc]]=_0x2d6cfa[DUPLICATES[_0xd490cc]];}var _0x4e35dd=_['find'](_0x461917,_0x4cc1b1);if(_0x4e35dd){return _0xf2082b(handleCheckRowError(_0xabac('0x22'),_0xabac('0x23'),_0x4e35dd,_0x6f26f7));}}return db['CmContact']['create'](_0x2d6cfa,{'raw':!![],'hooks':![],'fields':_['keys'](_0x2d6cfa)})[_0xabac('0x24')](function(_0x9da1f){if(DUPLICATES&&DUPLICATES[_0xabac('0x14')]&&_0x461917){_0x461917[_0xabac('0x25')](_['pick'](_0x2d6cfa,DUPLICATES));}hopperContacts+=(hopperContacts?',':'')+_0x9da1f['id'];return _0x5581b6();})['catch'](function(_0x5a0267){return _0xf2082b(handleCheckRowError(_0xabac('0x10'),_0xabac('0x26')+(_0x5a0267['message']||JSON[_0xabac('0x27')](_0x5a0267)),null,_0x6f26f7));});});}function checkHopper(){function _0x224d09(){return function(_0x2db1a9){logger[_0xabac('0x10')](_0xabac('0x28'),_0xabac('0x29'),util['inspect'](_0x2db1a9,{'showHidden':![],'depth':null}));};}var _0xe7c73e=function(_0x352201,_0x130210){var _0x11d3a8=squel['insert']()[_0xabac('0x2a')](_0xabac('0x2b'))[_0xabac('0x2c')]([_0xabac('0x1a'),_0xabac('0x2d'),_0xabac('0x2e'),_0xabac('0x20'),_0x130210,'createdAt',_0xabac('0x2f')],squel['select']()[_0xabac('0x30')](_0xabac('0x1a'),_0xabac('0x1a'))[_0xabac('0x30')](_0xabac('0x31'),_0xabac('0x2d'))[_0xabac('0x30')]('id',_0xabac('0x2e'))['field'](LISTID[_0xabac('0x32')](),'ListId')['field'](_0x352201['id'][_0xabac('0x32')](),_0x130210)[_0xabac('0x30')](_0xabac('0x31'),_0xabac('0x33'))['field'](_0xabac('0x31'),_0xabac('0x2f'))[_0xabac('0x34')](_0xabac('0x35'))[_0xabac('0x36')](_0xabac('0x37'))[_0xabac('0x36')](_0xabac('0x38'),LISTID[_0xabac('0x32')]())[_0xabac('0x36')](_0xabac('0x39'))[_0xabac('0x36')]('phone\x20NOT\x20IN\x20(?)',squel[_0xabac('0x3a')]()['field'](_0xabac('0x1a'))[_0xabac('0x34')](_0xabac('0x2b'))[_0xabac('0x36')](_0x130210+'\x20=\x20?',_0x352201['id']['toString']())))[_0xabac('0x32')]();return _0x11d3a8;};var _0x20c657=function(_0x5ed830,_0xa49722){var _0xc88ab8=squel['insert']()[_0xabac('0x2a')](_0xabac('0x2b'))['fromQuery']([_0xabac('0x1a'),_0xabac('0x2d'),_0xabac('0x2e'),_0xabac('0x20'),_0xa49722,_0xabac('0x33'),_0xabac('0x2f')],squel[_0xabac('0x3a')]()[_0xabac('0x30')]('phone',_0xabac('0x1a'))[_0xabac('0x30')](_0xabac('0x31'),_0xabac('0x2d'))[_0xabac('0x30')]('id',_0xabac('0x2e'))[_0xabac('0x30')](LISTID[_0xabac('0x32')](),_0xabac('0x20'))['field'](_0x5ed830['id'][_0xabac('0x32')](),_0xa49722)[_0xabac('0x30')](_0xabac('0x31'),_0xabac('0x33'))['field'](_0xabac('0x31'),_0xabac('0x2f'))[_0xabac('0x34')](_0xabac('0x35'))[_0xabac('0x36')](_0xabac('0x37'))[_0xabac('0x36')]('ListId\x20=\x20?',LISTID[_0xabac('0x32')]())[_0xabac('0x36')](_0xabac('0x3b'),squel[_0xabac('0x3c')](hopperContacts))[_0xabac('0x36')](_0xabac('0x39'))[_0xabac('0x36')](_0xabac('0x3d'),squel['select']()['field'](_0xabac('0x3e'))[_0xabac('0x34')]('cm_hopper_final')[_0xabac('0x36')](_0xa49722+_0xabac('0x3f'),_0x5ed830['id'][_0xabac('0x32')]()))['where'](_0xabac('0x3d'),squel['select']()[_0xabac('0x30')](_0xabac('0x1a'))['from']('cm_hopper')[_0xabac('0x36')](_0xa49722+'\x20=\x20?',_0x5ed830['id']['toString']())))[_0xabac('0x32')]();return _0xc88ab8;};function _0x32a598(_0x779ec9,_0x19fdd4){var _0x5c1afd=squel[_0xabac('0x40')]()[_0xabac('0x2a')](_0xabac('0x2b'))[_0xabac('0x2c')]([_0xabac('0x1a'),_0xabac('0x2d'),_0xabac('0x2e'),'ListId',_0x19fdd4,_0xabac('0x33'),_0xabac('0x2f')],squel['select']()['field'](_0xabac('0x1a'),_0xabac('0x1a'))[_0xabac('0x30')](_0xabac('0x31'),'scheduledAt')[_0xabac('0x30')]('id',_0xabac('0x2e'))[_0xabac('0x30')](LISTID['toString'](),_0xabac('0x20'))['field'](_0x779ec9['id'][_0xabac('0x32')](),_0x19fdd4)[_0xabac('0x30')]('NOW()',_0xabac('0x33'))[_0xabac('0x30')](_0xabac('0x31'),'updatedAt')['from'](_0xabac('0x35'))[_0xabac('0x36')](_0xabac('0x37'))[_0xabac('0x36')](_0xabac('0x38'),LISTID['toString']())[_0xabac('0x36')]('id\x20IN\x20?',squel[_0xabac('0x3c')](hopperContacts))[_0xabac('0x36')](_0xabac('0x39')))[_0xabac('0x32')]();return _0x5c1afd;}function _0x1030cb(_0x28fa6e,_0xa63259){var _0x3a6ef7=squel[_0xabac('0x40')]()[_0xabac('0x2a')](_0xabac('0x41'))[_0xabac('0x2c')]([_0xabac('0x1a'),'ContactId',_0xabac('0x20'),_0xa63259,_0xabac('0x33'),'updatedAt'],squel[_0xabac('0x3a')]()[_0xabac('0x30')](_0xabac('0x1a'),_0xabac('0x1a'))[_0xabac('0x30')]('id',_0xabac('0x2e'))[_0xabac('0x30')](LISTID['toString'](),'ListId')[_0xabac('0x30')](_0x28fa6e['id'][_0xabac('0x32')](),_0xa63259)[_0xabac('0x30')](_0xabac('0x31'),_0xabac('0x33'))[_0xabac('0x30')](_0xabac('0x31'),_0xabac('0x2f'))[_0xabac('0x34')](_0xabac('0x35'))[_0xabac('0x36')]('deletedAt\x20IS\x20NULL')[_0xabac('0x36')](_0xabac('0x38'),LISTID[_0xabac('0x32')]())[_0xabac('0x36')](_0xabac('0x3b'),squel[_0xabac('0x3c')](hopperContacts))[_0xabac('0x36')]('phone\x20IS\x20NOT\x20NULL'))[_0xabac('0x32')]();return _0x3a6ef7;}return db[_0xabac('0x42')]['findAll']({'where':{'type':_0xabac('0x43')},'attributes':['id','dialCheckDuplicateType'],'include':[{'model':db[_0xabac('0x44')],'as':'Lists','where':{'id':LISTID}}]})[_0xabac('0x24')](function(_0x235c78){var _0x2e532a=[];if(_0x235c78){var _0xf7d810;for(var _0x5875ac=0x0,_0x277459;_0x5875ac<_0x235c78[_0xabac('0x14')];_0x5875ac+=0x1){_0x277459=_0x235c78[_0x5875ac]['get']({'plain':!![]});switch(_0x277459[_0xabac('0x45')]){case _0xabac('0x46'):_0x2e532a[_0xabac('0x25')](db['sequelize'][_0xabac('0x47')](_0x20c657(_0x277459,_0xabac('0x48')))[_0xabac('0x24')](function(){})[_0xabac('0x49')](_0x224d09()));break;case _0xabac('0x4a'):_0x2e532a[_0xabac('0x25')](db[_0xabac('0x4b')]['query'](_0xe7c73e(_0x277459,_0xabac('0x48')))[_0xabac('0x24')](function(){})['catch'](_0x224d09()));break;default:_0x2e532a[_0xabac('0x25')](db[_0xabac('0x4b')][_0xabac('0x47')](_0x32a598(_0x277459,_0xabac('0x48')))[_0xabac('0x24')](function(){})[_0xabac('0x49')](_0x224d09()));}}}return _0x2e532a;})[_0xabac('0x4c')]()['then'](function(){return db[_0xabac('0x42')][_0xabac('0x4d')]({'where':{'type':_0xabac('0x43')},'attributes':['id'],'include':[{'model':db['CmList'],'as':_0xabac('0x4e'),'where':{'id':LISTID}}]})[_0xabac('0x24')](function(_0x14a12b){var _0x309b4c=[];if(_0x14a12b){var _0x121b3e;for(var _0x1fe8f2=0x0,_0x10f91a;_0x1fe8f2<_0x14a12b[_0xabac('0x14')];_0x1fe8f2+=0x1){_0x10f91a=_0x14a12b[_0x1fe8f2]['get']({'plain':!![]});_0x309b4c['push'](db[_0xabac('0x4b')][_0xabac('0x47')](_0x1030cb(_0x10f91a,_0xabac('0x48')))[_0xabac('0x24')](function(){})['catch'](_0x224d09()));}}return _0x309b4c;})[_0xabac('0x4c')]();})['then'](function(){return db['Campaign']['findAll']({'attributes':['id','dialCheckDuplicateType'],'include':[{'model':db[_0xabac('0x44')],'as':_0xabac('0x4f'),'where':{'id':LISTID}}]})[_0xabac('0x24')](function(_0x283790){var _0x371d79=[];if(_0x283790){for(var _0x431799=0x0,_0x5ea8ae;_0x431799<_0x283790['length'];_0x431799+=0x1){_0x5ea8ae=_0x283790[_0x431799][_0xabac('0x50')]({'plain':!![]});switch(_0x5ea8ae[_0xabac('0x45')]){case _0xabac('0x46'):_0x371d79[_0xabac('0x25')](db['sequelize'][_0xabac('0x47')](_0x20c657(_0x5ea8ae,_0xabac('0x51')))[_0xabac('0x24')](function(){})[_0xabac('0x49')](_0x224d09()));break;case _0xabac('0x4a'):_0x371d79[_0xabac('0x25')](db[_0xabac('0x4b')]['query'](_0xe7c73e(_0x5ea8ae,'CampaignId'))['then'](function(){})['catch'](_0x224d09()));break;default:_0x371d79[_0xabac('0x25')](db['sequelize']['query'](_0x32a598(_0x5ea8ae,_0xabac('0x51')))[_0xabac('0x24')](function(){})[_0xabac('0x49')](_0x224d09()));}}}return _0x371d79;})[_0xabac('0x4c')]();})[_0xabac('0x24')](function(){return db['Campaign'][_0xabac('0x4d')]({'attributes':['id'],'include':[{'model':db[_0xabac('0x44')],'as':_0xabac('0x4e'),'where':{'id':LISTID}}]})['then'](function(_0x1996ab){var _0x59d311=[];if(_0x1996ab){for(var _0x34527b=0x0,_0x99ee6a;_0x34527b<_0x1996ab[_0xabac('0x14')];_0x34527b+=0x1){_0x99ee6a=_0x1996ab[_0x34527b]['get']({'plain':!![]});_0x59d311[_0xabac('0x25')](db[_0xabac('0x4b')]['query'](_0x1030cb(_0x99ee6a,_0xabac('0x51')))['then'](function(){})[_0xabac('0x49')](_0x224d09()));}}return _0x59d311;})[_0xabac('0x4c')]();})['catch'](function(_0xe1f569){logger[_0xabac('0x10')](_0xabac('0x52'),_0xabac('0x53'),_0xe1f569[_0xabac('0x54')]);});}var processPromises=function(_0x19413b){return BPromise['all'](promises)[_0xabac('0x24')](function(_0x35cf97){})['catch'](function(_0x1e5a42){logger[_0xabac('0x10')]('Error\x20processing\x20rows\x20block:',JSON[_0xabac('0x27')](_0x1e5a42));})[_0xabac('0x55')](function(){socket['emit'](_0xabac('0x56')+SOCKET_TIMESTAMP,{'success':success,'errors':errors,'duplicates':duplicates,'rows':rows});promises=[];success=0x0;errors=0x0;duplicates=0x0;rows=[];if(_0x19413b){return _0x19413b[_0xabac('0x57')]();}});};var endCsv=function(){return BPromise[_0xabac('0x58')]()[_0xabac('0x24')](function(){if(hopperContacts){return checkHopper();}})[_0xabac('0x24')](function(){socket[_0xabac('0x59')](_0xabac('0x56')+SOCKET_TIMESTAMP,{'finished':!![],'success':success,'errors':errors,'duplicates':duplicates,'rows':rows});try{fs[_0xabac('0x5a')](FILEPATH);}catch(_0x5ec270){logger[_0xabac('0x10')](_0xabac('0x5b'),JSON[_0xabac('0x27')](_0x5ec270));}finally{process['exit'](0x0);}});};process['on'](_0xabac('0x5c'),function(){logger[_0xabac('0x5d')](_0xabac('0x5e'));endCsv();});function main(){return BPromise[_0xabac('0x58')]()[_0xabac('0x24')](function(){if(DUPLICATES){DUPLICATES=DUPLICATES[_0xabac('0xd')](',');return db[_0xabac('0x5f')]['findAll']({'where':{'ListId':LISTID},'attributes':DUPLICATES,'raw':!![]});}})['then'](function(_0x98e4ac){var _0x2cbd46=fs['createReadStream'](FILEPATH,{'highWaterMark':0xf*0x400*0x400});Papa['parse'](_0x2cbd46,{'header':!![],'skipEmptyLines':!![],'step':function(_0xb02eca,_0x432956){total+=0x1;var _0x16fa57=total;promises[_0xabac('0x25')](checkRow(_0xb02eca,_0x98e4ac,_0x16fa57)[_0xabac('0x24')](function(){success+=0x1;})[_0xabac('0x49')](function(_0x31b29a){if(_0x31b29a['error']){errors+=0x1;delete _0x31b29a['error'];}else if(_0x31b29a['duplicate']){duplicates+=0x1;delete _0x31b29a[_0xabac('0x22')];}rows[_0xabac('0x25')](_0x31b29a);}));if(total%0xc8===0x0){_0x432956[_0xabac('0x60')]();return processPromises(_0x432956);}},'complete':function(){return processPromises()[_0xabac('0x24')](function(){logger[_0xabac('0x5d')](_0xabac('0x61'));endCsv();});},'error':function(_0x59d23f,_0x27ab1b){logger[_0xabac('0x5d')](_0xabac('0x62'),JSON[_0xabac('0x27')](_0x59d23f));endCsv();}});})[_0xabac('0x49')](function(_0x8301b3){logger[_0xabac('0x10')]('Error\x20executing\x20contact\x20csv\x20import:',JSON[_0xabac('0x27')](_0x8301b3));});}main();
\ No newline at end of file