mirror of
				https://github.com/nodemailer/wildduck.git
				synced 2025-10-31 00:18:24 +08:00 
			
		
		
		
	
		
			
				
	
	
		
			89 lines
		
	
	
	
		
			3.4 KiB
		
	
	
	
		
			JavaScript
		
	
	
	
	
	
			
		
		
	
	
			89 lines
		
	
	
	
		
			3.4 KiB
		
	
	
	
		
			JavaScript
		
	
	
	
	
	
| 'use strict';
 | |
| 
 | |
| const config = require('wild-config');
 | |
| const log = require('npmlog');
 | |
| const imap = require('./imap');
 | |
| const pop3 = require('./pop3');
 | |
| const irc = require('./irc');
 | |
| const lmtp = require('./lmtp');
 | |
| const api = require('./api');
 | |
| const db = require('./lib/db');
 | |
| const errors = require('./lib/errors');
 | |
| 
 | |
| // preload certificate files
 | |
| require('./lib/certs');
 | |
| 
 | |
| // Initialize database connection
 | |
| db.connect(err => {
 | |
|     if (err) {
 | |
|         log.error('Db', 'Failed to setup database connection');
 | |
|         errors.notify(err);
 | |
|         return setTimeout(() => process.exit(1), 3000);
 | |
|     }
 | |
|     // Start IMAP server
 | |
|     imap(err => {
 | |
|         if (err) {
 | |
|             log.error('App', 'Failed to start IMAP server. %s', err.message);
 | |
|             errors.notify(err);
 | |
|             return setTimeout(() => process.exit(1), 3000);
 | |
|         }
 | |
|         // Start POP3 server
 | |
|         pop3(err => {
 | |
|             if (err) {
 | |
|                 log.error('App', 'Failed to start POP3 server');
 | |
|                 errors.notify(err);
 | |
|                 return setTimeout(() => process.exit(1), 3000);
 | |
|             }
 | |
|             // Start LMTP maildrop server
 | |
|             lmtp(err => {
 | |
|                 if (err) {
 | |
|                     log.error('App', 'Failed to start LMTP server');
 | |
|                     errors.notify(err);
 | |
|                     return setTimeout(() => process.exit(1), 3000);
 | |
|                 }
 | |
| 
 | |
|                 // Start HTTP API server
 | |
|                 api(err => {
 | |
|                     if (err) {
 | |
|                         log.error('App', 'Failed to start API server');
 | |
|                         errors.notify(err);
 | |
|                         return setTimeout(() => process.exit(1), 3000);
 | |
|                     }
 | |
| 
 | |
|                     // Start IRC server
 | |
|                     irc(err => {
 | |
|                         if (err) {
 | |
|                             log.error('App', 'Failed to start IRC server');
 | |
|                             errors.notify(err);
 | |
|                             return setTimeout(() => process.exit(1), 3000);
 | |
|                         }
 | |
| 
 | |
|                         log.info('App', 'All servers started, ready to process some mail');
 | |
| 
 | |
|                         // downgrade user and group if needed
 | |
|                         if (config.group) {
 | |
|                             try {
 | |
|                                 process.setgid(config.group);
 | |
|                                 log.info('App', 'Changed group to "%s" (%s)', config.group, process.getgid());
 | |
|                             } catch (E) {
 | |
|                                 log.error('App', 'Failed to change group to "%s" (%s)', config.group, E.message);
 | |
|                                 errors.notify(E);
 | |
|                                 return setTimeout(() => process.exit(1), 3000);
 | |
|                             }
 | |
|                         }
 | |
|                         if (config.user) {
 | |
|                             try {
 | |
|                                 process.setuid(config.user);
 | |
|                                 log.info('App', 'Changed user to "%s" (%s)', config.user, process.getuid());
 | |
|                             } catch (E) {
 | |
|                                 log.error('App', 'Failed to change user to "%s" (%s)', config.user, E.message);
 | |
|                                 errors.notify(E);
 | |
|                                 return setTimeout(() => process.exit(1), 3000);
 | |
|                             }
 | |
|                         }
 | |
|                     });
 | |
|                 });
 | |
|             });
 | |
|         });
 | |
|     });
 | |
| });
 |