@cocreate/crud-server 1.5.1 → 1.8.0
This diff represents the content of publicly available package versions that have been released to one of the supported registries. The information contained in this diff is provided for informational purposes only and reflects changes between package versions as they appear in their respective public registries.
- package/CHANGELOG.md +22 -0
- package/package.json +1 -1
- package/src/crud.js +23 -2
- package/src/database.js +47 -0
- package/src/index.js +17 -5
package/CHANGELOG.md
CHANGED
|
@@ -1,3 +1,25 @@
|
|
|
1
|
+
# [1.8.0](https://github.com/CoCreate-app/CoCreate-crud-server/compare/v1.7.0...v1.8.0) (2022-05-29)
|
|
2
|
+
|
|
3
|
+
|
|
4
|
+
### Features
|
|
5
|
+
|
|
6
|
+
* added constructor ([6335895](https://github.com/CoCreate-app/CoCreate-crud-server/commit/6335895e052a34bb3c560f882db80a6abb5b1582))
|
|
7
|
+
* added constructor ([8af6d34](https://github.com/CoCreate-app/CoCreate-crud-server/commit/8af6d34d0551d8380043103f0cc598d071a057d4))
|
|
8
|
+
|
|
9
|
+
# [1.7.0](https://github.com/CoCreate-app/CoCreate-crud-server/compare/v1.6.0...v1.7.0) (2022-05-28)
|
|
10
|
+
|
|
11
|
+
|
|
12
|
+
### Features
|
|
13
|
+
|
|
14
|
+
* readDatabases returns a list of databases in DB ([5c65622](https://github.com/CoCreate-app/CoCreate-crud-server/commit/5c65622908c5a154ade344aab48fb36b816470d6))
|
|
15
|
+
|
|
16
|
+
# [1.6.0](https://github.com/CoCreate-app/CoCreate-crud-server/compare/v1.5.1...v1.6.0) (2022-05-25)
|
|
17
|
+
|
|
18
|
+
|
|
19
|
+
### Features
|
|
20
|
+
|
|
21
|
+
* auto detects and updates data type ([ddb1391](https://github.com/CoCreate-app/CoCreate-crud-server/commit/ddb1391928a8a7acccd8d9e4c920adfdeb63f002))
|
|
22
|
+
|
|
1
23
|
## [1.5.1](https://github.com/CoCreate-app/CoCreate-crud-server/compare/v1.5.0...v1.5.1) (2022-05-17)
|
|
2
24
|
|
|
3
25
|
|
package/package.json
CHANGED
package/src/crud.js
CHANGED
|
@@ -108,11 +108,32 @@ class CoCreateCrud {
|
|
|
108
108
|
console.log(err);
|
|
109
109
|
}
|
|
110
110
|
const query = {"_id": objId };
|
|
111
|
-
const update = {};
|
|
111
|
+
const update = {"$set": {}};
|
|
112
112
|
|
|
113
113
|
|
|
114
114
|
if( req_data['set'] )
|
|
115
|
-
|
|
115
|
+
for (const [key, value] of Object.entries(req_data['set'])) {
|
|
116
|
+
let val;
|
|
117
|
+
let valueType = typeof value;
|
|
118
|
+
switch(valueType) {
|
|
119
|
+
case 'string':
|
|
120
|
+
val = value
|
|
121
|
+
break;
|
|
122
|
+
case 'number':
|
|
123
|
+
val = Number(value)
|
|
124
|
+
break;
|
|
125
|
+
case 'object':
|
|
126
|
+
if (Array.isArray(value))
|
|
127
|
+
val = new Array(...value)
|
|
128
|
+
else
|
|
129
|
+
val = new Object(value)
|
|
130
|
+
break;
|
|
131
|
+
default:
|
|
132
|
+
val = value
|
|
133
|
+
}
|
|
134
|
+
update.$set[key] = val
|
|
135
|
+
}
|
|
136
|
+
|
|
116
137
|
if( req_data['unset'] )
|
|
117
138
|
update['$unset'] = req_data['unset'].reduce((r, d) => {r[d] = ""; return r}, {});
|
|
118
139
|
update['$set']['organization_id'] = req_data['organization_id'];
|
package/src/database.js
ADDED
|
@@ -0,0 +1,47 @@
|
|
|
1
|
+
const {ObjectId} = require("mongodb");
|
|
2
|
+
const {encodeObject, replaceArray} = require("./utils.crud.js")
|
|
3
|
+
|
|
4
|
+
|
|
5
|
+
class CoCreateDatabases {
|
|
6
|
+
constructor(wsManager, dbClient) {
|
|
7
|
+
this.wsManager = wsManager
|
|
8
|
+
this.dbClient = dbClient
|
|
9
|
+
this.init();
|
|
10
|
+
}
|
|
11
|
+
|
|
12
|
+
init() {
|
|
13
|
+
if (this.wsManager) {
|
|
14
|
+
this.wsManager.on('readDatabases', (socket, data, socketInfo) => this.readDatabases(socket, data, socketInfo));
|
|
15
|
+
}
|
|
16
|
+
}
|
|
17
|
+
|
|
18
|
+
/** Create Document **/
|
|
19
|
+
async readDatabases(socket, req_data, socketInfo){
|
|
20
|
+
const self = this;
|
|
21
|
+
// if(!req_data.data) return;
|
|
22
|
+
|
|
23
|
+
try {
|
|
24
|
+
var db = this.dbClient.db().admin();
|
|
25
|
+
|
|
26
|
+
// List all the available databases
|
|
27
|
+
db.listDatabases(function(err, dbs) {
|
|
28
|
+
if (dbs.databases.length > 0){
|
|
29
|
+
console.log('dbs', dbs)
|
|
30
|
+
}
|
|
31
|
+
|
|
32
|
+
// db.close();
|
|
33
|
+
})
|
|
34
|
+
} catch(error) {
|
|
35
|
+
console.log('readDatabases error', error);
|
|
36
|
+
self.wsManager.send(socket, 'ServerError', 'error', socketInfo);
|
|
37
|
+
}
|
|
38
|
+
}
|
|
39
|
+
|
|
40
|
+
|
|
41
|
+
broadcast(socket, component, response, socketInfo) {
|
|
42
|
+
this.wsManager.broadcast(socket, response.namespace || response['organization_id'], response.room, component, response, socketInfo);
|
|
43
|
+
process.emit('changed-document', response)
|
|
44
|
+
}
|
|
45
|
+
}
|
|
46
|
+
|
|
47
|
+
module.exports = CoCreateDatabases;
|
package/src/index.js
CHANGED
|
@@ -3,9 +3,21 @@
|
|
|
3
3
|
const crud = require('./crud');
|
|
4
4
|
const list = require('./list');
|
|
5
5
|
const backup = require('./backup');
|
|
6
|
+
const database = require('./database');
|
|
6
7
|
|
|
7
|
-
|
|
8
|
-
|
|
9
|
-
|
|
10
|
-
|
|
11
|
-
|
|
8
|
+
class CoCreateCrudServer {
|
|
9
|
+
constructor(wsManager, dbClient) {
|
|
10
|
+
this.wsManager = wsManager
|
|
11
|
+
this.dbClient = dbClient
|
|
12
|
+
this.init()
|
|
13
|
+
}
|
|
14
|
+
|
|
15
|
+
init() {
|
|
16
|
+
new crud(this.wsManager, this.dbClient);
|
|
17
|
+
new list(this.wsManager, this.dbClient);
|
|
18
|
+
new backup(this.wsManager, this.dbClient);
|
|
19
|
+
new database(this.wsManager, this.dbClient);
|
|
20
|
+
}
|
|
21
|
+
}
|
|
22
|
+
|
|
23
|
+
module.exports = CoCreateCrudServer;
|