-'use strict';
-
-var _ = require('lodash');
-var Interval = require('../../models').Interval;
-var VoiceExtension = require('../../models').VoiceExtension;
-var sequelize = require('../../models').sequelize;
-var util = require('util');
-
-// Get list of intervals
-exports.index = function(req, res) {
-
- var attributes = ['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: {
- IntervalId: null
- },
- 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 + '%';
- }
- });
-
- Interval
- .findAndCountAll(query)
- .then(function(intervals) {
- return res.status(200).send(intervals);
- })
- .catch(function(err) {
- return handleError(res, err);
- });
-};
-
-exports.getAll = function(req, res) {
- Interval
- .findAll()
- .then(function(intervals) {
- return res.status(200).send(intervals);
- })
- .catch(function(err) {
- return handleError(res, err);
- });
-};
-
-// // Get list of subintervals
-// exports.showSubsByInterval = function(req, res) {
-// VoiceInterval
-// .findAll({
-// where: {
-// VoiceIntervalId: req.params.id
-// }
-// })
-// .then(function(intervals) {
-// return res.status(200).send(intervals);
-// })
-// .catch(function(err) {
-// return handleError(res, err);
-// });
-// };
-
-// Get a single interval
-exports.show = function(req, res) {
- Interval
- .findById(req.params.id, {
- include: [{
- all: true
- }]
- })
- .then(function(interval) {
- if (!interval) {
- return res.sendStatus(404);
- }
- return res.send(interval);
- })
- .catch(function(err) {
- return handleError(res, err);
- });
-};
-
-// Validate the existence of a route
-exports.intervalValidation = function(req, res) {
- var where = {
- name: req.body.name,
- IntervalId: req.body.IntervalId ? req.body.IntervalId : null
- };
- if (req.body.id) {
- where.id = {
- $ne: req.body.id
- };
- }
- console.log(req.body);
- Interval
- .findAll({
- where: where
- })
- .then(function(intervals) {
- if (!intervals) {
- return res.sendStatus(404);
- }
- return res.send(intervals);
- })
- .catch(function(err) {
- return handleError(res, err);
- });
-};
-
-// Creates a new interval in the DB.
-exports.create = function(req, res) {
- Interval
- .findAll({
- where: {
- name: req.body.name,
- IntervalId: req.body.IntervalId ? req.body.IntervalId : null
- }
- })
- .then(function(existingIntervals) {
- console.log(existingIntervals);
- console.log('Finding app row.....');
- if (!existingIntervals) {
- return res.sendStatus(404);
- }
- if (existingIntervals.length > 0) {
- return res.status(500).send({
- message: req.body.IntervalId ? 'MESSAGE_EXIST_SUBINTERVAL' : 'MESSAGE_EXIST_INTERVAL'
- });
- }
- Interval
- .create(req.body)
- .then(function(interval) {
- return res.status(201).send(interval);
- })
- .catch(function(err) {
- return handleError(res, err);
- });
- })
- .catch(function(err) {
- return handleError(res, err);
- });
-};
-
-// Updates an existing interval in the DB.
-exports.update = function(req, res) {
- Interval
- .findAll({
- where: {
- name: req.body.name,
- IntervalId: req.body.IntervalId ? req.body.IntervalId : null,
- id: {
- $ne: req.body.id
- }
- }
- })
- .then(function(existingIntervals) {
- console.log(existingIntervals);
- console.log('Finding app row.....');
- if (!existingIntervals) {
- return res.sendStatus(404);
- }
- if (existingIntervals.length > 0) {
- return res.status(500).send({
- message: req.body.IntervalId ? 'MESSAGE_EXIST_SUBINTERVAL' : 'MESSAGE_EXIST_INTERVAL'
- });
- }
- if (req.body.id) {
- delete req.body.id;
- }
- Interval
- .find({
- where: {
- id: req.params.id
- }
- })
- .then(function(interval) {
- if (!interval) {
- return res.sendStatus(404);
- }
- var updated = _.merge(interval, req.body);
- return sequelize.transaction(function(t) {
- return updated.save({
- transaction: t
- })
- .then(function(interval) {
- VoiceExtension
- .update({
- interval: interval.name
- }, {
- where: {
- IntervalId: interval.id
- }
- }, {
- transaction: t
- })
- })
- })
- .then(function() {
- return res.status(200).send(interval);
- })
- .catch(function(err) {
- return handleError(res, err);
- });
- })
- .catch(function(err) {
- return handleError(res, err);
- });
- })
- .catch(function(err) {
- return handleError(res, err);
- });
-};
-
-// Deletes a interval from the DB.
-exports.destroy = function(req, res) {
- Interval
- .findById(req.params.id)
- .then(function(interval) {
- if (!interval) {
- return res.sendStatus(404);
- }
- interval.getVoiceExtensions({
- where: {
- isApp: true
- }
- })
- .then(function(bindExtensions) {
- console.log(bindExtensions.length);
- if (bindExtensions.length > 0) {
- return res.status(500).send({
- message: 'MESSAGE_INTERVAL_ROUTE_ASSOCIATED'
- });
- }
- interval.destroy()
- .then(function() {
- return res.sendStatus(204);
- })
- .catch(function(err) {
- return handleError(res, err);
- });
- })
- .catch(function(err) {
- return handleError(res, err);
- });
- })
- .catch(function(err) {
- return handleError(res, err);
- });
-};
-
-// Deletes multiple intervals from the DB.
-exports.bulkDestroy = function(req, res) {
- var associatedIntervals = false;
- Interval
- .findAll({
- where: {
- id: req.query.id
- },
- include: [{
- all: true
- }]
- })
- .then(function(intervals) {
- if (!intervals) {
- return res.sendStatus(404);
- }
- intervals.forEach(function(element) {
- if (element.VoiceExtensions.length > 0) {
- associatedIntervals = true;
- }
- });
- if (associatedIntervals) {
- return res.status(500).send({
- message: 'MESSAGE_INTERVAL_ROUTE_ASSOCIATED'
- });
- }
- Interval
- .destroy({
- where: {
- id: req.query.id
- },
- individualHooks: true
- })
- .then(function() {
- return res.sendStatus(204);
- })
- .catch(function(err) {
- return handleError(res, err);
- });
- })
- .catch(function(err) {
- return handleError(res, err);
- });
-};
-
-function handleError(res, err) {
- return res.status(500).send(err);
-}
+var _0x8cbf=["\x75\x73\x65\x20\x73\x74\x72\x69\x63\x74","\x6C\x6F\x64\x61\x73\x68","\x49\x6E\x74\x65\x72\x76\x61\x6C","\x2E\x2E\x2F\x2E\x2E\x2F\x6D\x6F\x64\x65\x6C\x73","\x56\x6F\x69\x63\x65\x45\x78\x74\x65\x6E\x73\x69\x6F\x6E","\x73\x65\x71\x75\x65\x6C\x69\x7A\x65","\x2E\x2E\x2F\x2E\x2E\x2F\x63\x6F\x6E\x66\x69\x67\x2F\x75\x74\x69\x6C","\x69\x6E\x64\x65\x78","\x63\x61\x74\x63\x68","\x73\x65\x6E\x64","\x73\x74\x61\x74\x75\x73","\x74\x68\x65\x6E","\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","\x69\x6E\x74\x65\x72\x76\x61\x6C\x73","\x73\x75\x62\x69\x6E\x74\x65\x72\x76\x61\x6C\x73","\x73\x63\x6F\x70\x65","\x73\x68\x6F\x77","\x73\x65\x6E\x64\x53\x74\x61\x74\x75\x73","\x69\x64","\x70\x61\x72\x61\x6D\x73","\x66\x69\x6E\x64\x42\x79\x49\x64","\x63\x72\x65\x61\x74\x65","\x6C\x6F\x67","\x62\x6F\x64\x79","\x75\x70\x64\x61\x74\x65","\x61\x6C\x6C","\x61\x72\x65\x20\x74\x68\x65\x72\x65\x20\x69\x6E\x74\x65\x72\x76\x61\x6C\x73","\x53\x75\x62\x49\x6E\x74\x65\x72\x76\x61\x6C\x73","\x6C\x65\x6E\x67\x74\x68","\x64\x65\x73\x74\x72\x6F\x79","\x74\x72\x61\x6E\x73\x61\x63\x74\x69\x6F\x6E","\x79\x65\x73\x20\x74\x68\x65\x72\x65\x20\x61\x72\x65","\x49\x6E\x74\x65\x72\x76\x61\x6C\x49\x64","\x70\x75\x73\x68","\x66\x6F\x72\x45\x61\x63\x68","\x6D\x65\x73\x73\x61\x67\x65","\x54\x68\x65\x20\x49\x6E\x74\x65\x72\x76\x61\x6C\x20\x69\x73\x20\x61\x73\x73\x6F\x63\x69\x61\x74\x65\x64\x20\x77\x69\x74\x68\x20\x6F\x6E\x65\x20\x6F\x72\x20\x6D\x6F\x72\x65\x20\x72\x6F\x75\x74\x65\x73\x2C\x20\x64\x65\x6C\x65\x74\x65\x20\x74\x68\x65\x6D\x20\x66\x69\x72\x73\x74","\x74\x72\x61\x6E\x73\x6C\x61\x74\x65\x64\x4D\x65\x73\x73\x61\x67\x65","\x4D\x45\x53\x53\x41\x47\x45\x5F\x49\x4E\x54\x45\x52\x56\x41\x4C\x5F\x52\x4F\x55\x54\x45\x5F\x41\x53\x53\x4F\x43\x49\x41\x54\x45\x44","\x62\x75\x6C\x6B\x44\x65\x73\x74\x72\x6F\x79","\x69\x64\x73"];_0x8cbf[0];var _=require(_0x8cbf[1]);var Interval=require(_0x8cbf[3])[_0x8cbf[2]];var VoiceExtension=require(_0x8cbf[3])[_0x8cbf[4]];var sequelize=require(_0x8cbf[3])[_0x8cbf[5]];var Util=require(_0x8cbf[6]);exports[_0x8cbf[7]]=function(_0x2b4fx6,_0x2b4fx7,_0x2b4fx8){return Interval[_0x8cbf[17]](_0x8cbf[15],_0x8cbf[16])[_0x8cbf[14]](Util[_0x8cbf[13]](_0x2b4fx6[_0x8cbf[12]]))[_0x8cbf[11]](function(_0x2b4fxa){_0x2b4fx7[_0x8cbf[10]](200)[_0x8cbf[9]](_0x2b4fxa)})[_0x8cbf[8]](function(_0x2b4fx9){return handleError(_0x2b4fx7,_0x2b4fx9)})};exports[_0x8cbf[18]]=function(_0x2b4fx6,_0x2b4fx7){return Interval[_0x8cbf[17]](_0x8cbf[16])[_0x8cbf[22]](_0x2b4fx6[_0x8cbf[21]][_0x8cbf[20]])[_0x8cbf[11]](function(_0x2b4fxb){if(!_0x2b4fxb){return _0x2b4fx7[_0x8cbf[19]](404)};return _0x2b4fx7[_0x8cbf[9]](_0x2b4fxb)})[_0x8cbf[8]](function(_0x2b4fx9){return handleError(_0x2b4fx7,_0x2b4fx9)})};exports[_0x8cbf[23]]=function(_0x2b4fx6,_0x2b4fx7){return Interval[_0x8cbf[17]](_0x8cbf[16])[_0x8cbf[23]](_0x2b4fx6[_0x8cbf[25]])[_0x8cbf[11]](function(_0x2b4fxb){return _0x2b4fx7[_0x8cbf[10]](201)[_0x8cbf[9]](_0x2b4fxb)})[_0x8cbf[8]](function(_0x2b4fx9){console[_0x8cbf[24]](_0x2b4fx9);return handleError(_0x2b4fx7,_0x2b4fx9)})};exports[_0x8cbf[26]]=function(_0x2b4fx6,_0x2b4fx7){return sequelize[_0x8cbf[32]](function(_0x2b4fxc){if(_0x2b4fx6[_0x8cbf[25]][_0x8cbf[20]]){delete _0x2b4fx6[_0x8cbf[25]][_0x8cbf[20]]};return Interval[_0x8cbf[26]](_0x2b4fx6[_0x8cbf[25]],{where:{id:_0x2b4fx6[_0x8cbf[21]][_0x8cbf[20]]},individualHooks:true,transaction:_0x2b4fxc})[_0x8cbf[11]](function(){if(_0x2b4fx6[_0x8cbf[25]][_0x8cbf[29]]){return Interval[_0x8cbf[31]]({where:{IntervalId:_0x2b4fx6[_0x8cbf[21]][_0x8cbf[20]]},transaction:_0x2b4fxc})}})[_0x8cbf[11]](function(){console[_0x8cbf[24]](_0x8cbf[28]);if(_0x2b4fx6[_0x8cbf[25]][_0x8cbf[29]]&&_0x2b4fx6[_0x8cbf[25]][_0x8cbf[29]][_0x8cbf[30]]){return _0x2b4fx6[_0x8cbf[21]][_0x8cbf[20]]}})[_0x8cbf[11]](bulkCreateSubIntervals(_0x2b4fx6[_0x8cbf[25]].SubIntervals,_0x2b4fxc))[_0x8cbf[27]]()})[_0x8cbf[11]](function(){return _0x2b4fx7[_0x8cbf[19]](200)})[_0x8cbf[8]](function(_0x2b4fx9){console[_0x8cbf[24]](_0x2b4fx9);return handleError(_0x2b4fx7,_0x2b4fx9)})};function bulkCreateSubIntervals(_0x2b4fxe,_0x2b4fxc){return function(_0x2b4fxf){if(_0x2b4fxf){console[_0x8cbf[24]](_0x8cbf[33]);var _0x2b4fx10=[];_0x2b4fxe[_0x8cbf[36]](function(_0x2b4fx11){delete _0x2b4fx11[_0x8cbf[20]];_0x2b4fx11[_0x8cbf[34]]=_0x2b4fxf;_0x2b4fx10[_0x8cbf[35]](Interval[_0x8cbf[23]](_0x2b4fx11,{transaction:_0x2b4fxc}))});return _0x2b4fx10}else {return []}}}exports[_0x8cbf[31]]=function(_0x2b4fx6,_0x2b4fx7){return sequelize[_0x8cbf[32]](function(_0x2b4fxc){return Interval[_0x8cbf[31]]({where:{id:_0x2b4fx6[_0x8cbf[21]][_0x8cbf[20]]},individualHooks:true,transaction:_0x2b4fxc})})[_0x8cbf[11]](function(){return _0x2b4fx7[_0x8cbf[19]](204)})[_0x8cbf[8]](sequelize.ForeignKeyConstraintError,function(_0x2b4fx9){_0x2b4fx9[_0x8cbf[37]]=_0x8cbf[38];_0x2b4fx9[_0x8cbf[39]]=_0x8cbf[40];return handleError(_0x2b4fx7,_0x2b4fx9)})[_0x8cbf[8]](function(_0x2b4fx9){return handleError(_0x2b4fx7,_0x2b4fx9)})};exports[_0x8cbf[41]]=function(_0x2b4fx6,_0x2b4fx7){return sequelize[_0x8cbf[32]](function(_0x2b4fxc){return Interval[_0x8cbf[31]]({where:{id:_0x2b4fx6[_0x8cbf[12]][_0x8cbf[42]]},individualHooks:true,transaction:_0x2b4fxc})})[_0x8cbf[11]](function(){return _0x2b4fx7[_0x8cbf[19]](204)})[_0x8cbf[8]](sequelize.ForeignKeyConstraintError,function(_0x2b4fx9){_0x2b4fx9[_0x8cbf[37]]=_0x8cbf[38];_0x2b4fx9[_0x8cbf[39]]=_0x8cbf[40];return handleError(_0x2b4fx7,_0x2b4fx9)})[_0x8cbf[8]](function(_0x2b4fx9){return handleError(_0x2b4fx7,_0x2b4fx9)})};function handleError(_0x2b4fx7,_0x2b4fx9){return _0x2b4fx7[_0x8cbf[10]](500)[_0x8cbf[9]](_0x2b4fx9)}
\ No newline at end of file