Built motion from commit 5e31ea4.|0.0.32
[motion.git] / server / api / user / user.controller.js
index 592c3a1..3e2e864 100644 (file)
@@ -1 +1,447 @@
-var _0x1088=["\x75\x73\x65\x20\x73\x74\x72\x69\x63\x74","\x55\x73\x65\x72","\x2E\x2E\x2F\x2E\x2E\x2F\x6D\x6F\x64\x65\x6C\x73","\x4D\x6F\x64\x75\x6C\x65","\x2E\x2E\x2F\x2E\x2E\x2F\x63\x6F\x6E\x66\x69\x67\x2F\x65\x6E\x76\x69\x72\x6F\x6E\x6D\x65\x6E\x74","\x70\x61\x73\x73\x70\x6F\x72\x74","\x6D\x6F\x6D\x65\x6E\x74","\x6A\x73\x6F\x6E\x77\x65\x62\x74\x6F\x6B\x65\x6E","\x75\x70\x6C\x6F\x61\x64\x2D\x66\x69\x6C\x65","\x70\x61\x74\x68","\x66\x73","\x6C\x6F\x64\x61\x73\x68","\x75\x74\x69\x6C","\x73\x69\x6D\x70\x6C\x65\x2D\x72\x61\x6E\x64\x6F\x6D","\x69\x6E\x64\x65\x78","\x66\x75\x6C\x6C\x6E\x61\x6D\x65","\x6E\x61\x6D\x65","\x65\x6D\x61\x69\x6C","\x72\x6F\x6C\x65","\x70\x65\x72\x5F\x70\x61\x67\x65","\x71\x75\x65\x72\x79","\x70\x61\x67\x65","\x61\x64\x6D\x69\x6E","\x75\x73\x65\x72","\x6F\x72\x64\x65\x72","\x25\x73\x20\x25\x73","\x73\x6F\x72\x74\x5F\x62\x79","\x73\x6F\x72\x74\x5F\x6F\x72\x64\x65\x72","\x41\x53\x43","\x66\x6F\x72\x6D\x61\x74","\x24\x6F\x72","\x77\x68\x65\x72\x65","\x25","\x70\x75\x73\x68","\x66\x6F\x72\x45\x61\x63\x68","\x24","\x24\x6C\x69\x6B\x65","\x66\x6F\x72\x49\x6E","\x53\x6F\x6D\x65\x74\x68\x69\x6E\x67\x20\x62\x6C\x65\x77\x20\x75\x70\x21","\x73\x65\x6E\x64","\x73\x74\x61\x74\x75\x73","\x63\x61\x74\x63\x68","\x63\x6F\x75\x6E\x74","\x63\x65\x69\x6C","\x6F\x66\x66\x73\x65\x74","\x25\x73\x3A\x2F\x2F\x25\x73\x25\x73\x3F\x70\x61\x67\x65\x3D\x25\x64","\x70\x72\x6F\x74\x6F\x63\x6F\x6C","\x68\x6F\x73\x74","\x68\x65\x61\x64\x65\x72\x73","\x62\x61\x73\x65\x55\x72\x6C","\x72\x6F\x77\x73","\x74\x68\x65\x6E","\x66\x69\x6E\x64\x41\x6E\x64\x43\x6F\x75\x6E\x74\x41\x6C\x6C","\x67\x65\x74\x55\x73\x65\x72\x73","\x61\x67\x65\x6E\x74","\x66\x69\x6E\x64\x41\x6C\x6C","\x63\x72\x65\x61\x74\x65","\x62\x6F\x64\x79","\x65\x61\x63\x68","\x73\x6F\x72\x74","\x6B\x65\x79\x73","\x62\x75\x69\x6C\x64","\x70\x72\x6F\x76\x69\x64\x65\x72","\x6C\x6F\x63\x61\x6C","\x69\x64","\x73\x65\x63\x72\x65\x74","\x73\x65\x73\x73\x69\x6F\x6E","\x35\x68","\x73\x69\x67\x6E","\x73\x61\x76\x65","\x73\x68\x6F\x77","\x73\x65\x6E\x64\x53\x74\x61\x74\x75\x73","\x70\x61\x72\x61\x6D\x73","\x66\x69\x6E\x64\x42\x79\x49\x64","\x64\x65\x73\x74\x72\x6F\x79","\x6C\x6F\x67","\x63\x68\x61\x6E\x67\x65\x50\x61\x73\x73\x77\x6F\x72\x64","\x6F\x6C\x64\x50\x61\x73\x73\x77\x6F\x72\x64","\x6E\x65\x77\x50\x61\x73\x73\x77\x6F\x72\x64","\x61\x75\x74\x68\x65\x6E\x74\x69\x63\x61\x74\x65","\x70\x61\x73\x73\x77\x6F\x72\x64","\x72\x65\x73\x65\x74\x50\x61\x73\x73\x77\x6F\x72\x64","\x63\x68\x61\x6E\x67\x65\x41\x76\x61\x74\x61\x72","\x72\x6F\x6F\x74","\x73\x65\x72\x76\x65\x72","\x66\x69\x6C\x65\x73","\x69\x6D\x61\x67\x65\x73","\x6A\x6F\x69\x6E","\x66\x69\x6C\x65\x6E\x61\x6D\x65","\x65\x78\x74\x6E\x61\x6D\x65","\x4D\x61\x78\x20\x6E\x75\x6D\x62\x65\x72\x20\x6F\x66\x20\x66\x69\x6C\x65\x73\x20\x75\x70\x6C\x6F\x61\x64\x20\x65\x78\x63\x65\x65\x64\x65\x64","\x4F\x6E\x6C\x79\x20\x6A\x70\x65\x67\x20\x61\x6E\x64\x20\x70\x6E\x67\x20\x66\x6F\x72\x6D\x61\x74\x20\x61\x63\x63\x65\x70\x74\x65\x64","\x49\x6E\x76\x61\x6C\x69\x64\x20\x72\x65\x71\x75\x65\x73\x74","\x65\x6E\x64","\x66\x69\x6C\x65","\x75\x70\x64\x61\x74\x65\x41\x74\x74\x72\x69\x62\x75\x74\x65\x73","\x6F\x6E","\x65\x72\x72\x6F\x72","\x2A\x2A\x2A\x2A\x2A\x2A\x2A\x2A\x2A\x2A\x20\x55\x70\x6C\x6F\x61\x64\x20\x65\x72\x72\x6F\x72\x20\x3A","\x70\x61\x72\x73\x65","\x6D\x65","\x75\x73\x65\x72\x70\x69\x63","\x66\x69\x6E\x64\x4F\x6E\x65","\x75\x70\x64\x61\x74\x65","\x67\x65\x74\x41\x76\x61\x74\x61\x72","\x75\x73\x65\x72\x70\x69\x63\x2E\x70\x6E\x67","\x73\x65\x6E\x64\x46\x69\x6C\x65","\x65\x78\x69\x73\x74\x73","\x67\x65\x74\x41\x76\x61\x74\x61\x72\x42\x79\x49\x64","\x76\x69\x73\x69\x74\x6F\x72","\x63\x75\x73\x74\x6F\x6D\x65\x72\x2E\x70\x6E\x67","\x62\x75\x6C\x6B\x44\x65\x73\x74\x72\x6F\x79","\x75\x73\x65\x72\x56\x61\x6C\x69\x64\x61\x74\x69\x6F\x6E","\x66\x69\x65\x6C\x64","\x76\x61\x6C\x75\x65","\x61\x75\x74\x68\x43\x61\x6C\x6C\x62\x61\x63\x6B","\x2F","\x72\x65\x64\x69\x72\x65\x63\x74"];_0x1088[0];var User=require(_0x1088[2])[_0x1088[1]];var Module=require(_0x1088[2])[_0x1088[3]];var config=require(_0x1088[4]);var passport=require(_0x1088[5]);var moment=require(_0x1088[6]);var jwt=require(_0x1088[7]);var uploadFile=require(_0x1088[8]);var path=require(_0x1088[9]);var fs=require(_0x1088[10]);var _=require(_0x1088[11]);var util=require(_0x1088[12]);var sr=require(_0x1088[13]);exports[_0x1088[14]]=function(_0xba66xd,_0xba66xe,_0xba66xf){var _0xba66x10=[_0x1088[15],_0x1088[16],_0x1088[17],_0x1088[18]];var _0xba66x11=_0xba66xd[_0x1088[20]][_0x1088[19]]?parseInt(_0xba66xd[_0x1088[20]][_0x1088[19]],10):100;var _0xba66x12=_0xba66xd[_0x1088[20]][_0x1088[21]]?parseInt(_0xba66xd[_0x1088[20]][_0x1088[21]],10):0;var _0xba66x13={where:{role:[_0x1088[22],_0x1088[23]]},limit:_0xba66x11,offset:_0xba66x12*_0xba66x11};_[_0x1088[37]](_0xba66xd[_0x1088[20]],function(_0xba66x14,_0xba66x15){switch(_0xba66x15){case _0x1088[19]:;case _0x1088[21]:break ;;case _0x1088[26]:_0xba66x13[_0x1088[24]]=util[_0x1088[29]](_0x1088[25],_0xba66xd[_0x1088[20]][_0x1088[26]],_0xba66xd[_0x1088[20]][_0x1088[27]]||_0x1088[28])||null;break ;;case _0x1088[27]:break ;;case _0x1088[35]:_0xba66x13[_0x1088[31]][_0x1088[30]]=[];_0xba66x10[_0x1088[34]](function(_0xba66x16){var _0xba66x17={};_0xba66x17[_0xba66x16]={$like:_0x1088[32]+_0xba66x14+_0x1088[32]};_0xba66x13[_0x1088[31]][_0x1088[30]][_0x1088[33]](_0xba66x17);});break ;;default:_0xba66x13[_0x1088[31]][_0xba66x15]={$like:{}};_0xba66x13[_0x1088[31]][_0xba66x15][_0x1088[36]]=_0x1088[32]+_0xba66x14+_0x1088[32];;}});User[_0x1088[52]](_0xba66x13)[_0x1088[51]](function(_0xba66x19){var _0xba66x1a=Math[_0x1088[43]](_0xba66x19[_0x1088[42]]/_0xba66x11);var _0xba66x1b=_0xba66x1a>(_0xba66x13[_0x1088[44]]+1)?util[_0x1088[29]](_0x1088[45],_0xba66xd[_0x1088[46]],_0xba66xd[_0x1088[48]][_0x1088[47]],_0xba66xd[_0x1088[49]],_0xba66x12+1):null;var _0xba66x1c=_0xba66x12>0?util[_0x1088[29]](_0x1088[45],_0xba66xd[_0x1088[46]],_0xba66xd[_0x1088[48]][_0x1088[47]],_0xba66xd[_0x1088[49]],_0xba66x12-1):null;return _0xba66xe[_0x1088[40]](200)[_0x1088[39]]({count:_0xba66x19[_0x1088[42]],rows:_0xba66x19[_0x1088[50]],next_page:_0xba66x1b,previous_page:_0xba66x1c,total_pages:_0xba66x1a});})[_0x1088[41]](function(_0xba66x18){return _0xba66xe[_0x1088[40]](500)[_0x1088[39]]({error:_0x1088[38]})});};exports[_0x1088[53]]=function(_0xba66xd,_0xba66xe,_0xba66xf){User[_0x1088[55]]({where:{role:{$in:[_0x1088[22],_0x1088[23],_0x1088[54]]}}})[_0x1088[51]](function(_0xba66x1d){return _0xba66xe[_0x1088[40]](200)[_0x1088[39]](_0xba66x1d)})[_0x1088[41]](function(_0xba66x18){return handleError(_0xba66xe,_0xba66x18)})};exports[_0x1088[56]]=function(_0xba66xd,_0xba66xe,_0xba66xf){var _0xba66x1e=_0xba66xd[_0x1088[57]];_(_0xba66x1e)[_0x1088[60]]()[_0x1088[59]]()[_0x1088[58]](function(_0xba66x15){var _0xba66x14=_0xba66x1e[_0xba66x15]});var _0xba66x1f=User[_0x1088[61]](_0xba66xd[_0x1088[57]]);_0xba66x1f[_0x1088[62]]=_0x1088[63];_0xba66x1f[_0x1088[69]]()[_0x1088[51]](function(_0xba66x20){var _0xba66x21=jwt[_0x1088[68]]({id:_0xba66x20[_0x1088[64]]},config[_0x1088[66]][_0x1088[65]],{expiresIn:_0x1088[67]});return _0xba66xe[_0x1088[40]](201)[_0x1088[39]]({token:_0xba66x21});})[_0x1088[41]](function(_0xba66x18){return handleError(_0xba66xe,_0xba66x18)});};exports[_0x1088[70]]=function(_0xba66xd,_0xba66xe,_0xba66xf){User[_0x1088[73]](_0xba66xd[_0x1088[72]][_0x1088[64]])[_0x1088[51]](function(_0xba66x20){if(_0xba66x20){return _0xba66xe[_0x1088[40]](200)[_0x1088[39]](_0xba66x20)}else {return _0xba66xe[_0x1088[71]](404)}})[_0x1088[41]](function(_0xba66x18){return handleError(_0xba66xe,_0xba66x18)})};exports[_0x1088[74]]=function(_0xba66xd,_0xba66xe,_0xba66xf){var _0xba66x22=_0xba66xd[_0x1088[72]][_0x1088[64]];User[_0x1088[73]](_0xba66x22)[_0x1088[51]](function(_0xba66x20){if(_0xba66x20){_0xba66x20[_0x1088[74]]()[_0x1088[51]](function(_0xba66x20){console[_0x1088[75]](_0xba66x20);return _0xba66xe[_0x1088[40]](200)[_0x1088[39]](_0xba66x20);})[_0x1088[41]](function(_0xba66x18){return handleError(_0xba66xe,_0xba66x18)})}else {return _0xba66xe[_0x1088[71]](404)}})[_0x1088[41]](function(_0xba66x18){return handleError(_0xba66xe,_0xba66x18)});};exports[_0x1088[76]]=function(_0xba66xd,_0xba66xe,_0xba66xf){var _0xba66x22=_0xba66xd[_0x1088[23]][_0x1088[64]];var _0xba66x23=String(_0xba66xd[_0x1088[57]][_0x1088[77]]);var _0xba66x24=String(_0xba66xd[_0x1088[57]][_0x1088[78]]);User[_0x1088[73]](_0xba66x22)[_0x1088[51]](function(_0xba66x20){if(_0xba66x20[_0x1088[79]](_0xba66x23)){_0xba66x20[_0x1088[80]]=_0xba66x24;_0xba66x20[_0x1088[69]]()[_0x1088[51]](function(){return _0xba66xe[_0x1088[40]](200)[_0x1088[39]](_0xba66x20)})[_0x1088[41]](function(_0xba66x18){return handleError(_0xba66xe,_0xba66x18)});}else {return _0xba66xe[_0x1088[71]](403)}});};exports[_0x1088[81]]=function(_0xba66xd,_0xba66xe,_0xba66xf){var _0xba66x24=String(_0xba66xd[_0x1088[57]][_0x1088[78]]);User[_0x1088[73]](_0xba66xd[_0x1088[72]][_0x1088[64]])[_0x1088[51]](function(_0xba66x20){_0xba66x20[_0x1088[80]]=_0xba66x24;_0xba66x20[_0x1088[69]]()[_0x1088[51]](function(){return _0xba66xe[_0x1088[40]](200)[_0x1088[39]](_0xba66x20)})[_0x1088[41]](function(_0xba66x18){return handleError(_0xba66xe,_0xba66x18)});});};exports[_0x1088[82]]=function(_0xba66xd,_0xba66xe,_0xba66xf){var _0xba66x25= new uploadFile({dest:path[_0x1088[87]](config[_0x1088[83]],_0x1088[84],_0x1088[85],_0x1088[86]),maxNumberOfFiles:1,minNumberOfFiles:0,acceptFileTypes:/(\.|\/)(jpeg|png)$/i,rename:function(_0xba66x26,_0xba66x27){return sr()+path[_0x1088[89]](_0xba66x27[_0x1088[88]])},messages:{maxNumberOfFiles:_0x1088[90],acceptFileTypes:_0x1088[91],invalidRequest:_0x1088[92]}});_0xba66x25[_0x1088[96]](_0x1088[93],function(_0xba66x28,_0xba66x29){if(!_0xba66x29[_0x1088[94]][_0x1088[88]]){return _0xba66xe[_0x1088[40]](500)[_0x1088[39]](_0xba66x25)}else {User[_0x1088[73]](_0xba66xd[_0x1088[72]][_0x1088[64]])[_0x1088[51]](function(_0xba66x20){if(_0xba66x20){_0xba66x20[_0x1088[95]]({userpic:_0xba66x29[_0x1088[94]][_0x1088[88]]})[_0x1088[51]](function(){return _0xba66xe[_0x1088[40]](200)[_0x1088[39]](_0xba66x20)})[_0x1088[41]](function(_0xba66x18){return handleError(_0xba66xe,_0xba66x18)})}else {return _0xba66xe[_0x1088[71]](404)}})[_0x1088[41]](function(_0xba66x18){return handleError(_0xba66xe,_0xba66x18)})}});_0xba66x25[_0x1088[96]](_0x1088[97],function(_0xba66x18){console[_0x1088[75]](_0x1088[98],_0xba66x18);return handleError(_0xba66xe,_0xba66x18);});_0xba66x25[_0x1088[99]](_0xba66xd);};exports[_0x1088[100]]=function(_0xba66xd,_0xba66xe,_0xba66xf){var _0xba66x22=_0xba66xd[_0x1088[23]][_0x1088[64]];User[_0x1088[102]]({where:{id:_0xba66x22},attributes:[_0x1088[64],_0x1088[15],_0x1088[16],_0x1088[17],_0x1088[18],_0x1088[101]],include:[Module]})[_0x1088[51]](function(_0xba66x20){if(!_0xba66x20){return _0xba66xe[_0x1088[71]](401)};return _0xba66xe[_0x1088[40]](200)[_0x1088[39]](_0xba66x20);})[_0x1088[41]](function(_0xba66x18){return handleError(_0xba66xe,_0xba66x18)});};exports[_0x1088[103]]=function(_0xba66xd,_0xba66xe,_0xba66xf){var _0xba66x22=_0xba66xd[_0x1088[23]][_0x1088[64]];User[_0x1088[73]](_0xba66xd[_0x1088[72]][_0x1088[64]])[_0x1088[51]](function(_0xba66x20){if(_0xba66x20){_0xba66x20[_0x1088[95]](_0xba66xd[_0x1088[57]])[_0x1088[51]](function(_0xba66x20){return _0xba66xe[_0x1088[40]](200)[_0x1088[39]](_0xba66x20)})[_0x1088[41]](function(_0xba66x18){return handleError(_0xba66xe,_0xba66x18)})}else {return _0xba66xe[_0x1088[71]](500)}})[_0x1088[41]](function(_0xba66x18){return handleError(_0xba66xe,_0xba66x18)});};exports[_0x1088[104]]=function(_0xba66xd,_0xba66xe,_0xba66xf){var _0xba66x2a=path[_0x1088[87]](config[_0x1088[83]],_0x1088[84],_0x1088[85],_0x1088[86],_0xba66xd[_0x1088[72]][_0x1088[88]]);fs[_0x1088[107]](_0xba66x2a,function(_0xba66x2b){if(!_0xba66x2b){_0xba66x2a=path[_0x1088[87]](config[_0x1088[83]],_0x1088[84],_0x1088[85],_0x1088[86],_0x1088[105])};return _0xba66xe[_0x1088[106]](_0xba66x2a);});};exports[_0x1088[108]]=function(_0xba66xd,_0xba66xe,_0xba66xf){if(_0xba66xd[_0x1088[72]][_0x1088[64]]===_0x1088[109]){var _0xba66x2a=path[_0x1088[87]](config[_0x1088[83]],_0x1088[84],_0x1088[85],_0x1088[86],_0x1088[110]);fs[_0x1088[107]](_0xba66x2a,function(_0xba66x2b){return _0xba66xe[_0x1088[106]](_0xba66x2a)});}else {User[_0x1088[73]](_0xba66xd[_0x1088[72]][_0x1088[64]])[_0x1088[51]](function(_0xba66x20){if(_0xba66x20){var _0xba66x2a=path[_0x1088[87]](config[_0x1088[83]],_0x1088[84],_0x1088[85],_0x1088[86],_0xba66x20[_0x1088[101]]?_0xba66x20[_0x1088[101]]:_0x1088[105]);fs[_0x1088[107]](_0xba66x2a,function(_0xba66x2b){if(!_0xba66x2b){_0xba66x2a=path[_0x1088[87]](config[_0x1088[83]],_0x1088[84],_0x1088[85],_0x1088[86],_0x1088[105])};return _0xba66xe[_0x1088[106]](_0xba66x2a);});}else {return _0xba66xe[_0x1088[71]](500)}})[_0x1088[41]](function(_0xba66x18){return handleError(_0xba66xe,_0xba66x18)})}};exports[_0x1088[111]]=function(_0xba66xd,_0xba66xe){User[_0x1088[74]]({where:{id:_0xba66xd[_0x1088[20]][_0x1088[64]]},individualHooks:true})[_0x1088[51]](function(){return _0xba66xe[_0x1088[71]](204)})[_0x1088[41]](function(_0xba66x18){return handleError(_0xba66xe,_0xba66x18)})};exports[_0x1088[112]]=function(_0xba66xd,_0xba66xe){var _0xba66x2c={};_0xba66x2c[_0xba66xd[_0x1088[72]][_0x1088[113]]]=_0xba66xd[_0x1088[57]][_0x1088[114]];User[_0x1088[52]]({where:_0xba66x2c})[_0x1088[51]](function(_0xba66x19){if(_0xba66x19[_0x1088[42]]){return _0xba66xe[_0x1088[40]](200)[_0x1088[39]]({isValid:false,value:_0xba66xd[_0x1088[57]][_0x1088[114]]})};return _0xba66xe[_0x1088[40]](200)[_0x1088[39]]({isValid:true,value:_0xba66xd[_0x1088[57]][_0x1088[114]]});})[_0x1088[41]](function(_0xba66x18){return handleError(_0xba66xe,_0xba66x18)});};exports[_0x1088[115]]=function(_0xba66xd,_0xba66xe,_0xba66xf){_0xba66xe[_0x1088[117]](_0x1088[116])};function handleError(_0xba66xe,_0xba66x18){return _0xba66xe[_0x1088[40]](500)[_0x1088[39]](_0xba66x18)}
\ No newline at end of file
+'use strict';
+
+var User = require('../../models').User;
+var Module = require('../../models').Module;
+var config = require('../../config/environment');
+
+var passport = require('passport');
+var moment = require('moment');
+var jwt = require('jsonwebtoken');
+var uploadFile = require('upload-file');
+var path = require('path');
+var fs = require('fs');
+var _ = require('lodash');
+var util = require('util');
+var sr = require('simple-random');
+
+/**
+ * Get list of admin/user
+ */
+exports.index = function(req, res, next) {
+
+  var attributes = ['fullname', 'name', 'email', 'role'];
+  var per_page = req.query.per_page ? parseInt(req.query.per_page, 10) : 100;
+  var page = req.query.page ? parseInt(req.query.page, 10) : 0;
+
+  var query = {
+    where: {
+      role: ['admin', 'user']
+    },
+    limit: per_page,
+    offset: page * per_page
+  };
+
+  _.forIn(req.query, function(value, key) {
+    switch (key) {
+      case 'per_page':
+      case 'page':
+        break;
+      case 'sort_by':
+        query.order = util.format('%s %s', req.query.sort_by, req.query.sort_order || 'ASC') || null;
+        break;
+      case 'sort_order':
+        break;
+      case '$':
+        query.where.$or = [];
+        attributes.forEach(function(attribute) {
+          var tmp = {};
+          tmp[attribute] = {
+            $like: '%' + value + '%'
+          };
+
+          query.where.$or.push(tmp);
+        });
+        break;
+      default:
+        query.where[key] = {
+          $like: {}
+        };
+        query.where[key].$like = '%' + value + '%';
+    }
+  });
+
+  User
+    .findAndCountAll(query)
+    .then(function(result) {
+
+      var total_pages = Math.ceil(result.count / per_page);
+      var next_page = total_pages > (query.offset + 1) ? util.format('%s://%s%s?page=%d', req.protocol, req.headers.host, req.baseUrl, page + 1) : null;
+      var previous_page = page > 0 ? util.format('%s://%s%s?page=%d', req.protocol, req.headers.host, req.baseUrl, page - 1) : null;
+
+      return res.status(200).send({
+        count: result.count,
+        rows: result.rows,
+        next_page: next_page,
+        previous_page: previous_page,
+        total_pages: total_pages
+      });
+
+    })
+    .catch(function(err) {
+      return res.status(500).send({
+        error: 'Something blew up!'
+      });
+    });
+
+};
+
+/**
+ * Get list of admin/user/agent
+ */
+exports.getUsers = function(req, res, next) {
+  User
+    .findAll({
+      where: {
+        role: {
+          $in: ['admin', 'user', 'agent']
+        }
+      }
+    })
+    .then(function(users) {
+      return res.status(200).send(users);
+    })
+    .catch(function(err) {
+      return handleError(res, err);
+    });
+};
+
+/**
+ * Creates a new user
+ */
+exports.create = function(req, res, next) {
+
+  var body = req.body;
+  _(body).keys().sort().each(function(key) {
+    var value = body[key];
+  });
+
+  var newUser = User.build(req.body);
+  newUser.provider = 'local';
+  newUser
+    .save()
+    .then(function(user) {
+      var token = jwt.sign({
+        id: user.id
+      }, config.session.secret, {
+        expiresIn: "5h"
+      });
+      return res.status(201).send({
+        token: token
+      });
+    })
+    .catch(function(err) {
+      return handleError(res, err);
+    });
+};
+
+/**
+ * Get a single user
+ */
+exports.show = function(req, res, next) {
+
+  User
+    .findById(req.params.id)
+    .then(function(user) {
+      if (user) {
+        return res.status(200).send(user);
+      } else {
+        return res.sendStatus(404);
+      }
+    })
+    .catch(function(err) {
+      return handleError(res, err);
+    });
+};
+
+/**
+ * Deletes a user
+ */
+exports.destroy = function(req, res, next) {
+  var userId = req.params.id;
+  // console.log(req.params);
+  // console.log(req.body);
+
+  User
+    .findById(userId)
+    .then(function(user) {
+      if (user) {
+        user
+          .destroy()
+          .then(function(user) {
+            console.log(user);
+            return res.status(200).send(user);
+          })
+          .catch(function(err) {
+            return handleError(res, err);
+          });
+      } else {
+        return res.sendStatus(404);
+      }
+    })
+    .catch(function(err) {
+      return handleError(res, err);
+    });
+};
+
+/**
+ * Change a user password
+ */
+exports.changePassword = function(req, res, next) {
+  var userId = req.user.id;
+  var oldPass = String(req.body.oldPassword);
+  var newPass = String(req.body.newPassword);
+  User
+    .findById(userId)
+    .then(function(user) {
+      if (user.authenticate(oldPass)) {
+        user.password = newPass;
+        user.save()
+          .then(function() {
+            return res.status(200).send(user);
+          })
+          .catch(function(err) {
+            return handleError(res, err);
+          });
+      } else {
+        return res.sendStatus(403);
+      }
+    });
+};
+
+/**
+ * Change a user password by admin
+ */
+exports.resetPassword = function(req, res, next) {
+  var newPass = String(req.body.newPassword);
+  User
+    .findById(req.params.id)
+    .then(function(user) {
+      user.password = newPass;
+      user.save()
+        .then(function() {
+          return res.status(200).send(user);
+        })
+        .catch(function(err) {
+          return handleError(res, err);
+        });
+    });
+};
+
+/**
+ * Change the avatar of the user
+ */
+exports.changeAvatar = function(req, res, next) {
+
+  var upload = new uploadFile({
+    dest: path.join(config.root, 'server', 'files', 'images'),
+    maxNumberOfFiles: 1,
+    minNumberOfFiles: 0,
+    acceptFileTypes: /(\.|\/)(jpeg|png)$/i,
+    rename: function(name, file) {
+      return sr() + path.extname(file.filename);
+      // return 'avatar' + req.params.id + path.extname(file.filename);
+    },
+    messages: {
+      maxNumberOfFiles: "Max number of files upload exceeded",
+      acceptFileTypes: "Only jpeg and png format accepted",
+      // maxFileSize: "The maximum file size is 5 Mb",
+      invalidRequest: "Invalid request"
+    }
+  });
+
+  upload.on('end', function(fields, files) {
+    if (!files.file.filename) {
+      return res.status(500).send(upload);
+    } else {
+      User
+        .findById(req.params.id)
+        .then(function(user) {
+          if (user) {
+            user.updateAttributes({
+                userpic: files.file.filename
+              })
+              .then(function() {
+                return res.status(200).send(user);
+              })
+              .catch(function(err) {
+                return handleError(res, err);
+              });
+          } else {
+            return res.sendStatus(404);
+          }
+        })
+        .catch(function(err) {
+          return handleError(res, err);
+        });
+    }
+  });
+
+  upload.on('error', function(err) {
+    console.log('********** Upload error :', err)
+    return handleError(res, err);
+  });
+
+  upload.parse(req);
+};
+
+
+/**
+ * Get my info
+ */
+exports.me = function(req, res, next) {
+  var userId = req.user.id;
+
+  User
+    .findOne({
+      where: {
+        id: userId
+      },
+      attributes: ['id', 'fullname', 'name', 'email', 'role', 'userpic'],
+      include: [Module]
+    })
+    .then(function(user) {
+      if (!user) {
+        return res.sendStatus(401);
+      }
+      return res.status(200).send(user);
+    })
+    .catch(function(err) {
+      return handleError(res, err);
+    });
+};
+
+/**
+ * Update my user
+ */
+exports.update = function(req, res, next) {
+  var userId = req.user.id;
+
+  User
+    .findById(req.params.id)
+    .then(function(user) {
+      if (user) {
+        user
+          .updateAttributes(req.body)
+          .then(function(user) {
+            return res.status(200).send(user);
+          })
+          .catch(function(err) {
+            return handleError(res, err);
+          });
+      } else {
+        return res.sendStatus(500);
+      }
+    })
+    .catch(function(err) {
+      return handleError(res, err);
+    });
+};
+
+/**
+ * Get my avatar
+ */
+exports.getAvatar = function(req, res, next) {
+  // var userId = req.params.id;
+
+  var imgPath = path.join(config.root, 'server', 'files', 'images', req.params.filename);
+
+  fs.exists(imgPath, function(exists) {
+    if (!exists) {
+      imgPath = path.join(config.root, 'server', 'files', 'images', 'userpic.png');
+    }
+
+    return res.sendFile(imgPath);
+  });
+};
+
+/**
+ * Get my avatar by id
+ */
+exports.getAvatarById = function(req, res, next) {
+
+  // console.log('getAvatarById');
+  // console.log(req.params);
+
+  if (req.params.id === 'visitor') {
+    var imgPath = path.join(config.root, 'server', 'files', 'images', 'customer.png');
+
+    fs.exists(imgPath, function(exists) {
+      return res.sendFile(imgPath);
+    });
+
+  } else {
+    User
+      .findById(req.params.id)
+      .then(function(user) {
+        if (user) {
+          var imgPath = path.join(config.root, 'server', 'files', 'images', user.userpic ? user.userpic : 'userpic.png');
+
+          fs.exists(imgPath, function(exists) {
+            if (!exists) {
+              imgPath = path.join(config.root, 'server', 'files', 'images', 'userpic.png');
+            }
+
+            return res.sendFile(imgPath);
+          });
+        } else {
+          return res.sendStatus(500);
+        }
+      })
+      .catch(function(err) {
+        return handleError(res, err);
+      });
+  }
+};
+
+// Deletes a agent from the DB.
+exports.bulkDestroy = function(req, res) {
+  User
+    .destroy({
+      where: {
+        id: req.query.id
+      },
+      individualHooks: true
+    })
+    .then(function() {
+      return res.sendStatus(204);
+    })
+    .catch(function(err) {
+      return handleError(res, err);
+    });
+};
+
+exports.userValidation = function(req, res) {
+  var where = {};
+  where[req.params.field] = req.body.value;
+  User
+    .findAndCountAll({
+      where: where
+    })
+    .then(function(result) {
+      if (result.count) {
+        return res.status(200).send({
+          isValid: false,
+          value: req.body.value
+        });
+      }
+      return res.status(200).send({
+        isValid: true,
+        value: req.body.value
+      });
+    })
+    .catch(function(err) {
+      return handleError(res, err);
+    });
+
+};
+
+/**
+ * Authentication callback
+ */
+exports.authCallback = function(req, res, next) {
+  res.redirect('/');
+};
+
+function handleError(res, err) {
+  return res.status(500).send(err);
+}