-
Notifications
You must be signed in to change notification settings - Fork 0
/
Copy pathconfigure.js
88 lines (77 loc) · 1.58 KB
/
configure.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
82
83
84
85
86
/**
* Created by Amin on 31/01/2017.
*/
const env = require('./env');
const sql = require('./sql');
const lib = require('./lib');
const User = lib.User;
function dbTestCreate() {
return new Promise((resolve, reject) => {
sql.db.create({dbName: env.test_db_name}, true)
.then(() => {
resolve();
})
.catch(err => {
reject(err);
});
});
}
function createOrExist(tableName) {
return lib.helpers.createOrExist(tableName, sql);
}
function prodTablesCreate() {
return new Promise((resolve, reject) => {
[
'users',
'patients',
'visits',
'documents',
'shares',
'waiting'
].reduce((x, y) => createOrExist(x).then(createOrExist(y)))
.then(resolve())
.catch(err => reject(err));
});
}
function adminRowCreate() {
return new Promise((resolve, reject) => {
let user = new User();
let data = {
username: 'admin',
password: 'admin',
};
user.insert(data)
.then(() => {
resolve();
})
.catch((err) => {
reject(err);
});
});
}
function setupMainDatabase(msg) {
prodTablesCreate()
.then(() => {
return adminRowCreate();
})
.then(() => {
if (env.isDev)
return dbTestCreate();
else
process.exit();
})
.then(() => process.exit())
.catch((err) => {
console.log(err.message);
process.exit();
});
}
if (env.isDev) {
sql.db.create({dbName: env.db_name})
.then(res => {
setupMainDatabase(res);
})
.catch(err => {
setupMainDatabase(err.message);
});
}