forked from Stii/nodervisor
-
Notifications
You must be signed in to change notification settings - Fork 0
/
Copy pathconfig.js
69 lines (63 loc) · 1.7 KB
/
config.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
var config = {};
// Database configuration params.
// These are the connection parameters passed to our Knex db wrapper.
// Uncomment/Comment one of the below to switch between either Mysql or Sqlite.
// The format for this object is taken directly from Knex's connection object.
// Refer to the following if you wish to use PostgreSQL or connection pooling.
// http://knexjs.org/#Installation-client
// --
// Mysql Config:
//
// config.db = {
// client: 'mysql',
// connection: {
// host: 'localhost',
// user: 'root',
// password: '',
// database: 'nodervisor',
// charset: 'utf8',
// }
// };
//
// --
// We're using Sqlite by default now.
// Sqlite config:
//
config.db = {
client: 'sqlite3',
connection: {
filename: './nodervisor.sqlite'
}
};
// End of Database config
// Session storage config
// We're using Knex as with the db above, but only using sqlite and not mysql
// The express-session-knex module seems to have issues with mysql locks.
config.sessionstore = {
client: 'sqlite3',
connection: {
filename: './nv-sessions.sqlite'
}
};
// Application env config
config.port = process.env.PORT || 3000;
config.env = process.env.ENV || 'production';
config.sessionSecret = process.env.SECRET || '1234567890ABCDEF';
// Read and write settings
config.readHosts = function(db, callback){
var query = db('hosts')
.leftJoin('groups', 'hosts.idGroup', '=', 'groups.idGroup')
.select('hosts.idHost', 'hosts.Name', 'hosts.Url', 'groups.Name AS GroupName');
query.exec(function(err, data){
var hosts = {};
for (var host in data) {
hosts[data[host].idHost] = data[host];
}
config.hosts = hosts;
// Call the callback passed
if (callback) {
callback();
}
});
};
module.exports = config;