@decaf-ts/for-couchdb 0.0.2 → 0.1.1
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/dist/esm/for-couchdb.bundle.min.esm.js +1 -1
- package/dist/esm/for-couchdb.bundle.min.esm.js.LICENSE.txt +0 -11
- package/dist/for-couchdb.bundle.min.js +1 -1
- package/dist/for-couchdb.bundle.min.js.LICENSE.txt +0 -11
- package/docker/.dockerignore +5 -0
- package/docker/.env +7 -0
- package/docker/Dockerfile-booter +19 -0
- package/docker/Dockerfile-couchdb +4 -0
- package/docker/couchdb.ini +886 -0
- package/docker/docker-compose.yml +109 -0
- package/docker/init-cluster.sh +66 -0
- package/lib/adapter.cjs +80 -88
- package/lib/adapter.d.ts +11 -12
- package/lib/constants.cjs +2 -1
- package/lib/constants.d.ts +1 -0
- package/lib/esm/adapter.d.ts +11 -12
- package/lib/esm/adapter.js +80 -88
- package/lib/esm/constants.d.ts +1 -0
- package/lib/esm/constants.js +2 -1
- package/lib/esm/index.d.ts +4 -1
- package/lib/esm/index.js +5 -2
- package/lib/esm/indexes/generator.d.ts +1 -1
- package/lib/esm/indexes/generator.js +1 -1
- package/lib/esm/indexes/index.d.ts +0 -1
- package/lib/esm/indexes/index.js +1 -2
- package/lib/esm/interfaces/CouchDBRepository.d.ts +1 -1
- package/lib/esm/interfaces/CouchDBRepository.js +1 -1
- package/lib/esm/query/FromClause.d.ts +1 -1
- package/lib/esm/query/FromClause.js +1 -1
- package/lib/esm/query/InsertClause.d.ts +1 -1
- package/lib/esm/query/InsertClause.js +1 -1
- package/lib/esm/query/Paginator.d.ts +1 -1
- package/lib/esm/query/Paginator.js +1 -1
- package/lib/esm/query/SelectClause.d.ts +1 -1
- package/lib/esm/query/SelectClause.js +1 -1
- package/lib/esm/query/Statement.d.ts +3 -3
- package/lib/esm/query/Statement.js +1 -1
- package/lib/esm/query/ValuesClause.d.ts +1 -1
- package/lib/esm/query/ValuesClause.js +1 -1
- package/lib/esm/query/WhereClause.d.ts +1 -1
- package/lib/esm/query/WhereClause.js +1 -1
- package/lib/esm/query/constants.d.ts +1 -1
- package/lib/esm/query/constants.js +1 -1
- package/lib/esm/query/factory.d.ts +1 -1
- package/lib/esm/query/factory.js +1 -1
- package/lib/esm/query/translate.d.ts +1 -1
- package/lib/esm/query/translate.js +1 -1
- package/lib/esm/types.d.ts +406 -0
- package/lib/esm/types.js +3 -0
- package/lib/esm/utils.d.ts +3 -3
- package/lib/esm/utils.js +1 -1
- package/lib/index.cjs +5 -2
- package/lib/index.d.ts +4 -1
- package/lib/indexes/generator.cjs +1 -1
- package/lib/indexes/generator.d.ts +1 -1
- package/lib/indexes/index.cjs +1 -2
- package/lib/indexes/index.d.ts +0 -1
- package/lib/interfaces/CouchDBRepository.cjs +1 -1
- package/lib/interfaces/CouchDBRepository.d.ts +1 -1
- package/lib/query/FromClause.cjs +1 -1
- package/lib/query/FromClause.d.ts +1 -1
- package/lib/query/InsertClause.cjs +1 -1
- package/lib/query/InsertClause.d.ts +1 -1
- package/lib/query/Paginator.cjs +1 -1
- package/lib/query/Paginator.d.ts +1 -1
- package/lib/query/SelectClause.cjs +1 -1
- package/lib/query/SelectClause.d.ts +1 -1
- package/lib/query/Statement.cjs +1 -1
- package/lib/query/Statement.d.ts +3 -3
- package/lib/query/ValuesClause.cjs +1 -1
- package/lib/query/ValuesClause.d.ts +1 -1
- package/lib/query/WhereClause.cjs +1 -1
- package/lib/query/WhereClause.d.ts +1 -1
- package/lib/query/constants.cjs +1 -1
- package/lib/query/constants.d.ts +1 -1
- package/lib/query/factory.cjs +1 -1
- package/lib/query/factory.d.ts +1 -1
- package/lib/query/translate.cjs +1 -1
- package/lib/query/translate.d.ts +1 -1
- package/lib/types.cjs +4 -0
- package/lib/types.d.ts +406 -0
- package/lib/utils.cjs +1 -1
- package/lib/utils.d.ts +3 -3
- package/package.json +10 -16
- package/lib/esm/indexes/types.d.ts +0 -11
- package/lib/esm/indexes/types.js +0 -3
- package/lib/indexes/types.cjs +0 -4
- package/lib/indexes/types.d.ts +0 -11
|
@@ -0,0 +1,109 @@
|
|
|
1
|
+
version: "3.9"
|
|
2
|
+
|
|
3
|
+
services:
|
|
4
|
+
replica-0:
|
|
5
|
+
image: ghcr.io/decaf-ts/couchdb:latest
|
|
6
|
+
hostname: replica-0
|
|
7
|
+
container_name: replica-0
|
|
8
|
+
restart: always
|
|
9
|
+
environment:
|
|
10
|
+
COUCHDB_USER: ${COUCHDB_USER}
|
|
11
|
+
COUCHDB_PASSWORD: ${COUCHDB_PASSWORD}
|
|
12
|
+
COUCHDB_SECRET: ${COUCHDB_SECRET}
|
|
13
|
+
NODENAME: replica-0.${COMPOSE_PROJECT_NAME}
|
|
14
|
+
ERL_FLAGS: "-setcookie ${COUCHDB_COOKIE}"
|
|
15
|
+
networks:
|
|
16
|
+
replicas_net:
|
|
17
|
+
aliases:
|
|
18
|
+
- replica-0.${COMPOSE_PROJECT_NAME}
|
|
19
|
+
ports:
|
|
20
|
+
- "${PORT_BASE}0:5984"
|
|
21
|
+
volumes:
|
|
22
|
+
- couch-replica-0:/opt/couchdb/data
|
|
23
|
+
- cfg-replica-0:/opt/couchdb/etc/local.d
|
|
24
|
+
healthcheck:
|
|
25
|
+
test: curl -f http://localhost:5984/ || exit 1
|
|
26
|
+
interval: 3s
|
|
27
|
+
timeout: 3s
|
|
28
|
+
retries: 10
|
|
29
|
+
replica-1:
|
|
30
|
+
image: ghcr.io/decaf-ts/couchdb:latest
|
|
31
|
+
hostname: replica-1
|
|
32
|
+
container_name: replica-1
|
|
33
|
+
restart: always
|
|
34
|
+
environment:
|
|
35
|
+
COUCHDB_USER: ${COUCHDB_USER}
|
|
36
|
+
COUCHDB_PASSWORD: ${COUCHDB_PASSWORD}
|
|
37
|
+
COUCHDB_SECRET: ${COUCHDB_SECRET}
|
|
38
|
+
NODENAME: replica-1.${COMPOSE_PROJECT_NAME}
|
|
39
|
+
ERL_FLAGS: "-setcookie ${COUCHDB_COOKIE}"
|
|
40
|
+
networks:
|
|
41
|
+
replicas_net:
|
|
42
|
+
aliases:
|
|
43
|
+
- replica-1.${COMPOSE_PROJECT_NAME}
|
|
44
|
+
ports:
|
|
45
|
+
- "${PORT_BASE}1:5984"
|
|
46
|
+
volumes:
|
|
47
|
+
- couch-replica-1:/opt/couchdb/data
|
|
48
|
+
- cfg-replica-1:/opt/couchdb/etc/local.d
|
|
49
|
+
healthcheck:
|
|
50
|
+
test: curl -f http://localhost:5984/ || exit 1
|
|
51
|
+
interval: 3s
|
|
52
|
+
timeout: 3s
|
|
53
|
+
retries: 10
|
|
54
|
+
replica-2:
|
|
55
|
+
image: ghcr.io/decaf-ts/couchdb:latest
|
|
56
|
+
hostname: replica-2
|
|
57
|
+
container_name: replica-2
|
|
58
|
+
restart: always
|
|
59
|
+
environment:
|
|
60
|
+
COUCHDB_USER: ${COUCHDB_USER}
|
|
61
|
+
COUCHDB_PASSWORD: ${COUCHDB_PASSWORD}
|
|
62
|
+
COUCHDB_SECRET: ${COUCHDB_SECRET}
|
|
63
|
+
NODENAME: replica-2.${COMPOSE_PROJECT_NAME}
|
|
64
|
+
ERL_FLAGS: "-setcookie ${COUCHDB_COOKIE}"
|
|
65
|
+
networks:
|
|
66
|
+
replicas_net:
|
|
67
|
+
aliases:
|
|
68
|
+
- replica-2.${COMPOSE_PROJECT_NAME}
|
|
69
|
+
ports:
|
|
70
|
+
- "${PORT_BASE}2:5984"
|
|
71
|
+
volumes:
|
|
72
|
+
- couch-replica-2:/opt/couchdb/data
|
|
73
|
+
- cfg-replica-2:/opt/couchdb/etc/local.d
|
|
74
|
+
healthcheck:
|
|
75
|
+
test: curl -f http://localhost:5984/ || exit 1
|
|
76
|
+
interval: 3s
|
|
77
|
+
timeout: 3s
|
|
78
|
+
retries: 10
|
|
79
|
+
booter:
|
|
80
|
+
image: ghcr.io/decaf-ts/couchdb-booter:latest
|
|
81
|
+
container_name: cluster-booter
|
|
82
|
+
hostname: cluster-booter
|
|
83
|
+
restart: on-failure
|
|
84
|
+
depends_on:
|
|
85
|
+
replica-0:
|
|
86
|
+
condition: service_healthy
|
|
87
|
+
replica-1:
|
|
88
|
+
condition: service_healthy
|
|
89
|
+
replica-2:
|
|
90
|
+
condition: service_healthy
|
|
91
|
+
networks:
|
|
92
|
+
replicas_net:
|
|
93
|
+
aliases:
|
|
94
|
+
- booter.${COMPOSE_PROJECT_NAME}
|
|
95
|
+
environment:
|
|
96
|
+
COORDINATOR_HOST: replica-0.${COMPOSE_PROJECT_NAME}
|
|
97
|
+
REPLICA1_HOST: replica-1.${COMPOSE_PROJECT_NAME}
|
|
98
|
+
REPLICA2_HOST: replica-2.${COMPOSE_PROJECT_NAME}
|
|
99
|
+
|
|
100
|
+
networks:
|
|
101
|
+
replicas_net:
|
|
102
|
+
|
|
103
|
+
volumes:
|
|
104
|
+
couch-replica-0:
|
|
105
|
+
cfg-replica-0:
|
|
106
|
+
couch-replica-1:
|
|
107
|
+
cfg-replica-1:
|
|
108
|
+
couch-replica-2:
|
|
109
|
+
cfg-replica-2:
|
|
@@ -0,0 +1,66 @@
|
|
|
1
|
+
#!/bin/bash -e
|
|
2
|
+
|
|
3
|
+
echo "Booting clustered"
|
|
4
|
+
|
|
5
|
+
source .env
|
|
6
|
+
|
|
7
|
+
DEPLOYMENT_NAME=${COMPOSE_PROJECT_NAME}
|
|
8
|
+
IFS=","
|
|
9
|
+
COORDINATOR_NODE="0"
|
|
10
|
+
|
|
11
|
+
OUTER_PORT=$([ -z "$COORDINATOR_HOST" ] && echo "${PORT_BASE}0" || echo "5984")
|
|
12
|
+
|
|
13
|
+
COORDINATOR_HOST=$([ -z "$COORDINATOR_HOST" ] && echo "127.0.0.1" || echo "$COORDINATOR_HOST")
|
|
14
|
+
REPLICA1_HOST=$([ -z "$REPLICA1_HOST" ] && echo "127.0.0.1" || echo "$REPLICA1_HOST")
|
|
15
|
+
REPLICA2_HOST=$([ -z "$REPLICA2_HOST" ] && echo "127.0.0.1" || echo "$REPLICA2_HOST")
|
|
16
|
+
ADDITIONAL_NODES="1,2"
|
|
17
|
+
ALL_NODES="${COORDINATOR_NODE},${ADDITIONAL_NODES}"
|
|
18
|
+
HOSTS=("${COORDINATOR_HOST}" "${REPLICA1_HOST}" "${REPLICA2_HOST}")
|
|
19
|
+
|
|
20
|
+
|
|
21
|
+
# check if already running and clustered, and if so, exit
|
|
22
|
+
curl -s "http://${COUCHDB_USER}:${COUCHDB_PASSWORD}@${COORDINATOR_HOST}:${OUTER_PORT}/_cluster_setup"
|
|
23
|
+
STATUS=$(curl -s "http://${COUCHDB_USER}:${COUCHDB_PASSWORD}@${COORDINATOR_HOST}:${OUTER_PORT}/_cluster_setup")
|
|
24
|
+
|
|
25
|
+
if [[ "$STATUS" =~ "cluster_finished" ]]; then
|
|
26
|
+
echo "Cluster already set up"
|
|
27
|
+
exit 0
|
|
28
|
+
else
|
|
29
|
+
echo "Setting up cluster"
|
|
30
|
+
fi
|
|
31
|
+
|
|
32
|
+
# https://docs.couchdb.org/en/stable/setup/single-node.html
|
|
33
|
+
|
|
34
|
+
for NODE_ID in $ALL_NODES
|
|
35
|
+
do
|
|
36
|
+
PORT=$([ "$OUTER_PORT" == "5984" ] && echo "$OUTER_PORT" || echo "${PORT_BASE}${NODE_ID}")
|
|
37
|
+
curl -X PUT "${COUCHDB_USER}:${COUCHDB_PASSWORD}@${HOSTS[${NODE_ID}]}:${PORT}/_users"
|
|
38
|
+
curl -X PUT "http://${COUCHDB_USER}:${COUCHDB_PASSWORD}@${HOSTS[${NODE_ID}]}:${PORT}/_replicator"
|
|
39
|
+
done
|
|
40
|
+
|
|
41
|
+
# see https://docs.couchdb.org/en/master/setup/cluster.html
|
|
42
|
+
|
|
43
|
+
for NODE_ID in $COORDINATOR_NODE
|
|
44
|
+
do
|
|
45
|
+
curl -X POST -H "Content-Type: application/json" "http://${COUCHDB_USER}:${COUCHDB_PASSWORD}@${COORDINATOR_HOST}:${OUTER_PORT}/_cluster_setup" \
|
|
46
|
+
-d '{"action": "enable_cluster", "bind_address":"0.0.0.0", "username": "'"${COUCHDB_USER}"'", "password":"'"${COUCHDB_USER}"'", "node_count":"3"}'
|
|
47
|
+
echo You may safely ignore the warning above.
|
|
48
|
+
done
|
|
49
|
+
|
|
50
|
+
for NODE_ID in $ADDITIONAL_NODES
|
|
51
|
+
do
|
|
52
|
+
curl -X POST -H "Content-Type: application/json" "http://${COUCHDB_USER}:${COUCHDB_PASSWORD}@${COORDINATOR_HOST}:${OUTER_PORT}/_cluster_setup" -d '{"action": "enable_cluster", "bind_address":"0.0.0.0", "username": "'"${COUCHDB_USER}"'", "password":"'"${COUCHDB_PASSWORD}"'", "port": 5984, "node_count": "3", "remote_node": "'"replica-${NODE_ID}.${DEPLOYMENT_NAME}"'", "remote_current_user": "'"${COUCHDB_USER}"'", "remote_current_password": "'"${COUCHDB_PASSWORD}"'" }'
|
|
53
|
+
curl -X POST -H "Content-Type: application/json" "http://${COUCHDB_USER}:${COUCHDB_PASSWORD}@${COORDINATOR_HOST}:${OUTER_PORT}/_cluster_setup" -d '{"action": "add_node", "host":"'"replica-${NODE_ID}.${DEPLOYMENT_NAME}"'", "port": 5984, "username": "'"${COUCHDB_USER}"'", "password":"'"${COUCHDB_PASSWORD}"'"}'
|
|
54
|
+
done
|
|
55
|
+
|
|
56
|
+
curl -s "http://${COUCHDB_USER}:${COUCHDB_PASSWORD}@${COORDINATOR_HOST}:${OUTER_PORT}/_cluster_setup"
|
|
57
|
+
|
|
58
|
+
curl -s "http://${COUCHDB_USER}:${COUCHDB_PASSWORD}@${COORDINATOR_HOST}:${OUTER_PORT}/_membership"
|
|
59
|
+
|
|
60
|
+
|
|
61
|
+
echo Your cluster nodes are available at:
|
|
62
|
+
for NODE_ID in ${ALL_NODES}
|
|
63
|
+
do
|
|
64
|
+
PORT=$([ "$OUTER_PORT" == "5984" ] && echo "$OUTER_PORT" || echo "${PORT_BASE}${NODE_ID}")
|
|
65
|
+
echo "http://${COUCHDB_USER}:<password>@${HOSTS[${NODE_ID}]}:${PORT}"
|
|
66
|
+
done
|
package/lib/adapter.cjs
CHANGED
|
@@ -2,7 +2,6 @@
|
|
|
2
2
|
Object.defineProperty(exports, "__esModule", { value: true });
|
|
3
3
|
exports.CouchDBAdapter = void 0;
|
|
4
4
|
const core_1 = require("@decaf-ts/core");
|
|
5
|
-
const Nano = require("nano");
|
|
6
5
|
const constants_1 = require("./constants.cjs");
|
|
7
6
|
const db_decorators_1 = require("@decaf-ts/db-decorators");
|
|
8
7
|
require("reflect-metadata");
|
|
@@ -68,15 +67,6 @@ class CouchDBAdapter extends core_1.Adapter {
|
|
|
68
67
|
throw new db_decorators_1.ConflictError(`Index for table ${name} with id ${id}`);
|
|
69
68
|
}
|
|
70
69
|
}
|
|
71
|
-
async user() {
|
|
72
|
-
try {
|
|
73
|
-
const user = await this.native[constants_1.CouchDBKeys.NATIVE].session();
|
|
74
|
-
return user.userCtx.name;
|
|
75
|
-
}
|
|
76
|
-
catch (e) {
|
|
77
|
-
throw this.parseError(e);
|
|
78
|
-
}
|
|
79
|
-
}
|
|
80
70
|
async raw(rawInput, process = true) {
|
|
81
71
|
try {
|
|
82
72
|
const response = await this.native.find(rawInput);
|
|
@@ -157,6 +147,23 @@ class CouchDBAdapter extends core_1.Adapter {
|
|
|
157
147
|
});
|
|
158
148
|
return record;
|
|
159
149
|
}
|
|
150
|
+
async readAll(tableName, ids) {
|
|
151
|
+
const results = await this.native.fetch({ keys: ids.map((id) => this.generateId(tableName, id)) }, {});
|
|
152
|
+
return results.rows.map((r) => {
|
|
153
|
+
if (r.error)
|
|
154
|
+
throw new db_decorators_1.InternalError(r.error);
|
|
155
|
+
if (r.doc) {
|
|
156
|
+
const res = Object.assign({}, r.doc);
|
|
157
|
+
Object.defineProperty(res, core_1.PersistenceKeys.METADATA, {
|
|
158
|
+
enumerable: false,
|
|
159
|
+
writable: false,
|
|
160
|
+
value: r.doc[constants_1.CouchDBKeys.REV],
|
|
161
|
+
});
|
|
162
|
+
return res;
|
|
163
|
+
}
|
|
164
|
+
throw new db_decorators_1.InternalError("Should be impossible");
|
|
165
|
+
});
|
|
166
|
+
}
|
|
160
167
|
async update(tableName, id, model) {
|
|
161
168
|
const record = {};
|
|
162
169
|
record[constants_1.CouchDBKeys.TABLE] = tableName;
|
|
@@ -183,6 +190,41 @@ class CouchDBAdapter extends core_1.Adapter {
|
|
|
183
190
|
});
|
|
184
191
|
return model;
|
|
185
192
|
}
|
|
193
|
+
async updateAll(tableName, ids, models) {
|
|
194
|
+
if (ids.length !== models.length)
|
|
195
|
+
throw new db_decorators_1.InternalError("Ids and models must have the same length");
|
|
196
|
+
const records = ids.map((id, count) => {
|
|
197
|
+
const record = {};
|
|
198
|
+
record[constants_1.CouchDBKeys.TABLE] = tableName;
|
|
199
|
+
record[constants_1.CouchDBKeys.ID] = this.generateId(tableName, id);
|
|
200
|
+
const rev = models[count][core_1.PersistenceKeys.METADATA];
|
|
201
|
+
if (!rev)
|
|
202
|
+
throw new db_decorators_1.InternalError(`No revision number found for record with id ${id}`);
|
|
203
|
+
Object.assign(record, models[count]);
|
|
204
|
+
record[constants_1.CouchDBKeys.REV] = rev;
|
|
205
|
+
return record;
|
|
206
|
+
});
|
|
207
|
+
let response;
|
|
208
|
+
try {
|
|
209
|
+
response = await this.native.bulk({ docs: records });
|
|
210
|
+
}
|
|
211
|
+
catch (e) {
|
|
212
|
+
throw this.parseError(e);
|
|
213
|
+
}
|
|
214
|
+
if (!response.every((r) => !r.error)) {
|
|
215
|
+
const errors = response.reduce((accum, el, i) => {
|
|
216
|
+
if (el.error)
|
|
217
|
+
accum.push(`el ${i}: ${el.error}${el.reason ? ` - ${el.reason}` : ""}`);
|
|
218
|
+
return accum;
|
|
219
|
+
}, []);
|
|
220
|
+
throw new db_decorators_1.InternalError(errors.join("\n"));
|
|
221
|
+
}
|
|
222
|
+
models.forEach((m, i) => {
|
|
223
|
+
core_1.Repository.setMetadata(m, response[i].rev);
|
|
224
|
+
return m;
|
|
225
|
+
});
|
|
226
|
+
return models;
|
|
227
|
+
}
|
|
186
228
|
async delete(tableName, id) {
|
|
187
229
|
const _id = this.generateId(tableName, id);
|
|
188
230
|
let record;
|
|
@@ -201,6 +243,33 @@ class CouchDBAdapter extends core_1.Adapter {
|
|
|
201
243
|
});
|
|
202
244
|
return record;
|
|
203
245
|
}
|
|
246
|
+
async deleteAll(tableName, ids) {
|
|
247
|
+
const results = await this.native.fetch({ keys: ids.map((id) => this.generateId(tableName, id)) }, {});
|
|
248
|
+
const deletion = await this.native.bulk({
|
|
249
|
+
docs: results.rows.map((r) => {
|
|
250
|
+
r[constants_1.CouchDBKeys.DELETED] = true;
|
|
251
|
+
return r;
|
|
252
|
+
}),
|
|
253
|
+
});
|
|
254
|
+
deletion.forEach((d) => {
|
|
255
|
+
if (d.error)
|
|
256
|
+
console.error(d.error);
|
|
257
|
+
});
|
|
258
|
+
return results.rows.map((r) => {
|
|
259
|
+
if (r.error)
|
|
260
|
+
throw new db_decorators_1.InternalError(r.error);
|
|
261
|
+
if (r.doc) {
|
|
262
|
+
const res = Object.assign({}, r.doc);
|
|
263
|
+
Object.defineProperty(res, core_1.PersistenceKeys.METADATA, {
|
|
264
|
+
enumerable: false,
|
|
265
|
+
writable: false,
|
|
266
|
+
value: r.doc[constants_1.CouchDBKeys.REV],
|
|
267
|
+
});
|
|
268
|
+
return res;
|
|
269
|
+
}
|
|
270
|
+
throw new db_decorators_1.InternalError("Should be impossible");
|
|
271
|
+
});
|
|
272
|
+
}
|
|
204
273
|
generateId(tableName, id) {
|
|
205
274
|
return [tableName, id].join(constants_1.CouchDBKeys.SEPARATOR);
|
|
206
275
|
}
|
|
@@ -249,84 +318,7 @@ class CouchDBAdapter extends core_1.Adapter {
|
|
|
249
318
|
return new db_decorators_1.InternalError(err);
|
|
250
319
|
}
|
|
251
320
|
}
|
|
252
|
-
static connect(user, pass, host = "localhost:5984", protocol = "http") {
|
|
253
|
-
return Nano(`${protocol}://${user}:${pass}@${host}`);
|
|
254
|
-
}
|
|
255
|
-
static async createDatabase(con, name) {
|
|
256
|
-
let result;
|
|
257
|
-
try {
|
|
258
|
-
result = await con.db.create(name);
|
|
259
|
-
}
|
|
260
|
-
catch (e) {
|
|
261
|
-
throw this.parseError(e);
|
|
262
|
-
}
|
|
263
|
-
const { ok, error, reason } = result;
|
|
264
|
-
if (!ok)
|
|
265
|
-
throw this.parseError(error, reason);
|
|
266
|
-
}
|
|
267
|
-
static async deleteDatabase(con, name) {
|
|
268
|
-
let result;
|
|
269
|
-
try {
|
|
270
|
-
result = await con.db.destroy(name);
|
|
271
|
-
}
|
|
272
|
-
catch (e) {
|
|
273
|
-
throw this.parseError(e);
|
|
274
|
-
}
|
|
275
|
-
const { ok } = result;
|
|
276
|
-
if (!ok)
|
|
277
|
-
throw new db_decorators_1.InternalError(`Failed to delete database with name ${name}`);
|
|
278
|
-
}
|
|
279
|
-
static async createUser(con, dbName, user, pass, roles = ["reader", "writer"]) {
|
|
280
|
-
const users = await con.db.use("_users");
|
|
281
|
-
const usr = {
|
|
282
|
-
_id: "org.couchdb.user:" + user,
|
|
283
|
-
name: user,
|
|
284
|
-
password: pass,
|
|
285
|
-
roles: roles,
|
|
286
|
-
type: "user",
|
|
287
|
-
};
|
|
288
|
-
try {
|
|
289
|
-
const created = await users.insert(usr);
|
|
290
|
-
const { ok } = created;
|
|
291
|
-
if (!ok)
|
|
292
|
-
throw new db_decorators_1.InternalError(`Failed to create user ${user}`);
|
|
293
|
-
const security = await con.request({
|
|
294
|
-
db: dbName,
|
|
295
|
-
method: "put",
|
|
296
|
-
path: "_security",
|
|
297
|
-
// headers: {
|
|
298
|
-
//
|
|
299
|
-
// },
|
|
300
|
-
body: {
|
|
301
|
-
admins: {
|
|
302
|
-
names: [user],
|
|
303
|
-
roles: [],
|
|
304
|
-
},
|
|
305
|
-
members: {
|
|
306
|
-
names: [user],
|
|
307
|
-
roles: roles,
|
|
308
|
-
},
|
|
309
|
-
},
|
|
310
|
-
});
|
|
311
|
-
if (!security.ok)
|
|
312
|
-
throw new db_decorators_1.InternalError(`Failed to authorize user ${user} to db ${dbName}`);
|
|
313
|
-
}
|
|
314
|
-
catch (e) {
|
|
315
|
-
throw this.parseError(e);
|
|
316
|
-
}
|
|
317
|
-
}
|
|
318
|
-
static async deleteUser(con, dbName, user) {
|
|
319
|
-
const users = await con.db.use("_users");
|
|
320
|
-
const id = "org.couchdb.user:" + user;
|
|
321
|
-
try {
|
|
322
|
-
const usr = await users.get(id);
|
|
323
|
-
await users.destroy(id, usr._rev);
|
|
324
|
-
}
|
|
325
|
-
catch (e) {
|
|
326
|
-
throw this.parseError(e);
|
|
327
|
-
}
|
|
328
|
-
}
|
|
329
321
|
}
|
|
330
322
|
exports.CouchDBAdapter = CouchDBAdapter;
|
|
331
323
|
|
|
332
|
-
//# sourceMappingURL=data:application/json;charset=utf8;base64,{"version":3,"sources":["src/adapter.ts"],"names":[],"mappings":"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","file":"adapter.js","sourcesContent":["import {\n  Adapter,\n  Sequence,\n  SequenceOptions,\n  PersistenceKeys,\n  Operator,\n  GroupOperator,\n  Statement,\n  Query,\n  ClauseFactory,\n  Condition,\n  ConnectionError,\n  Repository,\n} from \"@decaf-ts/core\";\nimport {\n  MangoQuery,\n  DocumentScope,\n  DocumentInsertResponse,\n  DocumentGetResponse,\n  ServerScope,\n  DatabaseCreateResponse,\n  MaybeDocument,\n  MangoResponse,\n  MangoSelector,\n  DocumentBulkResponse,\n  MangoOperator,\n  DatabaseSessionResponse,\n  CreateIndexRequest,\n} from \"nano\";\nimport * as Nano from \"nano\";\nimport { CouchDBKeys, reservedAttributes } from \"./constants\";\nimport {\n  BaseError,\n  ConflictError,\n  InternalError,\n  NotFoundError,\n} from \"@decaf-ts/db-decorators\";\nimport \"reflect-metadata\";\nimport { CouchDBStatement } from \"./query/Statement\";\nimport { Factory } from \"./query\";\nimport { translateOperators } from \"./query/translate\";\nimport { CouchDBSequence } from \"./sequences/Sequence\";\nimport { Constructor, Model } from \"@decaf-ts/decorator-validation\";\nimport { IndexError } from \"./errors\";\nimport { generateIndexes } from \"./indexes/generator\";\n\nexport class CouchDBAdapter extends Adapter<DocumentScope<any>, MangoQuery> {\n  private factory?: Factory;\n\n  constructor(scope: DocumentScope<any>, flavour: string) {\n    super(scope, flavour);\n  }\n\n  get Clauses(): ClauseFactory<DocumentScope<any>, MangoQuery> {\n    if (!this.factory) this.factory = new Factory(this);\n    return this.factory;\n  }\n\n  Query<M extends Model>(): Query<MangoQuery, M> {\n    return super.Query();\n  }\n\n  get Statement(): Statement<MangoQuery> {\n    return new CouchDBStatement(this);\n  }\n\n  parseCondition(condition: Condition): MangoQuery {\n    function merge(\n      op: MangoOperator,\n      obj1: MangoSelector,\n      obj2: MangoSelector\n    ): MangoQuery {\n      const result: MangoQuery = { selector: {} as MangoSelector };\n      result.selector[op] = [obj1, obj2];\n      return result;\n    }\n\n    const { attr1, operator, comparison } = condition as unknown as {\n      attr1: string | Condition;\n      operator: Operator | GroupOperator;\n      comparison: any;\n    };\n\n    let op: MangoSelector = {} as MangoSelector;\n    if (\n      [GroupOperator.AND, GroupOperator.OR, Operator.NOT].indexOf(\n        operator as GroupOperator\n      ) === -1\n    ) {\n      op[attr1 as string] = {} as MangoSelector;\n      (op[attr1 as string] as MangoSelector)[translateOperators(operator)] =\n        comparison;\n    } else if (operator === Operator.NOT) {\n      op = this.parseCondition(attr1 as Condition).selector as MangoSelector;\n      op[translateOperators(Operator.NOT)] = {} as MangoSelector;\n      (op[translateOperators(Operator.NOT)] as MangoSelector)[\n        (attr1 as unknown as { attr1: string }).attr1\n      ] = comparison;\n    } else {\n      const op1: any = this.parseCondition(attr1 as Condition).selector;\n      const op2: any = this.parseCondition(comparison as Condition).selector;\n      op = merge(translateOperators(operator), op1, op2).selector;\n    }\n\n    return { selector: op };\n  }\n\n  async Sequence(options: SequenceOptions): Promise<Sequence> {\n    return new CouchDBSequence(options);\n  }\n\n  async initialize(): Promise<void> {\n    const managedModels = Adapter.models(this.flavour);\n    return this.index(...managedModels);\n  }\n\n  async index<M extends Model>(...models: Constructor<M>[]): Promise<any> {\n    const indexes: CreateIndexRequest[] = generateIndexes(models);\n    for (const index of indexes) {\n      const res = await this.native.createIndex(index);\n      const { result, id, name } = res;\n      if (result === \"existing\")\n        throw new ConflictError(`Index for table ${name} with id ${id}`);\n    }\n  }\n\n  async user() {\n    try {\n      const user: DatabaseSessionResponse = await (\n        (this.native as any)[CouchDBKeys.NATIVE] as ServerScope\n      ).session();\n      return user.userCtx.name;\n    } catch (e: any) {\n      throw this.parseError(e);\n    }\n  }\n\n  async raw<V>(rawInput: MangoQuery, process = true): Promise<V> {\n    try {\n      const response: MangoResponse<V> = await this.native.find(rawInput);\n      if (process) return response.docs as V;\n      return response as V;\n    } catch (e: any) {\n      throw this.parseError(e);\n    }\n  }\n\n  async create(\n    tableName: string,\n    id: string | number,\n    model: Record<string, any>\n  ): Promise<Record<string, any>> {\n    const record: Record<string, any> = {};\n    record[CouchDBKeys.TABLE] = tableName;\n    record[CouchDBKeys.ID] = this.generateId(tableName, id);\n    Object.assign(record, model);\n    let response: DocumentInsertResponse;\n    try {\n      response = await this.native.insert(record);\n    } catch (e: any) {\n      throw this.parseError(e);\n    }\n\n    if (!response.ok)\n      throw new InternalError(\n        `Failed to insert doc id: ${id} in table ${tableName}`\n      );\n    Object.defineProperty(model, PersistenceKeys.METADATA, {\n      enumerable: false,\n      configurable: false,\n      writable: false,\n      value: response.rev,\n    });\n    return model;\n  }\n\n  async createAll(\n    tableName: string,\n    ids: string[] | number[],\n    models: Record<string, any>[]\n  ): Promise<Record<string, any>[]> {\n    if (ids.length !== models.length)\n      throw new InternalError(\"Ids and models must have the same length\");\n\n    const records = ids.map((id, count) => {\n      const record: Record<string, any> = {};\n      record[CouchDBKeys.TABLE] = tableName;\n      record[CouchDBKeys.ID] = this.generateId(tableName, id);\n      Object.assign(record, models[count]);\n      return record;\n    });\n    let response: DocumentBulkResponse[];\n    try {\n      response = await this.native.bulk({ docs: records });\n    } catch (e: any) {\n      throw this.parseError(e);\n    }\n    if (!response.every((r) => !r.error)) {\n      const errors = response.reduce((accum: string[], el, i) => {\n        if (el.error)\n          accum.push(\n            `el ${i}: ${el.error}${el.reason ? ` - ${el.reason}` : \"\"}`\n          );\n        return accum;\n      }, []);\n      throw new InternalError(errors.join(\"\\n\"));\n    }\n\n    models.forEach((m, i) => {\n      Repository.setMetadata(m as any, response[i].rev);\n      return m;\n    });\n    return models;\n  }\n\n  async read(\n    tableName: string,\n    id: string | number\n  ): Promise<Record<string, any>> {\n    const _id = this.generateId(tableName, id);\n    let record: DocumentGetResponse;\n    try {\n      record = await this.native.get(_id);\n    } catch (e: any) {\n      throw this.parseError(e);\n    }\n    Object.defineProperty(record, PersistenceKeys.METADATA, {\n      enumerable: false,\n      writable: false,\n      value: record._rev,\n    });\n    return record;\n  }\n\n  async update(\n    tableName: string,\n    id: string | number,\n    model: Record<string, any>\n  ): Promise<Record<string, any>> {\n    const record: Record<string, any> = {};\n    record[CouchDBKeys.TABLE] = tableName;\n    record[CouchDBKeys.ID] = this.generateId(tableName, id);\n    const rev = model[PersistenceKeys.METADATA];\n    if (!rev)\n      throw new InternalError(\n        `No revision number found for record with id ${id}`\n      );\n    Object.assign(record, model);\n    record[CouchDBKeys.REV] = rev;\n    let response: DocumentInsertResponse;\n    try {\n      response = await this.native.insert(record);\n    } catch (e: any) {\n      throw this.parseError(e);\n    }\n\n    if (!response.ok)\n      throw new InternalError(\n        `Failed to update doc id: ${id} in table ${tableName}`\n      );\n    Object.defineProperty(model, PersistenceKeys.METADATA, {\n      enumerable: false,\n      configurable: false,\n      writable: false,\n      value: response.rev,\n    });\n    return model;\n  }\n\n  async delete(\n    tableName: string,\n    id: string | number\n  ): Promise<Record<string, any>> {\n    const _id = this.generateId(tableName, id);\n    let record: DocumentGetResponse;\n    try {\n      record = await this.native.get(_id);\n      await this.native.destroy(_id, record._rev);\n    } catch (e: any) {\n      throw this.parseError(e);\n    }\n    Object.defineProperty(record, PersistenceKeys.METADATA, {\n      enumerable: false,\n      configurable: false,\n      writable: false,\n      value: record._rev,\n    });\n    return record;\n  }\n\n  private generateId(tableName: string, id: string | number) {\n    return [tableName, id].join(CouchDBKeys.SEPARATOR);\n  }\n\n  protected parseError(err: Error | string, reason?: string): BaseError {\n    return CouchDBAdapter.parseError(err, reason);\n  }\n\n  protected isReserved(attr: string): boolean {\n    return !!attr.match(reservedAttributes);\n  }\n\n  protected static parseError(err: Error | string, reason?: string): BaseError {\n    if (err instanceof BaseError) return err as any;\n    let code: string = \"\";\n    if (typeof err === \"string\") {\n      code = err;\n      if (code.match(/already exist|update conflict/g))\n        return new ConflictError(code);\n      if (code.match(/missing|deleted/g)) return new NotFoundError(code);\n    } else if ((err as any).code) {\n      code = (err as any).code;\n      reason = reason || err.message;\n    } else if ((err as any).statusCode) {\n      code = (err as any).statusCode;\n      reason = reason || err.message;\n    } else {\n      code = err.message;\n    }\n\n    switch (code.toString()) {\n      case \"401\":\n      case \"412\":\n      case \"409\":\n        return new ConflictError(reason as string);\n      case \"404\":\n        return new NotFoundError(reason as string);\n      case \"400\":\n        if (code.toString().match(/No\\sindex\\sexists/g))\n          return new IndexError(err);\n        return new InternalError(err);\n      default:\n        if (code.toString().match(/ECONNREFUSED/g))\n          return new ConnectionError(err);\n        return new InternalError(err);\n    }\n  }\n\n  static connect(\n    user: string,\n    pass: string,\n    host = \"localhost:5984\",\n    protocol: \"http\" | \"https\" = \"http\"\n  ): ServerScope {\n    return Nano(`${protocol}://${user}:${pass}@${host}`);\n  }\n\n  static async createDatabase(con: ServerScope, name: string) {\n    let result: DatabaseCreateResponse;\n    try {\n      result = await con.db.create(name);\n    } catch (e: any) {\n      throw this.parseError(e);\n    }\n    const { ok, error, reason } = result;\n    if (!ok) throw this.parseError(error as string, reason);\n  }\n\n  static async deleteDatabase(con: ServerScope, name: string) {\n    let result;\n    try {\n      result = await con.db.destroy(name);\n    } catch (e: any) {\n      throw this.parseError(e);\n    }\n    const { ok } = result;\n    if (!ok)\n      throw new InternalError(`Failed to delete database with name ${name}`);\n  }\n\n  static async createUser(\n    con: ServerScope,\n    dbName: string,\n    user: string,\n    pass: string,\n    roles: string[] = [\"reader\", \"writer\"]\n  ) {\n    const users = await con.db.use(\"_users\");\n    const usr = {\n      _id: \"org.couchdb.user:\" + user,\n      name: user,\n      password: pass,\n      roles: roles,\n      type: \"user\",\n    };\n    try {\n      const created: DocumentInsertResponse = await users.insert(\n        usr as MaybeDocument\n      );\n      const { ok } = created;\n      if (!ok) throw new InternalError(`Failed to create user ${user}`);\n      const security: any = await con.request({\n        db: dbName,\n        method: \"put\",\n        path: \"_security\",\n        // headers: {\n        //\n        // },\n        body: {\n          admins: {\n            names: [user],\n            roles: [],\n          },\n          members: {\n            names: [user],\n            roles: roles,\n          },\n        },\n      });\n      if (!security.ok)\n        throw new InternalError(\n          `Failed to authorize user ${user} to db ${dbName}`\n        );\n    } catch (e: any) {\n      throw this.parseError(e);\n    }\n  }\n\n  static async deleteUser(con: ServerScope, dbName: string, user: string) {\n    const users = await con.db.use(\"_users\");\n    const id = \"org.couchdb.user:\" + user;\n    try {\n      const usr = await users.get(id);\n      await users.destroy(id, usr._rev);\n    } catch (e: any) {\n      throw this.parseError(e);\n    }\n  }\n}\n"]}
|
|
324
|
+
//# sourceMappingURL=data:application/json;charset=utf8;base64,{"version":3,"sources":["src/adapter.ts"],"names":[],"mappings":"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","file":"adapter.js","sourcesContent":["import {\n  Adapter,\n  Sequence,\n  SequenceOptions,\n  PersistenceKeys,\n  Operator,\n  GroupOperator,\n  Statement,\n  Query,\n  ClauseFactory,\n  Condition,\n  ConnectionError,\n  Repository,\n  User,\n} from \"@decaf-ts/core\";\nimport { CouchDBKeys, reservedAttributes } from \"./constants\";\nimport {\n  BaseError,\n  ConflictError,\n  InternalError,\n  NotFoundError,\n} from \"@decaf-ts/db-decorators\";\nimport \"reflect-metadata\";\nimport { CouchDBStatement } from \"./query/Statement\";\nimport { Factory } from \"./query\";\nimport { translateOperators } from \"./query/translate\";\nimport { CouchDBSequence } from \"./sequences/Sequence\";\nimport { Constructor, Model } from \"@decaf-ts/decorator-validation\";\nimport { IndexError } from \"./errors\";\nimport { generateIndexes } from \"./indexes/generator\";\nimport {\n  CreateIndexRequest,\n  DocumentBulkResponse,\n  DocumentGetResponse,\n  DocumentInsertResponse,\n  DocumentScope,\n  MangoOperator,\n  MangoQuery,\n  MangoResponse,\n  MangoSelector,\n} from \"./types\";\n\nexport abstract class CouchDBAdapter extends Adapter<\n  DocumentScope<any>,\n  MangoQuery\n> {\n  protected factory?: Factory;\n\n  protected constructor(scope: DocumentScope<any>, flavour: string) {\n    super(scope, flavour);\n  }\n\n  get Clauses(): ClauseFactory<DocumentScope<any>, MangoQuery> {\n    if (!this.factory) this.factory = new Factory(this);\n    return this.factory;\n  }\n\n  Query<M extends Model>(): Query<MangoQuery, M> {\n    return super.Query();\n  }\n\n  get Statement(): Statement<MangoQuery> {\n    return new CouchDBStatement(this);\n  }\n\n  parseCondition(condition: Condition): MangoQuery {\n    function merge(\n      op: MangoOperator,\n      obj1: MangoSelector,\n      obj2: MangoSelector\n    ): MangoQuery {\n      const result: MangoQuery = { selector: {} as MangoSelector };\n      result.selector[op] = [obj1, obj2];\n      return result;\n    }\n\n    const { attr1, operator, comparison } = condition as unknown as {\n      attr1: string | Condition;\n      operator: Operator | GroupOperator;\n      comparison: any;\n    };\n\n    let op: MangoSelector = {} as MangoSelector;\n    if (\n      [GroupOperator.AND, GroupOperator.OR, Operator.NOT].indexOf(\n        operator as GroupOperator\n      ) === -1\n    ) {\n      op[attr1 as string] = {} as MangoSelector;\n      (op[attr1 as string] as MangoSelector)[translateOperators(operator)] =\n        comparison;\n    } else if (operator === Operator.NOT) {\n      op = this.parseCondition(attr1 as Condition).selector as MangoSelector;\n      op[translateOperators(Operator.NOT)] = {} as MangoSelector;\n      (op[translateOperators(Operator.NOT)] as MangoSelector)[\n        (attr1 as unknown as { attr1: string }).attr1\n      ] = comparison;\n    } else {\n      const op1: any = this.parseCondition(attr1 as Condition).selector;\n      const op2: any = this.parseCondition(comparison as Condition).selector;\n      op = merge(translateOperators(operator), op1, op2).selector;\n    }\n\n    return { selector: op };\n  }\n\n  async Sequence(options: SequenceOptions): Promise<Sequence> {\n    return new CouchDBSequence(options);\n  }\n\n  async initialize(): Promise<void> {\n    const managedModels = Adapter.models(this.flavour);\n    return this.index(...managedModels);\n  }\n\n  async index<M extends Model>(...models: Constructor<M>[]): Promise<void> {\n    const indexes: CreateIndexRequest[] = generateIndexes(models);\n    for (const index of indexes) {\n      const res = await this.native.createIndex(index);\n      const { result, id, name } = res;\n      if (result === \"existing\")\n        throw new ConflictError(`Index for table ${name} with id ${id}`);\n    }\n  }\n\n  abstract user(): Promise<User>;\n\n  async raw<V>(rawInput: MangoQuery, process = true): Promise<V> {\n    try {\n      const response: MangoResponse<V> = await this.native.find(rawInput);\n      if (process) return response.docs as V;\n      return response as V;\n    } catch (e: any) {\n      throw this.parseError(e);\n    }\n  }\n\n  async create(\n    tableName: string,\n    id: string | number,\n    model: Record<string, any>\n  ): Promise<Record<string, any>> {\n    const record: Record<string, any> = {};\n    record[CouchDBKeys.TABLE] = tableName;\n    record[CouchDBKeys.ID] = this.generateId(tableName, id);\n    Object.assign(record, model);\n    let response: DocumentInsertResponse;\n    try {\n      response = await this.native.insert(record);\n    } catch (e: any) {\n      throw this.parseError(e);\n    }\n\n    if (!response.ok)\n      throw new InternalError(\n        `Failed to insert doc id: ${id} in table ${tableName}`\n      );\n    Object.defineProperty(model, PersistenceKeys.METADATA, {\n      enumerable: false,\n      configurable: false,\n      writable: false,\n      value: response.rev,\n    });\n    return model;\n  }\n\n  async createAll(\n    tableName: string,\n    ids: string[] | number[],\n    models: Record<string, any>[]\n  ): Promise<Record<string, any>[]> {\n    if (ids.length !== models.length)\n      throw new InternalError(\"Ids and models must have the same length\");\n\n    const records = ids.map((id, count) => {\n      const record: Record<string, any> = {};\n      record[CouchDBKeys.TABLE] = tableName;\n      record[CouchDBKeys.ID] = this.generateId(tableName, id);\n      Object.assign(record, models[count]);\n      return record;\n    });\n    let response: DocumentBulkResponse[];\n    try {\n      response = await this.native.bulk({ docs: records });\n    } catch (e: any) {\n      throw this.parseError(e);\n    }\n    if (!response.every((r) => !r.error)) {\n      const errors = response.reduce((accum: string[], el, i) => {\n        if (el.error)\n          accum.push(\n            `el ${i}: ${el.error}${el.reason ? ` - ${el.reason}` : \"\"}`\n          );\n        return accum;\n      }, []);\n      throw new InternalError(errors.join(\"\\n\"));\n    }\n\n    models.forEach((m, i) => {\n      Repository.setMetadata(m as any, response[i].rev);\n      return m;\n    });\n    return models;\n  }\n\n  async read(\n    tableName: string,\n    id: string | number\n  ): Promise<Record<string, any>> {\n    const _id = this.generateId(tableName, id);\n    let record: DocumentGetResponse;\n    try {\n      record = await this.native.get(_id);\n    } catch (e: any) {\n      throw this.parseError(e);\n    }\n    Object.defineProperty(record, PersistenceKeys.METADATA, {\n      enumerable: false,\n      writable: false,\n      value: record._rev,\n    });\n    return record;\n  }\n\n  async readAll(\n    tableName: string,\n    ids: (string | number | bigint)[]\n  ): Promise<Record<string, any>[]> {\n    const results = await this.native.fetch(\n      { keys: ids.map((id) => this.generateId(tableName, id as any)) },\n      {}\n    );\n    return results.rows.map((r) => {\n      if ((r as any).error) throw new InternalError((r as any).error);\n      if ((r as any).doc) {\n        const res = Object.assign({}, (r as any).doc);\n        Object.defineProperty(res, PersistenceKeys.METADATA, {\n          enumerable: false,\n          writable: false,\n          value: (r as any).doc[CouchDBKeys.REV],\n        });\n        return res;\n      }\n      throw new InternalError(\"Should be impossible\");\n    });\n  }\n\n  async update(\n    tableName: string,\n    id: string | number,\n    model: Record<string, any>\n  ): Promise<Record<string, any>> {\n    const record: Record<string, any> = {};\n    record[CouchDBKeys.TABLE] = tableName;\n    record[CouchDBKeys.ID] = this.generateId(tableName, id);\n    const rev = model[PersistenceKeys.METADATA];\n    if (!rev)\n      throw new InternalError(\n        `No revision number found for record with id ${id}`\n      );\n    Object.assign(record, model);\n    record[CouchDBKeys.REV] = rev;\n    let response: DocumentInsertResponse;\n    try {\n      response = await this.native.insert(record);\n    } catch (e: any) {\n      throw this.parseError(e);\n    }\n\n    if (!response.ok)\n      throw new InternalError(\n        `Failed to update doc id: ${id} in table ${tableName}`\n      );\n    Object.defineProperty(model, PersistenceKeys.METADATA, {\n      enumerable: false,\n      configurable: false,\n      writable: false,\n      value: response.rev,\n    });\n    return model;\n  }\n\n  async updateAll(\n    tableName: string,\n    ids: string[] | number[],\n    models: Record<string, any>[]\n  ): Promise<Record<string, any>[]> {\n    if (ids.length !== models.length)\n      throw new InternalError(\"Ids and models must have the same length\");\n\n    const records = ids.map((id, count) => {\n      const record: Record<string, any> = {};\n      record[CouchDBKeys.TABLE] = tableName;\n      record[CouchDBKeys.ID] = this.generateId(tableName, id);\n      const rev = models[count][PersistenceKeys.METADATA];\n      if (!rev)\n        throw new InternalError(\n          `No revision number found for record with id ${id}`\n        );\n      Object.assign(record, models[count]);\n      record[CouchDBKeys.REV] = rev;\n      return record;\n    });\n    let response: DocumentBulkResponse[];\n    try {\n      response = await this.native.bulk({ docs: records });\n    } catch (e: any) {\n      throw this.parseError(e);\n    }\n    if (!response.every((r) => !r.error)) {\n      const errors = response.reduce((accum: string[], el, i) => {\n        if (el.error)\n          accum.push(\n            `el ${i}: ${el.error}${el.reason ? ` - ${el.reason}` : \"\"}`\n          );\n        return accum;\n      }, []);\n      throw new InternalError(errors.join(\"\\n\"));\n    }\n\n    models.forEach((m, i) => {\n      Repository.setMetadata(m as any, response[i].rev);\n      return m;\n    });\n    return models;\n  }\n\n  async delete(\n    tableName: string,\n    id: string | number\n  ): Promise<Record<string, any>> {\n    const _id = this.generateId(tableName, id);\n    let record: DocumentGetResponse;\n    try {\n      record = await this.native.get(_id);\n      await this.native.destroy(_id, record._rev);\n    } catch (e: any) {\n      throw this.parseError(e);\n    }\n    Object.defineProperty(record, PersistenceKeys.METADATA, {\n      enumerable: false,\n      configurable: false,\n      writable: false,\n      value: record._rev,\n    });\n    return record;\n  }\n\n  async deleteAll(\n    tableName: string,\n    ids: (string | number | bigint)[]\n  ): Promise<Record<string, any>[]> {\n    const results = await this.native.fetch(\n      { keys: ids.map((id) => this.generateId(tableName, id as any)) },\n      {}\n    );\n    const deletion: DocumentBulkResponse[] = await this.native.bulk({\n      docs: results.rows.map((r) => {\n        (r as any)[CouchDBKeys.DELETED] = true;\n        return r;\n      }),\n    });\n    deletion.forEach((d: DocumentBulkResponse) => {\n      if (d.error) console.error(d.error);\n    });\n    return results.rows.map((r) => {\n      if ((r as any).error) throw new InternalError((r as any).error);\n      if ((r as any).doc) {\n        const res = Object.assign({}, (r as any).doc);\n        Object.defineProperty(res, PersistenceKeys.METADATA, {\n          enumerable: false,\n          writable: false,\n          value: (r as any).doc[CouchDBKeys.REV],\n        });\n        return res;\n      }\n      throw new InternalError(\"Should be impossible\");\n    });\n  }\n\n  private generateId(tableName: string, id: string | number) {\n    return [tableName, id].join(CouchDBKeys.SEPARATOR);\n  }\n\n  protected parseError(err: Error | string, reason?: string): BaseError {\n    return CouchDBAdapter.parseError(err, reason);\n  }\n\n  protected isReserved(attr: string): boolean {\n    return !!attr.match(reservedAttributes);\n  }\n\n  protected static parseError(err: Error | string, reason?: string): BaseError {\n    if (err instanceof BaseError) return err as any;\n    let code: string = \"\";\n    if (typeof err === \"string\") {\n      code = err;\n      if (code.match(/already exist|update conflict/g))\n        return new ConflictError(code);\n      if (code.match(/missing|deleted/g)) return new NotFoundError(code);\n    } else if ((err as any).code) {\n      code = (err as any).code;\n      reason = reason || err.message;\n    } else if ((err as any).statusCode) {\n      code = (err as any).statusCode;\n      reason = reason || err.message;\n    } else {\n      code = err.message;\n    }\n\n    switch (code.toString()) {\n      case \"401\":\n      case \"412\":\n      case \"409\":\n        return new ConflictError(reason as string);\n      case \"404\":\n        return new NotFoundError(reason as string);\n      case \"400\":\n        if (code.toString().match(/No\\sindex\\sexists/g))\n          return new IndexError(err);\n        return new InternalError(err);\n      default:\n        if (code.toString().match(/ECONNREFUSED/g))\n          return new ConnectionError(err);\n        return new InternalError(err);\n    }\n  }\n}\n"]}
|
package/lib/adapter.d.ts
CHANGED
|
@@ -1,32 +1,31 @@
|
|
|
1
|
-
import { Adapter, Sequence, SequenceOptions, Statement, Query, ClauseFactory, Condition } from "@decaf-ts/core";
|
|
2
|
-
import { MangoQuery, DocumentScope, ServerScope } from "nano";
|
|
1
|
+
import { Adapter, Sequence, SequenceOptions, Statement, Query, ClauseFactory, Condition, User } from "@decaf-ts/core";
|
|
3
2
|
import { BaseError } from "@decaf-ts/db-decorators";
|
|
4
3
|
import "reflect-metadata";
|
|
4
|
+
import { Factory } from "./query";
|
|
5
5
|
import { Constructor, Model } from "@decaf-ts/decorator-validation";
|
|
6
|
-
|
|
7
|
-
|
|
8
|
-
|
|
6
|
+
import { DocumentScope, MangoQuery } from "./types";
|
|
7
|
+
export declare abstract class CouchDBAdapter extends Adapter<DocumentScope<any>, MangoQuery> {
|
|
8
|
+
protected factory?: Factory;
|
|
9
|
+
protected constructor(scope: DocumentScope<any>, flavour: string);
|
|
9
10
|
get Clauses(): ClauseFactory<DocumentScope<any>, MangoQuery>;
|
|
10
11
|
Query<M extends Model>(): Query<MangoQuery, M>;
|
|
11
12
|
get Statement(): Statement<MangoQuery>;
|
|
12
13
|
parseCondition(condition: Condition): MangoQuery;
|
|
13
14
|
Sequence(options: SequenceOptions): Promise<Sequence>;
|
|
14
15
|
initialize(): Promise<void>;
|
|
15
|
-
index<M extends Model>(...models: Constructor<M>[]): Promise<
|
|
16
|
-
user(): Promise<
|
|
16
|
+
index<M extends Model>(...models: Constructor<M>[]): Promise<void>;
|
|
17
|
+
abstract user(): Promise<User>;
|
|
17
18
|
raw<V>(rawInput: MangoQuery, process?: boolean): Promise<V>;
|
|
18
19
|
create(tableName: string, id: string | number, model: Record<string, any>): Promise<Record<string, any>>;
|
|
19
20
|
createAll(tableName: string, ids: string[] | number[], models: Record<string, any>[]): Promise<Record<string, any>[]>;
|
|
20
21
|
read(tableName: string, id: string | number): Promise<Record<string, any>>;
|
|
22
|
+
readAll(tableName: string, ids: (string | number | bigint)[]): Promise<Record<string, any>[]>;
|
|
21
23
|
update(tableName: string, id: string | number, model: Record<string, any>): Promise<Record<string, any>>;
|
|
24
|
+
updateAll(tableName: string, ids: string[] | number[], models: Record<string, any>[]): Promise<Record<string, any>[]>;
|
|
22
25
|
delete(tableName: string, id: string | number): Promise<Record<string, any>>;
|
|
26
|
+
deleteAll(tableName: string, ids: (string | number | bigint)[]): Promise<Record<string, any>[]>;
|
|
23
27
|
private generateId;
|
|
24
28
|
protected parseError(err: Error | string, reason?: string): BaseError;
|
|
25
29
|
protected isReserved(attr: string): boolean;
|
|
26
30
|
protected static parseError(err: Error | string, reason?: string): BaseError;
|
|
27
|
-
static connect(user: string, pass: string, host?: string, protocol?: "http" | "https"): ServerScope;
|
|
28
|
-
static createDatabase(con: ServerScope, name: string): Promise<void>;
|
|
29
|
-
static deleteDatabase(con: ServerScope, name: string): Promise<void>;
|
|
30
|
-
static createUser(con: ServerScope, dbName: string, user: string, pass: string, roles?: string[]): Promise<void>;
|
|
31
|
-
static deleteUser(con: ServerScope, dbName: string, user: string): Promise<void>;
|
|
32
31
|
}
|
package/lib/constants.cjs
CHANGED
|
@@ -6,10 +6,11 @@ exports.CouchDBKeys = {
|
|
|
6
6
|
SEPARATOR: "_",
|
|
7
7
|
ID: "_id",
|
|
8
8
|
REV: "_rev",
|
|
9
|
+
DELETED: "_deleted",
|
|
9
10
|
TABLE: "??table",
|
|
10
11
|
DDOC: "ddoc",
|
|
11
12
|
NATIVE: "__native",
|
|
12
13
|
INDEX: "index",
|
|
13
14
|
};
|
|
14
15
|
|
|
15
|
-
//# sourceMappingURL=data:application/json;charset=utf8;base64,
|
|
16
|
+
//# sourceMappingURL=data:application/json;charset=utf8;base64,eyJ2ZXJzaW9uIjozLCJzb3VyY2VzIjpbInNyYy9jb25zdGFudHMudHMiXSwibmFtZXMiOltdLCJtYXBwaW5ncyI6Ijs7O0FBQWEsUUFBQSxrQkFBa0IsR0FBRyxRQUFRLENBQUM7QUFFOUIsUUFBQSxXQUFXLEdBQUc7SUFDekIsU0FBUyxFQUFFLEdBQUc7SUFDZCxFQUFFLEVBQUUsS0FBSztJQUNULEdBQUcsRUFBRSxNQUFNO0lBQ1gsT0FBTyxFQUFFLFVBQVU7SUFDbkIsS0FBSyxFQUFFLFNBQVM7SUFDaEIsSUFBSSxFQUFFLE1BQU07SUFDWixNQUFNLEVBQUUsVUFBVTtJQUNsQixLQUFLLEVBQUUsT0FBTztDQUNmLENBQUMiLCJmaWxlIjoiY29uc3RhbnRzLmpzIiwic291cmNlc0NvbnRlbnQiOlsiZXhwb3J0IGNvbnN0IHJlc2VydmVkQXR0cmlidXRlcyA9IC9eXy4qJC9nO1xuXG5leHBvcnQgY29uc3QgQ291Y2hEQktleXMgPSB7XG4gIFNFUEFSQVRPUjogXCJfXCIsXG4gIElEOiBcIl9pZFwiLFxuICBSRVY6IFwiX3JldlwiLFxuICBERUxFVEVEOiBcIl9kZWxldGVkXCIsXG4gIFRBQkxFOiBcIj8/dGFibGVcIixcbiAgRERPQzogXCJkZG9jXCIsXG4gIE5BVElWRTogXCJfX25hdGl2ZVwiLFxuICBJTkRFWDogXCJpbmRleFwiLFxufTtcbiJdfQ==
|
package/lib/constants.d.ts
CHANGED
package/lib/esm/adapter.d.ts
CHANGED
|
@@ -1,32 +1,31 @@
|
|
|
1
|
-
import { Adapter, Sequence, SequenceOptions, Statement, Query, ClauseFactory, Condition } from "@decaf-ts/core";
|
|
2
|
-
import { MangoQuery, DocumentScope, ServerScope } from "nano";
|
|
1
|
+
import { Adapter, Sequence, SequenceOptions, Statement, Query, ClauseFactory, Condition, User } from "@decaf-ts/core";
|
|
3
2
|
import { BaseError } from "@decaf-ts/db-decorators";
|
|
4
3
|
import "reflect-metadata";
|
|
4
|
+
import { Factory } from "./query";
|
|
5
5
|
import { Constructor, Model } from "@decaf-ts/decorator-validation";
|
|
6
|
-
|
|
7
|
-
|
|
8
|
-
|
|
6
|
+
import { DocumentScope, MangoQuery } from "./types";
|
|
7
|
+
export declare abstract class CouchDBAdapter extends Adapter<DocumentScope<any>, MangoQuery> {
|
|
8
|
+
protected factory?: Factory;
|
|
9
|
+
protected constructor(scope: DocumentScope<any>, flavour: string);
|
|
9
10
|
get Clauses(): ClauseFactory<DocumentScope<any>, MangoQuery>;
|
|
10
11
|
Query<M extends Model>(): Query<MangoQuery, M>;
|
|
11
12
|
get Statement(): Statement<MangoQuery>;
|
|
12
13
|
parseCondition(condition: Condition): MangoQuery;
|
|
13
14
|
Sequence(options: SequenceOptions): Promise<Sequence>;
|
|
14
15
|
initialize(): Promise<void>;
|
|
15
|
-
index<M extends Model>(...models: Constructor<M>[]): Promise<
|
|
16
|
-
user(): Promise<
|
|
16
|
+
index<M extends Model>(...models: Constructor<M>[]): Promise<void>;
|
|
17
|
+
abstract user(): Promise<User>;
|
|
17
18
|
raw<V>(rawInput: MangoQuery, process?: boolean): Promise<V>;
|
|
18
19
|
create(tableName: string, id: string | number, model: Record<string, any>): Promise<Record<string, any>>;
|
|
19
20
|
createAll(tableName: string, ids: string[] | number[], models: Record<string, any>[]): Promise<Record<string, any>[]>;
|
|
20
21
|
read(tableName: string, id: string | number): Promise<Record<string, any>>;
|
|
22
|
+
readAll(tableName: string, ids: (string | number | bigint)[]): Promise<Record<string, any>[]>;
|
|
21
23
|
update(tableName: string, id: string | number, model: Record<string, any>): Promise<Record<string, any>>;
|
|
24
|
+
updateAll(tableName: string, ids: string[] | number[], models: Record<string, any>[]): Promise<Record<string, any>[]>;
|
|
22
25
|
delete(tableName: string, id: string | number): Promise<Record<string, any>>;
|
|
26
|
+
deleteAll(tableName: string, ids: (string | number | bigint)[]): Promise<Record<string, any>[]>;
|
|
23
27
|
private generateId;
|
|
24
28
|
protected parseError(err: Error | string, reason?: string): BaseError;
|
|
25
29
|
protected isReserved(attr: string): boolean;
|
|
26
30
|
protected static parseError(err: Error | string, reason?: string): BaseError;
|
|
27
|
-
static connect(user: string, pass: string, host?: string, protocol?: "http" | "https"): ServerScope;
|
|
28
|
-
static createDatabase(con: ServerScope, name: string): Promise<void>;
|
|
29
|
-
static deleteDatabase(con: ServerScope, name: string): Promise<void>;
|
|
30
|
-
static createUser(con: ServerScope, dbName: string, user: string, pass: string, roles?: string[]): Promise<void>;
|
|
31
|
-
static deleteUser(con: ServerScope, dbName: string, user: string): Promise<void>;
|
|
32
31
|
}
|