Built motion from commit a5685af.|0.0.128
[motion.git] / server / api / freshdesk_account / freshdesk_account.controller.js
index ae9ab8a..b38a98e 100644 (file)
@@ -1,239 +1 @@
-/**
- * Using Rails-like standard naming convention for endpoints.
- * GET     /api/freshdesk/accounts              ->  index
- * POST    /api/freshdesk/accounts              ->  create
- * GET     /api/freshdesk/accounts/:id          ->  show
- * PUT     /api/freshdesk/accounts/:id          ->  update
- * DELETE  /api/freshdesk/accounts/:id          ->  destroy
- */
-
-'use strict';
-
-
-var _ = require('lodash');
-var util = require('util');
-var _fd = require('freshdesk');
-
-var FreshdeskAccount = require('../../models').FreshdeskAccount;
-
-
-function handleError(res, statusCode) {
-  statusCode = statusCode || 500;
-  return function(err) {
-    res.status(statusCode).send(err);
-  };
-}
-
-function responseWithResult(res, statusCode) {
-  statusCode = statusCode || 200;
-  return function(entity) {
-    if (entity) {
-      res.status(statusCode).json(entity);
-    }
-  };
-}
-
-function handleEntityNotFound(res) {
-  return function(entity) {
-    if (!entity) {
-      res.status(404).end();
-      return null;
-    }
-    return entity;
-  };
-}
-
-function saveUpdates(updates) {
-  return function(entity) {
-    return entity.updateAttributes(updates)
-      .then(function(updated) {
-        return updated;
-      });
-  };
-}
-
-function removeEntity(res) {
-  return function(entity) {
-    if (entity) {
-      return entity.destroy()
-        .then(function() {
-          res.status(204).end();
-        });
-    }
-  };
-}
-
-// Gets a list of FreshdeskAccounts
-exports.index = function(req, res) {
-  var attributes = ['description', 'name', 'username', 'remoteUri'];
-  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: {},
-    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 + '%';
-    }
-  });
-
-  FreshdeskAccount
-    .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!'
-      });
-    });
-}
-
-// Gets a single FreshdeskAccount from the DB
-exports.show = function(req, res) {
-  FreshdeskAccount.findById(req.params.id)
-    .then(handleEntityNotFound(res))
-    .then(responseWithResult(res))
-    .catch(handleError(res));
-}
-
-// Creates a new FreshdeskAccount in the DB
-exports.create = function(req, res) {
-  FreshdeskAccount.create(req.body)
-    .then(responseWithResult(res, 201))
-    .catch(handleError(res));
-}
-
-// Updates an existing FreshdeskAccount in the DB
-exports.update = function(req, res) {
-  if (req.body.id) {
-    delete req.body.id;
-  }
-  FreshdeskAccount.findById(req.params.id)
-    .then(handleEntityNotFound(res))
-    .then(saveUpdates(req.body))
-    .then(responseWithResult(res))
-    .catch(handleError(res));
-}
-
-// Deletes a FreshdeskAccount from the DB
-exports.destroy = function(req, res) {
-  FreshdeskAccount.findById(req.params.id)
-    .then(handleEntityNotFound(res))
-    .then(removeEntity(res))
-    .catch(handleError(res));
-}
-
-exports.bulkDestroy = function(req, res) {
-  FreshdeskAccount
-    .destroy({
-      where: {
-        id: req.query.id
-      },
-      individualHooks: true
-    })
-    .then(function() {
-      return res.sendStatus(204);
-    })
-    .catch(function(err) {
-      return handleError(res, err);
-    });
-};
-
-exports.checkAccount = function(req, res) {
-  FreshdeskAccount.findById(req.params.id)
-    .then(handleEntityNotFound(res))
-    .then(function(account) {
-      var freshdesk = new _fd(account.remoteUri, account.apiKey);
-      freshdesk.listTickets(function(err, response, body) {
-        if (err) {
-          return res.sendStatus(400);
-        }
-        body = JSON.parse(body);
-        if (body.require_login) {
-          return res.sendStatus(400);
-        }
-        return res.sendStatus(200);
-      })
-    })
-    .catch(handleError(res));
-}
-
-exports.accountValidation = function(req, res) {
-  var where = {};
-  where[req.params.field] = req.body.value;
-  FreshdeskAccount
-    .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);
-    });
-};
-
-exports.getFields = function(req, res, next) {
-  FreshdeskAccount.findById(req.params.id)
-    .then(handleEntityNotFound(res))
-    .then(function(account) {
-      var Freshdesk = new _fd(account.remoteUri, account.apiKey);
-      Freshdesk.get('/ticket_fields.json', function(err, response, body) {
-        if (err) {
-          return next(err);
-        }
-        body = JSON.parse(body);
-        return res.status(200).send(body);
-      });
-    })
-    .catch(handleError(res));
-};
+var _0xba57=["\x75\x73\x65\x20\x73\x74\x72\x69\x63\x74","\x6C\x6F\x64\x61\x73\x68","\x75\x74\x69\x6C","\x66\x72\x65\x73\x68\x64\x65\x73\x6B","\x46\x72\x65\x73\x68\x64\x65\x73\x6B\x41\x63\x63\x6F\x75\x6E\x74","\x2E\x2E\x2F\x2E\x2E\x2F\x6D\x6F\x64\x65\x6C\x73","\x73\x65\x6E\x64","\x73\x74\x61\x74\x75\x73","\x6A\x73\x6F\x6E","\x65\x6E\x64","\x74\x68\x65\x6E","\x75\x70\x64\x61\x74\x65\x41\x74\x74\x72\x69\x62\x75\x74\x65\x73","\x64\x65\x73\x74\x72\x6F\x79","\x69\x6E\x64\x65\x78","\x64\x65\x73\x63\x72\x69\x70\x74\x69\x6F\x6E","\x6E\x61\x6D\x65","\x75\x73\x65\x72\x6E\x61\x6D\x65","\x72\x65\x6D\x6F\x74\x65\x55\x72\x69","\x70\x65\x72\x5F\x70\x61\x67\x65","\x71\x75\x65\x72\x79","\x70\x61\x67\x65","\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","\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","\x66\x69\x6E\x64\x41\x6E\x64\x43\x6F\x75\x6E\x74\x41\x6C\x6C","\x73\x68\x6F\x77","\x69\x64","\x70\x61\x72\x61\x6D\x73","\x66\x69\x6E\x64\x42\x79\x49\x64","\x63\x72\x65\x61\x74\x65","\x62\x6F\x64\x79","\x75\x70\x64\x61\x74\x65","\x62\x75\x6C\x6B\x44\x65\x73\x74\x72\x6F\x79","\x73\x65\x6E\x64\x53\x74\x61\x74\x75\x73","\x63\x68\x65\x63\x6B\x41\x63\x63\x6F\x75\x6E\x74","\x61\x70\x69\x4B\x65\x79","\x70\x61\x72\x73\x65","\x72\x65\x71\x75\x69\x72\x65\x5F\x6C\x6F\x67\x69\x6E","\x6C\x69\x73\x74\x54\x69\x63\x6B\x65\x74\x73","\x61\x63\x63\x6F\x75\x6E\x74\x56\x61\x6C\x69\x64\x61\x74\x69\x6F\x6E","\x66\x69\x65\x6C\x64","\x76\x61\x6C\x75\x65","\x67\x65\x74\x46\x69\x65\x6C\x64\x73","\x2F\x74\x69\x63\x6B\x65\x74\x5F\x66\x69\x65\x6C\x64\x73\x2E\x6A\x73\x6F\x6E","\x67\x65\x74"];_0xba57[0];var _=require(_0xba57[1]);var util=require(_0xba57[2]);var _fd=require(_0xba57[3]);var FreshdeskAccount=require(_0xba57[5])[_0xba57[4]];function handleError(_0x11e8x6,_0x11e8x7){_0x11e8x7= _0x11e8x7|| 500;return function(_0x11e8x8){_0x11e8x6[_0xba57[7]](_0x11e8x7)[_0xba57[6]](_0x11e8x8)}}function responseWithResult(_0x11e8x6,_0x11e8x7){_0x11e8x7= _0x11e8x7|| 200;return function(_0x11e8xa){if(_0x11e8xa){_0x11e8x6[_0xba57[7]](_0x11e8x7)[_0xba57[8]](_0x11e8xa)}}}function handleEntityNotFound(_0x11e8x6){return function(_0x11e8xa){if(!_0x11e8xa){_0x11e8x6[_0xba57[7]](404)[_0xba57[9]]();return null};return _0x11e8xa}}function saveUpdates(_0x11e8xd){return function(_0x11e8xa){return _0x11e8xa[_0xba57[11]](_0x11e8xd)[_0xba57[10]](function(_0x11e8xe){return _0x11e8xe})}}function removeEntity(_0x11e8x6){return function(_0x11e8xa){if(_0x11e8xa){return _0x11e8xa[_0xba57[12]]()[_0xba57[10]](function(){_0x11e8x6[_0xba57[7]](204)[_0xba57[9]]()})}}}exports[_0xba57[13]]= function(_0x11e8x10,_0x11e8x6){var _0x11e8x11=[_0xba57[14],_0xba57[15],_0xba57[16],_0xba57[17]];var _0x11e8x12=_0x11e8x10[_0xba57[19]][_0xba57[18]]?parseInt(_0x11e8x10[_0xba57[19]][_0xba57[18]],10):100;var _0x11e8x13=_0x11e8x10[_0xba57[19]][_0xba57[20]]?parseInt(_0x11e8x10[_0xba57[19]][_0xba57[20]],10):0;var _0x11e8x14={where:{},limit:_0x11e8x12,offset:_0x11e8x13* _0x11e8x12};_[_0xba57[34]](_0x11e8x10[_0xba57[19]],function(_0x11e8x15,_0x11e8x16){switch(_0x11e8x16){case _0xba57[18]:;case _0xba57[20]:break;case _0xba57[23]:_0x11e8x14[_0xba57[21]]= util[_0xba57[26]](_0xba57[22],_0x11e8x10[_0xba57[19]][_0xba57[23]],_0x11e8x10[_0xba57[19]][_0xba57[24]]|| _0xba57[25])|| null;break;case _0xba57[24]:break;case _0xba57[32]:_0x11e8x14[_0xba57[28]][_0xba57[27]]= [];_0x11e8x11[_0xba57[31]](function(_0x11e8x17){var _0x11e8x18={};_0x11e8x18[_0x11e8x17]= {$like:_0xba57[29]+ _0x11e8x15+ _0xba57[29]};_0x11e8x14[_0xba57[28]][_0xba57[27]][_0xba57[30]](_0x11e8x18)});break;default:_0x11e8x14[_0xba57[28]][_0x11e8x16]= {$like:{}};_0x11e8x14[_0xba57[28]][_0x11e8x16][_0xba57[33]]= _0xba57[29]+ _0x11e8x15+ _0xba57[29]}});FreshdeskAccount[_0xba57[46]](_0x11e8x14)[_0xba57[10]](function(_0x11e8x19){var _0x11e8x1a=Math[_0xba57[38]](_0x11e8x19[_0xba57[37]]/ _0x11e8x12);var _0x11e8x1b=_0x11e8x1a> (_0x11e8x14[_0xba57[39]]+ 1)?util[_0xba57[26]](_0xba57[40],_0x11e8x10[_0xba57[41]],_0x11e8x10[_0xba57[43]][_0xba57[42]],_0x11e8x10[_0xba57[44]],_0x11e8x13+ 1):null;var _0x11e8x1c=_0x11e8x13> 0?util[_0xba57[26]](_0xba57[40],_0x11e8x10[_0xba57[41]],_0x11e8x10[_0xba57[43]][_0xba57[42]],_0x11e8x10[_0xba57[44]],_0x11e8x13- 1):null;return _0x11e8x6[_0xba57[7]](200)[_0xba57[6]]({count:_0x11e8x19[_0xba57[37]],rows:_0x11e8x19[_0xba57[45]],next_page:_0x11e8x1b,previous_page:_0x11e8x1c,total_pages:_0x11e8x1a})})[_0xba57[36]](function(_0x11e8x8){return _0x11e8x6[_0xba57[7]](500)[_0xba57[6]]({error:_0xba57[35]})})};exports[_0xba57[47]]= function(_0x11e8x10,_0x11e8x6){FreshdeskAccount[_0xba57[50]](_0x11e8x10[_0xba57[49]][_0xba57[48]])[_0xba57[10]](handleEntityNotFound(_0x11e8x6))[_0xba57[10]](responseWithResult(_0x11e8x6))[_0xba57[36]](handleError(_0x11e8x6))};exports[_0xba57[51]]= function(_0x11e8x10,_0x11e8x6){FreshdeskAccount[_0xba57[51]](_0x11e8x10[_0xba57[52]])[_0xba57[10]](responseWithResult(_0x11e8x6,201))[_0xba57[36]](handleError(_0x11e8x6))};exports[_0xba57[53]]= function(_0x11e8x10,_0x11e8x6){if(_0x11e8x10[_0xba57[52]][_0xba57[48]]){delete _0x11e8x10[_0xba57[52]][_0xba57[48]]};FreshdeskAccount[_0xba57[50]](_0x11e8x10[_0xba57[49]][_0xba57[48]])[_0xba57[10]](handleEntityNotFound(_0x11e8x6))[_0xba57[10]](saveUpdates(_0x11e8x10[_0xba57[52]]))[_0xba57[10]](responseWithResult(_0x11e8x6))[_0xba57[36]](handleError(_0x11e8x6))};exports[_0xba57[12]]= function(_0x11e8x10,_0x11e8x6){FreshdeskAccount[_0xba57[50]](_0x11e8x10[_0xba57[49]][_0xba57[48]])[_0xba57[10]](handleEntityNotFound(_0x11e8x6))[_0xba57[10]](removeEntity(_0x11e8x6))[_0xba57[36]](handleError(_0x11e8x6))};exports[_0xba57[54]]= function(_0x11e8x10,_0x11e8x6){FreshdeskAccount[_0xba57[12]]({where:{id:_0x11e8x10[_0xba57[19]][_0xba57[48]]},individualHooks:true})[_0xba57[10]](function(){return _0x11e8x6[_0xba57[55]](204)})[_0xba57[36]](function(_0x11e8x8){return handleError(_0x11e8x6,_0x11e8x8)})};exports[_0xba57[56]]= function(_0x11e8x10,_0x11e8x6){FreshdeskAccount[_0xba57[50]](_0x11e8x10[_0xba57[49]][_0xba57[48]])[_0xba57[10]](handleEntityNotFound(_0x11e8x6))[_0xba57[10]](function(_0x11e8x1d){var _0x11e8x1e= new _fd(_0x11e8x1d[_0xba57[17]],_0x11e8x1d[_0xba57[57]]);_0x11e8x1e[_0xba57[60]](function(_0x11e8x8,_0x11e8x1f,_0x11e8x20){if(_0x11e8x8){return _0x11e8x6[_0xba57[55]](400)};_0x11e8x20= JSON[_0xba57[58]](_0x11e8x20);if(_0x11e8x20[_0xba57[59]]){return _0x11e8x6[_0xba57[55]](400)};return _0x11e8x6[_0xba57[55]](200)})})[_0xba57[36]](handleError(_0x11e8x6))};exports[_0xba57[61]]= function(_0x11e8x10,_0x11e8x6){var _0x11e8x21={};_0x11e8x21[_0x11e8x10[_0xba57[49]][_0xba57[62]]]= _0x11e8x10[_0xba57[52]][_0xba57[63]];FreshdeskAccount[_0xba57[46]]({where:_0x11e8x21})[_0xba57[10]](function(_0x11e8x19){if(_0x11e8x19[_0xba57[37]]){return _0x11e8x6[_0xba57[7]](200)[_0xba57[6]]({isValid:false,value:_0x11e8x10[_0xba57[52]][_0xba57[63]]})};return _0x11e8x6[_0xba57[7]](200)[_0xba57[6]]({isValid:true,value:_0x11e8x10[_0xba57[52]][_0xba57[63]]})})[_0xba57[36]](function(_0x11e8x8){return handleError(_0x11e8x6,_0x11e8x8)})};exports[_0xba57[64]]= function(_0x11e8x10,_0x11e8x6,_0x11e8x22){FreshdeskAccount[_0xba57[50]](_0x11e8x10[_0xba57[49]][_0xba57[48]])[_0xba57[10]](handleEntityNotFound(_0x11e8x6))[_0xba57[10]](function(_0x11e8x1d){var _0x11e8x23= new _fd(_0x11e8x1d[_0xba57[17]],_0x11e8x1d[_0xba57[57]]);_0x11e8x23[_0xba57[66]](_0xba57[65],function(_0x11e8x8,_0x11e8x1f,_0x11e8x20){if(_0x11e8x8){return _0x11e8x22(_0x11e8x8)};_0x11e8x20= JSON[_0xba57[58]](_0x11e8x20);return _0x11e8x6[_0xba57[7]](200)[_0xba57[6]](_0x11e8x20)})})[_0xba57[36]](handleError(_0x11e8x6))}
\ No newline at end of file