-
Notifications
You must be signed in to change notification settings - Fork 0
/
express-crud-nedb-driver.js
109 lines (99 loc) · 3.45 KB
/
express-crud-nedb-driver.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
87
88
89
90
91
92
93
94
95
96
97
98
99
100
101
102
103
104
105
106
107
108
109
const Datastore = require('nedb');
const path = require('path');
const PATH_PREFIX = process.env.db || 'data';
const _db = {};
const collection = (table) => {
if(!_db[table]) {
_db[table] = new Datastore({ filename: path.resolve(PATH_PREFIX, `${table}.nedb`), autoload: true });
}
return _db[table];
}
const create = (table, doc) => {
return new Promise((accept, reject) => {
collection(table).insert(doc, (err, docs) => {
if (!err) {
accept(docs);
} else {
console.error('DB error:' + err);
reject({ status: 500, message: 'DB error' })
}
});
})
}
const update = (table, _id, newObj) => {
return new Promise((accept, reject) => {
collection(table).update({ _id }, { $set: newObj }, { multi: false, returnUpdatedDocs: true }, (err, numAffected, doc) => {
if (!err) {
if (numAffected === 1) {
accept(doc);
} else {
reject({ status: 404, message: `Record with id = ${_id} - not found` });
}
} else {
console.error('DB error:' + err);
reject({ status: 500, message: `Something wrong updating record with id ${_id}` });
}
});
})
}
const findAll = (table, options = {}) => {
return new Promise((accept, reject) => {
let {page, pageSize, ord, dir} = options;
let findAll = collection(table).find({});
if(page !== undefined || pageSize !== undefined || ord !== undefined) {
page = page || 0;
pageSize = pageSize || 10;
ord = ord || '_id';
dir = dir || 'asc';
findAll = findAll.sort({ [ord]: dir==='asc'?1:-1}).skip(page*pageSize).limit(pageSize);
}
findAll.exec((err, docs) => {
if (!err) {
accept(docs);
} else {
console.error('DB error:' + err);
reject({ status: 500, message: 'DB error' })
}
});
})
}
const findOne = (table, _id) => {
return new Promise((accept, reject) => {
collection(table).find({ _id }, (err, docs) => {
if (!err) {
if (!docs || docs.length === 0) {
reject({ status: 404, message: `Record not found with id = ${_id}` });
} else {
accept(docs[0]);
}
} else {
console.error('DB error:' + err);
reject({ status: 500, message: `Something went wrong while retrieving record with id = ${_id}` });
}
});
})
}
const remove = (table, _id) => {
return new Promise((accept, reject) => {
collection(table).remove({ _id }, {}, (err, numRemoved) => {
if (!err) {
if (numRemoved === 1) {
accept({});
} else {
reject({ status: 404, message: `Record with id = ${_id} - not found` })
}
} else {
console.error('DB error:' + err);
reject({ status: 500, message: `Something went wrong while deleting record with id = ${_id}` })
}
});
})
}
module.exports = {
create,
update,
findAll,
findOne,
remove,
collection
}