@decaf-ts/for-pouch 0.0.2
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/LICENSE.md +21 -0
- package/README.md +297 -0
- package/dist/esm/for-pouch.bundle.min.esm.js +2 -0
- package/dist/esm/for-pouch.bundle.min.esm.js.LICENSE.txt +14 -0
- package/dist/for-pouch.bundle.min.js +2 -0
- package/dist/for-pouch.bundle.min.js.LICENSE.txt +14 -0
- package/lib/PouchRepository.cjs +4 -0
- package/lib/PouchRepository.d.ts +7 -0
- package/lib/adapter.cjs +105 -0
- package/lib/adapter.d.ts +12 -0
- package/lib/esm/PouchRepository.d.ts +7 -0
- package/lib/esm/PouchRepository.js +3 -0
- package/lib/esm/adapter.d.ts +12 -0
- package/lib/esm/adapter.js +101 -0
- package/lib/esm/index.d.ts +15 -0
- package/lib/esm/index.js +17 -0
- package/lib/esm/utils.d.ts +21 -0
- package/lib/esm/utils.js +92 -0
- package/lib/index.cjs +34 -0
- package/lib/index.d.ts +15 -0
- package/lib/utils.cjs +96 -0
- package/lib/utils.d.ts +21 -0
- package/package.json +128 -0
package/lib/adapter.cjs
ADDED
|
@@ -0,0 +1,105 @@
|
|
|
1
|
+
"use strict";
|
|
2
|
+
Object.defineProperty(exports, "__esModule", { value: true });
|
|
3
|
+
exports.PouchAdapter = void 0;
|
|
4
|
+
require("reflect-metadata");
|
|
5
|
+
const for_couchdb_1 = require("@decaf-ts/for-couchdb");
|
|
6
|
+
const db_decorators_1 = require("@decaf-ts/db-decorators");
|
|
7
|
+
const core_1 = require("@decaf-ts/core");
|
|
8
|
+
class PouchAdapter extends for_couchdb_1.CouchDBAdapter {
|
|
9
|
+
constructor(scope, flavour = "pouch") {
|
|
10
|
+
super(scope, flavour);
|
|
11
|
+
}
|
|
12
|
+
async user() {
|
|
13
|
+
const url = this.native.server.name;
|
|
14
|
+
if (url) {
|
|
15
|
+
const regexp = /https?:\/\/(.+?):.+?@/g;
|
|
16
|
+
const m = regexp.exec(url);
|
|
17
|
+
if (m) {
|
|
18
|
+
return new core_1.User({
|
|
19
|
+
id: m[1],
|
|
20
|
+
});
|
|
21
|
+
}
|
|
22
|
+
}
|
|
23
|
+
throw new db_decorators_1.InternalError("Not implemented");
|
|
24
|
+
}
|
|
25
|
+
async readAll(tableName, ids) {
|
|
26
|
+
const results = await this.native.fetch({ keys: ids.map((id) => this.generateId(tableName, id)) }, {});
|
|
27
|
+
return results.rows.map((r) => {
|
|
28
|
+
if (r instanceof Error)
|
|
29
|
+
throw r;
|
|
30
|
+
const res = Object.assign({}, r);
|
|
31
|
+
Object.defineProperty(res, core_1.PersistenceKeys.METADATA, {
|
|
32
|
+
enumerable: false,
|
|
33
|
+
writable: false,
|
|
34
|
+
value: r[for_couchdb_1.CouchDBKeys.REV],
|
|
35
|
+
});
|
|
36
|
+
return res;
|
|
37
|
+
});
|
|
38
|
+
}
|
|
39
|
+
async deleteAll(tableName, ids) {
|
|
40
|
+
const results = await this.native.fetch({ keys: ids.map((id) => this.generateId(tableName, id)) }, {});
|
|
41
|
+
const deletion = await this.native.bulk({
|
|
42
|
+
docs: results.rows.map((r) => {
|
|
43
|
+
r[for_couchdb_1.CouchDBKeys.DELETED] = true;
|
|
44
|
+
return r;
|
|
45
|
+
}),
|
|
46
|
+
});
|
|
47
|
+
deletion.forEach((d) => {
|
|
48
|
+
if (d.error)
|
|
49
|
+
console.error(d.error);
|
|
50
|
+
});
|
|
51
|
+
return results.rows.map((r) => {
|
|
52
|
+
if (r instanceof Error)
|
|
53
|
+
throw r;
|
|
54
|
+
const res = Object.assign({}, r);
|
|
55
|
+
Object.defineProperty(res, core_1.PersistenceKeys.METADATA, {
|
|
56
|
+
enumerable: false,
|
|
57
|
+
writable: false,
|
|
58
|
+
value: r[for_couchdb_1.CouchDBKeys.REV],
|
|
59
|
+
});
|
|
60
|
+
return res;
|
|
61
|
+
});
|
|
62
|
+
}
|
|
63
|
+
parseError(err, reason) {
|
|
64
|
+
return PouchAdapter.parseError(err, reason);
|
|
65
|
+
}
|
|
66
|
+
static parseError(err, reason) {
|
|
67
|
+
// return super.parseError(err, reason);
|
|
68
|
+
if (err instanceof db_decorators_1.BaseError)
|
|
69
|
+
return err;
|
|
70
|
+
let code = "";
|
|
71
|
+
if (typeof err === "string") {
|
|
72
|
+
code = err;
|
|
73
|
+
if (code.match(/already exist|update conflict/g))
|
|
74
|
+
return new db_decorators_1.ConflictError(code);
|
|
75
|
+
if (code.match(/missing|deleted/g))
|
|
76
|
+
return new db_decorators_1.NotFoundError(code);
|
|
77
|
+
}
|
|
78
|
+
else if (err.status) {
|
|
79
|
+
code = err.status;
|
|
80
|
+
reason = reason || err.message;
|
|
81
|
+
}
|
|
82
|
+
else {
|
|
83
|
+
code = err.message;
|
|
84
|
+
}
|
|
85
|
+
switch (code.toString()) {
|
|
86
|
+
case "401":
|
|
87
|
+
case "412":
|
|
88
|
+
case "409":
|
|
89
|
+
return new db_decorators_1.ConflictError(reason);
|
|
90
|
+
case "404":
|
|
91
|
+
return new db_decorators_1.NotFoundError(reason);
|
|
92
|
+
case "400":
|
|
93
|
+
if (code.toString().match(/No\sindex\sexists/g))
|
|
94
|
+
return new for_couchdb_1.IndexError(err);
|
|
95
|
+
return new db_decorators_1.InternalError(err);
|
|
96
|
+
default:
|
|
97
|
+
if (code.toString().match(/ECONNREFUSED/g))
|
|
98
|
+
return new core_1.ConnectionError(err);
|
|
99
|
+
return new db_decorators_1.InternalError(err);
|
|
100
|
+
}
|
|
101
|
+
}
|
|
102
|
+
}
|
|
103
|
+
exports.PouchAdapter = PouchAdapter;
|
|
104
|
+
|
|
105
|
+
//# sourceMappingURL=data:application/json;charset=utf8;base64,{"version":3,"sources":["src/adapter.ts"],"names":[],"mappings":"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","file":"adapter.js","sourcesContent":["import \"reflect-metadata\";\nimport {\n  CouchDBAdapter,\n  CouchDBKeys,\n  DocumentBulkResponse,\n  DocumentScope,\n  IndexError,\n} from \"@decaf-ts/for-couchdb\";\nimport {\n  BaseError,\n  ConflictError,\n  InternalError,\n  NotFoundError,\n} from \"@decaf-ts/db-decorators\";\nimport { ConnectionError, PersistenceKeys, User } from \"@decaf-ts/core\";\n\nexport class PouchAdapter extends CouchDBAdapter {\n  constructor(scope: DocumentScope<any>, flavour: string = \"pouch\") {\n    super(scope, flavour);\n  }\n\n  async user(): Promise<User> {\n    const url = (this.native.server as unknown as { name: string }).name;\n    if (url) {\n      const regexp = /https?:\\/\\/(.+?):.+?@/g;\n      const m = regexp.exec(url);\n      if (m) {\n        return new User({\n          id: m[1],\n        });\n      }\n    }\n    throw new InternalError(\"Not implemented\");\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 instanceof Error) throw r;\n      const res = Object.assign({}, r);\n      Object.defineProperty(res, PersistenceKeys.METADATA, {\n        enumerable: false,\n        writable: false,\n        value: (r as any)[CouchDBKeys.REV],\n      });\n      return res;\n    });\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 instanceof Error) throw r;\n      const res = Object.assign({}, r);\n      Object.defineProperty(res, PersistenceKeys.METADATA, {\n        enumerable: false,\n        writable: false,\n        value: (r as any)[CouchDBKeys.REV],\n      });\n      return res;\n    });\n  }\n\n  parseError(err: Error | string, reason?: string): BaseError {\n    return PouchAdapter.parseError(err, reason);\n  }\n\n  static parseError(err: Error | string, reason?: string): BaseError {\n    // return super.parseError(err, reason);\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).status) {\n      code = (err as any).status;\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
ADDED
|
@@ -0,0 +1,12 @@
|
|
|
1
|
+
import "reflect-metadata";
|
|
2
|
+
import { CouchDBAdapter, DocumentScope } from "@decaf-ts/for-couchdb";
|
|
3
|
+
import { BaseError } from "@decaf-ts/db-decorators";
|
|
4
|
+
import { User } from "@decaf-ts/core";
|
|
5
|
+
export declare class PouchAdapter extends CouchDBAdapter {
|
|
6
|
+
constructor(scope: DocumentScope<any>, flavour?: string);
|
|
7
|
+
user(): Promise<User>;
|
|
8
|
+
readAll(tableName: string, ids: (string | number | bigint)[]): Promise<Record<string, any>[]>;
|
|
9
|
+
deleteAll(tableName: string, ids: (string | number | bigint)[]): Promise<Record<string, any>[]>;
|
|
10
|
+
parseError(err: Error | string, reason?: string): BaseError;
|
|
11
|
+
static parseError(err: Error | string, reason?: string): BaseError;
|
|
12
|
+
}
|
|
@@ -0,0 +1,7 @@
|
|
|
1
|
+
import { Model } from "@decaf-ts/decorator-validation";
|
|
2
|
+
import { MangoQuery } from "@decaf-ts/for-couchdb";
|
|
3
|
+
import { PouchAdapter } from "./adapter";
|
|
4
|
+
import { Repository } from "@decaf-ts/core";
|
|
5
|
+
export interface PouchRepository<M extends Model> extends Repository<M, MangoQuery> {
|
|
6
|
+
adapter: PouchAdapter;
|
|
7
|
+
}
|
|
@@ -0,0 +1,3 @@
|
|
|
1
|
+
export {};
|
|
2
|
+
|
|
3
|
+
//# sourceMappingURL=data:application/json;charset=utf8;base64,eyJ2ZXJzaW9uIjozLCJzb3VyY2VzIjpbInNyYy9Qb3VjaFJlcG9zaXRvcnkudHMiXSwibmFtZXMiOltdLCJtYXBwaW5ncyI6IiIsImZpbGUiOiJQb3VjaFJlcG9zaXRvcnkuanMiLCJzb3VyY2VzQ29udGVudCI6WyJpbXBvcnQgeyBNb2RlbCB9IGZyb20gXCJAZGVjYWYtdHMvZGVjb3JhdG9yLXZhbGlkYXRpb25cIjtcbmltcG9ydCB7IE1hbmdvUXVlcnkgfSBmcm9tIFwiQGRlY2FmLXRzL2Zvci1jb3VjaGRiXCI7XG5pbXBvcnQgeyBQb3VjaEFkYXB0ZXIgfSBmcm9tIFwiLi9hZGFwdGVyXCI7XG5pbXBvcnQgeyBSZXBvc2l0b3J5IH0gZnJvbSBcIkBkZWNhZi10cy9jb3JlXCI7XG5cbmV4cG9ydCBpbnRlcmZhY2UgUG91Y2hSZXBvc2l0b3J5PE0gZXh0ZW5kcyBNb2RlbD5cbiAgZXh0ZW5kcyBSZXBvc2l0b3J5PE0sIE1hbmdvUXVlcnk+IHtcbiAgYWRhcHRlcjogUG91Y2hBZGFwdGVyO1xufVxuIl19
|
|
@@ -0,0 +1,12 @@
|
|
|
1
|
+
import "reflect-metadata";
|
|
2
|
+
import { CouchDBAdapter, DocumentScope } from "@decaf-ts/for-couchdb";
|
|
3
|
+
import { BaseError } from "@decaf-ts/db-decorators";
|
|
4
|
+
import { User } from "@decaf-ts/core";
|
|
5
|
+
export declare class PouchAdapter extends CouchDBAdapter {
|
|
6
|
+
constructor(scope: DocumentScope<any>, flavour?: string);
|
|
7
|
+
user(): Promise<User>;
|
|
8
|
+
readAll(tableName: string, ids: (string | number | bigint)[]): Promise<Record<string, any>[]>;
|
|
9
|
+
deleteAll(tableName: string, ids: (string | number | bigint)[]): Promise<Record<string, any>[]>;
|
|
10
|
+
parseError(err: Error | string, reason?: string): BaseError;
|
|
11
|
+
static parseError(err: Error | string, reason?: string): BaseError;
|
|
12
|
+
}
|
|
@@ -0,0 +1,101 @@
|
|
|
1
|
+
import "reflect-metadata";
|
|
2
|
+
import { CouchDBAdapter, CouchDBKeys, IndexError, } from "@decaf-ts/for-couchdb";
|
|
3
|
+
import { BaseError, ConflictError, InternalError, NotFoundError, } from "@decaf-ts/db-decorators";
|
|
4
|
+
import { ConnectionError, PersistenceKeys, User } from "@decaf-ts/core";
|
|
5
|
+
export class PouchAdapter extends CouchDBAdapter {
|
|
6
|
+
constructor(scope, flavour = "pouch") {
|
|
7
|
+
super(scope, flavour);
|
|
8
|
+
}
|
|
9
|
+
async user() {
|
|
10
|
+
const url = this.native.server.name;
|
|
11
|
+
if (url) {
|
|
12
|
+
const regexp = /https?:\/\/(.+?):.+?@/g;
|
|
13
|
+
const m = regexp.exec(url);
|
|
14
|
+
if (m) {
|
|
15
|
+
return new User({
|
|
16
|
+
id: m[1],
|
|
17
|
+
});
|
|
18
|
+
}
|
|
19
|
+
}
|
|
20
|
+
throw new InternalError("Not implemented");
|
|
21
|
+
}
|
|
22
|
+
async readAll(tableName, ids) {
|
|
23
|
+
const results = await this.native.fetch({ keys: ids.map((id) => this.generateId(tableName, id)) }, {});
|
|
24
|
+
return results.rows.map((r) => {
|
|
25
|
+
if (r instanceof Error)
|
|
26
|
+
throw r;
|
|
27
|
+
const res = Object.assign({}, r);
|
|
28
|
+
Object.defineProperty(res, PersistenceKeys.METADATA, {
|
|
29
|
+
enumerable: false,
|
|
30
|
+
writable: false,
|
|
31
|
+
value: r[CouchDBKeys.REV],
|
|
32
|
+
});
|
|
33
|
+
return res;
|
|
34
|
+
});
|
|
35
|
+
}
|
|
36
|
+
async deleteAll(tableName, ids) {
|
|
37
|
+
const results = await this.native.fetch({ keys: ids.map((id) => this.generateId(tableName, id)) }, {});
|
|
38
|
+
const deletion = await this.native.bulk({
|
|
39
|
+
docs: results.rows.map((r) => {
|
|
40
|
+
r[CouchDBKeys.DELETED] = true;
|
|
41
|
+
return r;
|
|
42
|
+
}),
|
|
43
|
+
});
|
|
44
|
+
deletion.forEach((d) => {
|
|
45
|
+
if (d.error)
|
|
46
|
+
console.error(d.error);
|
|
47
|
+
});
|
|
48
|
+
return results.rows.map((r) => {
|
|
49
|
+
if (r instanceof Error)
|
|
50
|
+
throw r;
|
|
51
|
+
const res = Object.assign({}, r);
|
|
52
|
+
Object.defineProperty(res, PersistenceKeys.METADATA, {
|
|
53
|
+
enumerable: false,
|
|
54
|
+
writable: false,
|
|
55
|
+
value: r[CouchDBKeys.REV],
|
|
56
|
+
});
|
|
57
|
+
return res;
|
|
58
|
+
});
|
|
59
|
+
}
|
|
60
|
+
parseError(err, reason) {
|
|
61
|
+
return PouchAdapter.parseError(err, reason);
|
|
62
|
+
}
|
|
63
|
+
static parseError(err, reason) {
|
|
64
|
+
// return super.parseError(err, reason);
|
|
65
|
+
if (err instanceof BaseError)
|
|
66
|
+
return err;
|
|
67
|
+
let code = "";
|
|
68
|
+
if (typeof err === "string") {
|
|
69
|
+
code = err;
|
|
70
|
+
if (code.match(/already exist|update conflict/g))
|
|
71
|
+
return new ConflictError(code);
|
|
72
|
+
if (code.match(/missing|deleted/g))
|
|
73
|
+
return new NotFoundError(code);
|
|
74
|
+
}
|
|
75
|
+
else if (err.status) {
|
|
76
|
+
code = err.status;
|
|
77
|
+
reason = reason || err.message;
|
|
78
|
+
}
|
|
79
|
+
else {
|
|
80
|
+
code = err.message;
|
|
81
|
+
}
|
|
82
|
+
switch (code.toString()) {
|
|
83
|
+
case "401":
|
|
84
|
+
case "412":
|
|
85
|
+
case "409":
|
|
86
|
+
return new ConflictError(reason);
|
|
87
|
+
case "404":
|
|
88
|
+
return new NotFoundError(reason);
|
|
89
|
+
case "400":
|
|
90
|
+
if (code.toString().match(/No\sindex\sexists/g))
|
|
91
|
+
return new IndexError(err);
|
|
92
|
+
return new InternalError(err);
|
|
93
|
+
default:
|
|
94
|
+
if (code.toString().match(/ECONNREFUSED/g))
|
|
95
|
+
return new ConnectionError(err);
|
|
96
|
+
return new InternalError(err);
|
|
97
|
+
}
|
|
98
|
+
}
|
|
99
|
+
}
|
|
100
|
+
|
|
101
|
+
//# sourceMappingURL=data:application/json;charset=utf8;base64,{"version":3,"sources":["src/adapter.ts"],"names":[],"mappings":"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","file":"adapter.js","sourcesContent":["import \"reflect-metadata\";\nimport {\n  CouchDBAdapter,\n  CouchDBKeys,\n  DocumentBulkResponse,\n  DocumentScope,\n  IndexError,\n} from \"@decaf-ts/for-couchdb\";\nimport {\n  BaseError,\n  ConflictError,\n  InternalError,\n  NotFoundError,\n} from \"@decaf-ts/db-decorators\";\nimport { ConnectionError, PersistenceKeys, User } from \"@decaf-ts/core\";\n\nexport class PouchAdapter extends CouchDBAdapter {\n  constructor(scope: DocumentScope<any>, flavour: string = \"pouch\") {\n    super(scope, flavour);\n  }\n\n  async user(): Promise<User> {\n    const url = (this.native.server as unknown as { name: string }).name;\n    if (url) {\n      const regexp = /https?:\\/\\/(.+?):.+?@/g;\n      const m = regexp.exec(url);\n      if (m) {\n        return new User({\n          id: m[1],\n        });\n      }\n    }\n    throw new InternalError(\"Not implemented\");\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 instanceof Error) throw r;\n      const res = Object.assign({}, r);\n      Object.defineProperty(res, PersistenceKeys.METADATA, {\n        enumerable: false,\n        writable: false,\n        value: (r as any)[CouchDBKeys.REV],\n      });\n      return res;\n    });\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 instanceof Error) throw r;\n      const res = Object.assign({}, r);\n      Object.defineProperty(res, PersistenceKeys.METADATA, {\n        enumerable: false,\n        writable: false,\n        value: (r as any)[CouchDBKeys.REV],\n      });\n      return res;\n    });\n  }\n\n  parseError(err: Error | string, reason?: string): BaseError {\n    return PouchAdapter.parseError(err, reason);\n  }\n\n  static parseError(err: Error | string, reason?: string): BaseError {\n    // return super.parseError(err, reason);\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).status) {\n      code = (err as any).status;\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"]}
|
|
@@ -0,0 +1,15 @@
|
|
|
1
|
+
export * from "./adapter";
|
|
2
|
+
export * from "./PouchRepository";
|
|
3
|
+
export * from "./utils";
|
|
4
|
+
/**
|
|
5
|
+
* @summary Module summary
|
|
6
|
+
* @description Module description
|
|
7
|
+
* @module for-nano
|
|
8
|
+
*/
|
|
9
|
+
/**
|
|
10
|
+
* @summary stores the current package version
|
|
11
|
+
* @description this is how you should document a constant
|
|
12
|
+
* @const VERSION
|
|
13
|
+
* @memberOf module:ts-workspace
|
|
14
|
+
*/
|
|
15
|
+
export declare const VERSION = "0.0.1";
|
package/lib/esm/index.js
ADDED
|
@@ -0,0 +1,17 @@
|
|
|
1
|
+
export * from "./adapter";
|
|
2
|
+
export * from "./PouchRepository";
|
|
3
|
+
export * from "./utils";
|
|
4
|
+
/**
|
|
5
|
+
* @summary Module summary
|
|
6
|
+
* @description Module description
|
|
7
|
+
* @module for-nano
|
|
8
|
+
*/
|
|
9
|
+
/**
|
|
10
|
+
* @summary stores the current package version
|
|
11
|
+
* @description this is how you should document a constant
|
|
12
|
+
* @const VERSION
|
|
13
|
+
* @memberOf module:ts-workspace
|
|
14
|
+
*/
|
|
15
|
+
export const VERSION = "0.0.1";
|
|
16
|
+
|
|
17
|
+
//# sourceMappingURL=data:application/json;charset=utf8;base64,eyJ2ZXJzaW9uIjozLCJzb3VyY2VzIjpbInNyYy9pbmRleC50cyJdLCJuYW1lcyI6W10sIm1hcHBpbmdzIjoiQUFBQSxjQUFjLFdBQVcsQ0FBQztBQUMxQixjQUFjLG1CQUFtQixDQUFDO0FBQ2xDLGNBQWMsU0FBUyxDQUFDO0FBRXhCOzs7O0dBSUc7QUFFSDs7Ozs7R0FLRztBQUNILE1BQU0sQ0FBQyxNQUFNLE9BQU8sR0FBRyxPQUFPLENBQUMiLCJmaWxlIjoiaW5kZXguanMiLCJzb3VyY2VzQ29udGVudCI6WyJleHBvcnQgKiBmcm9tIFwiLi9hZGFwdGVyXCI7XG5leHBvcnQgKiBmcm9tIFwiLi9Qb3VjaFJlcG9zaXRvcnlcIjtcbmV4cG9ydCAqIGZyb20gXCIuL3V0aWxzXCI7XG5cbi8qKlxuICogQHN1bW1hcnkgTW9kdWxlIHN1bW1hcnlcbiAqIEBkZXNjcmlwdGlvbiBNb2R1bGUgZGVzY3JpcHRpb25cbiAqIEBtb2R1bGUgZm9yLW5hbm9cbiAqL1xuXG4vKipcbiAqIEBzdW1tYXJ5IHN0b3JlcyB0aGUgY3VycmVudCBwYWNrYWdlIHZlcnNpb25cbiAqIEBkZXNjcmlwdGlvbiB0aGlzIGlzIGhvdyB5b3Ugc2hvdWxkIGRvY3VtZW50IGEgY29uc3RhbnRcbiAqIEBjb25zdCBWRVJTSU9OXG4gKiBAbWVtYmVyT2YgbW9kdWxlOnRzLXdvcmtzcGFjZVxuICovXG5leHBvcnQgY29uc3QgVkVSU0lPTiA9IFwiMC4wLjFcIjtcbiJdfQ==
|
|
@@ -0,0 +1,21 @@
|
|
|
1
|
+
import Database = PouchDB.Database;
|
|
2
|
+
import { BulkFetchDocsWrapper, BulkModifyDocsWrapper, CreateIndexRequest, CreateIndexResponse, DatabaseAuthResponse, DatabaseSessionResponse, DocumentDestroyResponse, DocumentGetParams, DocumentInsertResponse, DocumentScope, MangoQuery, MangoResponse, ServerScope, DocumentFetchResponse } from "@decaf-ts/for-couchdb";
|
|
3
|
+
export declare function toServerScope(pouch: typeof PouchDB): {
|
|
4
|
+
pouch: typeof PouchDB;
|
|
5
|
+
use<D>(db: string): DocumentScope<D>;
|
|
6
|
+
auth(username: string, userpass: string): Promise<DatabaseAuthResponse>;
|
|
7
|
+
session(): Promise<DatabaseSessionResponse>;
|
|
8
|
+
};
|
|
9
|
+
export declare function toDocumentScope(database: Database): {
|
|
10
|
+
db: Database;
|
|
11
|
+
fetch(docnames: BulkFetchDocsWrapper): Promise<DocumentFetchResponse<any>>;
|
|
12
|
+
auth(username: string, userpass: string): Promise<DatabaseAuthResponse>;
|
|
13
|
+
session(): Promise<DatabaseSessionResponse>;
|
|
14
|
+
insert(document: any): Promise<DocumentInsertResponse>;
|
|
15
|
+
get(docname: string, params?: DocumentGetParams | undefined): Promise<any>;
|
|
16
|
+
destroy(docname: string, rev: string): Promise<DocumentDestroyResponse>;
|
|
17
|
+
bulk(docs: BulkModifyDocsWrapper): Promise<DocumentInsertResponse[]>;
|
|
18
|
+
createIndex(indexDef: CreateIndexRequest): Promise<CreateIndexResponse>;
|
|
19
|
+
find(query: MangoQuery): Promise<MangoResponse<any>>;
|
|
20
|
+
readonly server: ServerScope;
|
|
21
|
+
};
|
package/lib/esm/utils.js
ADDED
|
@@ -0,0 +1,92 @@
|
|
|
1
|
+
import { InternalError } from "@decaf-ts/db-decorators";
|
|
2
|
+
export function toServerScope(pouch) {
|
|
3
|
+
return new (class {
|
|
4
|
+
constructor(pouch) {
|
|
5
|
+
this.pouch = pouch;
|
|
6
|
+
}
|
|
7
|
+
// eslint-disable-next-line @typescript-eslint/no-unused-vars
|
|
8
|
+
use(db) {
|
|
9
|
+
throw new Error("Method not implemented.");
|
|
10
|
+
}
|
|
11
|
+
// eslint-disable-next-line @typescript-eslint/no-unused-vars
|
|
12
|
+
auth(username, userpass) {
|
|
13
|
+
throw new Error("Method not implemented.");
|
|
14
|
+
}
|
|
15
|
+
session() {
|
|
16
|
+
throw new Error("Method not implemented.");
|
|
17
|
+
}
|
|
18
|
+
})(pouch);
|
|
19
|
+
}
|
|
20
|
+
export function toDocumentScope(database) {
|
|
21
|
+
return new (class {
|
|
22
|
+
constructor(db) {
|
|
23
|
+
this.db = db;
|
|
24
|
+
}
|
|
25
|
+
async fetch(docnames) {
|
|
26
|
+
const result = await this.db.bulkGet({
|
|
27
|
+
docs: docnames.keys.map((k) => ({ id: k })),
|
|
28
|
+
});
|
|
29
|
+
return {
|
|
30
|
+
offset: 0,
|
|
31
|
+
rows: result.results.reduce((accum, r) => {
|
|
32
|
+
const docs = r.docs.map((d) => {
|
|
33
|
+
if (d["error"])
|
|
34
|
+
throw new InternalError(d["error"]);
|
|
35
|
+
return d["ok"];
|
|
36
|
+
});
|
|
37
|
+
accum.push(...docs);
|
|
38
|
+
return accum;
|
|
39
|
+
}, []),
|
|
40
|
+
total_rows: 0,
|
|
41
|
+
};
|
|
42
|
+
}
|
|
43
|
+
// eslint-disable-next-line @typescript-eslint/no-unused-vars
|
|
44
|
+
auth(username, userpass) {
|
|
45
|
+
throw new Error("Method not implemented.");
|
|
46
|
+
}
|
|
47
|
+
session() {
|
|
48
|
+
throw new Error("Method not implemented.");
|
|
49
|
+
}
|
|
50
|
+
async insert(document) {
|
|
51
|
+
return this.db.put(document);
|
|
52
|
+
}
|
|
53
|
+
get(docname, params) {
|
|
54
|
+
return new Promise((resolve, reject) => {
|
|
55
|
+
this.db.get(docname, params || {}, (err, result) => {
|
|
56
|
+
if (err)
|
|
57
|
+
return reject(err);
|
|
58
|
+
resolve(result);
|
|
59
|
+
});
|
|
60
|
+
});
|
|
61
|
+
}
|
|
62
|
+
destroy(docname, rev) {
|
|
63
|
+
return this.db.remove({ _id: docname, _rev: rev });
|
|
64
|
+
}
|
|
65
|
+
async bulk(docs) {
|
|
66
|
+
const results = await this.db.bulkDocs(docs.docs);
|
|
67
|
+
return results.map((r) => {
|
|
68
|
+
if (r instanceof Error)
|
|
69
|
+
return { ok: false };
|
|
70
|
+
return Object.assign({
|
|
71
|
+
ok: true,
|
|
72
|
+
}, r);
|
|
73
|
+
});
|
|
74
|
+
}
|
|
75
|
+
async createIndex(indexDef) {
|
|
76
|
+
const result = await this.db.createIndex(indexDef);
|
|
77
|
+
return {
|
|
78
|
+
result: result.result,
|
|
79
|
+
id: indexDef.ddoc,
|
|
80
|
+
name: indexDef.name,
|
|
81
|
+
};
|
|
82
|
+
}
|
|
83
|
+
find(query) {
|
|
84
|
+
return this.db.find(query);
|
|
85
|
+
}
|
|
86
|
+
get server() {
|
|
87
|
+
return this.db;
|
|
88
|
+
}
|
|
89
|
+
})(database);
|
|
90
|
+
}
|
|
91
|
+
|
|
92
|
+
//# sourceMappingURL=data:application/json;charset=utf8;base64,{"version":3,"sources":["src/utils.ts"],"names":[],"mappings":"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","file":"utils.js","sourcesContent":["import Database = PouchDB.Database;\nimport {\n  BulkFetchDocsWrapper,\n  BulkModifyDocsWrapper,\n  CreateIndexRequest,\n  CreateIndexResponse,\n  DatabaseAuthResponse,\n  DatabaseSessionResponse,\n  DocumentDestroyResponse,\n  DocumentGetParams,\n  DocumentInsertResponse,\n  DocumentScope,\n  MangoQuery,\n  MangoResponse,\n  ServerScope,\n  DocumentFetchResponse,\n} from \"@decaf-ts/for-couchdb\";\nimport FindRequest = PouchDB.Find.FindRequest;\nimport BulkGetResponse = PouchDB.Core.BulkGetResponse;\nimport { InternalError } from \"@decaf-ts/db-decorators\";\n\nexport function toServerScope(pouch: typeof PouchDB) {\n  return new (class implements ServerScope {\n    constructor(public pouch: typeof PouchDB) {}\n\n    // eslint-disable-next-line @typescript-eslint/no-unused-vars\n    use<D>(db: string): DocumentScope<D> {\n      throw new Error(\"Method not implemented.\");\n    }\n\n    // eslint-disable-next-line @typescript-eslint/no-unused-vars\n    auth(username: string, userpass: string): Promise<DatabaseAuthResponse> {\n      throw new Error(\"Method not implemented.\");\n    }\n\n    session(): Promise<DatabaseSessionResponse> {\n      throw new Error(\"Method not implemented.\");\n    }\n  })(pouch);\n}\n\nexport function toDocumentScope(database: Database) {\n  return new (class implements DocumentScope<any> {\n    constructor(public db: Database) {}\n\n    async fetch(\n      docnames: BulkFetchDocsWrapper\n    ): Promise<DocumentFetchResponse<any>> {\n      const result: BulkGetResponse<any> = await this.db.bulkGet({\n        docs: docnames.keys.map((k: string) => ({ id: k })),\n      });\n      return {\n        offset: 0,\n        rows: result.results.reduce((accum: any[], r) => {\n          const docs: any[] = r.docs.map((d) => {\n            if ((d as any)[\"error\"])\n              throw new InternalError((d as any)[\"error\"]);\n            return (d as any)[\"ok\"] as any;\n          });\n          accum.push(...docs);\n          return accum;\n        }, []),\n        total_rows: 0,\n      };\n    }\n\n    // eslint-disable-next-line @typescript-eslint/no-unused-vars\n    auth(username: string, userpass: string): Promise<DatabaseAuthResponse> {\n      throw new Error(\"Method not implemented.\");\n    }\n    session(): Promise<DatabaseSessionResponse> {\n      throw new Error(\"Method not implemented.\");\n    }\n    async insert(document: any): Promise<DocumentInsertResponse> {\n      return this.db.put(document);\n    }\n    get(docname: string, params?: DocumentGetParams | undefined): Promise<any> {\n      return new Promise<any>((resolve, reject) => {\n        this.db.get(docname, params || {}, (err, result) => {\n          if (err) return reject(err);\n          resolve(result);\n        });\n      });\n    }\n    destroy(docname: string, rev: string): Promise<DocumentDestroyResponse> {\n      return this.db.remove({ _id: docname, _rev: rev });\n    }\n    async bulk(docs: BulkModifyDocsWrapper): Promise<DocumentInsertResponse[]> {\n      const results = await this.db.bulkDocs(docs.docs);\n      return results.map((r) => {\n        if (r instanceof Error) return { ok: false };\n        return Object.assign(\n          {\n            ok: true,\n          },\n          r\n        );\n      }) as DocumentInsertResponse[];\n    }\n    async createIndex(\n      indexDef: CreateIndexRequest\n    ): Promise<CreateIndexResponse> {\n      const result = await this.db.createIndex(indexDef as any);\n      return {\n        result: result.result,\n        id: indexDef.ddoc as string,\n        name: indexDef.name as string,\n      };\n    }\n    find(query: MangoQuery): Promise<MangoResponse<any>> {\n      return this.db.find(query as unknown as FindRequest<any>);\n    }\n    get server() {\n      return this.db as unknown as ServerScope;\n    }\n  })(database);\n}\n"]}
|
package/lib/index.cjs
ADDED
|
@@ -0,0 +1,34 @@
|
|
|
1
|
+
"use strict";
|
|
2
|
+
var __createBinding = (this && this.__createBinding) || (Object.create ? (function(o, m, k, k2) {
|
|
3
|
+
if (k2 === undefined) k2 = k;
|
|
4
|
+
var desc = Object.getOwnPropertyDescriptor(m, k);
|
|
5
|
+
if (!desc || ("get" in desc ? !m.__esModule : desc.writable || desc.configurable)) {
|
|
6
|
+
desc = { enumerable: true, get: function() { return m[k]; } };
|
|
7
|
+
}
|
|
8
|
+
Object.defineProperty(o, k2, desc);
|
|
9
|
+
}) : (function(o, m, k, k2) {
|
|
10
|
+
if (k2 === undefined) k2 = k;
|
|
11
|
+
o[k2] = m[k];
|
|
12
|
+
}));
|
|
13
|
+
var __exportStar = (this && this.__exportStar) || function(m, exports) {
|
|
14
|
+
for (var p in m) if (p !== "default" && !Object.prototype.hasOwnProperty.call(exports, p)) __createBinding(exports, m, p);
|
|
15
|
+
};
|
|
16
|
+
Object.defineProperty(exports, "__esModule", { value: true });
|
|
17
|
+
exports.VERSION = void 0;
|
|
18
|
+
__exportStar(require("./adapter.cjs"), exports);
|
|
19
|
+
__exportStar(require("./PouchRepository.cjs"), exports);
|
|
20
|
+
__exportStar(require("./utils.cjs"), exports);
|
|
21
|
+
/**
|
|
22
|
+
* @summary Module summary
|
|
23
|
+
* @description Module description
|
|
24
|
+
* @module for-nano
|
|
25
|
+
*/
|
|
26
|
+
/**
|
|
27
|
+
* @summary stores the current package version
|
|
28
|
+
* @description this is how you should document a constant
|
|
29
|
+
* @const VERSION
|
|
30
|
+
* @memberOf module:ts-workspace
|
|
31
|
+
*/
|
|
32
|
+
exports.VERSION = "0.0.1";
|
|
33
|
+
|
|
34
|
+
//# sourceMappingURL=data:application/json;charset=utf8;base64,eyJ2ZXJzaW9uIjozLCJzb3VyY2VzIjpbInNyYy9pbmRleC50cyJdLCJuYW1lcyI6W10sIm1hcHBpbmdzIjoiOzs7Ozs7Ozs7Ozs7Ozs7OztBQUFBLDRDQUEwQjtBQUMxQixvREFBa0M7QUFDbEMsMENBQXdCO0FBRXhCOzs7O0dBSUc7QUFFSDs7Ozs7R0FLRztBQUNVLFFBQUEsT0FBTyxHQUFHLE9BQU8sQ0FBQyIsImZpbGUiOiJpbmRleC5qcyIsInNvdXJjZXNDb250ZW50IjpbImV4cG9ydCAqIGZyb20gXCIuL2FkYXB0ZXJcIjtcbmV4cG9ydCAqIGZyb20gXCIuL1BvdWNoUmVwb3NpdG9yeVwiO1xuZXhwb3J0ICogZnJvbSBcIi4vdXRpbHNcIjtcblxuLyoqXG4gKiBAc3VtbWFyeSBNb2R1bGUgc3VtbWFyeVxuICogQGRlc2NyaXB0aW9uIE1vZHVsZSBkZXNjcmlwdGlvblxuICogQG1vZHVsZSBmb3ItbmFub1xuICovXG5cbi8qKlxuICogQHN1bW1hcnkgc3RvcmVzIHRoZSBjdXJyZW50IHBhY2thZ2UgdmVyc2lvblxuICogQGRlc2NyaXB0aW9uIHRoaXMgaXMgaG93IHlvdSBzaG91bGQgZG9jdW1lbnQgYSBjb25zdGFudFxuICogQGNvbnN0IFZFUlNJT05cbiAqIEBtZW1iZXJPZiBtb2R1bGU6dHMtd29ya3NwYWNlXG4gKi9cbmV4cG9ydCBjb25zdCBWRVJTSU9OID0gXCIwLjAuMVwiO1xuIl19
|
package/lib/index.d.ts
ADDED
|
@@ -0,0 +1,15 @@
|
|
|
1
|
+
export * from "./adapter";
|
|
2
|
+
export * from "./PouchRepository";
|
|
3
|
+
export * from "./utils";
|
|
4
|
+
/**
|
|
5
|
+
* @summary Module summary
|
|
6
|
+
* @description Module description
|
|
7
|
+
* @module for-nano
|
|
8
|
+
*/
|
|
9
|
+
/**
|
|
10
|
+
* @summary stores the current package version
|
|
11
|
+
* @description this is how you should document a constant
|
|
12
|
+
* @const VERSION
|
|
13
|
+
* @memberOf module:ts-workspace
|
|
14
|
+
*/
|
|
15
|
+
export declare const VERSION = "0.0.1";
|
package/lib/utils.cjs
ADDED
|
@@ -0,0 +1,96 @@
|
|
|
1
|
+
"use strict";
|
|
2
|
+
Object.defineProperty(exports, "__esModule", { value: true });
|
|
3
|
+
exports.toServerScope = toServerScope;
|
|
4
|
+
exports.toDocumentScope = toDocumentScope;
|
|
5
|
+
const db_decorators_1 = require("@decaf-ts/db-decorators");
|
|
6
|
+
function toServerScope(pouch) {
|
|
7
|
+
return new (class {
|
|
8
|
+
constructor(pouch) {
|
|
9
|
+
this.pouch = pouch;
|
|
10
|
+
}
|
|
11
|
+
// eslint-disable-next-line @typescript-eslint/no-unused-vars
|
|
12
|
+
use(db) {
|
|
13
|
+
throw new Error("Method not implemented.");
|
|
14
|
+
}
|
|
15
|
+
// eslint-disable-next-line @typescript-eslint/no-unused-vars
|
|
16
|
+
auth(username, userpass) {
|
|
17
|
+
throw new Error("Method not implemented.");
|
|
18
|
+
}
|
|
19
|
+
session() {
|
|
20
|
+
throw new Error("Method not implemented.");
|
|
21
|
+
}
|
|
22
|
+
})(pouch);
|
|
23
|
+
}
|
|
24
|
+
function toDocumentScope(database) {
|
|
25
|
+
return new (class {
|
|
26
|
+
constructor(db) {
|
|
27
|
+
this.db = db;
|
|
28
|
+
}
|
|
29
|
+
async fetch(docnames) {
|
|
30
|
+
const result = await this.db.bulkGet({
|
|
31
|
+
docs: docnames.keys.map((k) => ({ id: k })),
|
|
32
|
+
});
|
|
33
|
+
return {
|
|
34
|
+
offset: 0,
|
|
35
|
+
rows: result.results.reduce((accum, r) => {
|
|
36
|
+
const docs = r.docs.map((d) => {
|
|
37
|
+
if (d["error"])
|
|
38
|
+
throw new db_decorators_1.InternalError(d["error"]);
|
|
39
|
+
return d["ok"];
|
|
40
|
+
});
|
|
41
|
+
accum.push(...docs);
|
|
42
|
+
return accum;
|
|
43
|
+
}, []),
|
|
44
|
+
total_rows: 0,
|
|
45
|
+
};
|
|
46
|
+
}
|
|
47
|
+
// eslint-disable-next-line @typescript-eslint/no-unused-vars
|
|
48
|
+
auth(username, userpass) {
|
|
49
|
+
throw new Error("Method not implemented.");
|
|
50
|
+
}
|
|
51
|
+
session() {
|
|
52
|
+
throw new Error("Method not implemented.");
|
|
53
|
+
}
|
|
54
|
+
async insert(document) {
|
|
55
|
+
return this.db.put(document);
|
|
56
|
+
}
|
|
57
|
+
get(docname, params) {
|
|
58
|
+
return new Promise((resolve, reject) => {
|
|
59
|
+
this.db.get(docname, params || {}, (err, result) => {
|
|
60
|
+
if (err)
|
|
61
|
+
return reject(err);
|
|
62
|
+
resolve(result);
|
|
63
|
+
});
|
|
64
|
+
});
|
|
65
|
+
}
|
|
66
|
+
destroy(docname, rev) {
|
|
67
|
+
return this.db.remove({ _id: docname, _rev: rev });
|
|
68
|
+
}
|
|
69
|
+
async bulk(docs) {
|
|
70
|
+
const results = await this.db.bulkDocs(docs.docs);
|
|
71
|
+
return results.map((r) => {
|
|
72
|
+
if (r instanceof Error)
|
|
73
|
+
return { ok: false };
|
|
74
|
+
return Object.assign({
|
|
75
|
+
ok: true,
|
|
76
|
+
}, r);
|
|
77
|
+
});
|
|
78
|
+
}
|
|
79
|
+
async createIndex(indexDef) {
|
|
80
|
+
const result = await this.db.createIndex(indexDef);
|
|
81
|
+
return {
|
|
82
|
+
result: result.result,
|
|
83
|
+
id: indexDef.ddoc,
|
|
84
|
+
name: indexDef.name,
|
|
85
|
+
};
|
|
86
|
+
}
|
|
87
|
+
find(query) {
|
|
88
|
+
return this.db.find(query);
|
|
89
|
+
}
|
|
90
|
+
get server() {
|
|
91
|
+
return this.db;
|
|
92
|
+
}
|
|
93
|
+
})(database);
|
|
94
|
+
}
|
|
95
|
+
|
|
96
|
+
//# sourceMappingURL=data:application/json;charset=utf8;base64,{"version":3,"sources":["src/utils.ts"],"names":[],"mappings":"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","file":"utils.js","sourcesContent":["import Database = PouchDB.Database;\nimport {\n  BulkFetchDocsWrapper,\n  BulkModifyDocsWrapper,\n  CreateIndexRequest,\n  CreateIndexResponse,\n  DatabaseAuthResponse,\n  DatabaseSessionResponse,\n  DocumentDestroyResponse,\n  DocumentGetParams,\n  DocumentInsertResponse,\n  DocumentScope,\n  MangoQuery,\n  MangoResponse,\n  ServerScope,\n  DocumentFetchResponse,\n} from \"@decaf-ts/for-couchdb\";\nimport FindRequest = PouchDB.Find.FindRequest;\nimport BulkGetResponse = PouchDB.Core.BulkGetResponse;\nimport { InternalError } from \"@decaf-ts/db-decorators\";\n\nexport function toServerScope(pouch: typeof PouchDB) {\n  return new (class implements ServerScope {\n    constructor(public pouch: typeof PouchDB) {}\n\n    // eslint-disable-next-line @typescript-eslint/no-unused-vars\n    use<D>(db: string): DocumentScope<D> {\n      throw new Error(\"Method not implemented.\");\n    }\n\n    // eslint-disable-next-line @typescript-eslint/no-unused-vars\n    auth(username: string, userpass: string): Promise<DatabaseAuthResponse> {\n      throw new Error(\"Method not implemented.\");\n    }\n\n    session(): Promise<DatabaseSessionResponse> {\n      throw new Error(\"Method not implemented.\");\n    }\n  })(pouch);\n}\n\nexport function toDocumentScope(database: Database) {\n  return new (class implements DocumentScope<any> {\n    constructor(public db: Database) {}\n\n    async fetch(\n      docnames: BulkFetchDocsWrapper\n    ): Promise<DocumentFetchResponse<any>> {\n      const result: BulkGetResponse<any> = await this.db.bulkGet({\n        docs: docnames.keys.map((k: string) => ({ id: k })),\n      });\n      return {\n        offset: 0,\n        rows: result.results.reduce((accum: any[], r) => {\n          const docs: any[] = r.docs.map((d) => {\n            if ((d as any)[\"error\"])\n              throw new InternalError((d as any)[\"error\"]);\n            return (d as any)[\"ok\"] as any;\n          });\n          accum.push(...docs);\n          return accum;\n        }, []),\n        total_rows: 0,\n      };\n    }\n\n    // eslint-disable-next-line @typescript-eslint/no-unused-vars\n    auth(username: string, userpass: string): Promise<DatabaseAuthResponse> {\n      throw new Error(\"Method not implemented.\");\n    }\n    session(): Promise<DatabaseSessionResponse> {\n      throw new Error(\"Method not implemented.\");\n    }\n    async insert(document: any): Promise<DocumentInsertResponse> {\n      return this.db.put(document);\n    }\n    get(docname: string, params?: DocumentGetParams | undefined): Promise<any> {\n      return new Promise<any>((resolve, reject) => {\n        this.db.get(docname, params || {}, (err, result) => {\n          if (err) return reject(err);\n          resolve(result);\n        });\n      });\n    }\n    destroy(docname: string, rev: string): Promise<DocumentDestroyResponse> {\n      return this.db.remove({ _id: docname, _rev: rev });\n    }\n    async bulk(docs: BulkModifyDocsWrapper): Promise<DocumentInsertResponse[]> {\n      const results = await this.db.bulkDocs(docs.docs);\n      return results.map((r) => {\n        if (r instanceof Error) return { ok: false };\n        return Object.assign(\n          {\n            ok: true,\n          },\n          r\n        );\n      }) as DocumentInsertResponse[];\n    }\n    async createIndex(\n      indexDef: CreateIndexRequest\n    ): Promise<CreateIndexResponse> {\n      const result = await this.db.createIndex(indexDef as any);\n      return {\n        result: result.result,\n        id: indexDef.ddoc as string,\n        name: indexDef.name as string,\n      };\n    }\n    find(query: MangoQuery): Promise<MangoResponse<any>> {\n      return this.db.find(query as unknown as FindRequest<any>);\n    }\n    get server() {\n      return this.db as unknown as ServerScope;\n    }\n  })(database);\n}\n"]}
|
package/lib/utils.d.ts
ADDED
|
@@ -0,0 +1,21 @@
|
|
|
1
|
+
import Database = PouchDB.Database;
|
|
2
|
+
import { BulkFetchDocsWrapper, BulkModifyDocsWrapper, CreateIndexRequest, CreateIndexResponse, DatabaseAuthResponse, DatabaseSessionResponse, DocumentDestroyResponse, DocumentGetParams, DocumentInsertResponse, DocumentScope, MangoQuery, MangoResponse, ServerScope, DocumentFetchResponse } from "@decaf-ts/for-couchdb";
|
|
3
|
+
export declare function toServerScope(pouch: typeof PouchDB): {
|
|
4
|
+
pouch: typeof PouchDB;
|
|
5
|
+
use<D>(db: string): DocumentScope<D>;
|
|
6
|
+
auth(username: string, userpass: string): Promise<DatabaseAuthResponse>;
|
|
7
|
+
session(): Promise<DatabaseSessionResponse>;
|
|
8
|
+
};
|
|
9
|
+
export declare function toDocumentScope(database: Database): {
|
|
10
|
+
db: Database;
|
|
11
|
+
fetch(docnames: BulkFetchDocsWrapper): Promise<DocumentFetchResponse<any>>;
|
|
12
|
+
auth(username: string, userpass: string): Promise<DatabaseAuthResponse>;
|
|
13
|
+
session(): Promise<DatabaseSessionResponse>;
|
|
14
|
+
insert(document: any): Promise<DocumentInsertResponse>;
|
|
15
|
+
get(docname: string, params?: DocumentGetParams | undefined): Promise<any>;
|
|
16
|
+
destroy(docname: string, rev: string): Promise<DocumentDestroyResponse>;
|
|
17
|
+
bulk(docs: BulkModifyDocsWrapper): Promise<DocumentInsertResponse[]>;
|
|
18
|
+
createIndex(indexDef: CreateIndexRequest): Promise<CreateIndexResponse>;
|
|
19
|
+
find(query: MangoQuery): Promise<MangoResponse<any>>;
|
|
20
|
+
readonly server: ServerScope;
|
|
21
|
+
};
|