pogi 2.11.0

This diff represents the content of publicly available package versions that have been released to one of the supported registries. The information contained in this diff is provided for informational purposes only and reflects changes between package versions as they appear in their respective public registries.
Files changed (82) hide show
  1. package/.vscode/launch.json +35 -0
  2. package/CHANGELOG.md +277 -0
  3. package/LICENSE +21 -0
  4. package/README.md +85 -0
  5. package/docs/API/PgDb.md +218 -0
  6. package/docs/API/PgSchema.md +91 -0
  7. package/docs/API/PgTable.md +365 -0
  8. package/docs/API/QueryOptions.md +77 -0
  9. package/docs/API/condition.md +133 -0
  10. package/docs/connection.md +91 -0
  11. package/docs/css/docs.css +164 -0
  12. package/docs/executingSqlFile.md +44 -0
  13. package/docs/faq.md +15 -0
  14. package/docs/functions.md +19 -0
  15. package/docs/generatingInterfaceForTables.md +35 -0
  16. package/docs/index.md +48 -0
  17. package/docs/logger.md +40 -0
  18. package/docs/mappingDatabaseTypes.md +89 -0
  19. package/docs/notification.md +19 -0
  20. package/docs/pitfalls.md +73 -0
  21. package/docs/streams.md +68 -0
  22. package/docs/transaction.md +65 -0
  23. package/lib/bin/generateInterface.d.ts +1 -0
  24. package/lib/bin/generateInterface.js +53 -0
  25. package/lib/bin/generateInterface.js.map +1 -0
  26. package/lib/connectionOptions.d.ts +25 -0
  27. package/lib/connectionOptions.js +3 -0
  28. package/lib/connectionOptions.js.map +1 -0
  29. package/lib/index.d.ts +6 -0
  30. package/lib/index.js +10 -0
  31. package/lib/index.js.map +1 -0
  32. package/lib/pgConverters.d.ts +10 -0
  33. package/lib/pgConverters.js +66 -0
  34. package/lib/pgConverters.js.map +1 -0
  35. package/lib/pgDb.d.ts +86 -0
  36. package/lib/pgDb.js +745 -0
  37. package/lib/pgDb.js.map +1 -0
  38. package/lib/pgDbLogger.d.ts +5 -0
  39. package/lib/pgDbLogger.js +3 -0
  40. package/lib/pgDbLogger.js.map +1 -0
  41. package/lib/pgDbOperators.d.ts +113 -0
  42. package/lib/pgDbOperators.js +44 -0
  43. package/lib/pgDbOperators.js.map +1 -0
  44. package/lib/pgSchema.d.ts +16 -0
  45. package/lib/pgSchema.js +16 -0
  46. package/lib/pgSchema.js.map +1 -0
  47. package/lib/pgTable.d.ts +131 -0
  48. package/lib/pgTable.js +322 -0
  49. package/lib/pgTable.js.map +1 -0
  50. package/lib/pgUtils.d.ts +31 -0
  51. package/lib/pgUtils.js +157 -0
  52. package/lib/pgUtils.js.map +1 -0
  53. package/lib/queryAble.d.ts +76 -0
  54. package/lib/queryAble.js +330 -0
  55. package/lib/queryAble.js.map +1 -0
  56. package/lib/queryWhere.d.ts +8 -0
  57. package/lib/queryWhere.js +249 -0
  58. package/lib/queryWhere.js.map +1 -0
  59. package/mkdocs.yml +25 -0
  60. package/package.json +65 -0
  61. package/spec/resources/init.sql +122 -0
  62. package/spec/resources/throw_exception.sql +5 -0
  63. package/spec/resources/tricky.sql +13 -0
  64. package/spec/run.js +5 -0
  65. package/spec/support/jasmine.json +9 -0
  66. package/src/bin/generateInterface.ts +54 -0
  67. package/src/connectionOptions.ts +42 -0
  68. package/src/index.ts +6 -0
  69. package/src/pgConverters.ts +55 -0
  70. package/src/pgDb.ts +820 -0
  71. package/src/pgDbLogger.ts +13 -0
  72. package/src/pgDbOperators.ts +62 -0
  73. package/src/pgSchema.ts +15 -0
  74. package/src/pgTable.ts +401 -0
  75. package/src/pgUtils.ts +176 -0
  76. package/src/queryAble.ts +393 -0
  77. package/src/queryWhere.ts +326 -0
  78. package/src/test/pgDbOperatorSpec.ts +492 -0
  79. package/src/test/pgDbSpec.ts +1339 -0
  80. package/src/test/pgServiceRestartTest.ts +1500 -0
  81. package/src/tsconfig.json +33 -0
  82. package/utils_sql/lower.sql +4 -0
@@ -0,0 +1 @@
1
+ {"version":3,"file":"pgTable.js","sourceRoot":"","sources":["../src/pgTable.ts"],"names":[],"mappings":"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"}
@@ -0,0 +1,31 @@
1
+ import { QueryOptions, ResultFieldType, QueryAble } from "./queryAble";
2
+ import { FieldType } from "./pgDb";
3
+ import { PgDbLogger } from "./pgDbLogger";
4
+ export declare let pgUtils: {
5
+ logError(logger: PgDbLogger, options: {
6
+ error?: string | Error;
7
+ sql: string;
8
+ params: any;
9
+ connection;
10
+ }): void;
11
+ quoteField(f: any): any;
12
+ processQueryFields(options: QueryOptions): string;
13
+ processNamedParams(sql: string, params: Object): {
14
+ sql: string;
15
+ params: any[];
16
+ };
17
+ processQueryOptions(options: QueryOptions): string;
18
+ transformInsertUpdateParams(param: any, fieldType: FieldType): any;
19
+ postProcessResult(res: any[], fields: ResultFieldType[], pgdbTypeParsers: {
20
+ [oid: number]: (s: string) => any;
21
+ }): void;
22
+ convertTypes(res: any[], fields: ResultFieldType[], pgdbTypeParsers: {
23
+ [oid: number]: (s: string) => any;
24
+ }): void;
25
+ createFunctionCaller(q: QueryAble, fn: {
26
+ schema: string;
27
+ name: string;
28
+ return_single_row: boolean;
29
+ return_single_value: boolean;
30
+ }): (...args: any[]) => Promise<any>;
31
+ };
package/lib/pgUtils.js ADDED
@@ -0,0 +1,157 @@
1
+ "use strict";
2
+ Object.defineProperty(exports, "__esModule", { value: true });
3
+ exports.pgUtils = void 0;
4
+ const tslib_1 = require("tslib");
5
+ const pgDb_1 = require("./pgDb");
6
+ const _ = require("lodash");
7
+ const util = require('util');
8
+ const NAMED_PARAMS_REGEXP = /(?:^|[^:]):(!?[a-zA-Z0-9_]+)/g;
9
+ const ASC_DESC_REGEXP = /^([^" (]+)( asc| desc)?$/;
10
+ exports.pgUtils = {
11
+ logError(logger, options) {
12
+ let { error, sql, params, connection } = options;
13
+ logger.error(error, sql, util.inspect(logger.paramSanitizer ? logger.paramSanitizer(params) : params, false, null), connection ? connection.processID : null);
14
+ },
15
+ quoteField(f) {
16
+ return f.indexOf('"') == -1 && f.indexOf('(') == -1 ? '"' + f + '"' : f;
17
+ },
18
+ processQueryFields(options) {
19
+ let s = options && options.distinct ? ' DISTINCT ' : ' ';
20
+ if (options && options.fields) {
21
+ if (Array.isArray(options.fields)) {
22
+ return s + options.fields.map(exports.pgUtils.quoteField).join(', ');
23
+ }
24
+ else {
25
+ return s + options.fields;
26
+ }
27
+ }
28
+ else {
29
+ return s + ' *';
30
+ }
31
+ },
32
+ processNamedParams(sql, params) {
33
+ let sql2 = [];
34
+ let params2 = [];
35
+ let p = NAMED_PARAMS_REGEXP.exec(sql);
36
+ let lastIndex = 0;
37
+ while (p) {
38
+ let ddl = false;
39
+ let name = p[1];
40
+ if (name[0] == '!') {
41
+ name = name.slice(1);
42
+ ddl = true;
43
+ }
44
+ if (!(name in params)) {
45
+ throw new Error(`No ${p[1]} in params (keys: ${Object.keys(params)})`);
46
+ }
47
+ sql2.push(sql.slice(lastIndex, NAMED_PARAMS_REGEXP.lastIndex - p[1].length - 1));
48
+ if (ddl) {
49
+ sql2.push('"' + ('' + params[name]).replace(/"/g, '""') + '"');
50
+ }
51
+ else {
52
+ params2.push(params[name]);
53
+ sql2.push('$' + params2.length);
54
+ }
55
+ lastIndex = NAMED_PARAMS_REGEXP.lastIndex;
56
+ p = NAMED_PARAMS_REGEXP.exec(sql);
57
+ }
58
+ sql2.push(sql.substr(lastIndex));
59
+ return {
60
+ sql: sql2.join(''),
61
+ params: params2
62
+ };
63
+ },
64
+ processQueryOptions(options) {
65
+ options = options || {};
66
+ let sql = '';
67
+ if (options.groupBy) {
68
+ if (Array.isArray(options.groupBy)) {
69
+ sql += ' GROUP BY ' + options.groupBy.map(exports.pgUtils.quoteField).join(',');
70
+ }
71
+ else {
72
+ sql += ' GROUP BY ' + exports.pgUtils.quoteField(options.groupBy);
73
+ }
74
+ }
75
+ if (options.orderBy) {
76
+ if (typeof options.orderBy == 'string') {
77
+ sql += ' ORDER BY ' + exports.pgUtils.quoteField(options.orderBy);
78
+ }
79
+ else if (Array.isArray(options.orderBy)) {
80
+ let orderBy = options.orderBy.map(v => v[0] == '+' ? exports.pgUtils.quoteField(v.substr(1, v.length - 1)) + ' asc' :
81
+ v[0] == '-' ? exports.pgUtils.quoteField(v.substr(1, v.length - 1)) + ' desc' :
82
+ v.replace(ASC_DESC_REGEXP, '"$1"$2'));
83
+ sql += ' ORDER BY ' + orderBy.join(',');
84
+ }
85
+ else {
86
+ let orderBy = [];
87
+ _.forEach(options.orderBy, (v, k) => orderBy.push(exports.pgUtils.quoteField(k) + ' ' + v));
88
+ sql += ' ORDER BY ' + orderBy.join(',');
89
+ }
90
+ }
91
+ if (options.limit) {
92
+ sql += util.format(' LIMIT %d', options.limit);
93
+ }
94
+ if (options.offset) {
95
+ sql += util.format(' OFFSET %d', options.offset);
96
+ }
97
+ if (options.forUpdate) {
98
+ sql += ' FOR UPDATE';
99
+ }
100
+ return sql;
101
+ },
102
+ transformInsertUpdateParams(param, fieldType) {
103
+ return (param != null && fieldType == pgDb_1.FieldType.JSON) ? JSON.stringify(param) :
104
+ (param != null && fieldType == pgDb_1.FieldType.TIME && !(param instanceof Date)) ? new Date(param) : param;
105
+ },
106
+ postProcessResult(res, fields, pgdbTypeParsers) {
107
+ if (res) {
108
+ if (res[0] && !Array.isArray(res[0])) {
109
+ if (Object.keys(res[0]).length != fields.length) {
110
+ throw Error("Name collision for the query, two or more fields have the same name.");
111
+ }
112
+ }
113
+ exports.pgUtils.convertTypes(res, fields, pgdbTypeParsers);
114
+ }
115
+ },
116
+ convertTypes(res, fields, pgdbTypeParsers) {
117
+ let isArrayMode = Array.isArray(res[0]);
118
+ fields.forEach((field, i) => {
119
+ if (pgdbTypeParsers[field.dataTypeID]) {
120
+ if (isArrayMode) {
121
+ res.forEach(e => e[i] = e[i] == null ? null : pgdbTypeParsers[field.dataTypeID](e[i]));
122
+ }
123
+ else {
124
+ res.forEach(e => e[field.name] = e[field.name] == null ? null : pgdbTypeParsers[field.dataTypeID](e[field.name]));
125
+ }
126
+ }
127
+ });
128
+ },
129
+ createFunctionCaller(q, fn) {
130
+ return (...args) => tslib_1.__awaiter(this, void 0, void 0, function* () {
131
+ let placeHolders = [];
132
+ let params = [];
133
+ args.forEach((arg) => {
134
+ placeHolders.push('$' + (placeHolders.length + 1));
135
+ params.push(arg);
136
+ });
137
+ let res = yield q.query(`SELECT "${fn.schema}"."${fn.name}"(${placeHolders.join(',')})`, params);
138
+ if (fn.return_single_value) {
139
+ let keys = res[0] ? Object.keys(res[0]) : [];
140
+ if (keys.length != 1) {
141
+ throw Error(`Return type error. schema: ${fn.schema} fn: ${fn.name} expected return type: single value, current value:` + JSON.stringify(res));
142
+ }
143
+ res = res.map((r) => r[keys[0]]);
144
+ }
145
+ if (fn.return_single_row) {
146
+ if (res.length != 1) {
147
+ throw Error(`Return type error. schema: ${fn.schema} fn: ${fn.name} expected return type: single value, current value:` + JSON.stringify(res));
148
+ }
149
+ return res[0];
150
+ }
151
+ else {
152
+ return res;
153
+ }
154
+ });
155
+ }
156
+ };
157
+ //# sourceMappingURL=pgUtils.js.map
@@ -0,0 +1 @@
1
+ {"version":3,"file":"pgUtils.js","sourceRoot":"","sources":["../src/pgUtils.ts"],"names":[],"mappings":";;;;AACA,iCAAiC;AAEjC,4BAA4B;AAE5B,MAAM,IAAI,GAAG,OAAO,CAAC,MAAM,CAAC,CAAC;AAC7B,MAAM,mBAAmB,GAAG,+BAA+B,CAAC;AAC5D,MAAM,eAAe,GAAG,0BAA0B,CAAC;AAExC,QAAA,OAAO,GAAG;IAEjB,QAAQ,CAAC,MAAkB,EAAE,OAAuE;QAChG,IAAI,EAAE,KAAK,EAAE,GAAG,EAAE,MAAM,EAAE,UAAU,EAAE,GAAG,OAAO,CAAC;QACjD,MAAM,CAAC,KAAK,CAAC,KAAK,EAAE,GAAG,EAAE,IAAI,CAAC,OAAO,CAAC,MAAM,CAAC,cAAc,CAAC,CAAC,CAAC,MAAM,CAAC,cAAc,CAAC,MAAM,CAAC,CAAC,CAAC,CAAC,MAAM,EAAE,KAAK,EAAE,IAAI,CAAC,EAAE,UAAU,CAAC,CAAC,CAAC,UAAU,CAAC,SAAS,CAAC,CAAC,CAAC,IAAI,CAAC,CAAC;IAClK,CAAC;IAED,UAAU,CAAC,CAAC;QACR,OAAO,CAAC,CAAC,OAAO,CAAC,GAAG,CAAC,IAAI,CAAC,CAAC,IAAI,CAAC,CAAC,OAAO,CAAC,GAAG,CAAC,IAAI,CAAC,CAAC,CAAC,CAAC,CAAC,GAAG,GAAG,CAAC,GAAG,GAAG,CAAC,CAAC,CAAC,CAAC,CAAC;IAC5E,CAAC;IAED,kBAAkB,CAAC,OAAqB;QACpC,IAAI,CAAC,GAAG,OAAO,IAAI,OAAO,CAAC,QAAQ,CAAC,CAAC,CAAC,YAAY,CAAC,CAAC,CAAC,GAAG,CAAC;QACzD,IAAI,OAAO,IAAI,OAAO,CAAC,MAAM,EAAE;YAC3B,IAAI,KAAK,CAAC,OAAO,CAAC,OAAO,CAAC,MAAM,CAAC,EAAE;gBAC/B,OAAO,CAAC,GAAG,OAAO,CAAC,MAAM,CAAC,GAAG,CAAC,eAAO,CAAC,UAAU,CAAC,CAAC,IAAI,CAAC,IAAI,CAAC,CAAC;aAChE;iBAAM;gBACH,OAAO,CAAC,GAAG,OAAO,CAAC,MAAM,CAAC;aAC7B;SACJ;aAAM;YACH,OAAO,CAAC,GAAG,IAAI,CAAC;SACnB;IACL,CAAC;IAOD,kBAAkB,CAAC,GAAW,EAAE,MAAc;QAC1C,IAAI,IAAI,GAAG,EAAE,CAAC;QACd,IAAI,OAAO,GAAG,EAAE,CAAC;QAEjB,IAAI,CAAC,GAAG,mBAAmB,CAAC,IAAI,CAAC,GAAG,CAAC,CAAC;QACtC,IAAI,SAAS,GAAG,CAAC,CAAC;QAClB,OAAO,CAAC,EAAE;YACN,IAAI,GAAG,GAAG,KAAK,CAAC;YAChB,IAAI,IAAI,GAAG,CAAC,CAAC,CAAC,CAAC,CAAC;YAChB,IAAI,IAAI,CAAC,CAAC,CAAC,IAAI,GAAG,EAAE;gBAChB,IAAI,GAAG,IAAI,CAAC,KAAK,CAAC,CAAC,CAAC,CAAC;gBACrB,GAAG,GAAG,IAAI,CAAC;aACd;YAED,IAAI,CAAC,CAAC,IAAI,IAAI,MAAM,CAAC,EAAE;gBACnB,MAAM,IAAI,KAAK,CAAC,MAAM,CAAC,CAAC,CAAC,CAAC,qBAAqB,MAAM,CAAC,IAAI,CAAC,MAAM,CAAC,GAAG,CAAC,CAAC;aAC1E;YACD,IAAI,CAAC,IAAI,CAAC,GAAG,CAAC,KAAK,CAAC,SAAS,EAAE,mBAAmB,CAAC,SAAS,GAAG,CAAC,CAAC,CAAC,CAAC,CAAC,MAAM,GAAG,CAAC,CAAC,CAAC,CAAC;YAEjF,IAAI,GAAG,EAAE;gBACL,IAAI,CAAC,IAAI,CAAC,GAAG,GAAG,CAAC,EAAE,GAAG,MAAM,CAAC,IAAI,CAAC,CAAC,CAAC,OAAO,CAAC,IAAI,EAAE,IAAI,CAAC,GAAG,GAAG,CAAC,CAAC;aAClE;iBAAM;gBACH,OAAO,CAAC,IAAI,CAAC,MAAM,CAAC,IAAI,CAAC,CAAC,CAAC;gBAC3B,IAAI,CAAC,IAAI,CAAC,GAAG,GAAG,OAAO,CAAC,MAAM,CAAC,CAAC;aACnC;YACD,SAAS,GAAG,mBAAmB,CAAC,SAAS,CAAC;YAC1C,CAAC,GAAG,mBAAmB,CAAC,IAAI,CAAC,GAAG,CAAC,CAAC;SACrC;QACD,IAAI,CAAC,IAAI,CAAC,GAAG,CAAC,MAAM,CAAC,SAAS,CAAC,CAAC,CAAC;QAEjC,OAAO;YACH,GAAG,EAAE,IAAI,CAAC,IAAI,CAAC,EAAE,CAAC;YAClB,MAAM,EAAE,OAAO;SAClB,CAAA;IACL,CAAC;IAED,mBAAmB,CAAC,OAAqB;QACrC,OAAO,GAAG,OAAO,IAAI,EAAE,CAAC;QACxB,IAAI,GAAG,GAAG,EAAE,CAAC;QAEb,IAAI,OAAO,CAAC,OAAO,EAAE;YACjB,IAAI,KAAK,CAAC,OAAO,CAAC,OAAO,CAAC,OAAO,CAAC,EAAE;gBAChC,GAAG,IAAI,YAAY,GAAG,OAAO,CAAC,OAAO,CAAC,GAAG,CAAC,eAAO,CAAC,UAAU,CAAC,CAAC,IAAI,CAAC,GAAG,CAAC,CAAC;aAC3E;iBAAM;gBACH,GAAG,IAAI,YAAY,GAAG,eAAO,CAAC,UAAU,CAAC,OAAO,CAAC,OAAO,CAAC,CAAC;aAC7D;SACJ;QACD,IAAI,OAAO,CAAC,OAAO,EAAE;YACjB,IAAI,OAAO,OAAO,CAAC,OAAO,IAAI,QAAQ,EAAE;gBACpC,GAAG,IAAI,YAAY,GAAG,eAAO,CAAC,UAAU,CAAC,OAAO,CAAC,OAAO,CAAC,CAAC;aAC7D;iBACI,IAAI,KAAK,CAAC,OAAO,CAAC,OAAO,CAAC,OAAO,CAAC,EAAE;gBACrC,IAAI,OAAO,GAAG,OAAO,CAAC,OAAO,CAAC,GAAG,CAAC,CAAC,CAAC,EAAE,CAClC,CAAC,CAAC,CAAC,CAAC,IAAI,GAAG,CAAC,CAAC,CAAC,eAAO,CAAC,UAAU,CAAC,CAAC,CAAC,MAAM,CAAC,CAAC,EAAE,CAAC,CAAC,MAAM,GAAG,CAAC,CAAC,CAAC,GAAG,MAAM,CAAC,CAAC;oBAClE,CAAC,CAAC,CAAC,CAAC,IAAI,GAAG,CAAC,CAAC,CAAC,eAAO,CAAC,UAAU,CAAC,CAAC,CAAC,MAAM,CAAC,CAAC,EAAE,CAAC,CAAC,MAAM,GAAG,CAAC,CAAC,CAAC,GAAG,OAAO,CAAC,CAAC;wBACnE,CAAC,CAAC,OAAO,CAAC,eAAe,EAAE,QAAQ,CAAC,CAAC,CAAC;gBAClD,GAAG,IAAI,YAAY,GAAG,OAAO,CAAC,IAAI,CAAC,GAAG,CAAC,CAAC;aAC3C;iBAAM;gBACH,IAAI,OAAO,GAAG,EAAE,CAAC;gBACjB,CAAC,CAAC,OAAO,CAAC,OAAO,CAAC,OAAO,EAAE,CAAC,CAAC,EAAE,CAAC,EAAE,EAAE,CAAC,OAAO,CAAC,IAAI,CAAC,eAAO,CAAC,UAAU,CAAC,CAAC,CAAC,GAAG,GAAG,GAAG,CAAC,CAAC,CAAC,CAAC;gBACpF,GAAG,IAAI,YAAY,GAAG,OAAO,CAAC,IAAI,CAAC,GAAG,CAAC,CAAC;aAC3C;SACJ;QACD,IAAI,OAAO,CAAC,KAAK,EAAE;YACf,GAAG,IAAI,IAAI,CAAC,MAAM,CAAC,WAAW,EAAE,OAAO,CAAC,KAAK,CAAC,CAAC;SAClD;QACD,IAAI,OAAO,CAAC,MAAM,EAAE;YAChB,GAAG,IAAI,IAAI,CAAC,MAAM,CAAC,YAAY,EAAE,OAAO,CAAC,MAAM,CAAC,CAAC;SACpD;QACD,IAAI,OAAO,CAAC,SAAS,EAAC;YAClB,GAAG,IAAI,aAAa,CAAC;SACxB;QACD,OAAO,GAAG,CAAC;IACf,CAAC;IAQD,2BAA2B,CAAC,KAAU,EAAE,SAAoB;QACxD,OAAO,CAAC,KAAK,IAAI,IAAI,IAAI,SAAS,IAAI,gBAAS,CAAC,IAAI,CAAC,CAAC,CAAC,CAAC,IAAI,CAAC,SAAS,CAAC,KAAK,CAAC,CAAC,CAAC;YAC3E,CAAC,KAAK,IAAI,IAAI,IAAI,SAAS,IAAI,gBAAS,CAAC,IAAI,IAAI,CAAC,CAAC,KAAK,YAAY,IAAI,CAAC,CAAC,CAAC,CAAC,CAAC,IAAI,IAAI,CAAC,KAAK,CAAC,CAAC,CAAC,CAAC,KAAK,CAAC;IAC7G,CAAC;IAED,iBAAiB,CAAC,GAAU,EAAE,MAAyB,EAAE,eAAqD;QAC1G,IAAI,GAAG,EAAE;YACL,IAAI,GAAG,CAAC,CAAC,CAAC,IAAI,CAAC,KAAK,CAAC,OAAO,CAAC,GAAG,CAAC,CAAC,CAAC,CAAC,EAAE;gBAClC,IAAI,MAAM,CAAC,IAAI,CAAC,GAAG,CAAC,CAAC,CAAC,CAAC,CAAC,MAAM,IAAI,MAAM,CAAC,MAAM,EAAE;oBAC7C,MAAM,KAAK,CAAC,sEAAsE,CAAC,CAAC;iBACvF;aACJ;YACD,eAAO,CAAC,YAAY,CAAC,GAAG,EAAE,MAAM,EAAE,eAAe,CAAC,CAAC;SACtD;IACL,CAAC;IAED,YAAY,CAAC,GAAU,EAAE,MAAyB,EAAE,eAAqD;QACrG,IAAI,WAAW,GAAG,KAAK,CAAC,OAAO,CAAC,GAAG,CAAC,CAAC,CAAC,CAAC,CAAC;QACxC,MAAM,CAAC,OAAO,CAAC,CAAC,KAAK,EAAE,CAAC,EAAE,EAAE;YACxB,IAAI,eAAe,CAAC,KAAK,CAAC,UAAU,CAAC,EAAE;gBACnC,IAAI,WAAW,EAAE;oBACb,GAAG,CAAC,OAAO,CAAC,CAAC,CAAC,EAAE,CAAC,CAAC,CAAC,CAAC,CAAC,GAAG,CAAC,CAAC,CAAC,CAAC,IAAI,IAAI,CAAC,CAAC,CAAC,IAAI,CAAC,CAAC,CAAC,eAAe,CAAC,KAAK,CAAC,UAAU,CAAC,CAAC,CAAC,CAAC,CAAC,CAAC,CAAC,CAAC,CAAC;iBAC1F;qBAAM;oBACH,GAAG,CAAC,OAAO,CAAC,CAAC,CAAC,EAAE,CAAC,CAAC,CAAC,KAAK,CAAC,IAAI,CAAC,GAAG,CAAC,CAAC,KAAK,CAAC,IAAI,CAAC,IAAI,IAAI,CAAC,CAAC,CAAC,IAAI,CAAC,CAAC,CAAC,eAAe,CAAC,KAAK,CAAC,UAAU,CAAC,CAAC,CAAC,CAAC,KAAK,CAAC,IAAI,CAAC,CAAC,CAAC,CAAC;iBACrH;aACJ;QACL,CAAC,CAAC,CAAC;IACP,CAAC;IAED,oBAAoB,CAAC,CAAY,EAAE,EAA8F;QAC7H,OAAO,CAAO,GAAG,IAAI,EAAE,EAAE;YACrB,IAAI,YAAY,GAAG,EAAE,CAAC;YACtB,IAAI,MAAM,GAAG,EAAE,CAAC;YAChB,IAAI,CAAC,OAAO,CAAC,CAAC,GAAG,EAAE,EAAE;gBACjB,YAAY,CAAC,IAAI,CAAC,GAAG,GAAG,CAAC,YAAY,CAAC,MAAM,GAAG,CAAC,CAAC,CAAC,CAAC;gBACnD,MAAM,CAAC,IAAI,CAAC,GAAG,CAAC,CAAC;YACrB,CAAC,CAAC,CAAC;YACH,IAAI,GAAG,GAAG,MAAM,CAAC,CAAC,KAAK,CAAC,WAAW,EAAE,CAAC,MAAM,MAAM,EAAE,CAAC,IAAI,KAAK,YAAY,CAAC,IAAI,CAAC,GAAG,CAAC,GAAG,EAAE,MAAM,CAAC,CAAC;YAEjG,IAAI,EAAE,CAAC,mBAAmB,EAAE;gBACxB,IAAI,IAAI,GAAG,GAAG,CAAC,CAAC,CAAC,CAAC,CAAC,CAAC,MAAM,CAAC,IAAI,CAAC,GAAG,CAAC,CAAC,CAAC,CAAC,CAAC,CAAC,CAAC,EAAE,CAAC;gBAC7C,IAAI,IAAI,CAAC,MAAM,IAAI,CAAC,EAAE;oBAClB,MAAM,KAAK,CAAC,8BAA8B,EAAE,CAAC,MAAM,QAAQ,EAAE,CAAC,IAAI,qDAAqD,GAAG,IAAI,CAAC,SAAS,CAAC,GAAG,CAAC,CAAC,CAAA;iBACjJ;gBACD,GAAG,GAAG,GAAG,CAAC,GAAG,CAAC,CAAC,CAAC,EAAE,EAAE,CAAC,CAAC,CAAC,IAAI,CAAC,CAAC,CAAC,CAAC,CAAC,CAAC;aACpC;YACD,IAAI,EAAE,CAAC,iBAAiB,EAAE;gBACtB,IAAI,GAAG,CAAC,MAAM,IAAI,CAAC,EAAE;oBACjB,MAAM,KAAK,CAAC,8BAA8B,EAAE,CAAC,MAAM,QAAQ,EAAE,CAAC,IAAI,qDAAqD,GAAG,IAAI,CAAC,SAAS,CAAC,GAAG,CAAC,CAAC,CAAA;iBACjJ;gBACD,OAAO,GAAG,CAAC,CAAC,CAAC,CAAC;aACjB;iBAAM;gBACH,OAAO,GAAG,CAAC;aACd;QACL,CAAC,CAAA,CAAA;IACL,CAAC;CACJ,CAAC"}
@@ -0,0 +1,76 @@
1
+ /// <reference types="node" />
2
+ import { PgDbLogger } from "./pgDbLogger";
3
+ import * as stream from "stream";
4
+ export interface QueryOptions {
5
+ limit?: number;
6
+ offset?: number;
7
+ orderBy?: string | string[] | {
8
+ [fieldName: string]: 'asc' | 'desc';
9
+ };
10
+ groupBy?: string | string[];
11
+ fields?: string | string[];
12
+ logger?: PgDbLogger;
13
+ forUpdate?: boolean;
14
+ distinct?: boolean;
15
+ skipUndefined?: boolean;
16
+ }
17
+ export interface SqlQueryOptions {
18
+ logger?: PgDbLogger;
19
+ }
20
+ export interface ResultFieldType {
21
+ name: string;
22
+ tableID: number;
23
+ columnID: number;
24
+ dataTypeID: number;
25
+ dataTypeSize: number;
26
+ dataTypeModifier: number;
27
+ format: string;
28
+ }
29
+ export interface ResultType {
30
+ command: 'SELECT' | 'UPDATE' | 'DELETE';
31
+ rowCount: number;
32
+ oid: number;
33
+ rows: any[];
34
+ fields: ResultFieldType[];
35
+ _parsers: Function[][];
36
+ RowCtor: Function[];
37
+ rowsAsArray: boolean;
38
+ _getTypeParser: Function[];
39
+ }
40
+ export interface PgRowResult {
41
+ columns: string[];
42
+ rows: any[];
43
+ }
44
+ export declare class QueryAble {
45
+ db: any;
46
+ schema: any;
47
+ protected logger: PgDbLogger;
48
+ constructor();
49
+ setLogger(logger: PgDbLogger): void;
50
+ getLogger(useConsoleAsDefault?: boolean): any;
51
+ run(sql: string, params?: any[] | {}, options?: SqlQueryOptions): Promise<any[]>;
52
+ query(sql: string, params?: any[] | {}, options?: SqlQueryOptions): Promise<any[]>;
53
+ protected internalQuery(options: {
54
+ connection: any;
55
+ sql: string;
56
+ params?: any;
57
+ logger?: any;
58
+ }): Promise<any[]>;
59
+ protected internalQuery(options: {
60
+ connection: any;
61
+ sql: string;
62
+ params?: any;
63
+ logger?: any;
64
+ rowMode: true;
65
+ }): Promise<PgRowResult>;
66
+ queryAsRows(sql: string, params?: any[] | {}, options?: SqlQueryOptions): Promise<PgRowResult>;
67
+ queryWithOnCursorCallback(sql: string, params: any[] | {}, options: SqlQueryOptions, callback: (any: any) => any): Promise<void>;
68
+ queryAsStream(sql: string, params?: any[] | {}, options?: SqlQueryOptions): Promise<stream.Readable>;
69
+ queryOne(sql: string, params?: any[] | {}, options?: SqlQueryOptions): Promise<any>;
70
+ queryFirst(sql: string, params?: any[] | {}, options?: SqlQueryOptions): Promise<any>;
71
+ queryOneField(sql: string, params?: any[] | {}, options?: SqlQueryOptions): Promise<any>;
72
+ queryOneColumn(sql: string, params?: any[] | {}, options?: SqlQueryOptions): Promise<any[]>;
73
+ private postProcessFields;
74
+ private checkAndFixOids;
75
+ private hasUnknownOids;
76
+ }
@@ -0,0 +1,330 @@
1
+ "use strict";
2
+ Object.defineProperty(exports, "__esModule", { value: true });
3
+ exports.QueryAble = void 0;
4
+ const tslib_1 = require("tslib");
5
+ const pgUtils_1 = require("./pgUtils");
6
+ const util = require('util');
7
+ const QueryStream = require('pg-query-stream');
8
+ const through = require('through');
9
+ let defaultLogger = {
10
+ log: () => { },
11
+ error: () => { }
12
+ };
13
+ class QueryAble {
14
+ constructor() {
15
+ }
16
+ setLogger(logger) {
17
+ this.logger = logger;
18
+ }
19
+ getLogger(useConsoleAsDefault = false) {
20
+ return this.logger || this.schema && this.schema.logger || this.db.logger || (useConsoleAsDefault ? console : defaultLogger);
21
+ }
22
+ run(sql, params, options) {
23
+ return tslib_1.__awaiter(this, void 0, void 0, function* () {
24
+ return this.query(sql, params, options);
25
+ });
26
+ }
27
+ query(sql, params, options) {
28
+ return tslib_1.__awaiter(this, void 0, void 0, function* () {
29
+ let connection = this.db.connection;
30
+ let logger = (options && options.logger || this.getLogger(false));
31
+ return this.internalQuery({ connection, sql, params, logger });
32
+ });
33
+ }
34
+ internalQuery(options) {
35
+ return tslib_1.__awaiter(this, void 0, void 0, function* () {
36
+ if (this.db.needToFixConnectionForListen()) {
37
+ yield this.db.runRestartConnectionForListen();
38
+ }
39
+ let { connection, sql, params, logger } = options;
40
+ logger = logger || this.getLogger(false);
41
+ try {
42
+ if (params && !Array.isArray(params)) {
43
+ let p = pgUtils_1.pgUtils.processNamedParams(sql, params);
44
+ sql = p.sql;
45
+ params = p.params;
46
+ }
47
+ if (connection) {
48
+ logger.log('reused connection', sql, util.inspect(params, false, null), connection.processID);
49
+ let res = yield connection.query({ text: sql, values: params, rowMode: (options === null || options === void 0 ? void 0 : options.rowMode) ? 'array' : undefined });
50
+ yield this.checkAndFixOids(connection, res.fields);
51
+ this.postProcessFields(res.rows, res.fields, logger);
52
+ return (options === null || options === void 0 ? void 0 : options.rowMode) ? { columns: (res.fields || []).map(f => f.name), rows: res.rows || [] } : res.rows;
53
+ }
54
+ else {
55
+ connection = yield this.db.pool.connect();
56
+ logger.log('new connection', sql, util.inspect(params, false, null), connection.processID);
57
+ connection.on('error', (err) => { });
58
+ let res = yield connection.query({ text: sql, values: params, rowMode: (options === null || options === void 0 ? void 0 : options.rowMode) ? 'array' : undefined });
59
+ yield this.checkAndFixOids(connection, res.fields);
60
+ connection.release();
61
+ connection = null;
62
+ this.postProcessFields(res.rows, res.fields, logger);
63
+ return (options === null || options === void 0 ? void 0 : options.rowMode) ? { columns: (res.fields || []).map(f => f.name), rows: res.rows || [] } : res.rows;
64
+ }
65
+ }
66
+ catch (e) {
67
+ pgUtils_1.pgUtils.logError(logger, { error: e, sql, params, connection });
68
+ if (connection) {
69
+ try {
70
+ connection.release();
71
+ }
72
+ catch (e) {
73
+ logger.error('connection error', e.message);
74
+ }
75
+ }
76
+ throw e;
77
+ }
78
+ });
79
+ }
80
+ queryAsRows(sql, params, options) {
81
+ return tslib_1.__awaiter(this, void 0, void 0, function* () {
82
+ let connection = this.db.connection;
83
+ let logger = (options && options.logger || this.getLogger(false));
84
+ return this.internalQuery({ connection, sql, params, logger, rowMode: true });
85
+ });
86
+ }
87
+ queryWithOnCursorCallback(sql, params, options, callback) {
88
+ return tslib_1.__awaiter(this, void 0, void 0, function* () {
89
+ if (this.db.needToFixConnectionForListen()) {
90
+ yield this.db.runRestartConnectionForListen();
91
+ }
92
+ let connection = this.db.connection;
93
+ let logger = this.getLogger(true);
94
+ try {
95
+ if (params && !Array.isArray(params)) {
96
+ let p = pgUtils_1.pgUtils.processNamedParams(sql, params);
97
+ sql = p.sql;
98
+ params = p.params;
99
+ }
100
+ let queryInternal = () => tslib_1.__awaiter(this, void 0, void 0, function* () {
101
+ this.getLogger(false).log(sql, util.inspect(params, false, null), connection.processID);
102
+ let fieldsToFix;
103
+ let isFirst = true;
104
+ let query = new QueryStream(sql, params);
105
+ let stream = connection.query(query);
106
+ yield new Promise((resolve, reject) => {
107
+ query.handleError = (err, connection) => {
108
+ reject(err);
109
+ };
110
+ stream.on('data', (res) => {
111
+ try {
112
+ let fields = stream._result && stream._result.fields || stream.cursor._result && stream.cursor._result.fields;
113
+ if (isFirst) {
114
+ if (this.hasUnknownOids(fields)) {
115
+ fieldsToFix = fields;
116
+ stream.destroy();
117
+ return;
118
+ }
119
+ isFirst = false;
120
+ }
121
+ this.postProcessFields([res], fields, this.getLogger(false));
122
+ if (callback(res)) {
123
+ stream.destroy();
124
+ }
125
+ }
126
+ catch (e) {
127
+ reject(e);
128
+ }
129
+ });
130
+ stream.on('close', resolve);
131
+ stream.on('error', reject);
132
+ });
133
+ if (fieldsToFix) {
134
+ yield this.checkAndFixOids(connection, fieldsToFix);
135
+ query = new QueryStream(sql, params);
136
+ stream = connection.query(query);
137
+ yield new Promise((resolve, reject) => {
138
+ query.handleError = (err, connection) => {
139
+ reject(err);
140
+ };
141
+ stream.on('data', (res) => {
142
+ try {
143
+ let fields = stream._result && stream._result.fields || stream.cursor._result && stream.cursor._result.fields;
144
+ this.postProcessFields([res], fields, this.getLogger(false));
145
+ if (callback(res)) {
146
+ stream.destroy();
147
+ }
148
+ }
149
+ catch (e) {
150
+ reject(e);
151
+ }
152
+ });
153
+ stream.on('close', resolve);
154
+ stream.on('error', reject);
155
+ });
156
+ }
157
+ });
158
+ if (connection) {
159
+ yield queryInternal();
160
+ }
161
+ else {
162
+ connection = yield this.db.pool.connect();
163
+ logger.log('new connection', sql, util.inspect(params, false, null), connection.processID);
164
+ connection.on('error', (err) => { });
165
+ yield queryInternal();
166
+ connection.release();
167
+ connection = null;
168
+ }
169
+ }
170
+ catch (e) {
171
+ pgUtils_1.pgUtils.logError(logger, { error: e, sql, params, connection });
172
+ if (connection) {
173
+ try {
174
+ connection.release();
175
+ }
176
+ catch (e) {
177
+ logger.error('connection error', e.message);
178
+ }
179
+ }
180
+ throw e;
181
+ }
182
+ });
183
+ }
184
+ queryAsStream(sql, params, options) {
185
+ return tslib_1.__awaiter(this, void 0, void 0, function* () {
186
+ if (this.db.needToFixConnectionForListen()) {
187
+ yield this.db.runRestartConnectionForListen();
188
+ }
189
+ let connection = this.db.connection;
190
+ let logger = (options && options.logger || this.getLogger(false));
191
+ let pgStream;
192
+ let queriable = this;
193
+ let isFirst = true;
194
+ let convertTypeFilter = through(function (data) {
195
+ try {
196
+ let fields = pgStream._result && pgStream._result.fields || pgStream.cursor._result && pgStream.cursor._result.fields;
197
+ if (isFirst) {
198
+ if (queriable.hasUnknownOids(fields)) {
199
+ throw new Error('[337] Query returns fields with unknown oid.');
200
+ }
201
+ isFirst = false;
202
+ }
203
+ queriable.postProcessFields([data], fields, queriable.db.pgdbTypeParsers);
204
+ this.emit('data', data);
205
+ }
206
+ catch (err) {
207
+ this.emit('error', err);
208
+ }
209
+ });
210
+ convertTypeFilter.on('error', (e) => {
211
+ if (connection) {
212
+ try {
213
+ connection.release();
214
+ }
215
+ catch (e) {
216
+ logger.error('connection error', e.message);
217
+ }
218
+ }
219
+ connection = null;
220
+ pgUtils_1.pgUtils.logError(logger, { error: e, sql, params, connection });
221
+ });
222
+ try {
223
+ if (params && !Array.isArray(params)) {
224
+ let p = pgUtils_1.pgUtils.processNamedParams(sql, params);
225
+ sql = p.sql;
226
+ params = p.params;
227
+ }
228
+ if (connection) {
229
+ logger.log(sql, util.inspect(params, false, null), connection.processID);
230
+ let query = new QueryStream(sql, params);
231
+ query.handleError = (err, connection) => {
232
+ convertTypeFilter.emit('error', err);
233
+ };
234
+ pgStream = connection.query(query);
235
+ return pgStream.pipe(convertTypeFilter);
236
+ }
237
+ else {
238
+ connection = yield this.db.pool.connect();
239
+ logger.log('new connection', sql, util.inspect(params, false, null), connection.processID);
240
+ connection.on('error', (err) => { });
241
+ let query = new QueryStream(sql, params);
242
+ query.handleError = (err, connection) => {
243
+ convertTypeFilter.emit('error', err);
244
+ };
245
+ pgStream = connection.query(query);
246
+ pgStream.on('close', () => {
247
+ if (connection)
248
+ connection.release();
249
+ connection = null;
250
+ });
251
+ pgStream.on('error', (e) => {
252
+ pgUtils_1.pgUtils.logError(logger, { error: e, sql, params, connection });
253
+ if (connection)
254
+ connection.release();
255
+ connection = null;
256
+ });
257
+ return pgStream.pipe(convertTypeFilter);
258
+ }
259
+ }
260
+ catch (e) {
261
+ pgUtils_1.pgUtils.logError(logger, { error: e, sql, params, connection });
262
+ throw e;
263
+ }
264
+ });
265
+ }
266
+ queryOne(sql, params, options) {
267
+ return tslib_1.__awaiter(this, void 0, void 0, function* () {
268
+ let res = yield this.query(sql, params, options);
269
+ if (res.length > 1) {
270
+ let logger = (options && options.logger || this.getLogger(false));
271
+ let error = Error('More then one rows exists');
272
+ pgUtils_1.pgUtils.logError(logger, { error, sql, params, connection: this.db.connection });
273
+ throw error;
274
+ }
275
+ return res[0];
276
+ });
277
+ }
278
+ queryFirst(sql, params, options) {
279
+ return tslib_1.__awaiter(this, void 0, void 0, function* () {
280
+ let res = yield this.query(sql, params, options);
281
+ return res[0];
282
+ });
283
+ }
284
+ queryOneField(sql, params, options) {
285
+ return tslib_1.__awaiter(this, void 0, void 0, function* () {
286
+ let res = yield this.query(sql, params, options);
287
+ if (!res.length) {
288
+ return null;
289
+ }
290
+ let fieldName = Object.keys(res[0])[0];
291
+ if (res.length > 1) {
292
+ let logger = (options && options.logger || this.getLogger(false));
293
+ let error = Error('More then one field exists!');
294
+ pgUtils_1.pgUtils.logError(logger, { error, sql, params, connection: this.db.connection });
295
+ throw error;
296
+ }
297
+ return res.length == 1 ? res[0][fieldName] : null;
298
+ });
299
+ }
300
+ queryOneColumn(sql, params, options) {
301
+ return tslib_1.__awaiter(this, void 0, void 0, function* () {
302
+ let res = yield this.query(sql, params, options);
303
+ if (!res.length) {
304
+ return [];
305
+ }
306
+ let fieldName = Object.keys(res[0])[0];
307
+ return res.map(r => r[fieldName]);
308
+ });
309
+ }
310
+ postProcessFields(rows, fields, logger) {
311
+ pgUtils_1.pgUtils.postProcessResult(rows, fields, this.db.pgdbTypeParsers);
312
+ if (this.db.postProcessResult)
313
+ this.db.postProcessResult(rows, fields, logger);
314
+ }
315
+ checkAndFixOids(connection, fields) {
316
+ return tslib_1.__awaiter(this, void 0, void 0, function* () {
317
+ if (fields) {
318
+ let oidList = fields.map(field => field.dataTypeID);
319
+ return this.db.resetMissingParsers(connection, oidList);
320
+ }
321
+ });
322
+ }
323
+ hasUnknownOids(fields) {
324
+ let oidList = fields.map(field => field.dataTypeID);
325
+ let unknownOids = oidList.filter(oid => !this.db.knownOids[oid]);
326
+ return !!unknownOids.length;
327
+ }
328
+ }
329
+ exports.QueryAble = QueryAble;
330
+ //# sourceMappingURL=queryAble.js.map