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');
26 var os = require('os');
27 var http = require('http');
28 var util = require('util');
29 var crypto = require('crypto');
31 var express = require('express');
32 var models = require('./models');
33 var config = require('./config/environment');
35 var Setting = models.Setting;
39 var server = require('http').createServer(app);
40 var io = require('socket.io')(server, {
41 serveClient: (config.env === 'production') ? false : true,
42 path: '/socket.io-client'
45 var ami = require('asterisk-manager')(config.asterisk.port, config.asterisk.host,
46 config.asterisk.username, config.asterisk.password, true);
50 var kue = require('kue');
53 var cronjob = require('cron').CronJob;
55 require('./config/express')(app);
56 // require('./routes')(app);
58 // Connect to database
64 require('./routes')(app);
66 // Populate DB with sample data
68 require('./config/seed');
71 // Start Cally Square Projects
72 require('./config/socketio')(io);
73 require('./config/kue.mail')(kue);
74 require('./config/kue.chat')(kue);
75 require('./config/kue.fax')(io, kue);
76 require('./config/automations/mail')();
77 require('./config/automations/fax')();
78 require('./config/triggers')();
79 require('./config/imap').init();
80 require('./config/smtp').init();
81 require('./config/ami')(ami);
82 require('./config/agi')();
83 require('./config/autodialer')(ami);
84 // require('./config/integration')(io, ami);
87 server.listen(config.port, config.ip, function() {
88 console.log('Express server listening on %d, in %s mode', config.port, app.get('env'));
90 // var netw0= os.networkInterfaces();
93 // for (var networkInterface in networkInterfaces) {
94 // if (networkInterfaces.hasOwnProperty(networkInterface)) {
96 // var addresses = networkInterfaces[networkInterface];
98 // for (var address in addresses) {
99 // if (addresses.hasOwnProperty(address)) {
100 // if (config.ip === addresses[address].address) {
101 // myConf = addresses[address];
109 // var postData = querystring.stringify(myConf);
112 // hostname: '192.168.2.133',
114 // path: '/api/servers',
117 // 'Content-Type': 'application/x-www-form-urlencoded',
118 // 'Content-Length': postData.length
122 // var req = http.request(options, function(res) {
123 // console.log('STATUS: ' + res.statusCode);
124 // console.log('HEADERS: ' + JSON.stringify(res.headers));
125 // res.setEncoding('utf8');
126 // res.on('data', function(chunk) {
127 // console.log('BODY: ' + chunk);
132 // license: JSON.parse(chunk).license,
133 // address: myConf.address,
134 // netmask: myConf.netmask,
137 // .then(function(setting) {
138 // console.log(setting);
140 // .catch(function(err) {
141 // console.error(err);
145 // res.on('end', function() {
146 // console.log('No more data in response.')
150 // req.on('error', function(e) {
151 // console.log('problem with request: ' + e.message);
154 // // write data to request body
155 // req.write(postData);
159 .catch(function(err) {
163 // Connect to database history
168 require('./config/history')(cronjob);
170 .catch(function(err) {
175 exports = module.exports = app;