@cocreate/crud-server 1.4.4 → 1.6.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 +37 -16
- package/src/list.js +8 -8
package/CHANGELOG.md
CHANGED
|
@@ -1,3 +1,25 @@
|
|
|
1
|
+
# [1.6.0](https://github.com/CoCreate-app/CoCreate-crud-server/compare/v1.5.1...v1.6.0) (2022-05-25)
|
|
2
|
+
|
|
3
|
+
|
|
4
|
+
### Features
|
|
5
|
+
|
|
6
|
+
* auto detects and updates data type ([ddb1391](https://github.com/CoCreate-app/CoCreate-crud-server/commit/ddb1391928a8a7acccd8d9e4c920adfdeb63f002))
|
|
7
|
+
|
|
8
|
+
## [1.5.1](https://github.com/CoCreate-app/CoCreate-crud-server/compare/v1.5.0...v1.5.1) (2022-05-17)
|
|
9
|
+
|
|
10
|
+
|
|
11
|
+
### Bug Fixes
|
|
12
|
+
|
|
13
|
+
* get orgId from socketInfo ([da03da3](https://github.com/CoCreate-app/CoCreate-crud-server/commit/da03da39aa383c71a802bbbfa9ecea5b637c5262))
|
|
14
|
+
* reorder broadcast params ([96deccb](https://github.com/CoCreate-app/CoCreate-crud-server/commit/96deccb415e47dbfbfad4311985b3a7082cb57ff))
|
|
15
|
+
|
|
16
|
+
# [1.5.0](https://github.com/CoCreate-app/CoCreate-crud-server/compare/v1.4.4...v1.5.0) (2022-05-14)
|
|
17
|
+
|
|
18
|
+
|
|
19
|
+
### Features
|
|
20
|
+
|
|
21
|
+
* function readDocumentList has been renamed to readDocuments ([3081581](https://github.com/CoCreate-app/CoCreate-crud-server/commit/308158148dccc82411e625d8270e5dd107b7df94))
|
|
22
|
+
|
|
1
23
|
## [1.4.4](https://github.com/CoCreate-app/CoCreate-crud-server/compare/v1.4.3...v1.4.4) (2022-05-13)
|
|
2
24
|
|
|
3
25
|
|
package/package.json
CHANGED
package/src/crud.js
CHANGED
|
@@ -35,21 +35,21 @@ class CoCreateCrud {
|
|
|
35
35
|
// let isFlat = req_data.isFlat == false ? false : true;
|
|
36
36
|
// const response_data = isFlat ? encodeObject(response) : response;
|
|
37
37
|
// const response_data = response;
|
|
38
|
-
self.broadcast('createDocument',
|
|
38
|
+
self.broadcast(socket, 'createDocument', response, socketInfo)
|
|
39
39
|
} else {
|
|
40
|
-
self.wsManager.send(socket, 'ServerError', error,
|
|
40
|
+
self.wsManager.send(socket, 'ServerError', error, socketInfo);
|
|
41
41
|
}
|
|
42
42
|
});
|
|
43
43
|
}catch(error){
|
|
44
44
|
console.log('createDocument error', error);
|
|
45
|
-
self.wsManager.send(socket, 'ServerError', 'error',
|
|
45
|
+
self.wsManager.send(socket, 'ServerError', 'error', socketInfo);
|
|
46
46
|
}
|
|
47
47
|
}
|
|
48
48
|
|
|
49
49
|
/** Read Document **/
|
|
50
50
|
async readDocument(socket, req_data, socketInfo) {
|
|
51
51
|
if (!req_data['collection'] || req_data['collection'] == 'null' || typeof req_data['collection'] !== 'string') {
|
|
52
|
-
this.wsManager.send(socket, 'ServerError', 'error',
|
|
52
|
+
this.wsManager.send(socket, 'ServerError', 'error', socketInfo);
|
|
53
53
|
return;
|
|
54
54
|
}
|
|
55
55
|
const self = this;
|
|
@@ -82,14 +82,14 @@ class CoCreateCrud {
|
|
|
82
82
|
}
|
|
83
83
|
|
|
84
84
|
let isFlat = req_data.isFlat == true ? true : false;
|
|
85
|
-
self.wsManager.send(socket, 'readDocument', { ...req_data, data: isFlat ? encodeObject(tmp) : tmp },
|
|
85
|
+
self.wsManager.send(socket, 'readDocument', { ...req_data, data: isFlat ? encodeObject(tmp) : tmp }, socketInfo);
|
|
86
86
|
} else {
|
|
87
|
-
self.wsManager.send(socket, '
|
|
87
|
+
self.wsManager.send(socket, 'readDocument error', req_data, socketInfo);
|
|
88
88
|
}
|
|
89
89
|
});
|
|
90
90
|
} catch (error) {
|
|
91
91
|
console.log('readDocument error', error, req_data);
|
|
92
|
-
self.wsManager.send(socket, 'ServerError', 'error',
|
|
92
|
+
self.wsManager.send(socket, 'ServerError', 'error', socketInfo);
|
|
93
93
|
}
|
|
94
94
|
}
|
|
95
95
|
|
|
@@ -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'];
|
|
@@ -136,15 +157,15 @@ class CoCreateCrud {
|
|
|
136
157
|
if(req_data['unset'])
|
|
137
158
|
response['delete_fields'] = req_data['unset'];
|
|
138
159
|
|
|
139
|
-
self.broadcast('updateDocument',
|
|
160
|
+
self.broadcast(socket, 'updateDocument', response, socketInfo)
|
|
140
161
|
}).catch((error) => {
|
|
141
162
|
console.log('error', error)
|
|
142
|
-
self.wsManager.send(socket, 'ServerError', error,
|
|
163
|
+
self.wsManager.send(socket, 'ServerError', error, socketInfo);
|
|
143
164
|
});
|
|
144
165
|
|
|
145
166
|
} catch (error) {
|
|
146
167
|
console.log(error)
|
|
147
|
-
self.wsManager.send(socket, 'updateDocumentError', error,
|
|
168
|
+
self.wsManager.send(socket, 'updateDocumentError', error, socketInfo);
|
|
148
169
|
}
|
|
149
170
|
}
|
|
150
171
|
|
|
@@ -162,18 +183,18 @@ class CoCreateCrud {
|
|
|
162
183
|
collection.deleteOne(query, function(error, result) {
|
|
163
184
|
if (!error) {
|
|
164
185
|
let response = { ...req_data }
|
|
165
|
-
self.broadcast('deleteDocument',
|
|
186
|
+
self.broadcast(socket, 'deleteDocument', response, socketInfo)
|
|
166
187
|
} else {
|
|
167
|
-
self.wsManager.send(socket, 'ServerError', error,
|
|
188
|
+
self.wsManager.send(socket, 'ServerError', error, socketInfo);
|
|
168
189
|
}
|
|
169
190
|
})
|
|
170
191
|
} catch (error) {
|
|
171
192
|
console.log(error);
|
|
172
|
-
self.wsManager.send(socket, 'ServerError', 'error',
|
|
193
|
+
self.wsManager.send(socket, 'ServerError', 'error', socketInfo);
|
|
173
194
|
}
|
|
174
195
|
}
|
|
175
196
|
|
|
176
|
-
broadcast(
|
|
197
|
+
broadcast(socket, component, response, socketInfo) {
|
|
177
198
|
this.wsManager.broadcast(socket, response.namespace || response['organization_id'], response.room, component, response, socketInfo);
|
|
178
199
|
process.emit('changed-document', response)
|
|
179
200
|
}
|
package/src/list.js
CHANGED
|
@@ -8,7 +8,7 @@ class CoCreateList {
|
|
|
8
8
|
}
|
|
9
9
|
|
|
10
10
|
init() {
|
|
11
|
-
this.wsManager.on('
|
|
11
|
+
this.wsManager.on('readDocuments', (socket, data, socketInfo) => this.readDocuments(socket, data, socketInfo));
|
|
12
12
|
this.wsManager.on('readCollections', (socket, data, socketInfo) => this.readCollections(socket, data, socketInfo));
|
|
13
13
|
}
|
|
14
14
|
|
|
@@ -46,7 +46,7 @@ class CoCreateList {
|
|
|
46
46
|
data: [] // array
|
|
47
47
|
}
|
|
48
48
|
**/
|
|
49
|
-
async
|
|
49
|
+
async readDocuments(socket, req_data, socketInfo) {
|
|
50
50
|
function sleep(ms) {
|
|
51
51
|
return new Promise((resolve) => {
|
|
52
52
|
setTimeout(resolve, ms);
|
|
@@ -113,15 +113,15 @@ class CoCreateList {
|
|
|
113
113
|
|
|
114
114
|
result_data = result;
|
|
115
115
|
}
|
|
116
|
-
self.wsManager.send(socket, '
|
|
116
|
+
self.wsManager.send(socket, 'readDocuments', { ...req_data, data: result_data, operator: {...operator, total: total}}, socketInfo);
|
|
117
117
|
} else {
|
|
118
118
|
console.log(error)
|
|
119
|
-
self.wsManager.send(socket, 'ServerError', error,
|
|
119
|
+
self.wsManager.send(socket, 'ServerError', error, socketInfo);
|
|
120
120
|
}
|
|
121
121
|
})
|
|
122
122
|
} catch (error) {
|
|
123
|
-
console.log('
|
|
124
|
-
this.wsManager.send(socket, 'ServerError', 'error',
|
|
123
|
+
console.log('readDocuments error', error);
|
|
124
|
+
this.wsManager.send(socket, 'ServerError', 'error', socketInfo);
|
|
125
125
|
}
|
|
126
126
|
}
|
|
127
127
|
|
|
@@ -131,12 +131,12 @@ class CoCreateList {
|
|
|
131
131
|
const db = this.dbClient.db(data['organization_id']);
|
|
132
132
|
db.listCollections().toArray(function(error, result) {
|
|
133
133
|
if (!error && result && result.length > 0) {
|
|
134
|
-
self.wsManager.send(socket, 'readCollections', {...data, data: result },
|
|
134
|
+
self.wsManager.send(socket, 'readCollections', {...data, data: result }, socketInfo);
|
|
135
135
|
}
|
|
136
136
|
})
|
|
137
137
|
} catch(error) {
|
|
138
138
|
console.log('readCollections error', error);
|
|
139
|
-
this.wsManager.send(socket, 'ServerError', 'error',
|
|
139
|
+
this.wsManager.send(socket, 'ServerError', 'error', socketInfo);
|
|
140
140
|
}
|
|
141
141
|
}
|
|
142
142
|
|