pogi 2.10.2 → 3.0.0-beta2

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 (83) hide show
  1. package/.vscode/launch.json +47 -15
  2. package/CHANGELOG.md +11 -0
  3. package/docs/API/PgDb.md +25 -0
  4. package/docs/notification.md +19 -0
  5. package/jest.config.js +23 -0
  6. package/lib/bin/generateInterface.js +3 -3
  7. package/lib/bin/generateInterface.js.map +1 -1
  8. package/lib/connectionOptions.d.ts +10 -0
  9. package/lib/index.d.ts +1 -1
  10. package/lib/pgConverters.d.ts +9 -8
  11. package/lib/pgConverters.js +46 -32
  12. package/lib/pgConverters.js.map +1 -1
  13. package/lib/pgConverters.test.d.ts +1 -0
  14. package/lib/pgConverters.test.js +13 -0
  15. package/lib/pgConverters.test.js.map +1 -0
  16. package/lib/pgDb.d.ts +27 -27
  17. package/lib/pgDb.js +293 -100
  18. package/lib/pgDb.js.map +1 -1
  19. package/lib/pgDb.test.d.ts +1 -0
  20. package/lib/pgDb.test.js +1126 -0
  21. package/lib/pgDb.test.js.map +1 -0
  22. package/lib/pgDbInterface.d.ts +53 -0
  23. package/lib/pgDbInterface.js +11 -0
  24. package/lib/pgDbInterface.js.map +1 -0
  25. package/lib/pgDbOperators.d.ts +3 -3
  26. package/lib/pgDbOperators.js +4 -7
  27. package/lib/pgDbOperators.js.map +1 -1
  28. package/lib/pgDbOperators.test.d.ts +1 -0
  29. package/lib/pgDbOperators.test.js +313 -0
  30. package/lib/pgDbOperators.test.js.map +1 -0
  31. package/lib/pgSchema.d.ts +10 -9
  32. package/lib/pgSchema.js.map +1 -1
  33. package/lib/pgSchemaInterface.d.ts +12 -0
  34. package/lib/pgSchemaInterface.js +3 -0
  35. package/lib/pgSchemaInterface.js.map +1 -0
  36. package/lib/pgTable.d.ts +15 -40
  37. package/lib/pgTable.js +54 -54
  38. package/lib/pgTable.js.map +1 -1
  39. package/lib/pgTableInterface.d.ts +102 -0
  40. package/lib/pgTableInterface.js +4 -0
  41. package/lib/pgTableInterface.js.map +1 -0
  42. package/lib/pgUtils.d.ts +16 -6
  43. package/lib/pgUtils.js +162 -31
  44. package/lib/pgUtils.js.map +1 -1
  45. package/lib/queryAble.d.ts +20 -53
  46. package/lib/queryAble.js +149 -80
  47. package/lib/queryAble.js.map +1 -1
  48. package/lib/queryAbleInterface.d.ts +55 -0
  49. package/lib/queryAbleInterface.js +7 -0
  50. package/lib/queryAbleInterface.js.map +1 -0
  51. package/lib/queryWhere.d.ts +2 -2
  52. package/lib/queryWhere.js +19 -23
  53. package/lib/queryWhere.js.map +1 -1
  54. package/mkdocs.yml +1 -0
  55. package/package.json +21 -11
  56. package/src/bin/generateInterface.ts +2 -2
  57. package/src/connectionOptions.ts +48 -13
  58. package/src/index.d.ts +7 -0
  59. package/src/index.ts +1 -1
  60. package/src/pgConverters.test.ts +10 -0
  61. package/src/pgConverters.ts +34 -22
  62. package/src/pgDb.test.ts +1324 -0
  63. package/src/pgDb.ts +318 -122
  64. package/src/pgDbInterface.ts +57 -0
  65. package/src/pgDbOperators.test.ts +478 -0
  66. package/src/pgDbOperators.ts +45 -22
  67. package/src/pgSchema.ts +10 -9
  68. package/src/pgSchemaInterface.ts +12 -0
  69. package/src/pgTable.ts +66 -98
  70. package/src/pgTableInterface.ts +131 -0
  71. package/src/pgUtils.ts +166 -42
  72. package/src/queryAble.ts +167 -125
  73. package/src/queryAbleInterface.ts +104 -0
  74. package/src/queryWhere.ts +42 -43
  75. package/{spec/resources → src/test}/init.sql +23 -0
  76. package/src/test/pgServiceRestartTest.ts +1500 -0
  77. package/{spec/resources → src/test}/throw_exception.sql +0 -0
  78. package/{spec/resources → src/test}/tricky.sql +0 -0
  79. package/{src/tsconfig.json → tsconfig.json} +12 -11
  80. package/spec/run.js +0 -5
  81. package/spec/support/jasmine.json +0 -9
  82. package/src/test/pgDbOperatorSpec.ts +0 -492
  83. package/src/test/pgDbSpec.ts +0 -994
@@ -0,0 +1,102 @@
1
+ /// <reference types="node" />
2
+ import { IQueryAble, QueryOptions } from "./queryAbleInterface";
3
+ import { FieldType } from "./pgDb";
4
+ import { IPgDb } from "./pgDbInterface";
5
+ import { PgDbLogger } from "./pgDbLogger";
6
+ import * as stream from "stream";
7
+ export interface InsertOption {
8
+ logger?: PgDbLogger;
9
+ }
10
+ export interface Return {
11
+ return?: string[] | '*';
12
+ }
13
+ export interface UpdateDeleteOption {
14
+ skipUndefined?: boolean;
15
+ logger?: PgDbLogger;
16
+ }
17
+ export interface UpsertOption {
18
+ constraint?: string;
19
+ columns?: string[];
20
+ logger?: PgDbLogger;
21
+ }
22
+ export interface CountOption {
23
+ skipUndefined?: boolean;
24
+ logger?: PgDbLogger;
25
+ }
26
+ export interface Stream {
27
+ stream: true;
28
+ }
29
+ export interface TruncateOptions {
30
+ restartIdentity?: boolean;
31
+ cascade?: boolean;
32
+ logger?: PgDbLogger;
33
+ }
34
+ export interface IPgTable<T> extends IQueryAble {
35
+ qualifiedName: string;
36
+ pkey: string;
37
+ db: IPgDb;
38
+ fieldTypes: {
39
+ [index: string]: FieldType;
40
+ };
41
+ toString: () => String;
42
+ insert(records: T[], options?: InsertOption): Promise<number>;
43
+ insert(records: T, options?: InsertOption): Promise<number>;
44
+ insert(records: any, options?: any): Promise<any>;
45
+ insertAndGet(records: T[], options?: InsertOption & Return): Promise<T[]>;
46
+ insertAndGet(records: T, options?: InsertOption & Return): Promise<T>;
47
+ insertAndGet(records: any, options?: InsertOption & Return): Promise<any>;
48
+ updateOne(conditions: {
49
+ [k: string]: any;
50
+ }, fields: {
51
+ [k: string]: any;
52
+ }, options?: UpdateDeleteOption): Promise<number>;
53
+ updateAndGetOne(conditions: {
54
+ [k: string]: any;
55
+ }, fields: {
56
+ [k: string]: any;
57
+ }, options?: UpdateDeleteOption & Return): Promise<T>;
58
+ update(conditions: {
59
+ [k: string]: any;
60
+ }, fields: {
61
+ [k: string]: any;
62
+ }, options?: UpdateDeleteOption): Promise<number>;
63
+ updateAndGet(conditions: {
64
+ [k: string]: any;
65
+ }, fields: {
66
+ [k: string]: any;
67
+ }, options?: UpdateDeleteOption & Return): Promise<T[]>;
68
+ upsert(record: T, options?: UpsertOption): Promise<number>;
69
+ upsertAndGet(record: T, options?: UpsertOption & Return): Promise<T>;
70
+ delete(conditions: {
71
+ [k: string]: any;
72
+ }, options?: UpdateDeleteOption): Promise<number>;
73
+ deleteOne(conditions: {
74
+ [k: string]: any;
75
+ }, options?: UpdateDeleteOption): Promise<number>;
76
+ deleteAndGet(conditions: {
77
+ [k: string]: any;
78
+ }, options?: UpdateDeleteOption & Return): Promise<any[]>;
79
+ deleteAndGetOne(conditions: {
80
+ [k: string]: any;
81
+ }, options?: UpdateDeleteOption & Return): Promise<any>;
82
+ truncate(options?: TruncateOptions): Promise<void>;
83
+ find(conditions: {
84
+ [k: string]: any;
85
+ }, options?: QueryOptions): Promise<T[]>;
86
+ find(conditions: {
87
+ [k: string]: any;
88
+ }, options?: QueryOptions & Stream): Promise<stream.Readable>;
89
+ find(conditions: {
90
+ [k: string]: any;
91
+ }, options?: any): Promise<any>;
92
+ findWhere(where: string, params: any[] | {}, options?: QueryOptions): Promise<T[]>;
93
+ findWhere(where: string, params: any[] | {}, options?: QueryOptions & Stream): Promise<stream.Readable>;
94
+ findWhere(where: string, params: any, options?: any): Promise<any>;
95
+ findAll(options?: QueryOptions): Promise<T[]>;
96
+ findAll(options?: QueryOptions & Stream): Promise<stream.Readable>;
97
+ findAll(options?: any): Promise<any>;
98
+ findOne(conditions: Record<string, any>, options?: QueryOptions): Promise<T>;
99
+ findFirst(conditions: Record<string, any>, options?: QueryOptions): Promise<T>;
100
+ count(conditions?: {}, options?: CountOption): Promise<number>;
101
+ findOneFieldOnly(conditions: Record<string, any>, field: string, options?: QueryOptions): Promise<any>;
102
+ }
@@ -0,0 +1,4 @@
1
+ "use strict";
2
+ Object.defineProperty(exports, "__esModule", { value: true });
3
+ const util = require('util');
4
+ //# sourceMappingURL=pgTableInterface.js.map
@@ -0,0 +1 @@
1
+ {"version":3,"file":"pgTableInterface.js","sourceRoot":"","sources":["../src/pgTableInterface.ts"],"names":[],"mappings":";;AAQA,MAAM,IAAI,GAAG,OAAO,CAAC,MAAM,CAAC,CAAC"}
package/lib/pgUtils.d.ts CHANGED
@@ -1,20 +1,29 @@
1
- import { QueryOptions, ResultFieldType, QueryAble } from "./queryAble";
1
+ import { QueryOptions, IQueryAble } from "./queryAbleInterface";
2
+ import { ResultFieldType } from "./pgDbInterface";
2
3
  import { FieldType } from "./pgDb";
3
4
  import { PgDbLogger } from "./pgDbLogger";
5
+ import { IPgTable } from "./pgTableInterface";
6
+ import * as pg from 'pg';
4
7
  export declare let pgUtils: {
5
8
  logError(logger: PgDbLogger, options: {
6
9
  error?: string | Error;
7
10
  sql: string;
8
11
  params: any;
9
- connection;
12
+ connection?: pg.PoolClient | null;
10
13
  }): void;
11
- quoteField(f: any): any;
12
- processQueryFields(options: QueryOptions): string;
14
+ quoteFieldNameInsecure(f: string): string;
15
+ quoteFieldName(f: string): string;
16
+ quoteFieldNameOrPositionInsecure(f: string | number): string;
17
+ quoteFieldNameOrPosition(f: string | number): string;
18
+ quoteFieldNameJsonbOrPosition(f: string | number): string;
19
+ processQueryFields<T>(options: QueryOptions, pgTable?: IPgTable<T> | undefined): string;
13
20
  processNamedParams(sql: string, params: Object): {
14
21
  sql: string;
15
22
  params: any[];
16
23
  };
17
- processQueryOptions(options: QueryOptions): string;
24
+ handleColumnEscapeGroupBy<T_1>(options: QueryOptions, pgTable?: IPgTable<T_1> | undefined): string;
25
+ handleColumnEscapeOrderBy<T_2>(options: QueryOptions, pgTable: IPgTable<T_2>): string;
26
+ processQueryOptions<T_3>(options: QueryOptions, pgTable: IPgTable<T_3>): string;
18
27
  transformInsertUpdateParams(param: any, fieldType: FieldType): any;
19
28
  postProcessResult(res: any[], fields: ResultFieldType[], pgdbTypeParsers: {
20
29
  [oid: number]: (s: string) => any;
@@ -22,10 +31,11 @@ export declare let pgUtils: {
22
31
  convertTypes(res: any[], fields: ResultFieldType[], pgdbTypeParsers: {
23
32
  [oid: number]: (s: string) => any;
24
33
  }): void;
25
- createFunctionCaller(q: QueryAble, fn: {
34
+ createFunctionCaller(q: IQueryAble, fn: {
26
35
  schema: string;
27
36
  name: string;
28
37
  return_single_row: boolean;
29
38
  return_single_value: boolean;
30
39
  }): (...args: any[]) => Promise<any>;
40
+ escapeForLike(s: string): string;
31
41
  };
package/lib/pgUtils.js CHANGED
@@ -3,23 +3,84 @@ Object.defineProperty(exports, "__esModule", { value: true });
3
3
  exports.pgUtils = void 0;
4
4
  const tslib_1 = require("tslib");
5
5
  const pgDb_1 = require("./pgDb");
6
- const _ = require("lodash");
7
- const util = require('util');
6
+ const util = require("util");
8
7
  const NAMED_PARAMS_REGEXP = /(?:^|[^:]):(!?[a-zA-Z0-9_]+)/g;
9
- const ASC_DESC_REGEXP = /^([^" (]+)( asc| desc)?$/;
8
+ const ASC_DESC_REGEXP = /^\s*(.+?)(?:\s+(asc|desc))?\s*$/i;
10
9
  exports.pgUtils = {
11
10
  logError(logger, options) {
12
11
  let { error, sql, params, connection } = options;
13
12
  logger.error(error, sql, util.inspect(logger.paramSanitizer ? logger.paramSanitizer(params) : params, false, null), connection ? connection.processID : null);
14
13
  },
15
- quoteField(f) {
14
+ quoteFieldNameInsecure(f) {
16
15
  return f.indexOf('"') == -1 && f.indexOf('(') == -1 ? '"' + f + '"' : f;
17
16
  },
18
- processQueryFields(options) {
17
+ quoteFieldName(f) {
18
+ if (typeof f === 'string' && f.length) {
19
+ return `"${f
20
+ .replace(/^\s*"*/, '')
21
+ .replace(/"*\s*$/, '')
22
+ .replace(/"/g, '""')}"`;
23
+ }
24
+ else {
25
+ throw new Error(`Invalid field: ${f}`);
26
+ }
27
+ },
28
+ quoteFieldNameOrPositionInsecure(f) {
29
+ if (Number.isInteger(+f)) {
30
+ if (!Number.isInteger(+f) || +f < 1)
31
+ throw new Error(`Invalid field: ${f}`);
32
+ return '' + f;
33
+ }
34
+ else if (typeof f === 'string' && f.length) {
35
+ return f.indexOf('"') == -1 && f.indexOf('(') == -1 ? '"' + f + '"' : f;
36
+ }
37
+ else {
38
+ throw new Error(`Invalid field: ${f}`);
39
+ }
40
+ },
41
+ quoteFieldNameOrPosition(f) {
42
+ if (Number.isInteger(+f)) {
43
+ if (!Number.isInteger(+f) || +f < 1)
44
+ throw new Error(`Invalid field: ${f}`);
45
+ return '' + f;
46
+ }
47
+ else if (typeof f === 'string' && f.length) {
48
+ return `"${f
49
+ .replace(/^\s*"*\s*/, '')
50
+ .replace(/\s*"*\s*$/, '')
51
+ .replace(/"/g, '""')}"`;
52
+ }
53
+ else {
54
+ throw new Error(`Invalid field: ${f}`);
55
+ }
56
+ },
57
+ quoteFieldNameJsonbOrPosition(f) {
58
+ if (Number.isInteger(+f)) {
59
+ return '' + f;
60
+ }
61
+ if (typeof f === 'string' && f.length) {
62
+ return `'${f
63
+ .replace(/^\s*'*/, '')
64
+ .replace(/'*\s*$/, '')
65
+ .replace(/'/g, "''")}'`;
66
+ }
67
+ else {
68
+ throw new Error(`Invalid field: ${f}`);
69
+ }
70
+ },
71
+ processQueryFields(options, pgTable) {
72
+ var _a, _b, _c;
73
+ let escapeColumns = (((pgTable === null || pgTable === void 0 ? void 0 : pgTable.db.config.forceEscapeColumns) === true || ((_a = pgTable === null || pgTable === void 0 ? void 0 : pgTable.db.config.forceEscapeColumns) === null || _a === void 0 ? void 0 : _a.select) === true)
74
+ && options.forceEscapeColumns !== false && ((_b = options.forceEscapeColumns) === null || _b === void 0 ? void 0 : _b.select) !== false)
75
+ || options.forceEscapeColumns === true
76
+ || ((_c = options.forceEscapeColumns) === null || _c === void 0 ? void 0 : _c.select);
19
77
  let s = options && options.distinct ? ' DISTINCT ' : ' ';
20
78
  if (options && options.fields) {
21
79
  if (Array.isArray(options.fields)) {
22
- return s + options.fields.map(exports.pgUtils.quoteField).join(', ');
80
+ if (escapeColumns) {
81
+ return s + options.fields.map(exports.pgUtils.quoteFieldName).join(', ');
82
+ }
83
+ return s + options.fields.map(exports.pgUtils.quoteFieldNameInsecure).join(', ');
23
84
  }
24
85
  else {
25
86
  return s + options.fields;
@@ -46,7 +107,7 @@ exports.pgUtils = {
46
107
  }
47
108
  sql2.push(sql.slice(lastIndex, NAMED_PARAMS_REGEXP.lastIndex - p[1].length - 1));
48
109
  if (ddl) {
49
- sql2.push('"' + ('' + params[name]).replace(/"/g, '""') + '"');
110
+ sql2.push(exports.pgUtils.quoteFieldName(params[name]));
50
111
  }
51
112
  else {
52
113
  params2.push(params[name]);
@@ -55,44 +116,111 @@ exports.pgUtils = {
55
116
  lastIndex = NAMED_PARAMS_REGEXP.lastIndex;
56
117
  p = NAMED_PARAMS_REGEXP.exec(sql);
57
118
  }
58
- sql2.push(sql.substr(lastIndex));
119
+ sql2.push(sql.slice(lastIndex));
59
120
  return {
60
121
  sql: sql2.join(''),
61
122
  params: params2
62
123
  };
63
124
  },
64
- processQueryOptions(options) {
65
- options = options || {};
66
- let sql = '';
67
- if (options.groupBy) {
125
+ handleColumnEscapeGroupBy(options, pgTable) {
126
+ var _a, _b, _c;
127
+ if (!options.groupBy)
128
+ return '';
129
+ let escapeColumns = (((pgTable === null || pgTable === void 0 ? void 0 : pgTable.db.config.forceEscapeColumns) === true || ((_a = pgTable === null || pgTable === void 0 ? void 0 : pgTable.db.config.forceEscapeColumns) === null || _a === void 0 ? void 0 : _a.groupBy) === true)
130
+ && options.forceEscapeColumns !== false && ((_b = options.forceEscapeColumns) === null || _b === void 0 ? void 0 : _b.groupBy) !== false)
131
+ || options.forceEscapeColumns === true
132
+ || ((_c = options.forceEscapeColumns) === null || _c === void 0 ? void 0 : _c.groupBy);
133
+ if (escapeColumns) {
68
134
  if (Array.isArray(options.groupBy)) {
69
- sql += ' GROUP BY ' + options.groupBy.map(exports.pgUtils.quoteField).join(',');
135
+ return ' GROUP BY ' + options.groupBy.map(exports.pgUtils.quoteFieldNameOrPosition).join(',');
70
136
  }
71
137
  else {
72
- sql += ' GROUP BY ' + exports.pgUtils.quoteField(options.groupBy);
138
+ return ' GROUP BY ' + exports.pgUtils.quoteFieldNameOrPosition(options.groupBy);
73
139
  }
74
140
  }
75
- if (options.orderBy) {
76
- if (typeof options.orderBy == 'string') {
77
- sql += ' ORDER BY ' + exports.pgUtils.quoteField(options.orderBy);
141
+ else {
142
+ if (Array.isArray(options.groupBy)) {
143
+ return ' GROUP BY ' + options.groupBy.map(exports.pgUtils.quoteFieldNameOrPositionInsecure).join(',');
78
144
  }
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(',');
145
+ else {
146
+ return ' GROUP BY ' + exports.pgUtils.quoteFieldNameOrPositionInsecure(options.groupBy);
147
+ }
148
+ }
149
+ },
150
+ handleColumnEscapeOrderBy(options, pgTable) {
151
+ var _a, _b, _c;
152
+ if (!options.orderBy)
153
+ return '';
154
+ let sql = '';
155
+ let escapeColumns = (((pgTable === null || pgTable === void 0 ? void 0 : pgTable.db.config.forceEscapeColumns) === true || ((_a = pgTable === null || pgTable === void 0 ? void 0 : pgTable.db.config.forceEscapeColumns) === null || _a === void 0 ? void 0 : _a.orderBy) === true)
156
+ && options.forceEscapeColumns !== false && ((_b = options.forceEscapeColumns) === null || _b === void 0 ? void 0 : _b.orderBy) !== false)
157
+ || options.forceEscapeColumns === true
158
+ || ((_c = options.forceEscapeColumns) === null || _c === void 0 ? void 0 : _c.orderBy);
159
+ let orderBy = typeof options.orderBy === 'string' ? options.orderBy.split(',') : options.orderBy;
160
+ if (Array.isArray(orderBy)) {
161
+ let orderBy2;
162
+ if (escapeColumns) {
163
+ orderBy2 = orderBy.map(v => {
164
+ var _a;
165
+ if (typeof v === 'number')
166
+ return exports.pgUtils.quoteFieldNameOrPosition(v);
167
+ else if (typeof v !== 'string' || !v.length)
168
+ throw new Error(`Invalid orderBy: ${v}`);
169
+ if (v[0] == '+')
170
+ return exports.pgUtils.quoteFieldNameOrPosition(v.slice(1));
171
+ if (v[0] == '-')
172
+ return exports.pgUtils.quoteFieldNameOrPosition(v.slice(1)) + ' desc';
173
+ let o = ASC_DESC_REGEXP.exec(v);
174
+ if (!o)
175
+ throw new Error(`Invalid orderBy: ${v}`);
176
+ return `${exports.pgUtils.quoteFieldNameOrPosition(o[1])} ${(_a = o[2]) !== null && _a !== void 0 ? _a : ''}`;
177
+ });
84
178
  }
85
179
  else {
86
- let orderBy = [];
87
- _.forEach(options.orderBy, (v, k) => orderBy.push(exports.pgUtils.quoteField(k) + ' ' + v));
88
- sql += ' ORDER BY ' + orderBy.join(',');
180
+ orderBy2 = orderBy.map(v => {
181
+ var _a;
182
+ if (typeof v === 'number')
183
+ return exports.pgUtils.quoteFieldNameOrPositionInsecure(v);
184
+ else if (typeof v !== 'string' || !v.length)
185
+ throw new Error(`Invalid orderBy: ${v}`);
186
+ if (v[0] == '+')
187
+ return exports.pgUtils.quoteFieldNameOrPositionInsecure(v.slice(1));
188
+ if (v[0] == '-')
189
+ return exports.pgUtils.quoteFieldNameOrPositionInsecure(v.slice(1)) + ' desc';
190
+ let o = ASC_DESC_REGEXP.exec(v);
191
+ if (!o)
192
+ throw new Error(`Invalid orderBy: ${v}`);
193
+ return `${exports.pgUtils.quoteFieldNameOrPositionInsecure(o[1])} ${(_a = o[2]) !== null && _a !== void 0 ? _a : ''}`;
194
+ });
195
+ }
196
+ sql += ' ORDER BY ' + orderBy2.join(',');
197
+ }
198
+ else {
199
+ throw new Error(`Invalid orderBy: ${options.orderBy}`);
200
+ }
201
+ return sql;
202
+ },
203
+ processQueryOptions(options, pgTable) {
204
+ options = options || {};
205
+ let sql = '';
206
+ if (options.groupBy) {
207
+ sql += exports.pgUtils.handleColumnEscapeGroupBy(options, pgTable);
208
+ }
209
+ if (options.orderBy) {
210
+ sql += exports.pgUtils.handleColumnEscapeOrderBy(options, pgTable);
211
+ if (options.orderByNullsFirst != null) {
212
+ sql += ' NULLS ' + options.orderByNullsFirst ? 'FIRST' : 'LAST';
89
213
  }
90
214
  }
91
215
  if (options.limit) {
92
- sql += util.format(' LIMIT %d', options.limit);
216
+ if (!Number.isInteger(options.limit) || options.limit < 0)
217
+ throw new Error(`Invalid limit: ${options.limit}`);
218
+ sql += ` LIMIT ${options.limit}`;
93
219
  }
94
220
  if (options.offset) {
95
- sql += util.format(' OFFSET %d', options.offset);
221
+ if (!Number.isInteger(options.offset) || options.offset < 0)
222
+ throw new Error(`Invalid offset: ${options.offset}`);
223
+ sql += ` OFFSET ${options.offset}`;
96
224
  }
97
225
  if (options.forUpdate) {
98
226
  sql += ' FOR UPDATE';
@@ -107,7 +235,7 @@ exports.pgUtils = {
107
235
  if (res) {
108
236
  if (res[0] && !Array.isArray(res[0])) {
109
237
  if (Object.keys(res[0]).length != fields.length) {
110
- throw Error("Name collision for the query, two or more fields have the same name.");
238
+ throw new Error("Name collision for the query, two or more fields have the same name.");
111
239
  }
112
240
  }
113
241
  exports.pgUtils.convertTypes(res, fields, pgdbTypeParsers);
@@ -127,7 +255,7 @@ exports.pgUtils = {
127
255
  });
128
256
  },
129
257
  createFunctionCaller(q, fn) {
130
- return (...args) => tslib_1.__awaiter(this, void 0, void 0, function* () {
258
+ return (...args) => (0, tslib_1.__awaiter)(this, void 0, void 0, function* () {
131
259
  let placeHolders = [];
132
260
  let params = [];
133
261
  args.forEach((arg) => {
@@ -138,13 +266,13 @@ exports.pgUtils = {
138
266
  if (fn.return_single_value) {
139
267
  let keys = res[0] ? Object.keys(res[0]) : [];
140
268
  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));
269
+ throw new Error(`Return type error. schema: ${fn.schema} fn: ${fn.name} expected return type: single value, current value:` + JSON.stringify(res));
142
270
  }
143
271
  res = res.map((r) => r[keys[0]]);
144
272
  }
145
273
  if (fn.return_single_row) {
146
274
  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));
275
+ throw new Error(`Return type error. schema: ${fn.schema} fn: ${fn.name} expected return type: single value, current value:` + JSON.stringify(res));
148
276
  }
149
277
  return res[0];
150
278
  }
@@ -152,6 +280,9 @@ exports.pgUtils = {
152
280
  return res;
153
281
  }
154
282
  });
283
+ },
284
+ escapeForLike(s) {
285
+ return s.replace(/([\\%_])/g, '\\$1');
155
286
  }
156
287
  };
157
288
  //# sourceMappingURL=pgUtils.js.map
@@ -1 +1 @@
1
- {"version":3,"file":"pgUtils.js","sourceRoot":"","sources":["../src/pgUtils.ts"],"names":[],"mappings":"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"}
1
+ {"version":3,"file":"pgUtils.js","sourceRoot":"","sources":["../src/pgUtils.ts"],"names":[],"mappings":"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"}
@@ -1,73 +1,40 @@
1
1
  /// <reference types="node" />
2
2
  import { PgDbLogger } from "./pgDbLogger";
3
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();
4
+ import { IPgSchema } from "./pgSchemaInterface";
5
+ import * as pg from 'pg';
6
+ import { IPgDb } from "./pgDbInterface";
7
+ import { SqlQueryOptions, IQueryAble, PgRowResult } from "./queryAbleInterface";
8
+ export declare abstract class QueryAble implements IQueryAble {
9
+ db: IPgDb & IQueryAble;
10
+ schema: IPgSchema;
11
+ logger: PgDbLogger;
12
+ static connectionErrorListener: () => void;
49
13
  setLogger(logger: PgDbLogger): void;
50
- getLogger(useConsoleAsDefault?: boolean): any;
14
+ getLogger(useConsoleAsDefault?: boolean): PgDbLogger;
51
15
  run(sql: string, params?: any[] | {}, options?: SqlQueryOptions): Promise<any[]>;
52
- query(sql: string, params?: any[] | {}, options?: SqlQueryOptions): Promise<any[]>;
16
+ query(sql: string, params?: any[] | {} | null, options?: SqlQueryOptions): Promise<any[]>;
53
17
  protected internalQuery(options: {
54
- connection: any;
18
+ connection: pg.PoolClient | null;
55
19
  sql: string;
56
20
  params?: any;
57
- logger?: any;
21
+ logger?: PgDbLogger;
58
22
  }): Promise<any[]>;
59
23
  protected internalQuery(options: {
60
- connection: any;
24
+ connection: pg.PoolClient | null;
61
25
  sql: string;
62
26
  params?: any;
63
- logger?: any;
27
+ logger?: PgDbLogger;
64
28
  rowMode: true;
65
29
  }): Promise<PgRowResult>;
66
30
  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>;
31
+ queryWithOnCursorCallback(sql: string, params: any[] | Record<string, any> | null, options: SqlQueryOptions | null, callback: (res: any) => any): Promise<void>;
32
+ queryAsStream(sql: string, params?: any[] | Record<string, any> | null, options?: SqlQueryOptions | null): Promise<stream.Readable>;
69
33
  queryOne(sql: string, params?: any[] | {}, options?: SqlQueryOptions): Promise<any>;
70
34
  queryFirst(sql: string, params?: any[] | {}, options?: SqlQueryOptions): Promise<any>;
71
35
  queryOneField(sql: string, params?: any[] | {}, options?: SqlQueryOptions): Promise<any>;
72
36
  queryOneColumn(sql: string, params?: any[] | {}, options?: SqlQueryOptions): Promise<any[]>;
37
+ private postProcessFields;
38
+ private checkAndFixOids;
39
+ private hasUnknownOids;
73
40
  }