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