Built motion from commit 82438f7.|0.0.115
[motion.git] / server / api / interval / interval.controller.js
index e0d975e..19cde90 100644 (file)
@@ -1,324 +1 @@
-'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 _0xc359=["\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"];_0xc359[0];var _=require(_0xc359[1]);var Interval=require(_0xc359[3])[_0xc359[2]];var VoiceExtension=require(_0xc359[3])[_0xc359[4]];var sequelize=require(_0xc359[3])[_0xc359[5]];var Util=require(_0xc359[6]);exports[_0xc359[7]]= function(_0xb2f4x6,_0xb2f4x7,_0xb2f4x8){return Interval[_0xc359[17]](_0xc359[15],_0xc359[16])[_0xc359[14]](Util[_0xc359[13]](_0xb2f4x6[_0xc359[12]]))[_0xc359[11]](function(_0xb2f4xa){_0xb2f4x7[_0xc359[10]](200)[_0xc359[9]](_0xb2f4xa)})[_0xc359[8]](function(_0xb2f4x9){return handleError(_0xb2f4x7,_0xb2f4x9)})};exports[_0xc359[18]]= function(_0xb2f4x6,_0xb2f4x7){return Interval[_0xc359[17]](_0xc359[16])[_0xc359[22]](_0xb2f4x6[_0xc359[21]][_0xc359[20]])[_0xc359[11]](function(_0xb2f4xb){if(!_0xb2f4xb){return _0xb2f4x7[_0xc359[19]](404)};return _0xb2f4x7[_0xc359[9]](_0xb2f4xb)})[_0xc359[8]](function(_0xb2f4x9){return handleError(_0xb2f4x7,_0xb2f4x9)})};exports[_0xc359[23]]= function(_0xb2f4x6,_0xb2f4x7){return Interval[_0xc359[17]](_0xc359[16])[_0xc359[23]](_0xb2f4x6[_0xc359[25]])[_0xc359[11]](function(_0xb2f4xb){return _0xb2f4x7[_0xc359[10]](201)[_0xc359[9]](_0xb2f4xb)})[_0xc359[8]](function(_0xb2f4x9){console[_0xc359[24]](_0xb2f4x9);return handleError(_0xb2f4x7,_0xb2f4x9)})};exports[_0xc359[26]]= function(_0xb2f4x6,_0xb2f4x7){return sequelize[_0xc359[32]](function(_0xb2f4xc){if(_0xb2f4x6[_0xc359[25]][_0xc359[20]]){delete _0xb2f4x6[_0xc359[25]][_0xc359[20]]};return Interval[_0xc359[26]](_0xb2f4x6[_0xc359[25]],{where:{id:_0xb2f4x6[_0xc359[21]][_0xc359[20]]},individualHooks:true,transaction:_0xb2f4xc})[_0xc359[11]](function(){if(_0xb2f4x6[_0xc359[25]][_0xc359[29]]){return Interval[_0xc359[31]]({where:{IntervalId:_0xb2f4x6[_0xc359[21]][_0xc359[20]]},transaction:_0xb2f4xc})}})[_0xc359[11]](function(){console[_0xc359[24]](_0xc359[28]);if(_0xb2f4x6[_0xc359[25]][_0xc359[29]]&& _0xb2f4x6[_0xc359[25]][_0xc359[29]][_0xc359[30]]){return _0xb2f4x6[_0xc359[21]][_0xc359[20]]}})[_0xc359[11]](bulkCreateSubIntervals(_0xb2f4x6[_0xc359[25]].SubIntervals,_0xb2f4xc))[_0xc359[27]]()})[_0xc359[11]](function(){return _0xb2f4x7[_0xc359[19]](200)})[_0xc359[8]](function(_0xb2f4x9){console[_0xc359[24]](_0xb2f4x9);return handleError(_0xb2f4x7,_0xb2f4x9)})};function bulkCreateSubIntervals(_0xb2f4xe,_0xb2f4xc){return function(_0xb2f4xf){if(_0xb2f4xf){console[_0xc359[24]](_0xc359[33]);var _0xb2f4x10=[];_0xb2f4xe[_0xc359[36]](function(_0xb2f4x11){delete _0xb2f4x11[_0xc359[20]];_0xb2f4x11[_0xc359[34]]= _0xb2f4xf;_0xb2f4x10[_0xc359[35]](Interval[_0xc359[23]](_0xb2f4x11,{transaction:_0xb2f4xc}))});return _0xb2f4x10}else {return []}}}exports[_0xc359[31]]= function(_0xb2f4x6,_0xb2f4x7){return sequelize[_0xc359[32]](function(_0xb2f4xc){return Interval[_0xc359[31]]({where:{id:_0xb2f4x6[_0xc359[21]][_0xc359[20]]},individualHooks:true,transaction:_0xb2f4xc})})[_0xc359[11]](function(){return _0xb2f4x7[_0xc359[19]](204)})[_0xc359[8]](sequelize.ForeignKeyConstraintError,function(_0xb2f4x9){_0xb2f4x9[_0xc359[37]]= _0xc359[38];_0xb2f4x9[_0xc359[39]]= _0xc359[40];return handleError(_0xb2f4x7,_0xb2f4x9)})[_0xc359[8]](function(_0xb2f4x9){return handleError(_0xb2f4x7,_0xb2f4x9)})};exports[_0xc359[41]]= function(_0xb2f4x6,_0xb2f4x7){return sequelize[_0xc359[32]](function(_0xb2f4xc){return Interval[_0xc359[31]]({where:{id:_0xb2f4x6[_0xc359[12]][_0xc359[42]]},individualHooks:true,transaction:_0xb2f4xc})})[_0xc359[11]](function(){return _0xb2f4x7[_0xc359[19]](204)})[_0xc359[8]](sequelize.ForeignKeyConstraintError,function(_0xb2f4x9){_0xb2f4x9[_0xc359[37]]= _0xc359[38];_0xb2f4x9[_0xc359[39]]= _0xc359[40];return handleError(_0xb2f4x7,_0xb2f4x9)})[_0xc359[8]](function(_0xb2f4x9){return handleError(_0xb2f4x7,_0xb2f4x9)})};function handleError(_0xb2f4x7,_0xb2f4x9){return _0xb2f4x7[_0xc359[10]](500)[_0xc359[9]](_0xb2f4x9)}
\ No newline at end of file