-
Notifications
You must be signed in to change notification settings - Fork 16
/
app.js
81 lines (75 loc) · 2.59 KB
/
app.js
1
2
3
4
5
6
7
8
9
10
11
12
13
14
15
16
17
18
19
20
21
22
23
24
25
26
27
28
29
30
31
32
33
34
35
36
37
38
39
40
41
42
43
44
45
46
47
48
49
50
51
52
53
54
55
56
57
58
59
60
61
62
63
64
65
66
67
68
69
70
71
72
73
74
75
76
77
78
79
80
81
/**
Copyright (c) 2019, salesforce.com, inc.
All rights reserved.
SPDX-License-Identifier: BSD-3-Clause
For full license text, see the LICENSE file in the repo root or https://opensource.org/licenses/BSD-3-Clause
*/
/**
* app.js
*
* Use `app.js` to run your app without `sails lift`.
* To start the server, run: `node app.js`.
*
* This is handy in situations where the sails CLI is not relevant or useful,
* such as when you deploy to a server, or a PaaS like Heroku.
*
* For example:
* => `node app.js`
* => `npm start`
* => `forever start app.js`
* => `node debug app.js`
*
* The same command-line arguments and env vars are supported, e.g.:
* `NODE_ENV=production node app.js --port=80 --verbose`
*
* For more information see:
* https://sailsjs.com/anatomy/app.js
*/
const logger = require('./api/services/Logs/logger');
// Ensure we're in the project directory, so cwd-relative paths work as expected
// no matter where we actually lift from.
// > Note: This is not required in order to lift, but it is a convenient default.
process.chdir(__dirname);
// Attempt to import `sails` dependency, as well as `rc` (for loading `.sailsrc` files).
var sails;
var rc;
try {
sails = require('sails');
rc = require('sails/accessible/rc');
} catch (err) {
console.error("Encountered an error when attempting to require('sails'):");
console.error(err.stack);
console.error('--');
console.error(
'To run an app using `node app.js`, you need to have Sails installed'
);
console.error(
"locally (`./node_modules/sails`). To do that, just make sure you're"
);
console.error('in the same directory as your app and run `npm install`.');
console.error();
console.error(
'If Sails is installed globally (i.e. `npm install -g sails`) you can'
);
console.error(
'also run this app with `sails lift`. Running with `sails lift` will'
);
console.error(
'not run this file (`app.js`), but it will do exactly the same thing.'
);
console.error(
"(It even uses your app directory's local Sails install, if possible.)"
);
return;
} //-•
// Start server
sails.lift(rc('sails'));
// Unhandled Promise rejections don't put our app in a bad state unable to serve
// new requests. Instead of crashing the app, just log unhandled promise rejections
process.on('unhandledRejection', (error, promise) => {
logger.error('Unhandled Promise Rejection', promise, error);
});
process.on('warning', error => {
// if error has a stack trace, it will be printed
logger.warn(`Warning from Node: ${error}`, error);
});