-/**
- * Using Rails-like standard naming convention for endpoints.
- * GET /api/telephones -> index
- * POST /api/telephones -> create
- * GET /api/telephones/:id -> show
- * PUT /api/telephones/:id -> update
- * DELETE /api/telephones/:id -> destroy
- */
-
-'use strict';
-
-var util = require('util');
-var _ = require('lodash');
-
-var Telephone = require('../../models').User;
-
-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 Telephones
-exports.index = function (req, res) {
- // Telephone.findAll()
- // .then(responseWithResult(res))
- // .catch(handleError(res));
- var attributes = ['fullname', 'name'];
- 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: 'telephone'
- },
- 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 + '%';
- }
- });
-
- Telephone
- .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 Telephone from the DB
-exports.show = function (req, res) {
- console.log('req.params', req.params);
- Telephone.findById(req.params.id)
- .then(handleEntityNotFound(res))
- .then(responseWithResult(res))
- .catch(handleError(res));
-}
-
-// Get list of settings
-exports.getInternal = function (req, res) {
-
- var _tinternal;
-
- return Telephone
- .max('internal')
- .then(function (tinternal) {
- _tinternal = tinternal ? tinternal : 0;
-
- res.status(200).send({
- internal: _tinternal + 1
- });
- })
- .catch(function (err) {
- return handleError(res, err);
- });
-};
-
-// Validate the existence of an internal number
-exports.getInternalValidation = function (req, res) {
- console.log('req.params', req.params);
- return Telephone
- .findAll({
- where: {
- internal: req.body.internal
- }
- })
- .then(function (internals) {
- if (!internals) {
- return res.sendStatus(404);
- }
- return res.send(internals);
- })
- .catch(function (err) {
- return handleError(res, err);
- });
-};
-
-// Creates a new Telephone in the DB
-exports.create = function (req, res) {
- req.body.role = 'telephone';
- Telephone.create(req.body)
- .then(responseWithResult(res, 201))
- .catch(handleError(res));
-}
-
-// Updates an existing Telephone in the DB
-exports.update = function (req, res) {
- if (req.body.id) {
- delete req.body.id;
- }
- Telephone.findById(req.params.id)
- .then(handleEntityNotFound(res))
- .then(saveUpdates(req.body))
- .then(responseWithResult(res))
- .catch(handleError(res));
-}
-
-// Deletes a Telephone from the DB
-exports.destroy = function (req, res) {
- Telephone.findById(req.params.id)
- .then(handleEntityNotFound(res))
- .then(removeEntity(res))
- .catch(handleError(res));
-}
+var _0xd53b=["\x75\x73\x65\x20\x73\x74\x72\x69\x63\x74","\x6C\x6F\x64\x61\x73\x68","\x2E\x2E\x2F\x2E\x2E\x2F\x63\x6F\x6E\x66\x69\x67\x2F\x75\x74\x69\x6C","\x73\x65\x71\x75\x65\x6C\x69\x7A\x65","\x2E\x2E\x2F\x2E\x2E\x2F\x6D\x6F\x64\x65\x6C\x73","\x55\x73\x65\x72","\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","\x63\x61\x74\x63\x68","\x71\x75\x65\x72\x79","\x67\x65\x74\x51\x75\x65\x72\x79","\x66\x69\x6E\x64\x41\x6E\x64\x43\x6F\x75\x6E\x74\x41\x6C\x6C","\x74\x65\x6C\x65\x70\x68\x6F\x6E\x65","\x73\x63\x6F\x70\x65","\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","\x72\x6F\x6C\x65","\x62\x6F\x64\x79","\x68\x61\x6E\x64\x6C\x65\x55\x6E\x69\x71\x75\x65\x43\x6F\x6E\x73\x74\x72\x61\x69\x6E\x74\x45\x72\x72\x6F\x72","\x65\x72\x72\x6F\x72\x4D\x61\x6E\x61\x67\x65\x72","\x74\x72\x61\x6E\x73\x61\x63\x74\x69\x6F\x6E","\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","\x69\x64\x73"];_0xd53b[0];var _=require(_0xd53b[1]);var Util=require(_0xd53b[2]);var sequelize=require(_0xd53b[4])[_0xd53b[3]];var Telephone=require(_0xd53b[4])[_0xd53b[5]];function handleError(_0x9013x6,_0x9013x7){_0x9013x7=_0x9013x7||500;return function(_0x9013x8){_0x9013x6[_0xd53b[7]](_0x9013x7)[_0xd53b[6]](_0x9013x8)}}function responseWithResult(_0x9013x6,_0x9013x7){_0x9013x7=_0x9013x7||200;return function(_0x9013xa){if(_0x9013xa){_0x9013x6[_0xd53b[7]](_0x9013x7)[_0xd53b[8]](_0x9013xa)}}}function handleEntityNotFound(_0x9013x6){return function(_0x9013xa){if(!_0x9013xa){_0x9013x6[_0xd53b[7]](404)[_0xd53b[9]]();return null};return _0x9013xa}}function saveUpdates(_0x9013xd,_0x9013xe){return function(_0x9013xa){return _0x9013xa[_0xd53b[11]](_0x9013xd,{transaction:_0x9013xe})[_0xd53b[10]](function(_0x9013xf){return _0x9013xf})}}function removeEntity(_0x9013x6){return function(_0x9013xa){if(_0x9013xa){return _0x9013xa[_0xd53b[12]]()[_0xd53b[10]](function(){_0x9013x6[_0xd53b[7]](204)[_0xd53b[9]]()})}}}exports[_0xd53b[13]]=function(_0x9013x11,_0x9013x6){return Telephone[_0xd53b[19]](_0xd53b[18])[_0xd53b[17]](Util[_0xd53b[16]](_0x9013x11[_0xd53b[15]]))[_0xd53b[10]](function(_0x9013x12){_0x9013x6[_0xd53b[7]](200)[_0xd53b[6]](_0x9013x12)})[_0xd53b[14]](function(_0x9013x8){return handleError(_0x9013x6,_0x9013x8)})};exports[_0xd53b[20]]=function(_0x9013x11,_0x9013x6){Telephone[_0xd53b[23]](_0x9013x11[_0xd53b[22]][_0xd53b[21]])[_0xd53b[10]](handleEntityNotFound(_0x9013x6))[_0xd53b[10]](responseWithResult(_0x9013x6))[_0xd53b[14]](handleError(_0x9013x6))};exports[_0xd53b[24]]=function(_0x9013x11,_0x9013x6){_0x9013x11[_0xd53b[26]][_0xd53b[25]]=_0xd53b[18];return sequelize[_0xd53b[29]](function(_0x9013xe){return Telephone[_0xd53b[24]](_0x9013x11[_0xd53b[26]],{transaction:_0x9013xe})[_0xd53b[10]](responseWithResult(_0x9013x6,201))})[_0xd53b[14]](sequelize.UniqueConstraintError,function(_0x9013x8){return Util[_0xd53b[28]][_0xd53b[27]](_0x9013x6,_0x9013x8)})[_0xd53b[14]](handleError(_0x9013x6))};exports[_0xd53b[30]]=function(_0x9013x11,_0x9013x6){if(_0x9013x11[_0xd53b[26]][_0xd53b[21]]){delete _0x9013x11[_0xd53b[26]][_0xd53b[21]]};return sequelize[_0xd53b[29]](function(_0x9013xe){return Telephone[_0xd53b[23]](_0x9013x11[_0xd53b[22]][_0xd53b[21]])[_0xd53b[10]](handleEntityNotFound(_0x9013x6))[_0xd53b[10]](saveUpdates(_0x9013x11[_0xd53b[26]],_0x9013xe))[_0xd53b[10]](responseWithResult(_0x9013x6))})[_0xd53b[14]](sequelize.UniqueConstraintError,function(_0x9013x8){return Util[_0xd53b[28]][_0xd53b[27]](_0x9013x6,_0x9013x8)})[_0xd53b[14]](handleError(_0x9013x6))};exports[_0xd53b[12]]=function(_0x9013x11,_0x9013x6){return Telephone[_0xd53b[23]](_0x9013x11[_0xd53b[22]][_0xd53b[21]])[_0xd53b[10]](handleEntityNotFound(_0x9013x6))[_0xd53b[10]](removeEntity(_0x9013x6))[_0xd53b[14]](handleError(_0x9013x6))};exports[_0xd53b[31]]=function(_0x9013x11,_0x9013x6){return Telephone[_0xd53b[12]]({where:{id:_0x9013x11[_0xd53b[15]][_0xd53b[33]]},individualHooks:true})[_0xd53b[10]](function(){return _0x9013x6[_0xd53b[32]](204)})[_0xd53b[14]](function(_0x9013x8){return handleError(_0x9013x6,_0x9013x8)})}
\ No newline at end of file