@decaf-ts/for-nano 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.
@@ -0,0 +1,25 @@
1
+ /*!
2
+ * The buffer module from node.js, for the browser.
3
+ *
4
+ * @author Feross Aboukhadijeh <https://feross.org>
5
+ * @license MIT
6
+ */
7
+
8
+ /*! *****************************************************************************
9
+ Copyright (C) Microsoft. All rights reserved.
10
+ Licensed under the Apache License, Version 2.0 (the "License"); you may not use
11
+ this file except in compliance with the License. You may obtain a copy of the
12
+ License at http://www.apache.org/licenses/LICENSE-2.0
13
+
14
+ THIS CODE IS PROVIDED ON AN *AS IS* BASIS, WITHOUT WARRANTIES OR CONDITIONS OF ANY
15
+ KIND, EITHER EXPRESS OR IMPLIED, INCLUDING WITHOUT LIMITATION ANY IMPLIED
16
+ WARRANTIES OR CONDITIONS OF TITLE, FITNESS FOR A PARTICULAR PURPOSE,
17
+ MERCHANTABLITY OR NON-INFRINGEMENT.
18
+
19
+ See the Apache Version 2.0 License for specific language governing permissions
20
+ and limitations under the License.
21
+ ***************************************************************************** */
22
+
23
+ /*! https://mths.be/punycode v1.4.1 by @mathias */
24
+
25
+ /*! ieee754. BSD-3-Clause License. Feross Aboukhadijeh <https://feross.org/opensource> */
@@ -0,0 +1,106 @@
1
+ "use strict";
2
+ Object.defineProperty(exports, "__esModule", { value: true });
3
+ exports.NanoAdapter = void 0;
4
+ const db_decorators_1 = require("@decaf-ts/db-decorators");
5
+ require("reflect-metadata");
6
+ const for_couchdb_1 = require("@decaf-ts/for-couchdb");
7
+ const Nano = require("nano");
8
+ const core_1 = require("@decaf-ts/core");
9
+ class NanoAdapter extends for_couchdb_1.CouchDBAdapter {
10
+ constructor(scope, flavour) {
11
+ super(scope, flavour);
12
+ }
13
+ async user() {
14
+ try {
15
+ const user = await this.native.server.session();
16
+ return new core_1.User({
17
+ id: user.userCtx.name,
18
+ roles: user.userCtx.roles,
19
+ affiliations: user.userCtx.affiliations,
20
+ });
21
+ }
22
+ catch (e) {
23
+ throw this.parseError(e);
24
+ }
25
+ }
26
+ static connect(user, pass, host = "localhost:5984", protocol = "http") {
27
+ return Nano(`${protocol}://${user}:${pass}@${host}`);
28
+ }
29
+ static async createDatabase(con, name) {
30
+ let result;
31
+ try {
32
+ result = await con.db.create(name);
33
+ }
34
+ catch (e) {
35
+ throw for_couchdb_1.CouchDBAdapter.parseError(e);
36
+ }
37
+ const { ok, error, reason } = result;
38
+ if (!ok)
39
+ throw for_couchdb_1.CouchDBAdapter.parseError(error, reason);
40
+ }
41
+ static async deleteDatabase(con, name) {
42
+ let result;
43
+ try {
44
+ result = await con.db.destroy(name);
45
+ }
46
+ catch (e) {
47
+ throw for_couchdb_1.CouchDBAdapter.parseError(e);
48
+ }
49
+ const { ok } = result;
50
+ if (!ok)
51
+ throw new db_decorators_1.InternalError(`Failed to delete database with name ${name}`);
52
+ }
53
+ static async createUser(con, dbName, user, pass, roles = ["reader", "writer"]) {
54
+ const users = con.db.use("_users");
55
+ const usr = {
56
+ _id: "org.couchdb.user:" + user,
57
+ name: user,
58
+ password: pass,
59
+ roles: roles,
60
+ type: "user",
61
+ };
62
+ try {
63
+ const created = await users.insert(usr);
64
+ const { ok } = created;
65
+ if (!ok)
66
+ throw new db_decorators_1.InternalError(`Failed to create user ${user}`);
67
+ const security = await con.request({
68
+ db: dbName,
69
+ method: "put",
70
+ path: "_security",
71
+ // headers: {
72
+ //
73
+ // },
74
+ body: {
75
+ admins: {
76
+ names: [user],
77
+ roles: [],
78
+ },
79
+ members: {
80
+ names: [user],
81
+ roles: roles,
82
+ },
83
+ },
84
+ });
85
+ if (!security.ok)
86
+ throw new db_decorators_1.InternalError(`Failed to authorize user ${user} to db ${dbName}`);
87
+ }
88
+ catch (e) {
89
+ throw for_couchdb_1.CouchDBAdapter.parseError(e);
90
+ }
91
+ }
92
+ static async deleteUser(con, dbName, user) {
93
+ const users = con.db.use("_users");
94
+ const id = "org.couchdb.user:" + user;
95
+ try {
96
+ const usr = await users.get(id);
97
+ await users.destroy(id, usr._rev);
98
+ }
99
+ catch (e) {
100
+ throw for_couchdb_1.CouchDBAdapter.parseError(e);
101
+ }
102
+ }
103
+ }
104
+ exports.NanoAdapter = NanoAdapter;
105
+
106
+ //# sourceMappingURL=data:application/json;charset=utf8;base64,{"version":3,"sources":["src/adapter.ts"],"names":[],"mappings":"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","file":"adapter.js","sourcesContent":["import { InternalError } from \"@decaf-ts/db-decorators\";\nimport \"reflect-metadata\";\nimport {\n  CouchDBAdapter,\n  DatabaseSessionResponse,\n  DocumentInsertResponse,\n  MaybeDocument,\n} from \"@decaf-ts/for-couchdb\";\nimport * as Nano from \"nano\";\nimport { DocumentScope, ServerScope } from \"nano\";\nimport { User } from \"@decaf-ts/core\";\n\nexport class NanoAdapter extends CouchDBAdapter {\n  constructor(scope: DocumentScope<any>, flavour: string) {\n    super(scope, flavour);\n  }\n\n  async user(): Promise<User> {\n    try {\n      const user: DatabaseSessionResponse = await this.native.server.session();\n      return new User({\n        id: user.userCtx.name,\n        roles: user.userCtx.roles,\n        affiliations: user.userCtx.affiliations,\n      });\n    } catch (e: any) {\n      throw this.parseError(e);\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: any;\n    try {\n      result = await con.db.create(name);\n    } catch (e: any) {\n      throw CouchDBAdapter.parseError(e);\n    }\n    const { ok, error, reason } = result;\n    if (!ok) throw CouchDBAdapter.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 CouchDBAdapter.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 = 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 CouchDBAdapter.parseError(e);\n    }\n  }\n\n  static async deleteUser(con: ServerScope, dbName: string, user: string) {\n    const users = 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 CouchDBAdapter.parseError(e);\n    }\n  }\n}\n"]}
@@ -0,0 +1,13 @@
1
+ import "reflect-metadata";
2
+ import { CouchDBAdapter } from "@decaf-ts/for-couchdb";
3
+ import { DocumentScope, ServerScope } from "nano";
4
+ import { User } from "@decaf-ts/core";
5
+ export declare class NanoAdapter extends CouchDBAdapter {
6
+ constructor(scope: DocumentScope<any>, flavour: string);
7
+ user(): Promise<User>;
8
+ static connect(user: string, pass: string, host?: string, protocol?: "http" | "https"): ServerScope;
9
+ static createDatabase(con: ServerScope, name: string): Promise<void>;
10
+ static deleteDatabase(con: ServerScope, name: string): Promise<void>;
11
+ static createUser(con: ServerScope, dbName: string, user: string, pass: string, roles?: string[]): Promise<void>;
12
+ static deleteUser(con: ServerScope, dbName: string, user: string): Promise<void>;
13
+ }
@@ -0,0 +1,13 @@
1
+ import "reflect-metadata";
2
+ import { CouchDBAdapter } from "@decaf-ts/for-couchdb";
3
+ import { DocumentScope, ServerScope } from "nano";
4
+ import { User } from "@decaf-ts/core";
5
+ export declare class NanoAdapter extends CouchDBAdapter {
6
+ constructor(scope: DocumentScope<any>, flavour: string);
7
+ user(): Promise<User>;
8
+ static connect(user: string, pass: string, host?: string, protocol?: "http" | "https"): ServerScope;
9
+ static createDatabase(con: ServerScope, name: string): Promise<void>;
10
+ static deleteDatabase(con: ServerScope, name: string): Promise<void>;
11
+ static createUser(con: ServerScope, dbName: string, user: string, pass: string, roles?: string[]): Promise<void>;
12
+ static deleteUser(con: ServerScope, dbName: string, user: string): Promise<void>;
13
+ }
@@ -0,0 +1,102 @@
1
+ import { InternalError } from "@decaf-ts/db-decorators";
2
+ import "reflect-metadata";
3
+ import { CouchDBAdapter, } from "@decaf-ts/for-couchdb";
4
+ import * as Nano from "nano";
5
+ import { User } from "@decaf-ts/core";
6
+ export class NanoAdapter extends CouchDBAdapter {
7
+ constructor(scope, flavour) {
8
+ super(scope, flavour);
9
+ }
10
+ async user() {
11
+ try {
12
+ const user = await this.native.server.session();
13
+ return new User({
14
+ id: user.userCtx.name,
15
+ roles: user.userCtx.roles,
16
+ affiliations: user.userCtx.affiliations,
17
+ });
18
+ }
19
+ catch (e) {
20
+ throw this.parseError(e);
21
+ }
22
+ }
23
+ static connect(user, pass, host = "localhost:5984", protocol = "http") {
24
+ return Nano(`${protocol}://${user}:${pass}@${host}`);
25
+ }
26
+ static async createDatabase(con, name) {
27
+ let result;
28
+ try {
29
+ result = await con.db.create(name);
30
+ }
31
+ catch (e) {
32
+ throw CouchDBAdapter.parseError(e);
33
+ }
34
+ const { ok, error, reason } = result;
35
+ if (!ok)
36
+ throw CouchDBAdapter.parseError(error, reason);
37
+ }
38
+ static async deleteDatabase(con, name) {
39
+ let result;
40
+ try {
41
+ result = await con.db.destroy(name);
42
+ }
43
+ catch (e) {
44
+ throw CouchDBAdapter.parseError(e);
45
+ }
46
+ const { ok } = result;
47
+ if (!ok)
48
+ throw new InternalError(`Failed to delete database with name ${name}`);
49
+ }
50
+ static async createUser(con, dbName, user, pass, roles = ["reader", "writer"]) {
51
+ const users = con.db.use("_users");
52
+ const usr = {
53
+ _id: "org.couchdb.user:" + user,
54
+ name: user,
55
+ password: pass,
56
+ roles: roles,
57
+ type: "user",
58
+ };
59
+ try {
60
+ const created = await users.insert(usr);
61
+ const { ok } = created;
62
+ if (!ok)
63
+ throw new InternalError(`Failed to create user ${user}`);
64
+ const security = await con.request({
65
+ db: dbName,
66
+ method: "put",
67
+ path: "_security",
68
+ // headers: {
69
+ //
70
+ // },
71
+ body: {
72
+ admins: {
73
+ names: [user],
74
+ roles: [],
75
+ },
76
+ members: {
77
+ names: [user],
78
+ roles: roles,
79
+ },
80
+ },
81
+ });
82
+ if (!security.ok)
83
+ throw new InternalError(`Failed to authorize user ${user} to db ${dbName}`);
84
+ }
85
+ catch (e) {
86
+ throw CouchDBAdapter.parseError(e);
87
+ }
88
+ }
89
+ static async deleteUser(con, dbName, user) {
90
+ const users = con.db.use("_users");
91
+ const id = "org.couchdb.user:" + user;
92
+ try {
93
+ const usr = await users.get(id);
94
+ await users.destroy(id, usr._rev);
95
+ }
96
+ catch (e) {
97
+ throw CouchDBAdapter.parseError(e);
98
+ }
99
+ }
100
+ }
101
+
102
+ //# sourceMappingURL=data:application/json;charset=utf8;base64,{"version":3,"sources":["src/adapter.ts"],"names":[],"mappings":"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","file":"adapter.js","sourcesContent":["import { InternalError } from \"@decaf-ts/db-decorators\";\nimport \"reflect-metadata\";\nimport {\n  CouchDBAdapter,\n  DatabaseSessionResponse,\n  DocumentInsertResponse,\n  MaybeDocument,\n} from \"@decaf-ts/for-couchdb\";\nimport * as Nano from \"nano\";\nimport { DocumentScope, ServerScope } from \"nano\";\nimport { User } from \"@decaf-ts/core\";\n\nexport class NanoAdapter extends CouchDBAdapter {\n  constructor(scope: DocumentScope<any>, flavour: string) {\n    super(scope, flavour);\n  }\n\n  async user(): Promise<User> {\n    try {\n      const user: DatabaseSessionResponse = await this.native.server.session();\n      return new User({\n        id: user.userCtx.name,\n        roles: user.userCtx.roles,\n        affiliations: user.userCtx.affiliations,\n      });\n    } catch (e: any) {\n      throw this.parseError(e);\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: any;\n    try {\n      result = await con.db.create(name);\n    } catch (e: any) {\n      throw CouchDBAdapter.parseError(e);\n    }\n    const { ok, error, reason } = result;\n    if (!ok) throw CouchDBAdapter.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 CouchDBAdapter.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 = 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 CouchDBAdapter.parseError(e);\n    }\n  }\n\n  static async deleteUser(con: ServerScope, dbName: string, user: string) {\n    const users = 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 CouchDBAdapter.parseError(e);\n    }\n  }\n}\n"]}
@@ -0,0 +1,13 @@
1
+ export * from "./adapter";
2
+ /**
3
+ * @summary Module summary
4
+ * @description Module description
5
+ * @module for-nano
6
+ */
7
+ /**
8
+ * @summary stores the current package version
9
+ * @description this is how you should document a constant
10
+ * @const VERSION
11
+ * @memberOf module:ts-workspace
12
+ */
13
+ export declare const VERSION = "0.0.1";
@@ -0,0 +1,15 @@
1
+ export * from "./adapter";
2
+ /**
3
+ * @summary Module summary
4
+ * @description Module description
5
+ * @module for-nano
6
+ */
7
+ /**
8
+ * @summary stores the current package version
9
+ * @description this is how you should document a constant
10
+ * @const VERSION
11
+ * @memberOf module:ts-workspace
12
+ */
13
+ export const VERSION = "0.0.1";
14
+
15
+ //# sourceMappingURL=data:application/json;charset=utf8;base64,eyJ2ZXJzaW9uIjozLCJzb3VyY2VzIjpbInNyYy9pbmRleC50cyJdLCJuYW1lcyI6W10sIm1hcHBpbmdzIjoiQUFBQSxjQUFjLFdBQVcsQ0FBQztBQUUxQjs7OztHQUlHO0FBRUg7Ozs7O0dBS0c7QUFDSCxNQUFNLENBQUMsTUFBTSxPQUFPLEdBQUcsT0FBTyxDQUFDIiwiZmlsZSI6ImluZGV4LmpzIiwic291cmNlc0NvbnRlbnQiOlsiZXhwb3J0ICogZnJvbSBcIi4vYWRhcHRlclwiO1xuXG4vKipcbiAqIEBzdW1tYXJ5IE1vZHVsZSBzdW1tYXJ5XG4gKiBAZGVzY3JpcHRpb24gTW9kdWxlIGRlc2NyaXB0aW9uXG4gKiBAbW9kdWxlIGZvci1uYW5vXG4gKi9cblxuLyoqXG4gKiBAc3VtbWFyeSBzdG9yZXMgdGhlIGN1cnJlbnQgcGFja2FnZSB2ZXJzaW9uXG4gKiBAZGVzY3JpcHRpb24gdGhpcyBpcyBob3cgeW91IHNob3VsZCBkb2N1bWVudCBhIGNvbnN0YW50XG4gKiBAY29uc3QgVkVSU0lPTlxuICogQG1lbWJlck9mIG1vZHVsZTp0cy13b3Jrc3BhY2VcbiAqL1xuZXhwb3J0IGNvbnN0IFZFUlNJT04gPSBcIjAuMC4xXCI7XG4iXX0=
package/lib/index.cjs ADDED
@@ -0,0 +1,32 @@
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
+ /**
20
+ * @summary Module summary
21
+ * @description Module description
22
+ * @module for-nano
23
+ */
24
+ /**
25
+ * @summary stores the current package version
26
+ * @description this is how you should document a constant
27
+ * @const VERSION
28
+ * @memberOf module:ts-workspace
29
+ */
30
+ exports.VERSION = "0.0.1";
31
+
32
+ //# sourceMappingURL=data:application/json;charset=utf8;base64,eyJ2ZXJzaW9uIjozLCJzb3VyY2VzIjpbInNyYy9pbmRleC50cyJdLCJuYW1lcyI6W10sIm1hcHBpbmdzIjoiOzs7Ozs7Ozs7Ozs7Ozs7OztBQUFBLDRDQUEwQjtBQUUxQjs7OztHQUlHO0FBRUg7Ozs7O0dBS0c7QUFDVSxRQUFBLE9BQU8sR0FBRyxPQUFPLENBQUMiLCJmaWxlIjoiaW5kZXguanMiLCJzb3VyY2VzQ29udGVudCI6WyJleHBvcnQgKiBmcm9tIFwiLi9hZGFwdGVyXCI7XG5cbi8qKlxuICogQHN1bW1hcnkgTW9kdWxlIHN1bW1hcnlcbiAqIEBkZXNjcmlwdGlvbiBNb2R1bGUgZGVzY3JpcHRpb25cbiAqIEBtb2R1bGUgZm9yLW5hbm9cbiAqL1xuXG4vKipcbiAqIEBzdW1tYXJ5IHN0b3JlcyB0aGUgY3VycmVudCBwYWNrYWdlIHZlcnNpb25cbiAqIEBkZXNjcmlwdGlvbiB0aGlzIGlzIGhvdyB5b3Ugc2hvdWxkIGRvY3VtZW50IGEgY29uc3RhbnRcbiAqIEBjb25zdCBWRVJTSU9OXG4gKiBAbWVtYmVyT2YgbW9kdWxlOnRzLXdvcmtzcGFjZVxuICovXG5leHBvcnQgY29uc3QgVkVSU0lPTiA9IFwiMC4wLjFcIjtcbiJdfQ==
package/lib/index.d.ts ADDED
@@ -0,0 +1,13 @@
1
+ export * from "./adapter";
2
+ /**
3
+ * @summary Module summary
4
+ * @description Module description
5
+ * @module for-nano
6
+ */
7
+ /**
8
+ * @summary stores the current package version
9
+ * @description this is how you should document a constant
10
+ * @const VERSION
11
+ * @memberOf module:ts-workspace
12
+ */
13
+ export declare const VERSION = "0.0.1";
package/package.json ADDED
@@ -0,0 +1,117 @@
1
+ {
2
+ "name": "@decaf-ts/for-nano",
3
+ "version": "0.0.2",
4
+ "description": "decaf-ts persistence adapter for CouchDB via nano",
5
+ "type": "module",
6
+ "exports": {
7
+ "require": "./lib/index.cjs",
8
+ "import": "./lib/esm/index.js"
9
+ },
10
+ "types": "lib/index.d.ts",
11
+ "scripts": {
12
+ "do-install": "TOKEN=$(cat .token) npm install",
13
+ "update-dependencies": "rimraf node_modules/@decaf-ts package-lock.json && npm run do-install",
14
+ "flash-forward": "npx npm-check-updates -u && npm run do-install",
15
+ "reset": "rm -rf * && git checkout . && git pull && npm run do-install",
16
+ "build": "rimraf ./lib && rimraf ./dist && gulp dev",
17
+ "build:prod": "rimraf ./lib && rimraf ./dist && gulp prod",
18
+ "test": "jest --coverage --testPathPattern=\"/tests/unit\" --passWithNoTests --detectOpenHandles",
19
+ "test:integration": "jest --coverage --testPathPattern=\"/tests/(integration)\" --passWithNoTests --detectOpenHandles --globalSetup=./tests/integration/setup.ts --globalTeardown=./tests/integration/teardown.ts",
20
+ "test:all": "jest --coverage --testPathPattern=\"/tests/(unit|integration)\" --passWithNoTests",
21
+ "lint": "eslint .",
22
+ "lint-fix": "eslint --fix ./src/*",
23
+ "test:circular": "dpdm -T --no-warning --no-tree ./src/index.ts",
24
+ "prepare-release": "npm run lint-fix && npm run build:prod && npm run coverage && npm run docs",
25
+ "release": "./bin/tag-release.sh",
26
+ "clean-publish": "npx clean-publish",
27
+ "coverage": "npm run test:all && cd workdocs && jest-coverage-badges",
28
+ "drawings": "for FILE in workdocs/drawings/*.drawio; do echo \"converting $FILE to image...\" && docker run --rm -v $(pwd):/data rlespinasse/drawio-export --format png $FILE; done && cp -rf workdocs/drawings/export/* workdocs/resources/",
29
+ "uml": "cd workdocs/uml && for FILE in ./*.puml; do docker run --rm -v $(pwd):/work -w /work miy4/plantuml -DPLANTUML_LIMIT_SIZE=8192 -tpng $FILE; done && cd ../.. && cp -fr workdocs/uml/*.png workdocs/resources/",
30
+ "docs": "npx rimraf ./docs && mkdir docs && npm run do-install -- better-docs taffydb && gulp docs; npm remove better-docs taffydb"
31
+ },
32
+ "repository": {
33
+ "type": "git",
34
+ "url": "git+https://github.com/decaf-ts/for-couchdb.git"
35
+ },
36
+ "engines": {
37
+ "node": ">=20.0.0",
38
+ "npm": ">=10.0.0"
39
+ },
40
+ "files": [
41
+ "lib",
42
+ "dist"
43
+ ],
44
+ "keywords": [
45
+ "plantuml",
46
+ "mermaid",
47
+ "uml",
48
+ "drawio",
49
+ "mddocs",
50
+ "md",
51
+ "jsdoc",
52
+ "doc",
53
+ "docs",
54
+ "documentation",
55
+ "ci/cd",
56
+ "ci",
57
+ "cd",
58
+ "template",
59
+ "typescript",
60
+ "ts"
61
+ ],
62
+ "author": "Tiago Venceslau",
63
+ "license": "MIT",
64
+ "bugs": {
65
+ "url": "https://github.com/decaf-ts/for-couchdb/issues"
66
+ },
67
+ "homepage": "https://github.com/decaf-ts/for-couchdb#readme",
68
+ "devDependencies": {
69
+ "@eslint/js": "^9.13.0",
70
+ "@types/jest": "^29.5.14",
71
+ "@typescript-eslint/eslint-plugin": "^8.12.2",
72
+ "clean-publish": "^5.1.0",
73
+ "dpdm": "^3.14.0",
74
+ "eslint": "^9.13.0",
75
+ "eslint-config-prettier": "^9.1.0",
76
+ "eslint-plugin-prettier": "^5.2.1",
77
+ "globals": "^15.11.0",
78
+ "gulp": "^5.0.0",
79
+ "gulp-if": "^3.0.0",
80
+ "gulp-rename": "^2.0.0",
81
+ "gulp-replace": "^1.1.4",
82
+ "gulp-run-command": "^0.0.10",
83
+ "gulp-sourcemaps": "^2.6.5",
84
+ "gulp-typescript": "^6.0.0-alpha.1",
85
+ "gulp-uglify": "^3.0.2",
86
+ "https-browserify": "^1.0.0",
87
+ "jest": "^29.7.0",
88
+ "jest-coverage-badges": "^1.0.0",
89
+ "jest-junit": "^16.0.0",
90
+ "jsdoc": "^4.0.4",
91
+ "jsdoc-mermaid": "^1.0.0",
92
+ "markdown-include": "^0.4.3",
93
+ "merge-stream": "^2.0.0",
94
+ "nodemon": "^3.1.7",
95
+ "npm-check-updates": "^17.1.9",
96
+ "prettier": "^3.3.3",
97
+ "rimraf": "^6.0.1",
98
+ "stream-http": "^3.2.0",
99
+ "ts-jest": "^29.2.5",
100
+ "ts-loader": "^9.5.1",
101
+ "ts-node": "^10.9.2",
102
+ "typescript": "^5.6.3",
103
+ "typescript-eslint": "^8.12.2",
104
+ "url": "^0.11.4",
105
+ "vinyl-named": "^1.1.0",
106
+ "webpack-stream": "^7.0.0"
107
+ },
108
+ "peerDependencies": {
109
+ "@decaf-ts/core": "latest",
110
+ "@decaf-ts/db-decorators": "latest",
111
+ "@decaf-ts/decorator-validation": "latest",
112
+ "@decaf-ts/for-couchdb": "latest",
113
+ "@decaf-ts/injectable-decorators": "latest",
114
+ "@decaf-ts/reflection": "latest",
115
+ "nano": "^10.1.4"
116
+ }
117
+ }