2 * Main application file
7 // Set default node environment to development
8 process.env.NODE_ENV = process.env.NODE_ENV || 'development';
9 process.env.NODE_TLS_REJECT_UNAUTHORIZED = 0;
11 process.on('uncaughtException', function(err) {
12 if (typeof err === 'object') {
14 console.log('\nMessage: ' + err.message)
17 console.log('\nStacktrace:')
18 console.log('====================')
19 console.log(err.stack);
22 console.log('dumpError :: argument is not an object');
27 var _ = require('lodash');
28 var os = require('os');
29 var http = require('http');
30 var util = require('util');
31 var crypto = require('crypto');
33 var express = require('express');
34 var models = require('./models');
35 var config = require('./config/environment');
37 var Setting = models.Setting;
41 var server = require('http').createServer(app);
42 var io = require('socket.io')(server, {
43 serveClient: (config.env === 'production') ? false : true,
44 path: '/socket.io-client'
47 var ami = require('asterisk-manager')('5038', '185.43.210.57', 'xcall', 'xcall1234', true);
51 var kue = require('kue');
54 var cronjob = require('cron').CronJob;
56 require('./config/express')(app);
57 require('./routes')(app);
59 // Connect to database
65 // Populate DB with sample data
67 require('./config/seed');
70 // Start Cally Square Projects
71 require('./config/socketio')(io);
72 require('./config/kue.mail')(kue);
73 require('./config/kue.chat')(kue);
74 require('./config/kue.fax')(io, kue);
75 require('./config/automations/mail')();
76 require('./config/automations/fax')();
77 require('./config/triggers/mail')();
78 require('./config/imap')();
79 require('./config/ami')(ami);
80 require('./config/agi')();
81 require('./config/autodialer')(ami);
82 require('./config/integration')(io, ami);
85 server.listen(config.port, config.ip, function() {
86 console.log('Express server listening on %d, in %s mode', config.port, app.get('env'));
88 // var netw0= os.networkInterfaces();
91 // for (var networkInterface in networkInterfaces) {
92 // if (networkInterfaces.hasOwnProperty(networkInterface)) {
94 // var addresses = networkInterfaces[networkInterface];
96 // for (var address in addresses) {
97 // if (addresses.hasOwnProperty(address)) {
98 // if (config.ip === addresses[address].address) {
99 // myConf = addresses[address];
107 // var postData = querystring.stringify(myConf);
110 // hostname: '192.168.2.133',
112 // path: '/api/servers',
115 // 'Content-Type': 'application/x-www-form-urlencoded',
116 // 'Content-Length': postData.length
120 // var req = http.request(options, function(res) {
121 // console.log('STATUS: ' + res.statusCode);
122 // console.log('HEADERS: ' + JSON.stringify(res.headers));
123 // res.setEncoding('utf8');
124 // res.on('data', function(chunk) {
125 // console.log('BODY: ' + chunk);
130 // license: JSON.parse(chunk).license,
131 // address: myConf.address,
132 // netmask: myConf.netmask,
135 // .then(function(setting) {
136 // console.log(setting);
138 // .catch(function(err) {
139 // console.error(err);
143 // res.on('end', function() {
144 // console.log('No more data in response.')
148 // req.on('error', function(e) {
149 // console.log('problem with request: ' + e.message);
152 // // write data to request body
153 // req.write(postData);
157 .catch(function(err) {
161 // Connect to database history
166 require('./config/history')(cronjob);
168 .catch(function(err) {
173 exports = module.exports = app;