pogi 2.11.1 → 3.0.0-beta

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 (95) hide show
  1. package/.vscode/launch.json +47 -15
  2. package/jest.config.js +23 -0
  3. package/lib/bin/generateInterface.js +2 -2
  4. package/lib/bin/generateInterface.js.map +1 -1
  5. package/lib/pgConverters.js +1 -1
  6. package/lib/pgConverters.js.map +1 -1
  7. package/lib/pgDb.js +5 -5
  8. package/lib/pgDb.js.map +1 -1
  9. package/lib/pgTable.js +7 -7
  10. package/lib/pgTable.js.map +1 -1
  11. package/lib/pgUtils.d.ts +3 -1
  12. package/lib/pgUtils.js +61 -23
  13. package/lib/pgUtils.js.map +1 -1
  14. package/lib/src/bin/generateInterface.d.ts +1 -0
  15. package/lib/src/bin/generateInterface.js +53 -0
  16. package/lib/src/bin/generateInterface.js.map +1 -0
  17. package/lib/src/connectionOptions.d.ts +34 -0
  18. package/lib/src/connectionOptions.js +3 -0
  19. package/lib/src/connectionOptions.js.map +1 -0
  20. package/lib/src/index.d.ts +6 -0
  21. package/lib/src/index.js +12 -0
  22. package/lib/src/index.js.map +1 -0
  23. package/lib/src/pgConverters.d.ts +9 -0
  24. package/lib/src/pgConverters.js +71 -0
  25. package/lib/src/pgConverters.js.map +1 -0
  26. package/lib/src/pgConverters.test.d.ts +1 -0
  27. package/lib/src/pgConverters.test.js +13 -0
  28. package/lib/src/pgConverters.test.js.map +1 -0
  29. package/lib/src/pgDb.d.ts +79 -0
  30. package/lib/src/pgDb.js +764 -0
  31. package/lib/src/pgDb.js.map +1 -0
  32. package/lib/src/pgDb.test.d.ts +1 -0
  33. package/lib/src/pgDb.test.js +1126 -0
  34. package/lib/src/pgDb.test.js.map +1 -0
  35. package/lib/src/pgDbInterface.js +11 -0
  36. package/lib/src/pgDbInterface.js.map +1 -0
  37. package/lib/src/pgDbLogger.d.ts +5 -0
  38. package/lib/src/pgDbLogger.js +3 -0
  39. package/lib/src/pgDbLogger.js.map +1 -0
  40. package/lib/src/pgDbOperators.d.ts +113 -0
  41. package/lib/src/pgDbOperators.js +41 -0
  42. package/lib/src/pgDbOperators.js.map +1 -0
  43. package/lib/src/pgDbOperators.test.d.ts +1 -0
  44. package/lib/src/pgDbOperators.test.js +313 -0
  45. package/lib/src/pgDbOperators.test.js.map +1 -0
  46. package/lib/src/pgSchema.d.ts +17 -0
  47. package/lib/src/pgSchema.js +16 -0
  48. package/lib/src/pgSchema.js.map +1 -0
  49. package/lib/src/pgSchemaInterface.d.ts +12 -0
  50. package/lib/src/pgSchemaInterface.js +3 -0
  51. package/lib/src/pgSchemaInterface.js.map +1 -0
  52. package/lib/src/pgTable.d.ts +105 -0
  53. package/lib/src/pgTable.js +322 -0
  54. package/lib/src/pgTable.js.map +1 -0
  55. package/lib/src/pgTableInterface.d.ts +102 -0
  56. package/lib/src/pgTableInterface.js +4 -0
  57. package/lib/src/pgTableInterface.js.map +1 -0
  58. package/lib/src/pgUtils.d.ts +41 -0
  59. package/lib/src/pgUtils.js +282 -0
  60. package/lib/src/pgUtils.js.map +1 -0
  61. package/lib/src/queryAble.d.ts +40 -0
  62. package/lib/src/queryAble.js +338 -0
  63. package/lib/src/queryAble.js.map +1 -0
  64. package/lib/src/queryAbleInterface.d.ts +59 -0
  65. package/lib/src/queryAbleInterface.js +7 -0
  66. package/lib/src/queryAbleInterface.js.map +1 -0
  67. package/lib/src/queryWhere.d.ts +8 -0
  68. package/lib/src/queryWhere.js +245 -0
  69. package/lib/src/queryWhere.js.map +1 -0
  70. package/package.json +20 -14
  71. package/src/bin/generateInterface.ts +2 -2
  72. package/src/connectionOptions.ts +46 -13
  73. package/src/index.d.ts +7 -0
  74. package/src/pgConverters.test.ts +10 -0
  75. package/src/pgConverters.ts +30 -26
  76. package/src/{test/pgDbSpec.ts → pgDb.test.ts} +170 -185
  77. package/src/pgDb.ts +91 -88
  78. package/src/pgDbInterface.ts +57 -0
  79. package/src/pgDbOperators.test.ts +478 -0
  80. package/src/pgDbOperators.ts +45 -22
  81. package/src/pgSchema.ts +10 -9
  82. package/src/pgSchemaInterface.ts +12 -0
  83. package/src/pgTable.ts +65 -97
  84. package/src/pgTableInterface.ts +131 -0
  85. package/src/pgUtils.ts +156 -42
  86. package/src/queryAble.ts +61 -118
  87. package/src/queryAbleInterface.ts +108 -0
  88. package/src/queryWhere.ts +42 -43
  89. package/{spec/resources → src/test}/init.sql +0 -0
  90. package/{spec/resources → src/test}/throw_exception.sql +0 -0
  91. package/{spec/resources → src/test}/tricky.sql +0 -0
  92. package/{src/tsconfig.json → tsconfig.json} +8 -6
  93. package/spec/run.js +0 -5
  94. package/spec/support/jasmine.json +0 -9
  95. package/src/test/pgDbOperatorSpec.ts +0 -492
@@ -0,0 +1,313 @@
1
+ "use strict";
2
+ Object.defineProperty(exports, "__esModule", { value: true });
3
+ const tslib_1 = require("tslib");
4
+ const pgDb_1 = require("./pgDb");
5
+ describe("pgdb", () => {
6
+ let pgdb;
7
+ let schema = 'pgdb_test';
8
+ let tableUsers;
9
+ let viewUsers;
10
+ beforeAll(() => (0, tslib_1.__awaiter)(void 0, void 0, void 0, function* () {
11
+ try {
12
+ pgdb = yield pgDb_1.PgDb.connect({ connectionString: "postgres://" });
13
+ }
14
+ catch (e) {
15
+ console.error("connection failed! Are you specified PGUSER/PGDATABASE/PGPASSWORD correctly?");
16
+ console.error(e);
17
+ process.exit(1);
18
+ }
19
+ yield pgdb.run('CREATE SCHEMA IF NOT EXISTS "' + schema + '"');
20
+ yield pgdb.execute('src/test/init.sql', (cmd) => cmd.replace(/__SCHEMA__/g, '"' + schema + '"'));
21
+ yield pgdb.reload();
22
+ pgdb.setLogger(console);
23
+ tableUsers = pgdb.schemas[schema]['users'];
24
+ viewUsers = pgdb.schemas[schema]['users_view'];
25
+ return Promise.resolve();
26
+ }));
27
+ beforeEach(() => (0, tslib_1.__awaiter)(void 0, void 0, void 0, function* () {
28
+ yield tableUsers.run('DELETE FROM ' + tableUsers);
29
+ }));
30
+ afterAll(() => (0, tslib_1.__awaiter)(void 0, void 0, void 0, function* () {
31
+ yield pgdb.close();
32
+ }));
33
+ it("Testing Array operators", () => (0, tslib_1.__awaiter)(void 0, void 0, void 0, function* () {
34
+ yield tableUsers.insert({ name: 'S', favourites: ['sport'] });
35
+ yield tableUsers.insert({ name: 'SF', favourites: ['sport', 'food'] });
36
+ yield tableUsers.insert({ name: 'TF', favourites: ['tech', 'food'] });
37
+ let res;
38
+ res = yield tableUsers.find({ 'favourites': 'sport' }, { fields: ['name'] });
39
+ expect(res.map(r => r.name)).toEqual(['S', 'SF']);
40
+ res = yield tableUsers.find({ 'favourites': ['sport', 'food'] }, { fields: ['name'] });
41
+ expect(res.map(r => r.name)).toEqual(['SF']);
42
+ res = yield tableUsers.find({ 'favourites @>': ['sport'] });
43
+ expect(res.map(r => r.name)).toEqual(['S', 'SF']);
44
+ res = yield tableUsers.find({ 'favourites <@': ['sport', 'food', 'tech'] });
45
+ expect(res.map(r => r.name)).toEqual(['S', 'SF', 'TF']);
46
+ res = yield tableUsers.find({ 'favourites &&': ['sport', 'music'] });
47
+ expect(res.map(r => r.name)).toEqual(['S', 'SF']);
48
+ res = yield tableUsers.find({ 'favourites !=': ['sport'] });
49
+ expect(res.map(r => r.name)).toEqual(['SF', 'TF']);
50
+ }));
51
+ it("Testing Array operators on view", () => (0, tslib_1.__awaiter)(void 0, void 0, void 0, function* () {
52
+ yield viewUsers.insert({ name: 'S', favourites: ['sport'] });
53
+ yield viewUsers.insert({ name: 'SF', favourites: ['sport', 'food'] });
54
+ yield viewUsers.insert({ name: 'TF', favourites: ['tech', 'food'] });
55
+ let res;
56
+ res = yield viewUsers.find({ 'favourites': 'sport' }, { fields: ['name'] });
57
+ expect(res.map(r => r.name)).toEqual(['S', 'SF']);
58
+ res = yield viewUsers.find({ 'favourites': ['sport', 'food'] }, { fields: ['name'] });
59
+ expect(res.map(r => r.name)).toEqual(['SF']);
60
+ res = yield viewUsers.find({ 'favourites @>': ['sport'] });
61
+ expect(res.map(r => r.name)).toEqual(['S', 'SF']);
62
+ res = yield viewUsers.find({ 'favourites <@': ['sport', 'food', 'tech'] });
63
+ expect(res.map(r => r.name)).toEqual(['S', 'SF', 'TF']);
64
+ res = yield viewUsers.find({ 'favourites &&': ['sport', 'music'] });
65
+ expect(res.map(r => r.name)).toEqual(['S', 'SF']);
66
+ res = yield viewUsers.find({ 'favourites !=': ['sport'] });
67
+ expect(res.map(r => r.name)).toEqual(['SF', 'TF']);
68
+ }));
69
+ it("Searching in elements in jsonList", () => (0, tslib_1.__awaiter)(void 0, void 0, void 0, function* () {
70
+ yield tableUsers.insert({ name: 'Medium and high risk', jsonList: [{ risk: 'H' }, { risk: 'M' }] });
71
+ let query1 = {
72
+ or: [{ '"jsonList" @>': [{ "risk": "H" }] }, { '"jsonList" @>': [{ "risk": "L" }] }]
73
+ };
74
+ let query2 = {
75
+ or: [{ 'jsonList @>': [{ "risk": "H" }] }, { 'jsonList @>': [{ "risk": "L" }] }]
76
+ };
77
+ let query3 = {
78
+ or: [{ 'jsonList @>': '[{"risk": "H"}]' }, { 'jsonList @>': '[{"risk": "L"}]' }]
79
+ };
80
+ let res;
81
+ res = yield tableUsers.find(query1, { fields: ['name'] });
82
+ expect(res.map(r => r.name)).toEqual(['Medium and high risk']);
83
+ res = yield tableUsers.find(query2, { fields: ['name'] });
84
+ expect(res.map(r => r.name)).toEqual(['Medium and high risk']);
85
+ res = yield tableUsers.find(query3, { fields: ['name'] });
86
+ expect(res.map(r => r.name)).toEqual(['Medium and high risk']);
87
+ }));
88
+ it("Free text search", () => (0, tslib_1.__awaiter)(void 0, void 0, void 0, function* () {
89
+ yield tableUsers.insert({ name: 'Medium and high risk', jsonList: [{ name: "The return of the Jedi" }] });
90
+ let res;
91
+ for (let searchCol of ['"name"||"jsonList" @@', 'tsv @@']) {
92
+ res = yield tableUsers.find({ [searchCol]: 'risk & return' }, { fields: ['name'] });
93
+ expect(res.map(r => r.name)).toEqual(['Medium and high risk']);
94
+ res = yield tableUsers.find({ [searchCol]: 'risk & future' }, { fields: ['name'] });
95
+ expect(res.length).toEqual(0);
96
+ res = yield tableUsers.find({
97
+ [searchCol]: {
98
+ lang: 'english',
99
+ query: 'risk & return'
100
+ }
101
+ }, { fields: ['name'] });
102
+ expect(res.map(r => r.name)).toEqual(['Medium and high risk']);
103
+ }
104
+ }));
105
+ it("Testing Jsonb list selector operators", () => (0, tslib_1.__awaiter)(void 0, void 0, void 0, function* () {
106
+ yield tableUsers.insert({ name: 'Somebody', jsonList: ['sport', 'season'] });
107
+ yield tableUsers.insert({ name: 'Anybody', jsonList: ['art', 'age'] });
108
+ yield tableUsers.insert({ name: 'Nobody', jsonList: ['neverending', 'nearby'] });
109
+ yield tableUsers.insert({ name: 'Noone', jsonList: null, });
110
+ yield tableUsers.insert({ name: 'Anonymous', jsonList: [] });
111
+ yield tableUsers.insert({ name: 'Obi1', jsonObject: { a: { b: 3 } } });
112
+ yield tableUsers.insert({ name: 'Obi2', jsonObject: { a: { b: [3, 4, 5, 6] }, d: 'c', g: 'e' } });
113
+ let res;
114
+ res = yield tableUsers.find({ '"jsonObject" ?|': ['d', 'f'] }, { fields: ['name'] });
115
+ expect(res.map(r => r.name)).toEqual(['Obi2']);
116
+ res = yield tableUsers.find({ 'jsonList @>': ['sport'] }, { fields: ['name'] });
117
+ expect(res.map(r => r.name)).toEqual(['Somebody']);
118
+ res = yield tableUsers.find({ 'jsonList <@': ['sport', 'tech', 'season'] }, { fields: ['name'] });
119
+ expect(res.map(r => r.name)).toEqual(['Somebody', 'Anonymous']);
120
+ res = yield tableUsers.find({ 'jsonList ?': 0 }, { fields: ['name'] });
121
+ expect(res.map(r => r.name)).toEqual([]);
122
+ res = yield tableUsers.find({ 'jsonList ?': '0' }, { fields: ['name'] });
123
+ expect(res.map(r => r.name)).toEqual([]);
124
+ res = yield tableUsers.find({ 'jsonObject -> a': { b: 3 } }, { fields: ['name'] });
125
+ expect(res.map(r => r.name)).toEqual(['Obi1']);
126
+ res = yield tableUsers.find({ "jsonObject -> 'a'": { b: 3 } }, { fields: ['name'] });
127
+ expect(res.map(r => r.name)).toEqual(['Obi1']);
128
+ res = yield tableUsers.find({ 'jsonList ->> 0': 'art' }, { fields: ['name'] });
129
+ expect(res.map(r => r.name)).toEqual(['Anybody']);
130
+ res = yield tableUsers.find({ 'jsonObject ->> a': '{"b": 3}' }, { fields: ['name'] });
131
+ expect(res.map(r => r.name)).toEqual(['Obi1']);
132
+ res = yield tableUsers.find({ "jsonObject ->> 'a'": '{"b": 3}' }, { fields: ['name'] });
133
+ expect(res.map(r => r.name)).toEqual(['Obi1']);
134
+ res = yield tableUsers.find({ "jsonList ->> '0'": 'art' }, { fields: ['name'] });
135
+ expect(res.map(r => r.name)).toEqual([]);
136
+ res = yield tableUsers.find({ "jsonObject #> {a}": { b: 3 } }, { fields: ['name'] });
137
+ expect(res.map(r => r.name)).toEqual(['Obi1']);
138
+ res = yield tableUsers.find({ "jsonObject #>> {a}": '{"b": 3}' }, { fields: ['name'] });
139
+ expect(res.map(r => r.name)).toEqual(['Obi1']);
140
+ res = yield tableUsers.find({ "jsonObject #>> {a,b}": 3 }, { fields: ['name'] });
141
+ expect(res.map(r => r.name)).toEqual(['Obi1']);
142
+ res = yield tableUsers.find({ "jsonObject #>> {a,b,1}": 4 }, { fields: ['name'] });
143
+ expect(res.map(r => r.name)).toEqual(['Obi2']);
144
+ res = yield tableUsers.find({ "jsonObject #>> {a,b,1}": '4' }, { fields: ['name'] });
145
+ expect(res.map(r => r.name)).toEqual(['Obi2']);
146
+ }));
147
+ it("Testing Jsonb list update", () => (0, tslib_1.__awaiter)(void 0, void 0, void 0, function* () {
148
+ yield tableUsers.insert({ name: 'Somebody', jsonList: ['sport', 'season'] });
149
+ yield tableUsers.update({ name: 'Somebody' }, { jsonList: [{ name: 'sport' }, { name: 'season' }] });
150
+ let res = yield tableUsers.findAll();
151
+ expect(res.map(r => r.jsonList.map((e) => e.name))[0]).toEqual(['sport', 'season']);
152
+ }));
153
+ it("Testing Jsonb list operators", () => (0, tslib_1.__awaiter)(void 0, void 0, void 0, function* () {
154
+ yield tableUsers.insert({ name: 'Somebody', jsonObject: { realName: 'somebody', webpage: 's.com' } });
155
+ yield tableUsers.insert({ name: 'Anybody', jsonObject: { realName: 'anybody', webpage: 'a.com' } });
156
+ yield tableUsers.insert({ name: 'Nobody', jsonObject: { realName: 'nobody', email: 'nobody@nowhere.com' } });
157
+ yield tableUsers.insert({ name: 'Noone', jsonObject: null });
158
+ yield tableUsers.insert({ name: 'Anonymous', jsonObject: {} });
159
+ let res;
160
+ res = yield tableUsers.find({ 'jsonObject ?': 'email' }, { fields: ['name'] });
161
+ expect(res.map(r => r.name)).toEqual(['Nobody']);
162
+ res = yield tableUsers.find({ 'jsonObject ?&': ['email', 'realName'] }, { fields: ['name'] });
163
+ expect(res.map(r => r.name)).toEqual(['Nobody']);
164
+ res = yield tableUsers.find({ 'jsonObject ?|': ['email', 'webpage'] }, { fields: ['name'] });
165
+ expect(res.map(r => r.name)).toEqual(['Somebody', 'Anybody', 'Nobody']);
166
+ res = yield tableUsers.find({ 'jsonObject @>': { realName: 'somebody' } }, { fields: ['name'] });
167
+ expect(res.map(r => r.name)).toEqual(['Somebody']);
168
+ res = yield tableUsers.find({ 'jsonObject ->> realName': 'somebody' }, { fields: ['name'] });
169
+ expect(res.map(r => r.name)).toEqual(['Somebody']);
170
+ res = yield tableUsers.find({ 'jsonObject ->> \'realName\'': 'somebody' }, { fields: ['name'] });
171
+ expect(res.map(r => r.name)).toEqual(['Somebody']);
172
+ res = yield tableUsers.find({ '"jsonObject" ->> \'realName\'': 'somebody' }, { fields: ['name'] });
173
+ expect(res.map(r => r.name)).toEqual(['Somebody']);
174
+ res = yield tableUsers.find({ 'jsonObject ->> realName': ['somebody', 'anybody'] }, { fields: ['name'] });
175
+ expect(res.map(r => r.name)).toEqual(['Somebody', 'Anybody']);
176
+ res = yield tableUsers.find({ 'jsonObject ->> realName like': '%body' }, { fields: ['name'] });
177
+ expect(res.map(r => r.name)).toEqual(['Somebody', 'Anybody', 'Nobody']);
178
+ res = yield tableUsers.find({ 'jsonObject ->> realName ~~': '%body' }, { fields: ['name'] });
179
+ expect(res.map(r => r.name)).toEqual(['Somebody', 'Anybody', 'Nobody']);
180
+ }));
181
+ it("Test deep jsonb @>", () => (0, tslib_1.__awaiter)(void 0, void 0, void 0, function* () {
182
+ yield tableUsers.insert({ name: 'Somebody', jsonObject: { service: { indexing: { by: [1, 2, 3] }, database: true }, paid: true } });
183
+ yield tableUsers.insert({ name: 'Anybody', jsonList: [{ realName: 'anyone' }, { realName: 'anybody' }] });
184
+ let res;
185
+ res = yield tableUsers.find({ 'jsonObject @>': { service: { indexing: { by: [1] } }, paid: true } });
186
+ expect(res.map(r => r.name)).toEqual(['Somebody']);
187
+ res = yield tableUsers.find({ 'jsonList @>': [{ realName: 'anybody' }] });
188
+ expect(res.map(r => r.name)).toEqual(['Anybody']);
189
+ }));
190
+ it("Testing is (not) null", () => (0, tslib_1.__awaiter)(void 0, void 0, void 0, function* () {
191
+ yield tableUsers.insert({ name: 'Noone', jsonObject: null });
192
+ yield tableUsers.insert({ name: 'Anonymous', jsonObject: {} });
193
+ let count;
194
+ count = yield tableUsers.count({ 'jsonObject !': null });
195
+ expect(count).toEqual(1);
196
+ count = yield tableUsers.count({ 'jsonObject': null });
197
+ expect(count).toEqual(1);
198
+ count = yield tableUsers.count({});
199
+ expect(count).toEqual(2);
200
+ }));
201
+ it("Test regexp ~,~*,!~,!~*", () => (0, tslib_1.__awaiter)(void 0, void 0, void 0, function* () {
202
+ yield tableUsers.insert({ name: "All' o Phoibe" });
203
+ yield tableUsers.insert({ name: "I've got that tune" });
204
+ let res = yield tableUsers.find({ 'name ~': "\\so\\s" });
205
+ expect(res.map(r => r.name)).toEqual(["All' o Phoibe"]);
206
+ res = yield tableUsers.find({ 'name ~*': "\\sO\\s" });
207
+ expect(res.map(r => r.name)).toEqual(["All' o Phoibe"]);
208
+ res = yield tableUsers.find({ 'name !~': "\\so\\s" });
209
+ expect(res.map(r => r.name)).toEqual(["I've got that tune"]);
210
+ res = yield tableUsers.find({ 'name !~*': "\\sO\\s" });
211
+ expect(res.map(r => r.name)).toEqual(["I've got that tune"]);
212
+ }));
213
+ it("Test regexp " +
214
+ "~/~* ANY" +
215
+ "!~/!~* ALL", () => (0, tslib_1.__awaiter)(void 0, void 0, void 0, function* () {
216
+ yield tableUsers.insert({ name: "All' o Phoibe" });
217
+ yield tableUsers.insert({ name: "I've got that tune" });
218
+ let res = yield tableUsers.find({ 'name ~': ["\\so\\s", '\\d+'] });
219
+ expect(res.map(r => r.name)).toEqual(["All' o Phoibe"]);
220
+ res = yield tableUsers.find({ 'name ~*': ["\\sO\\s", '\\d+'] });
221
+ expect(res.map(r => r.name)).toEqual(["All' o Phoibe"]);
222
+ res = yield tableUsers.find({ 'name !~': ["\\so\\s", '\\d+'] });
223
+ expect(res.map(r => r.name)).toEqual(["I've got that tune"]);
224
+ res = yield tableUsers.find({ 'name !~*': ["\\sO\\s", '\\d+'] });
225
+ expect(res.map(r => r.name)).toEqual(["I've got that tune"]);
226
+ }));
227
+ it("Test like ~~, like, ~~*, ilike, !~~, not like, !~~*, not ilike", () => (0, tslib_1.__awaiter)(void 0, void 0, void 0, function* () {
228
+ yield tableUsers.insert({ name: 'Iced lemonade' });
229
+ yield tableUsers.insert({ name: 'Cucumber pear juice' });
230
+ let res;
231
+ res = yield tableUsers.find({ 'name ~~': '%lemon%' });
232
+ expect(res.map(r => r.name)).toEqual(['Iced lemonade']);
233
+ res = yield tableUsers.find({ 'name like': '%lemon%' });
234
+ expect(res.map(r => r.name)).toEqual(['Iced lemonade']);
235
+ res = yield tableUsers.find({ 'name ~~*': '%LEMON%' });
236
+ expect(res.map(r => r.name)).toEqual(['Iced lemonade']);
237
+ res = yield tableUsers.find({ 'name ilike': '%LEMON%' });
238
+ expect(res.map(r => r.name)).toEqual(['Iced lemonade']);
239
+ res = yield tableUsers.find({ 'name !~~': '%lemon%' });
240
+ expect(res.map(r => r.name)).toEqual(['Cucumber pear juice']);
241
+ res = yield tableUsers.find({ 'name not like': '%lemon%' });
242
+ expect(res.map(r => r.name)).toEqual(['Cucumber pear juice']);
243
+ res = yield tableUsers.find({ 'name !~~*': '%LEMON%' });
244
+ expect(res.map(r => r.name)).toEqual(['Cucumber pear juice']);
245
+ res = yield tableUsers.find({ 'name not ilike': '%LEMON%' });
246
+ expect(res.map(r => r.name)).toEqual(['Cucumber pear juice']);
247
+ }));
248
+ it("Test " +
249
+ "like/~~/ilike/~~* ANY(), " +
250
+ "not like/!~~/not ilike/!~~* ALL()", () => (0, tslib_1.__awaiter)(void 0, void 0, void 0, function* () {
251
+ yield tableUsers.insert({ name: 'Iced lemonade' });
252
+ yield tableUsers.insert({ name: 'Cucumber pear juice' });
253
+ let res;
254
+ res = yield tableUsers.find({ 'name ~~': ['BB', '%lemon%'] });
255
+ expect(res.map(r => r.name)).toEqual(['Iced lemonade']);
256
+ res = yield tableUsers.find({ 'name like': ['BB', '%lemon%'] });
257
+ expect(res.map(r => r.name)).toEqual(['Iced lemonade']);
258
+ res = yield tableUsers.find({ 'name ~~*': ['bb', '%LEMON%'] });
259
+ expect(res.map(r => r.name)).toEqual(['Iced lemonade']);
260
+ res = yield tableUsers.find({ 'name ilike': ['bb', '%LEMON%'] });
261
+ expect(res.map(r => r.name)).toEqual(['Iced lemonade']);
262
+ res = yield tableUsers.find({ 'name !~~': ['BB', '%lemon%'] });
263
+ expect(res.map(r => r.name)).toEqual(['Cucumber pear juice']);
264
+ res = yield tableUsers.find({ 'name not like': ['BB', '%lemon%'] });
265
+ expect(res.map(r => r.name)).toEqual(['Cucumber pear juice']);
266
+ res = yield tableUsers.find({ 'name !~~*': ['bb', '%LEMON%'] });
267
+ expect(res.map(r => r.name)).toEqual(['Cucumber pear juice']);
268
+ res = yield tableUsers.find({ 'name not ilike': ['bb', '%LEMON%'] });
269
+ expect(res.map(r => r.name)).toEqual(['Cucumber pear juice']);
270
+ }));
271
+ it("Special added operators =*, icontains", () => (0, tslib_1.__awaiter)(void 0, void 0, void 0, function* () {
272
+ yield tableUsers.insert({ name: 'Iced lemonade' });
273
+ yield tableUsers.insert({ name: 'Cucumber pear juice', textList: ['good', 'better', 'best'] });
274
+ let res;
275
+ res = yield tableUsers.find({ 'name =*': 'ICED LEMONADE' });
276
+ expect(res.map(r => r.name)).toEqual(['Iced lemonade']);
277
+ res = yield tableUsers.find({ 'textList icontains': 'GOOD' });
278
+ expect(res.map(r => r.name)).toEqual(['Cucumber pear juice']);
279
+ res = yield tableUsers.find({ 'textList =*': 'GOOD' });
280
+ expect(res.map(r => r.name)).toEqual(['Cucumber pear juice']);
281
+ res = yield tableUsers.find({ 'textList &&*': ['GOOD', 'Bad'] });
282
+ expect(res.map(r => r.name)).toEqual(['Cucumber pear juice']);
283
+ }));
284
+ });
285
+ function parseComplexTypeArray(str) {
286
+ let list = JSON.parse('[' + str.substring(1, str.length - 1) + ']');
287
+ let result = [];
288
+ for (let elementStr of list) {
289
+ result.push(parseComplexType(elementStr));
290
+ }
291
+ return result;
292
+ }
293
+ function parseComplexType(str) {
294
+ str = str.substring(1, str.length - 1);
295
+ let e = /"((?:[^"]|"")*)"(?:,|$)|([^,]*)(?:,|$)/g;
296
+ let valList = [];
297
+ let parsingResult;
298
+ let valStr;
299
+ let hasNextValue;
300
+ do {
301
+ parsingResult = e.exec(str);
302
+ if (!parsingResult)
303
+ break;
304
+ valStr = (parsingResult[0] == '' || parsingResult[0] == ',' || parsingResult[2] == 'null') ? null : parsingResult[1] || parsingResult[2];
305
+ if (parsingResult[0] == '"",' || parsingResult[0] == '""') {
306
+ valStr = '';
307
+ }
308
+ valList.push(valStr ? valStr.replace(/""/g, '"') : valStr);
309
+ hasNextValue = parsingResult[0].substring(parsingResult[0].length - 1, parsingResult[0].length) == ',';
310
+ } while (hasNextValue);
311
+ return valList;
312
+ }
313
+ //# sourceMappingURL=pgDbOperators.test.js.map
@@ -0,0 +1 @@
1
+ {"version":3,"file":"pgDbOperators.test.js","sourceRoot":"","sources":["../../src/pgDbOperators.test.ts"],"names":[],"mappings":"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"}
@@ -0,0 +1,17 @@
1
+ import { QueryAble } from "./queryAble";
2
+ import { IPgDb } from "./pgDbInterface";
3
+ import { IPgTable } from "./pgTableInterface";
4
+ import { IPgSchema } from "./pgSchemaInterface";
5
+ export declare class PgSchema extends QueryAble implements IPgSchema {
6
+ db: IPgDb;
7
+ schemaName: string;
8
+ schema: IPgSchema;
9
+ tables: {
10
+ [name: string]: IPgTable<any>;
11
+ };
12
+ fn: {
13
+ [name: string]: (...args: any[]) => any;
14
+ };
15
+ [name: string]: any | IPgTable<any>;
16
+ constructor(db: IPgDb, schemaName: string);
17
+ }
@@ -0,0 +1,16 @@
1
+ "use strict";
2
+ Object.defineProperty(exports, "__esModule", { value: true });
3
+ exports.PgSchema = void 0;
4
+ const queryAble_1 = require("./queryAble");
5
+ class PgSchema extends queryAble_1.QueryAble {
6
+ constructor(db, schemaName) {
7
+ super();
8
+ this.db = db;
9
+ this.schemaName = schemaName;
10
+ this.tables = {};
11
+ this.fn = {};
12
+ this.schema = this;
13
+ }
14
+ }
15
+ exports.PgSchema = PgSchema;
16
+ //# sourceMappingURL=pgSchema.js.map
@@ -0,0 +1 @@
1
+ {"version":3,"file":"pgSchema.js","sourceRoot":"","sources":["../../src/pgSchema.ts"],"names":[],"mappings":";;;AAAA,2CAAwC;AAKxC,MAAa,QAAS,SAAQ,qBAAS;IAMnC,YAAmB,EAAS,EAAS,UAAkB;QACnD,KAAK,EAAE,CAAC;QADO,OAAE,GAAF,EAAE,CAAO;QAAS,eAAU,GAAV,UAAU,CAAQ;QAJvD,WAAM,GAAsC,EAAE,CAAC;QAC/C,OAAE,GAAgD,EAAE,CAAC;QAKjD,IAAI,CAAC,MAAM,GAAG,IAAI,CAAC;IACvB,CAAC;CACJ;AAVD,4BAUC"}
@@ -0,0 +1,12 @@
1
+ import { IPgTable } from "./pgTableInterface";
2
+ import { IQueryAble } from "./queryAbleInterface";
3
+ export interface IPgSchema extends IQueryAble {
4
+ schemaName: string;
5
+ tables: {
6
+ [name: string]: IPgTable<any>;
7
+ };
8
+ fn: {
9
+ [name: string]: (...args: any[]) => any;
10
+ };
11
+ [name: string]: any | IPgTable<any>;
12
+ }
@@ -0,0 +1,3 @@
1
+ "use strict";
2
+ Object.defineProperty(exports, "__esModule", { value: true });
3
+ //# sourceMappingURL=pgSchemaInterface.js.map
@@ -0,0 +1 @@
1
+ {"version":3,"file":"pgSchemaInterface.js","sourceRoot":"","sources":["../../src/pgSchemaInterface.ts"],"names":[],"mappings":""}
@@ -0,0 +1,105 @@
1
+ /// <reference types="node" />
2
+ import { QueryAble, QueryOptions } from "./queryAble";
3
+ import { FieldType } from "./pgDb";
4
+ import { IPgDb } from "./pgDbInterface";
5
+ import { PgSchema } from "./pgSchema";
6
+ import * as stream from "stream";
7
+ import { IPgTable, TruncateOptions, InsertOption, Return, UpdateDeleteOption, UpsertOption, Stream, CountOption } from "./pgTableInterface";
8
+ export declare class PgTable<T> extends QueryAble implements IPgTable<T> {
9
+ schema: PgSchema;
10
+ protected desc: {
11
+ name: string;
12
+ pkey?: string;
13
+ schema: string;
14
+ };
15
+ qualifiedName: string;
16
+ pkey: string;
17
+ db: IPgDb;
18
+ fieldTypes: {
19
+ [index: string]: FieldType;
20
+ };
21
+ constructor(schema: PgSchema, desc: {
22
+ name: string;
23
+ pkey?: string;
24
+ schema: string;
25
+ }, fieldTypes?: Record<string, FieldType>);
26
+ toString(): string;
27
+ insert(records: T[], options?: InsertOption): Promise<number>;
28
+ insert(records: T, options?: InsertOption): Promise<number>;
29
+ insertAndGet(records: T[], options?: InsertOption & Return): Promise<T[]>;
30
+ insertAndGet(records: T, options?: InsertOption & Return): Promise<T>;
31
+ updateOne(conditions: {
32
+ [k: string]: any;
33
+ }, fields: {
34
+ [k: string]: any;
35
+ }, options?: UpdateDeleteOption): Promise<number>;
36
+ updateAndGetOne(conditions: {
37
+ [k: string]: any;
38
+ }, fields: {
39
+ [k: string]: any;
40
+ }, options?: UpdateDeleteOption & Return): Promise<T>;
41
+ update(conditions: {
42
+ [k: string]: any;
43
+ }, fields: {
44
+ [k: string]: any;
45
+ }, options?: UpdateDeleteOption): Promise<number>;
46
+ updateAndGet(conditions: {
47
+ [k: string]: any;
48
+ }, fields: {
49
+ [k: string]: any;
50
+ }, options?: UpdateDeleteOption & Return): Promise<T[]>;
51
+ upsert(record: T, options?: UpsertOption): Promise<number>;
52
+ upsertAndGet(record: T, options?: UpsertOption & Return): Promise<T>;
53
+ delete(conditions: {
54
+ [k: string]: any;
55
+ }, options?: UpdateDeleteOption): Promise<number>;
56
+ deleteOne(conditions: {
57
+ [k: string]: any;
58
+ }, options?: UpdateDeleteOption): Promise<number>;
59
+ deleteAndGet(conditions: {
60
+ [k: string]: any;
61
+ }, options?: UpdateDeleteOption & Return): Promise<any[]>;
62
+ deleteAndGetOne(conditions: {
63
+ [k: string]: any;
64
+ }, options?: UpdateDeleteOption & Return): Promise<any>;
65
+ truncate(options?: TruncateOptions): Promise<void>;
66
+ find(conditions: {
67
+ [k: string]: any;
68
+ }, options?: QueryOptions): Promise<T[]>;
69
+ find(conditions: {
70
+ [k: string]: any;
71
+ }, options?: QueryOptions & Stream): Promise<stream.Readable>;
72
+ findWhere(where: string, params: any[] | {}, options?: QueryOptions): Promise<T[]>;
73
+ findWhere(where: string, params: any[] | {}, options?: QueryOptions & Stream): Promise<stream.Readable>;
74
+ findAll(options?: QueryOptions): Promise<T[]>;
75
+ findAll(options?: QueryOptions & Stream): Promise<stream.Readable>;
76
+ findOne(conditions: Record<string, any>, options?: QueryOptions): Promise<T>;
77
+ findFirst(conditions: Record<string, any>, options?: QueryOptions): Promise<T>;
78
+ count(conditions?: Record<string, any>, options?: CountOption): Promise<number>;
79
+ findOneFieldOnly(conditions: Record<string, any>, field: string, options?: QueryOptions): Promise<any>;
80
+ private getInsertQuery;
81
+ protected getUpdateSetSnippet(fields: {
82
+ [k: string]: any;
83
+ }, parameters?: any[]): {
84
+ snippet: string;
85
+ parameters: any[];
86
+ };
87
+ protected getUpdateQuery(conditions: {
88
+ [k: string]: any;
89
+ }, fields: {
90
+ [k: string]: any;
91
+ }, options?: UpdateDeleteOption): {
92
+ sql: string;
93
+ parameters: any[];
94
+ };
95
+ protected getUpsertQuery(record: T, options?: UpsertOption): {
96
+ sql: string;
97
+ parameters: any[];
98
+ };
99
+ protected getDeleteQuery(conditions: {
100
+ [k: string]: any;
101
+ }, options?: UpdateDeleteOption): {
102
+ sql: string;
103
+ parameters: any[];
104
+ };
105
+ }