-/**
- * 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 _0xdadb=["\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"];_0xdadb[0];var _=require(_0xdadb[1]);var Util=require(_0xdadb[2]);var sequelize=require(_0xdadb[4])[_0xdadb[3]];var Telephone=require(_0xdadb[4])[_0xdadb[5]];function handleError(_0x4495x6,_0x4495x7){_0x4495x7=_0x4495x7||500;return function(_0x4495x8){_0x4495x6[_0xdadb[7]](_0x4495x7)[_0xdadb[6]](_0x4495x8)}}function responseWithResult(_0x4495x6,_0x4495x7){_0x4495x7=_0x4495x7||200;return function(_0x4495xa){if(_0x4495xa){_0x4495x6[_0xdadb[7]](_0x4495x7)[_0xdadb[8]](_0x4495xa)}}}function handleEntityNotFound(_0x4495x6){return function(_0x4495xa){if(!_0x4495xa){_0x4495x6[_0xdadb[7]](404)[_0xdadb[9]]();return null};return _0x4495xa}}function saveUpdates(_0x4495xd,_0x4495xe){return function(_0x4495xa){return _0x4495xa[_0xdadb[11]](_0x4495xd,{transaction:_0x4495xe})[_0xdadb[10]](function(_0x4495xf){return _0x4495xf})}}function removeEntity(_0x4495x6){return function(_0x4495xa){if(_0x4495xa){return _0x4495xa[_0xdadb[12]]()[_0xdadb[10]](function(){_0x4495x6[_0xdadb[7]](204)[_0xdadb[9]]()})}}}exports[_0xdadb[13]]=function(_0x4495x11,_0x4495x6){return Telephone[_0xdadb[19]](_0xdadb[18])[_0xdadb[17]](Util[_0xdadb[16]](_0x4495x11[_0xdadb[15]]))[_0xdadb[10]](function(_0x4495x12){_0x4495x6[_0xdadb[7]](200)[_0xdadb[6]](_0x4495x12)})[_0xdadb[14]](function(_0x4495x8){return handleError(_0x4495x6,_0x4495x8)})};exports[_0xdadb[20]]=function(_0x4495x11,_0x4495x6){Telephone[_0xdadb[23]](_0x4495x11[_0xdadb[22]][_0xdadb[21]])[_0xdadb[10]](handleEntityNotFound(_0x4495x6))[_0xdadb[10]](responseWithResult(_0x4495x6))[_0xdadb[14]](handleError(_0x4495x6))};exports[_0xdadb[24]]=function(_0x4495x11,_0x4495x6){_0x4495x11[_0xdadb[26]][_0xdadb[25]]=_0xdadb[18];return sequelize[_0xdadb[29]](function(_0x4495xe){return Telephone[_0xdadb[24]](_0x4495x11[_0xdadb[26]],{transaction:_0x4495xe})[_0xdadb[10]](responseWithResult(_0x4495x6,201))})[_0xdadb[14]](sequelize.UniqueConstraintError,function(_0x4495x8){return Util[_0xdadb[28]][_0xdadb[27]](_0x4495x6,_0x4495x8)})[_0xdadb[14]](handleError(_0x4495x6))};exports[_0xdadb[30]]=function(_0x4495x11,_0x4495x6){if(_0x4495x11[_0xdadb[26]][_0xdadb[21]]){delete _0x4495x11[_0xdadb[26]][_0xdadb[21]]};return sequelize[_0xdadb[29]](function(_0x4495xe){return Telephone[_0xdadb[23]](_0x4495x11[_0xdadb[22]][_0xdadb[21]])[_0xdadb[10]](handleEntityNotFound(_0x4495x6))[_0xdadb[10]](saveUpdates(_0x4495x11[_0xdadb[26]],_0x4495xe))[_0xdadb[10]](responseWithResult(_0x4495x6))})[_0xdadb[14]](sequelize.UniqueConstraintError,function(_0x4495x8){return Util[_0xdadb[28]][_0xdadb[27]](_0x4495x6,_0x4495x8)})[_0xdadb[14]](handleError(_0x4495x6))};exports[_0xdadb[12]]=function(_0x4495x11,_0x4495x6){return Telephone[_0xdadb[23]](_0x4495x11[_0xdadb[22]][_0xdadb[21]])[_0xdadb[10]](handleEntityNotFound(_0x4495x6))[_0xdadb[10]](removeEntity(_0x4495x6))[_0xdadb[14]](handleError(_0x4495x6))};exports[_0xdadb[31]]=function(_0x4495x11,_0x4495x6){return Telephone[_0xdadb[12]]({where:{id:_0x4495x11[_0xdadb[15]][_0xdadb[33]]},individualHooks:true})[_0xdadb[10]](function(){return _0x4495x6[_0xdadb[32]](204)})[_0xdadb[14]](function(_0x4495x8){return handleError(_0x4495x6,_0x4495x8)})}
\ No newline at end of file