prostgles-server 4.0.57 → 4.0.59

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 (221) hide show
  1. package/dist/DboBuilder/getColumns.d.ts.map +1 -1
  2. package/dist/DboBuilder/getColumns.js +1 -13
  3. package/dist/DboBuilder/getColumns.js.map +1 -1
  4. package/dist/DboBuilder/runSQL.js +2 -2
  5. package/dist/DboBuilder/runSQL.js.map +1 -1
  6. package/dist/Prostgles.d.ts.map +1 -1
  7. package/dist/PubSubManager/PubSubManager.d.ts +1 -1
  8. package/dist/PubSubManager/PubSubManager.d.ts.map +1 -1
  9. package/dist/PubSubManager/PubSubManager.js +14 -1
  10. package/dist/PubSubManager/PubSubManager.js.map +1 -1
  11. package/lib/DboBuilder/getColumns.ts +1 -18
  12. package/lib/DboBuilder/runSQL.ts +2 -2
  13. package/lib/Prostgles.ts +3 -3
  14. package/lib/PubSubManager/PubSubManager.ts +14 -1
  15. package/package.json +2 -2
  16. package/tests/client/PID.txt +1 -1
  17. package/tests/client/package.json +2 -2
  18. package/tests/client/tsconfig.json +2 -1
  19. package/tests/isomorphic_queries.ts +11 -9
  20. package/tests/server/DBoGenerated.d.ts +1 -1
  21. package/tests/server/dboTypeCheck.ts +3 -3
  22. package/tests/server/index.ts +7 -6
  23. package/tests/server/package-lock.json +1 -1
  24. package/tests/server/package.json +3 -3
  25. package/tests/server/publishTypeCheck.ts +1 -1
  26. package/tests/server/tsconfig.json +3 -2
  27. package/tests/test.sh +2 -0
  28. package/dist/FileManager.d.ts +0 -143
  29. package/dist/FileManager.d.ts.map +0 -1
  30. package/dist/FileManager.js +0 -646
  31. package/dist/FileManager.js.map +0 -1
  32. package/dist/TableConfig.d.ts +0 -267
  33. package/dist/TableConfig.d.ts.map +0 -1
  34. package/dist/TableConfig.js +0 -463
  35. package/dist/TableConfig.js.map +0 -1
  36. package/dist/validation.d.ts +0 -126
  37. package/dist/validation.d.ts.map +0 -1
  38. package/dist/validation.js +0 -405
  39. package/dist/validation.js.map +0 -1
  40. package/lib/AuthHandler.d.ts +0 -187
  41. package/lib/AuthHandler.d.ts.map +0 -1
  42. package/lib/AuthHandler.js +0 -478
  43. package/lib/DBEventsManager.d.ts +0 -38
  44. package/lib/DBEventsManager.d.ts.map +0 -1
  45. package/lib/DBEventsManager.js +0 -140
  46. package/lib/DBSchemaBuilder.d.ts +0 -13
  47. package/lib/DBSchemaBuilder.d.ts.map +0 -1
  48. package/lib/DBSchemaBuilder.js +0 -145
  49. package/lib/DboBuilder/QueryBuilder/Functions.d.ts +0 -64
  50. package/lib/DboBuilder/QueryBuilder/Functions.d.ts.map +0 -1
  51. package/lib/DboBuilder/QueryBuilder/Functions.js +0 -984
  52. package/lib/DboBuilder/QueryBuilder/QueryBuilder.d.ts +0 -73
  53. package/lib/DboBuilder/QueryBuilder/QueryBuilder.d.ts.map +0 -1
  54. package/lib/DboBuilder/QueryBuilder/QueryBuilder.js +0 -335
  55. package/lib/DboBuilder/QueryBuilder/makeSelectQuery.d.ts +0 -8
  56. package/lib/DboBuilder/QueryBuilder/makeSelectQuery.d.ts.map +0 -1
  57. package/lib/DboBuilder/QueryBuilder/makeSelectQuery.js +0 -227
  58. package/lib/DboBuilder/TableHandler.d.ts +0 -37
  59. package/lib/DboBuilder/TableHandler.d.ts.map +0 -1
  60. package/lib/DboBuilder/TableHandler.js +0 -213
  61. package/lib/DboBuilder/ViewHandler.d.ts +0 -119
  62. package/lib/DboBuilder/ViewHandler.d.ts.map +0 -1
  63. package/lib/DboBuilder/ViewHandler.js +0 -1023
  64. package/lib/DboBuilder/delete.d.ts +0 -6
  65. package/lib/DboBuilder/delete.d.ts.map +0 -1
  66. package/lib/DboBuilder/delete.js +0 -128
  67. package/lib/DboBuilder/find.d.ts +0 -8
  68. package/lib/DboBuilder/find.d.ts.map +0 -1
  69. package/lib/DboBuilder/find.js +0 -91
  70. package/lib/DboBuilder/getColumns.d.ts +0 -12
  71. package/lib/DboBuilder/getColumns.d.ts.map +0 -1
  72. package/lib/DboBuilder/getColumns.js +0 -92
  73. package/lib/DboBuilder/getCondition.d.ts +0 -22
  74. package/lib/DboBuilder/getCondition.d.ts.map +0 -1
  75. package/lib/DboBuilder/getCondition.js +0 -236
  76. package/lib/DboBuilder/getSubscribeRelatedTables.d.ts +0 -20
  77. package/lib/DboBuilder/getSubscribeRelatedTables.d.ts.map +0 -1
  78. package/lib/DboBuilder/getSubscribeRelatedTables.js +0 -152
  79. package/lib/DboBuilder/getTablesForSchemaPostgresSQL.d.ts +0 -3
  80. package/lib/DboBuilder/getTablesForSchemaPostgresSQL.d.ts.map +0 -1
  81. package/lib/DboBuilder/getTablesForSchemaPostgresSQL.js +0 -207
  82. package/lib/DboBuilder/insert.d.ts +0 -6
  83. package/lib/DboBuilder/insert.d.ts.map +0 -1
  84. package/lib/DboBuilder/insert.js +0 -180
  85. package/lib/DboBuilder/insertDataParse.d.ts +0 -12
  86. package/lib/DboBuilder/insertDataParse.d.ts.map +0 -1
  87. package/lib/DboBuilder/insertDataParse.js +0 -253
  88. package/lib/DboBuilder/parseUpdateRules.d.ts +0 -18
  89. package/lib/DboBuilder/parseUpdateRules.d.ts.map +0 -1
  90. package/lib/DboBuilder/parseUpdateRules.js +0 -123
  91. package/lib/DboBuilder/runSQL.d.ts +0 -7
  92. package/lib/DboBuilder/runSQL.d.ts.map +0 -1
  93. package/lib/DboBuilder/runSQL.js +0 -135
  94. package/lib/DboBuilder/subscribe.d.ts +0 -20
  95. package/lib/DboBuilder/subscribe.d.ts.map +0 -1
  96. package/lib/DboBuilder/subscribe.js +0 -90
  97. package/lib/DboBuilder/update.d.ts +0 -6
  98. package/lib/DboBuilder/update.d.ts.map +0 -1
  99. package/lib/DboBuilder/update.js +0 -151
  100. package/lib/DboBuilder/uploadFile.d.ts +0 -7
  101. package/lib/DboBuilder/uploadFile.d.ts.map +0 -1
  102. package/lib/DboBuilder/uploadFile.js +0 -53
  103. package/lib/DboBuilder.d.ts +0 -306
  104. package/lib/DboBuilder.d.ts.map +0 -1
  105. package/lib/DboBuilder.js +0 -745
  106. package/lib/Event_Trigger_Tags.d.ts +0 -4
  107. package/lib/Event_Trigger_Tags.d.ts.map +0 -1
  108. package/lib/Event_Trigger_Tags.js +0 -116
  109. package/lib/FileManager/FileManager.d.ts +0 -135
  110. package/lib/FileManager/FileManager.d.ts.map +0 -1
  111. package/lib/FileManager/FileManager.js +0 -303
  112. package/lib/FileManager/initFileManager.d.ts +0 -4
  113. package/lib/FileManager/initFileManager.d.ts.map +0 -1
  114. package/lib/FileManager/initFileManager.js +0 -231
  115. package/lib/FileManager/parseFile.d.ts +0 -15
  116. package/lib/FileManager/parseFile.d.ts.map +0 -1
  117. package/lib/FileManager/parseFile.js +0 -58
  118. package/lib/FileManager/upload.d.ts +0 -6
  119. package/lib/FileManager/upload.d.ts.map +0 -1
  120. package/lib/FileManager/upload.js +0 -98
  121. package/lib/FileManager/uploadStream.d.ts +0 -5
  122. package/lib/FileManager/uploadStream.d.ts.map +0 -1
  123. package/lib/FileManager/uploadStream.js +0 -92
  124. package/lib/Filtering.d.ts +0 -15
  125. package/lib/Filtering.d.ts.map +0 -1
  126. package/lib/Filtering.js +0 -336
  127. package/lib/JSONBValidation/validate_jsonb_schema_sql.d.ts +0 -4
  128. package/lib/JSONBValidation/validate_jsonb_schema_sql.d.ts.map +0 -1
  129. package/lib/JSONBValidation/validate_jsonb_schema_sql.js +0 -500
  130. package/lib/JSONBValidation/validation.d.ts +0 -9
  131. package/lib/JSONBValidation/validation.d.ts.map +0 -1
  132. package/lib/JSONBValidation/validation.js +0 -131
  133. package/lib/PostgresNotifListenManager.d.ts +0 -28
  134. package/lib/PostgresNotifListenManager.d.ts.map +0 -1
  135. package/lib/PostgresNotifListenManager.js +0 -134
  136. package/lib/Prostgles.d.ts +0 -289
  137. package/lib/Prostgles.d.ts.map +0 -1
  138. package/lib/Prostgles.js +0 -685
  139. package/lib/PubSubManager/PubSubManager.d.ts +0 -175
  140. package/lib/PubSubManager/PubSubManager.d.ts.map +0 -1
  141. package/lib/PubSubManager/PubSubManager.js +0 -452
  142. package/lib/PubSubManager/addSub.d.ts +0 -8
  143. package/lib/PubSubManager/addSub.d.ts.map +0 -1
  144. package/lib/PubSubManager/addSub.js +0 -166
  145. package/lib/PubSubManager/addSync.d.ts +0 -8
  146. package/lib/PubSubManager/addSync.d.ts.map +0 -1
  147. package/lib/PubSubManager/addSync.js +0 -109
  148. package/lib/PubSubManager/getInitQuery.d.ts +0 -9
  149. package/lib/PubSubManager/getInitQuery.d.ts.map +0 -1
  150. package/lib/PubSubManager/getInitQuery.js +0 -552
  151. package/lib/PubSubManager/initPubSubManager.d.ts +0 -3
  152. package/lib/PubSubManager/initPubSubManager.d.ts.map +0 -1
  153. package/lib/PubSubManager/initPubSubManager.js +0 -116
  154. package/lib/PubSubManager/notifListener.d.ts +0 -5
  155. package/lib/PubSubManager/notifListener.d.ts.map +0 -1
  156. package/lib/PubSubManager/notifListener.js +0 -100
  157. package/lib/PubSubManager/pushSubData.d.ts +0 -3
  158. package/lib/PubSubManager/pushSubData.d.ts.map +0 -1
  159. package/lib/PubSubManager/pushSubData.js +0 -51
  160. package/lib/PublishParser.d.ts +0 -284
  161. package/lib/PublishParser.d.ts.map +0 -1
  162. package/lib/PublishParser.js +0 -421
  163. package/lib/SchemaWatch.d.ts +0 -13
  164. package/lib/SchemaWatch.d.ts.map +0 -1
  165. package/lib/SchemaWatch.js +0 -35
  166. package/lib/SyncReplication.d.ts +0 -34
  167. package/lib/SyncReplication.d.ts.map +0 -1
  168. package/lib/SyncReplication.js +0 -412
  169. package/lib/TableConfig/TableConfig.d.ts +0 -284
  170. package/lib/TableConfig/TableConfig.d.ts.map +0 -1
  171. package/lib/TableConfig/TableConfig.js +0 -437
  172. package/lib/TableConfig/getColumnDefinitionQuery.d.ts +0 -27
  173. package/lib/TableConfig/getColumnDefinitionQuery.d.ts.map +0 -1
  174. package/lib/TableConfig/getColumnDefinitionQuery.js +0 -87
  175. package/lib/TableConfig/getConstraintDefinitionQueries.d.ts +0 -34
  176. package/lib/TableConfig/getConstraintDefinitionQueries.d.ts.map +0 -1
  177. package/lib/TableConfig/getConstraintDefinitionQueries.js +0 -65
  178. package/lib/TableConfig/getFutureTableSchema.d.ts +0 -15
  179. package/lib/TableConfig/getFutureTableSchema.d.ts.map +0 -1
  180. package/lib/TableConfig/getFutureTableSchema.js +0 -43
  181. package/lib/TableConfig/getTableColumnQueries.d.ts +0 -16
  182. package/lib/TableConfig/getTableColumnQueries.d.ts.map +0 -1
  183. package/lib/TableConfig/getTableColumnQueries.js +0 -107
  184. package/lib/index.d.ts +0 -5
  185. package/lib/index.d.ts.map +0 -1
  186. package/lib/index.js +0 -7
  187. package/lib/shortestPath.d.ts +0 -10
  188. package/lib/shortestPath.d.ts.map +0 -1
  189. package/lib/shortestPath.js +0 -111
  190. package/lib/utils.d.ts +0 -3
  191. package/lib/utils.d.ts.map +0 -1
  192. package/lib/utils.js +0 -12
  193. package/tests/client/index.d.ts +0 -2
  194. package/tests/client/index.d.ts.map +0 -1
  195. package/tests/client/index.js +0 -80
  196. package/tests/client/index.js.map +0 -1
  197. package/tests/client_only_queries.d.ts +0 -4
  198. package/tests/client_only_queries.d.ts.map +0 -1
  199. package/tests/client_only_queries.js +0 -282
  200. package/tests/config_test/DBoGenerated.d.ts +0 -388
  201. package/tests/config_test/index.js +0 -174
  202. package/tests/config_test/index.js.map +0 -1
  203. package/tests/isomorphic_queries.d.ts +0 -9
  204. package/tests/isomorphic_queries.d.ts.map +0 -1
  205. package/tests/isomorphic_queries.js +0 -773
  206. package/tests/manual_test/DBoGenerated.d.ts +0 -398
  207. package/tests/manual_test/index.d.ts +0 -2
  208. package/tests/manual_test/index.d.ts.map +0 -1
  209. package/tests/manual_test/index.js +0 -65
  210. package/tests/server/dboTypeCheck.d.ts +0 -2
  211. package/tests/server/dboTypeCheck.d.ts.map +0 -1
  212. package/tests/server/dboTypeCheck.js +0 -27
  213. package/tests/server/index.d.ts +0 -2
  214. package/tests/server/index.d.ts.map +0 -1
  215. package/tests/server/index.js +0 -507
  216. package/tests/server/publishTypeCheck.d.ts +0 -2
  217. package/tests/server/publishTypeCheck.d.ts.map +0 -1
  218. package/tests/server/publishTypeCheck.js +0 -130
  219. package/tests/server_only_queries.d.ts +0 -2
  220. package/tests/server_only_queries.d.ts.map +0 -1
  221. package/tests/server_only_queries.js +0 -19
@@ -1,6 +0,0 @@
1
- import { DeleteParams } from "prostgles-types";
2
- import { Filter, LocalParams } from "../DboBuilder";
3
- import { TableRule } from "../PublishParser";
4
- import { TableHandler } from "./TableHandler";
5
- export declare function _delete(this: TableHandler, filter?: Filter, params?: DeleteParams, param3_unused?: undefined, table_rules?: TableRule, localParams?: LocalParams): Promise<any>;
6
- //# sourceMappingURL=delete.d.ts.map
@@ -1 +0,0 @@
1
- {"version":3,"file":"delete.d.ts","sourceRoot":"","sources":["delete.ts"],"names":[],"mappings":"AACA,OAAO,EAAqB,YAAY,EAAe,MAAM,iBAAiB,CAAC;AAC/E,OAAO,EAAE,MAAM,EAAE,WAAW,EAA2B,MAAM,eAAe,CAAC;AAC7E,OAAO,EAAc,SAAS,EAAE,MAAM,kBAAkB,CAAC;AAEzD,OAAO,EAAE,YAAY,EAAE,MAAM,gBAAgB,CAAC;AAG9C,wBAAsB,OAAO,CAAC,IAAI,EAAE,YAAY,EAAE,MAAM,CAAC,EAAE,MAAM,EAAE,MAAM,CAAC,EAAE,YAAY,EAAE,aAAa,CAAC,EAAE,SAAS,EAAE,WAAW,CAAC,EAAE,SAAS,EAAE,WAAW,CAAC,EAAE,WAAW,GAAG,OAAO,CAAC,GAAG,CAAC,CAiIrL"}
@@ -1,128 +0,0 @@
1
- "use strict";
2
- Object.defineProperty(exports, "__esModule", { value: true });
3
- exports._delete = void 0;
4
- const prostgles_types_1 = require("prostgles-types");
5
- const DboBuilder_1 = require("../DboBuilder");
6
- const PubSubManager_1 = require("../PubSubManager/PubSubManager");
7
- const find_1 = require("./find");
8
- async function _delete(filter, params, param3_unused, table_rules, localParams) {
9
- try {
10
- const { returning } = params || {};
11
- filter = filter || {};
12
- this.checkFilter(filter);
13
- // table_rules = table_rules || {};
14
- let forcedFilter = {}, filterFields = "*", returningFields = "*", validate;
15
- const { testRule = false, returnQuery = false } = localParams || {};
16
- if (table_rules) {
17
- if (!table_rules.delete)
18
- throw "delete rules missing";
19
- forcedFilter = table_rules.delete.forcedFilter;
20
- filterFields = table_rules.delete.filterFields;
21
- returningFields = table_rules.delete.returningFields;
22
- validate = table_rules.delete.validate;
23
- if (!returningFields)
24
- returningFields = table_rules?.select?.fields;
25
- if (!returningFields)
26
- returningFields = table_rules?.delete?.filterFields;
27
- if (!filterFields)
28
- throw ` Invalid delete rule for ${this.name}. filterFields missing `;
29
- /* Safely test publish rules */
30
- if (testRule) {
31
- await this.validateViewRules({ filterFields, returningFields, forcedFilter, rule: "delete" });
32
- return true;
33
- }
34
- }
35
- if (params) {
36
- const good_paramsObj = { returning: 1, returnType: 1 };
37
- const good_params = Object.keys(good_paramsObj);
38
- const bad_params = Object.keys(params).filter(k => !good_params.includes(k));
39
- if (bad_params && bad_params.length)
40
- throw "Invalid params: " + bad_params.join(", ") + " \n Expecting: " + good_params.join(", ");
41
- }
42
- let queryType = 'none';
43
- let _query = "DELETE FROM " + this.escapedName;
44
- const filterOpts = (await this.prepareWhere({
45
- filter,
46
- forcedFilter,
47
- filterFields,
48
- localParams,
49
- tableRule: table_rules
50
- }));
51
- _query += filterOpts.where;
52
- if (validate) {
53
- const _filter = filterOpts.filter;
54
- await validate(_filter);
55
- }
56
- let returningQuery = "";
57
- if (returning) {
58
- queryType = "any";
59
- if (!returningFields) {
60
- throw "Returning dissallowed";
61
- }
62
- returningQuery = this.makeReturnQuery(await this.prepareReturning(returning, this.parseFieldFilter(returningFields)));
63
- _query += returningQuery;
64
- }
65
- _query = (0, DboBuilder_1.withUserRLS)(localParams, _query);
66
- if (returnQuery)
67
- return _query;
68
- /**
69
- * Delete file
70
- */
71
- const dbHandler = (this.t || this.db);
72
- if (this.is_media) {
73
- if (!this.dboBuilder.prostgles.fileManager)
74
- throw new Error("fileManager missing");
75
- if (this.dboBuilder.prostgles.opts.fileTable?.delayedDelete) {
76
- return dbHandler[queryType](`UPDATE ${(0, prostgles_types_1.asName)(this.name)} SET deleted = now() ${filterOpts.where} ${returningQuery};`);
77
- }
78
- else {
79
- const txDelete = async (tbl) => {
80
- if (!tbl.t)
81
- throw new Error("Missing transaction object t");
82
- let files = [];
83
- const totalFiles = await tbl.count(filterOpts.filter);
84
- do {
85
- const batch = await tbl.find(filterOpts.filter, { limit: 100, offset: files.length });
86
- files = files.concat(batch);
87
- } while (files.length < totalFiles);
88
- const fileManager = tbl.dboBuilder.prostgles.fileManager;
89
- if (!fileManager)
90
- throw new Error("fileManager missing");
91
- for await (const file of files) {
92
- await tbl.t?.any(`DELETE FROM ${(0, prostgles_types_1.asName)(this.name)} WHERE id = ` + "${id}", file);
93
- }
94
- /** If any table delete fails then do not delete files */
95
- for await (const file of files) {
96
- await fileManager.deleteFile(file.name);
97
- /** TODO: Keep track of deleted files in case of failure */
98
- // await tbl.t?.any(`UPDATE ${asName(this.name)} SET deleted = NOW(), deleted_from_storage = NOW() WHERE id = ` + "${id}", file);
99
- }
100
- if (returning) {
101
- return files.map(f => (0, PubSubManager_1.pickKeys)(f, ["id", "name"]));
102
- }
103
- return undefined;
104
- };
105
- if (localParams?.tx?.dbTX) {
106
- return txDelete(localParams.tx.dbTX[this.name]);
107
- }
108
- else if (this.t) {
109
- return txDelete(this);
110
- }
111
- else {
112
- return this.dboBuilder.getTX(tx => {
113
- return txDelete(tx[this.name]);
114
- });
115
- }
116
- }
117
- }
118
- return (0, find_1.runQueryReturnType)(_query, params?.returnType, this, localParams);
119
- // return dbHandler[queryType](_query).catch((err: any) => makeErrorFromPGError(err, localParams));
120
- }
121
- catch (e) {
122
- // console.trace(e)
123
- if (localParams && localParams.testRule)
124
- throw e;
125
- throw (0, DboBuilder_1.parseError)(e, `dbo.${this.name}.delete(${JSON.stringify(filter || {}, null, 2)}, ${JSON.stringify(params || {}, null, 2)})`);
126
- }
127
- }
128
- exports._delete = _delete;
@@ -1,8 +0,0 @@
1
- import { SelectParams } from "prostgles-types";
2
- import { Filter, LocalParams } from "../DboBuilder";
3
- import { TableRule } from "../PublishParser";
4
- import { TableHandler } from "./TableHandler";
5
- import { ViewHandler } from "./ViewHandler";
6
- export declare const find: (this: ViewHandler, filter?: Filter, selectParams?: SelectParams, param3_unused?: undefined, tableRules?: TableRule, localParams?: LocalParams) => Promise<any[]>;
7
- export declare const runQueryReturnType: (query: string, returnType: SelectParams["returnType"], handler: ViewHandler | TableHandler, localParams: LocalParams | undefined) => Promise<any>;
8
- //# sourceMappingURL=find.d.ts.map
@@ -1 +0,0 @@
1
- {"version":3,"file":"find.d.ts","sourceRoot":"","sources":["find.ts"],"names":[],"mappings":"AACA,OAAO,EAAE,YAAY,EAAY,MAAM,iBAAiB,CAAC;AACzD,OAAO,EAAE,MAAM,EAAE,WAAW,EAAiD,MAAM,eAAe,CAAC;AAGnG,OAAO,EAAE,SAAS,EAAE,MAAM,kBAAkB,CAAC;AAC7C,OAAO,EAAE,YAAY,EAAE,MAAM,gBAAgB,CAAC;AAE9C,OAAO,EAAE,WAAW,EAAE,MAAM,eAAe,CAAC;AAE5C,eAAO,MAAM,IAAI,SAAwB,WAAW,WAAW,MAAM,iBAAiB,YAAY,kBAAkB,SAAS,eAAe,SAAS,gBAAgB,WAAW,KAAG,QAAQ,GAAG,EAAE,CA2D/L,CAAA;AAGD,eAAO,MAAM,kBAAkB,UAAiB,MAAM,cAAc,YAAY,CAAC,YAAY,CAAC,WAAW,WAAW,GAAG,YAAY,eAAe,WAAW,GAAG,SAAS,iBAoBxK,CAAA"}
@@ -1,91 +0,0 @@
1
- "use strict";
2
- Object.defineProperty(exports, "__esModule", { value: true });
3
- exports.runQueryReturnType = exports.find = void 0;
4
- const prostgles_types_1 = require("prostgles-types");
5
- const DboBuilder_1 = require("../DboBuilder");
6
- const makeSelectQuery_1 = require("../DboBuilder/QueryBuilder/makeSelectQuery");
7
- const runSQL_1 = require("../DboBuilder/runSQL");
8
- const QueryBuilder_1 = require("./QueryBuilder/QueryBuilder");
9
- const find = async function (filter, selectParams, param3_unused, tableRules, localParams) {
10
- try {
11
- filter = filter || {};
12
- const allowedReturnTypes = ["row", "value", "values", "statement"];
13
- const { returnType } = selectParams || {};
14
- if (returnType && !allowedReturnTypes.includes(returnType)) {
15
- throw `returnType (${returnType}) can only be ${allowedReturnTypes.join(" OR ")}`;
16
- }
17
- const { testRule = false, returnQuery = false, returnNewQuery } = localParams || {};
18
- if (testRule)
19
- return [];
20
- if (selectParams) {
21
- const good_params = ["select", "orderBy", "offset", "limit", "returnType", "groupBy"];
22
- const bad_params = Object.keys(selectParams).filter(k => !good_params.includes(k));
23
- if (bad_params && bad_params.length)
24
- throw "Invalid params: " + bad_params.join(", ") + " \n Expecting: " + good_params.join(", ");
25
- }
26
- /* Validate publish */
27
- if (tableRules) {
28
- if (!tableRules.select)
29
- throw "select rules missing for " + this.name;
30
- const fields = tableRules.select.fields;
31
- const maxLimit = tableRules.select.maxLimit;
32
- if (tableRules.select !== "*" && typeof tableRules.select !== "boolean" && !(0, prostgles_types_1.isObject)(tableRules.select))
33
- throw `\nINVALID publish.${this.name}.select\nExpecting any of: "*" | { fields: "*" } | true | false`;
34
- if (!fields)
35
- throw ` invalid ${this.name}.select rule -> fields (required) setting missing.\nExpecting any of: "*" | { col_name: false } | { col1: true, col2: true }`;
36
- if (maxLimit && !Number.isInteger(maxLimit))
37
- throw ` invalid publish.${this.name}.select.maxLimit -> expecting integer but got ` + maxLimit;
38
- }
39
- const q = await (0, QueryBuilder_1.getNewQuery)(this, filter, selectParams, param3_unused, tableRules, localParams, this.columns);
40
- const queryWithoutRLS = (0, makeSelectQuery_1.makeSelectQuery)(this, q, undefined, undefined, selectParams);
41
- const queryWithRLS = (0, DboBuilder_1.withUserRLS)(localParams, queryWithoutRLS);
42
- // console.log(_query, JSON.stringify(q, null, 2))
43
- if (testRule) {
44
- try {
45
- await this.db.any((0, DboBuilder_1.withUserRLS)(localParams, "EXPLAIN " + queryWithRLS));
46
- return [];
47
- }
48
- catch (e) {
49
- console.error(e);
50
- throw `INTERNAL ERROR: Publish config is not valid for publish.${this.name}.select `;
51
- }
52
- }
53
- /** Used for subscribe */
54
- if (returnNewQuery)
55
- return q;
56
- if (returnQuery) {
57
- return (returnQuery === "noRLS" ? queryWithoutRLS : queryWithRLS);
58
- }
59
- return (0, exports.runQueryReturnType)(queryWithRLS, returnType, this, localParams);
60
- }
61
- catch (e) {
62
- // console.trace(e)
63
- if (localParams && localParams.testRule)
64
- throw e;
65
- throw (0, DboBuilder_1.parseError)(e, `dbo.${this.name}.find()`);
66
- // throw { err: parseError(e), msg: `Issue with dbo.${this.name}.find()`, args: { filter, selectParams} };
67
- }
68
- };
69
- exports.find = find;
70
- const runQueryReturnType = async (query, returnType, handler, localParams) => {
71
- if (returnType === "statement") {
72
- if (!(await (0, runSQL_1.canRunSQL)(handler.dboBuilder.prostgles, localParams))) {
73
- throw `Not allowed: {returnType: "statement"} requires sql privileges `;
74
- }
75
- return query;
76
- }
77
- else if (["row", "value"].includes(returnType)) {
78
- return (handler.t || handler.db).oneOrNone(query).then(data => {
79
- return (data && returnType === "value") ? Object.values(data)[0] : data;
80
- }).catch(err => (0, DboBuilder_1.makeErrorFromPGError)(err, localParams, this));
81
- }
82
- else {
83
- return (handler.t || handler.db).any(query).then(data => {
84
- if (returnType === "values") {
85
- return data.map(d => Object.values(d)[0]);
86
- }
87
- return data;
88
- }).catch(err => (0, DboBuilder_1.makeErrorFromPGError)(err, localParams, this));
89
- }
90
- };
91
- exports.runQueryReturnType = runQueryReturnType;
@@ -1,12 +0,0 @@
1
- import { AnyObject, ValidatedColumnInfo } from "prostgles-types";
2
- import { LocalParams } from "../DboBuilder";
3
- import { TableRule } from "../PublishParser";
4
- import { TableHandler } from "./TableHandler";
5
- import { ViewHandler } from "./ViewHandler";
6
- export declare const isTableHandler: (v: any) => v is TableHandler;
7
- export declare function getColumns(this: ViewHandler, lang?: string, params?: {
8
- rule: "update";
9
- filter: AnyObject;
10
- data: AnyObject;
11
- }, _param3?: undefined, tableRules?: TableRule, localParams?: LocalParams): Promise<ValidatedColumnInfo[]>;
12
- //# sourceMappingURL=getColumns.d.ts.map
@@ -1 +0,0 @@
1
- {"version":3,"file":"getColumns.d.ts","sourceRoot":"","sources":["getColumns.ts"],"names":[],"mappings":"AAAA,OAAO,EACL,SAAS,EACT,mBAAmB,EACpB,MAAM,iBAAiB,CAAC;AACzB,OAAO,EAAiB,WAAW,EAAgC,MAAM,eAAe,CAAC;AACzF,OAAO,EAAE,SAAS,EAAE,MAAM,kBAAkB,CAAC;AAC7C,OAAO,EAAE,YAAY,EAAE,MAAM,gBAAgB,CAAC;AAC9C,OAAO,EAAE,WAAW,EAAE,MAAM,eAAe,CAAC;AAE5C,eAAO,MAAM,cAAc,MAAO,GAAG,sBAA+C,CAAC;AAErF,wBAAsB,UAAU,CAC9B,IAAI,EAAE,WAAW,EACjB,IAAI,CAAC,EAAE,MAAM,EACb,MAAM,CAAC,EAAE;IAAE,IAAI,EAAE,QAAQ,CAAC;IAAC,MAAM,EAAE,SAAS,CAAC;IAAC,IAAI,EAAE,SAAS,CAAA;CAAE,EAC/D,OAAO,CAAC,EAAE,SAAS,EACnB,UAAU,CAAC,EAAE,SAAS,EACtB,WAAW,CAAC,EAAE,WAAW,GACxB,OAAO,CAAC,mBAAmB,EAAE,CAAC,CAmGhC"}
@@ -1,92 +0,0 @@
1
- "use strict";
2
- Object.defineProperty(exports, "__esModule", { value: true });
3
- exports.getColumns = exports.isTableHandler = void 0;
4
- const prostgles_types_1 = require("prostgles-types");
5
- const DboBuilder_1 = require("../DboBuilder");
6
- const isTableHandler = (v) => "parseUpdateRules" in v;
7
- exports.isTableHandler = isTableHandler;
8
- async function getColumns(lang, params, _param3, tableRules, localParams) {
9
- try {
10
- const p = this.getValidatedRules(tableRules, localParams);
11
- if (!p.getColumns)
12
- throw "Not allowed";
13
- // console.log("getColumns", this.name, this.columns.map(c => c.name))
14
- let dynamicUpdateFields = this.column_names;
15
- if (params && tableRules && (0, exports.isTableHandler)(this)) {
16
- if (!(0, DboBuilder_1.isPlainObject)(params) ||
17
- (params.data && !(0, DboBuilder_1.isPlainObject)(params.data)) ||
18
- !(0, DboBuilder_1.isPlainObject)(params.filter) ||
19
- params.rule !== "update") {
20
- throw "params must be { rule: 'update', filter: object, data?: object } but got: " + JSON.stringify(params);
21
- }
22
- if (!tableRules?.update) {
23
- dynamicUpdateFields = [];
24
- }
25
- else {
26
- const { data, filter } = params;
27
- const updateRules = await this.parseUpdateRules(filter, data, undefined, tableRules, localParams);
28
- dynamicUpdateFields = updateRules.fields;
29
- }
30
- }
31
- const columns = this.columns
32
- .filter(c => {
33
- const { insert, select, update } = p || {};
34
- return [
35
- ...(insert?.fields || []),
36
- ...(select?.fields || []),
37
- ...(update?.fields || []),
38
- ].includes(c.name);
39
- })
40
- .map(_c => {
41
- const c = { ..._c };
42
- const label = c.comment || capitalizeFirstLetter(c.name, " ");
43
- const select = c.privileges.some(p => p.privilege_type === "SELECT"), insert = c.privileges.some(p => p.privilege_type === "INSERT"), _delete = this.tableOrViewInfo.privileges.delete; // c.privileges.some(p => p.privilege_type === "DELETE");
44
- let update = c.privileges.some(p => p.privilege_type === "UPDATE");
45
- delete c.privileges;
46
- const prostgles = this.dboBuilder?.prostgles;
47
- const fileConfig = prostgles.fileManager?.getColInfo({ colName: c.name, tableName: this.name });
48
- /** Do not allow updates to file table unless it's to delete fields */
49
- if (prostgles.fileManager?.config && prostgles.fileManager.tableName === this.name) {
50
- update = false;
51
- }
52
- const nonOrderableUD_Types = [...prostgles_types_1._PG_geometric, "xml"];
53
- const result = {
54
- ...c,
55
- label,
56
- tsDataType: (0, DboBuilder_1.postgresToTsType)(c.udt_name),
57
- insert: insert && Boolean(p.insert?.fields?.includes(c.name)) && tableRules?.insert?.forcedData?.[c.name] === undefined && c.is_updatable,
58
- select: select && Boolean(p.select?.fields?.includes(c.name)),
59
- orderBy: select && Boolean(p.select?.fields && p.select.orderByFields.includes(c.name)) && !nonOrderableUD_Types.includes(c.udt_name),
60
- filter: Boolean(p.select?.filterFields?.includes(c.name)),
61
- update: update && Boolean(p.update?.fields?.includes(c.name)) && tableRules?.update?.forcedData?.[c.name] === undefined && c.is_updatable && dynamicUpdateFields.includes(c.name),
62
- delete: _delete && Boolean(p.delete && p.delete.filterFields && p.delete.filterFields.includes(c.name)),
63
- ...(prostgles?.tableConfigurator?.getColInfo({ table: this.name, col: c.name, lang }) || {}),
64
- ...(fileConfig && { file: fileConfig })
65
- };
66
- return result;
67
- }).filter(c => c.select || c.update || c.delete || c.insert);
68
- //.sort((a, b) => a.ordinal_position - b.ordinal_position);
69
- // const tblInfo = await this.getInfo();
70
- // if(tblInfo && tblInfo.media_table_name && tblInfo.has_media){
71
- // const mediaRules = this.dboBuilder.dbo[tblInfo.media_table_name]?.
72
- // return columns.concat({
73
- // comment: "",
74
- // data_type: "file",
75
- // delete: false,
76
- // });
77
- // }
78
- return columns;
79
- }
80
- catch (e) {
81
- throw (0, DboBuilder_1.parseError)(e, `db.${this.name}.getColumns()`);
82
- // throw "Something went wrong in " + `db.${this.name}.getColumns()`;
83
- }
84
- }
85
- exports.getColumns = getColumns;
86
- function replaceNonAlphaNumeric(string, replacement = "_") {
87
- return string.replace(/[\W_]+/g, replacement);
88
- }
89
- function capitalizeFirstLetter(string, nonalpha_replacement) {
90
- const str = replaceNonAlphaNumeric(string, nonalpha_replacement);
91
- return str.charAt(0).toUpperCase() + str.slice(1);
92
- }
@@ -1,22 +0,0 @@
1
- import { ExistsFilterConfig, LocalParams } from "../DboBuilder";
2
- import { TableRule } from "../PublishParser";
3
- import { SelectItem } from "./QueryBuilder/QueryBuilder";
4
- import { ViewHandler } from "./ViewHandler";
5
- /**
6
- * parses a single filter
7
- * @example
8
- * { fff: 2 } => "fff" = 2
9
- * { fff: { $ilike: 'abc' } } => "fff" ilike 'abc'
10
- */
11
- export declare function getCondition(this: ViewHandler, params: {
12
- filter: any;
13
- select?: SelectItem[];
14
- allowed_colnames: string[];
15
- tableAlias?: string;
16
- localParams?: LocalParams;
17
- tableRules?: TableRule;
18
- }): Promise<{
19
- exists: ExistsFilterConfig[];
20
- condition: string;
21
- }>;
22
- //# sourceMappingURL=getCondition.d.ts.map
@@ -1 +0,0 @@
1
- {"version":3,"file":"getCondition.d.ts","sourceRoot":"","sources":["getCondition.ts"],"names":[],"mappings":"AACA,OAAO,EAAE,kBAAkB,EAAE,WAAW,EAAO,MAAM,eAAe,CAAC;AACrE,OAAO,EAAE,SAAS,EAAE,MAAM,kBAAkB,CAAC;AAG7C,OAAO,EAAoC,UAAU,EAAE,MAAM,6BAA6B,CAAC;AAC3F,OAAO,EAAE,WAAW,EAAE,MAAM,eAAe,CAAC;AAM5C;;;;;GAKG;AACH,wBAAsB,YAAY,CAChC,IAAI,EAAE,WAAW,EACjB,MAAM,EAAE;IACN,MAAM,EAAE,GAAG,CAAC;IACZ,MAAM,CAAC,EAAE,UAAU,EAAE,CAAC;IACtB,gBAAgB,EAAE,MAAM,EAAE,CAAC;IAC3B,UAAU,CAAC,EAAE,MAAM,CAAC;IACpB,WAAW,CAAC,EAAE,WAAW,CAAC;IAC1B,UAAU,CAAC,EAAE,SAAS,CAAA;CACvB,GACA,OAAO,CAAC;IAAE,MAAM,EAAE,kBAAkB,EAAE,CAAC;IAAC,SAAS,EAAE,MAAM,CAAA;CAAE,CAAC,CAuQ9D"}
@@ -1,236 +0,0 @@
1
- "use strict";
2
- Object.defineProperty(exports, "__esModule", { value: true });
3
- exports.getCondition = void 0;
4
- const prostgles_types_1 = require("prostgles-types");
5
- const DboBuilder_1 = require("../DboBuilder");
6
- const PubSubManager_1 = require("../PubSubManager/PubSubManager");
7
- const Functions_1 = require("./QueryBuilder/Functions");
8
- const QueryBuilder_1 = require("./QueryBuilder/QueryBuilder");
9
- const Filtering_1 = require("../Filtering");
10
- const FILTER_FUNCS = Functions_1.FUNCTIONS.filter(f => f.canBeUsedForFilter);
11
- /**
12
- * parses a single filter
13
- * @example
14
- * { fff: 2 } => "fff" = 2
15
- * { fff: { $ilike: 'abc' } } => "fff" ilike 'abc'
16
- */
17
- async function getCondition(params) {
18
- const { filter: rawFilter, select, allowed_colnames, tableAlias, localParams, tableRules } = params;
19
- const filter = { ...rawFilter };
20
- /* Exists join filter */
21
- const ERR = "Invalid exists filter. \nExpecting somethibng like: \n | { $exists: { tableName.tableName2: Filter } } \n | { $exists: { \"**.tableName3\": Filter } }\n | { path: string[]; filter: AnyObject }";
22
- const SP_WILDCARD = "**";
23
- const exists = (0, prostgles_types_1.getKeys)(filter)
24
- .filter((k) => prostgles_types_1.EXISTS_KEYS.includes(k) && !!Object.keys(filter[k] ?? {}).length)
25
- .map(key => {
26
- const isJoined = key.toLowerCase().includes("join");
27
- const filterValue = filter[key];
28
- /**
29
- * type ExistsJoined =
30
- * | { "table1.table2": { column: filterValue } }
31
- * | { path: string[]; filter: AnyObject }
32
- */
33
- const dataKeys = Object.keys(filterValue);
34
- const isDetailed = dataKeys.length === 2 && dataKeys.every(key => ["path", "filter"].includes(key));
35
- const firstKey = dataKeys[0];
36
- /**
37
- * Prevent some errors with table names that contain "."
38
- */
39
- const firstKeyIsATable = !!this.dboBuilder.dbo[firstKey];
40
- let tables = isDetailed ? filterValue.path : (firstKeyIsATable ? [firstKey] : firstKey.split("."));
41
- const f2 = isDetailed ? filterValue.filter : filterValue[firstKey];
42
- let shortestJoin = false;
43
- if (!isJoined) {
44
- if (tables.length !== 1)
45
- throw "Expecting single table in exists filter. Example: { $exists: { tableName: Filter } }";
46
- }
47
- else {
48
- /* First part can be the ** param meaning shortest join. Will be overriden by anything in tableConfig */
49
- if (!tables.length) {
50
- throw ERR + "\nBut got: " + filterValue;
51
- }
52
- if (tables[0] === SP_WILDCARD) {
53
- tables = tables.slice(1);
54
- shortestJoin = true;
55
- }
56
- }
57
- return {
58
- key,
59
- existType: key,
60
- isJoined,
61
- shortestJoin,
62
- f2,
63
- tables
64
- };
65
- });
66
- /* Exists with exact path */
67
- // Object.keys(data).map(k => {
68
- // let isthis = isPlainObject(data[k]) && !this.column_names.includes(k) && !k.split(".").find(kt => !this.dboBuilder.dbo[kt]);
69
- // if(isthis) {
70
- // existsKeys.push({
71
- // key: k,
72
- // notJoined: false,
73
- // exactPaths: k.split(".")
74
- // });
75
- // }
76
- // });
77
- const funcConds = [];
78
- const funcFilter = FILTER_FUNCS.filter(f => f.name in filter);
79
- funcFilter.map(f => {
80
- const funcArgs = filter[f.name];
81
- if (!Array.isArray(funcArgs)) {
82
- throw `A function filter must contain an array. E.g: { $funcFilterName: ["col1"] } \n but got: ${JSON.stringify((0, prostgles_types_1.pickKeys)(filter, [f.name]))} `;
83
- }
84
- const fields = this.parseFieldFilter(f.getFields(funcArgs), true, allowed_colnames);
85
- const dissallowedCols = fields.filter(fname => !allowed_colnames.includes(fname));
86
- if (dissallowedCols.length) {
87
- throw `Invalid/disallowed columns found in function filter: ${dissallowedCols}`;
88
- }
89
- funcConds.push(f.getQuery({ args: funcArgs, allColumns: this.columns, allowedFields: allowed_colnames, tableAlias }));
90
- });
91
- let existsCond = "";
92
- if (exists.length) {
93
- existsCond = (await Promise.all(exists.map(async (k) => await this.prepareExistCondition(k, localParams)))).join(" AND ");
94
- }
95
- /* Computed field queries */
96
- const p = this.getValidatedRules(tableRules, localParams);
97
- const computedFields = p.allColumns.filter(c => c.type === "computed");
98
- const computedColConditions = [];
99
- Object.keys(filter || {}).map(key => {
100
- const compCol = computedFields.find(cf => cf.name === key);
101
- if (compCol) {
102
- computedColConditions.push(compCol.getQuery({
103
- tableAlias,
104
- allowedFields: p.select.fields,
105
- allColumns: this.columns,
106
- /* CTID not available in AFTER trigger */
107
- // ctidField: this.is_view? undefined : "ctid"
108
- ctidField: undefined,
109
- }) + ` = ${DboBuilder_1.pgp.as.format("$1", [filter[key]])}`);
110
- delete filter[key];
111
- }
112
- });
113
- let allowedSelect = [];
114
- /* Select aliases take precedence over col names. This is to ensure filters work correctly and even on computed cols*/
115
- if (select) {
116
- /* Allow filtering by selected fields/funcs */
117
- allowedSelect = select.filter(s => {
118
- /* */
119
- if (["function", "computed", "column"].includes(s.type)) {
120
- if (s.type !== "column" || allowed_colnames.includes(s.alias)) {
121
- return true;
122
- }
123
- }
124
- return false;
125
- });
126
- }
127
- /* Add remaining allowed fields */
128
- allowedSelect = allowedSelect.concat(p.allColumns.filter(c => allowed_colnames.includes(c.name) &&
129
- !allowedSelect.find(s => s.alias === c.name)).map(f => ({
130
- type: f.type,
131
- alias: f.name,
132
- getQuery: (tableAlias) => f.getQuery({
133
- tableAlias,
134
- allColumns: this.columns,
135
- allowedFields: allowed_colnames
136
- }),
137
- selected: false,
138
- getFields: () => [f.name],
139
- column_udt_type: f.type === "column" ? this.columns.find(c => c.name === f.name)?.udt_name : undefined
140
- })));
141
- /* Parse complex filters
142
- {
143
- $filter: [
144
- { $func: [...] },
145
- "=",
146
- value | { $func: [..] }
147
- ]
148
- }
149
- */
150
- const complexFilters = [];
151
- const complexFilterKey = "$filter";
152
- const allowedComparators = [">", "<", "=", "<=", ">=", "<>", "!="];
153
- if (complexFilterKey in filter) {
154
- /**
155
- * { $funcName: [arg1, arg2] }
156
- * { $column: "column_name" }
157
- */
158
- const getFuncQuery = (funcData) => {
159
- if ((0, prostgles_types_1.isObject)(funcData) && "$column" in funcData) {
160
- const column = funcData["$column"];
161
- if (typeof column !== "string") {
162
- throw `expecting: \n { $column: "column_name" } received:\n ${JSON.stringify(funcData)}`;
163
- }
164
- if (!allowed_colnames.includes(column)) {
165
- throw `Dissallowed or Invalid column ${column}. Allowed columns: ${allowed_colnames}`;
166
- }
167
- return (0, QueryBuilder_1.asNameAlias)(column, tableAlias);
168
- }
169
- const { funcName, args } = (0, QueryBuilder_1.parseFunctionObject)(funcData);
170
- const funcDef = (0, Functions_1.parseFunction)({ func: funcName, args, functions: Functions_1.FUNCTIONS, allowedFields: allowed_colnames });
171
- return funcDef.getQuery({ args, tableAlias, allColumns: this.columns, allowedFields: allowed_colnames });
172
- };
173
- const complexFilter = filter[complexFilterKey];
174
- if (!Array.isArray(complexFilter)) {
175
- throw `Invalid $filter. Must contain an array of at least element but got: ${JSON.stringify(complexFilter)} `;
176
- }
177
- const [leftFilter, comparator, rightFilterOrValue] = complexFilter;
178
- const leftVal = getFuncQuery(leftFilter);
179
- let result = leftVal;
180
- if (comparator) {
181
- if (!allowedComparators.includes(comparator)) {
182
- throw `Invalid $filter. comparator ${JSON.stringify(comparator)} is not valid. Expecting one of: ${allowedComparators}`;
183
- }
184
- if (!rightFilterOrValue) {
185
- throw "Invalid $filter. Expecting a value or function after the comparator";
186
- }
187
- const rightVal = (0, prostgles_types_1.isObject)(rightFilterOrValue) ? getFuncQuery(rightFilterOrValue) : (0, PubSubManager_1.asValue)(rightFilterOrValue);
188
- if (leftVal === rightVal) {
189
- throw "Invalid $filter. Cannot compare two identical function signatures: " + JSON.stringify(leftFilter);
190
- }
191
- result += ` ${comparator} ${rightVal}`;
192
- }
193
- complexFilters.push(result);
194
- }
195
- /* Parse join filters
196
- { $joinFilter: { $ST_DWithin: [table.col, foreignTable.col, distance] }
197
- will make an exists filter
198
- */
199
- const filterKeys = Object.keys(filter).filter(k => k !== complexFilterKey && !funcFilter.find(ek => ek.name === k) && !computedFields.find(cf => cf.name === k) && !exists.find(ek => ek.key === k));
200
- // if(allowed_colnames){
201
- // const aliasedColumns = (select || []).filter(s =>
202
- // ["function", "computed", "column"].includes(s.type) && allowed_colnames.includes(s.alias) ||
203
- // s.getFields().find(f => allowed_colnames.includes(f))
204
- // ).map(s => s.alias);
205
- // const validCols = [...allowed_colnames, ...aliasedColumns];
206
- // }
207
- const validFieldNames = allowedSelect.map(s => s.alias);
208
- const invalidColumn = filterKeys
209
- .find(fName => !validFieldNames.find(c => c === fName ||
210
- (fName.startsWith(c) && (fName.slice(c.length).includes("->") ||
211
- fName.slice(c.length).includes(".")))));
212
- if (invalidColumn) {
213
- throw `Table: ${this.name} -> disallowed/inexistent columns in filter: ${invalidColumn} \n Expecting one of: ${allowedSelect.map(s => s.type === "column" ? s.getQuery() : s.alias).join(", ")}`;
214
- }
215
- /* TODO: Allow filter funcs */
216
- // const singleFuncs = FUNCTIONS.filter(f => f.singleColArg);
217
- const f = (0, prostgles_types_1.pickKeys)(filter, filterKeys);
218
- const q = (0, Filtering_1.parseFilterItem)({
219
- filter: f,
220
- tableAlias,
221
- pgp: DboBuilder_1.pgp,
222
- select: allowedSelect
223
- });
224
- let templates = [q].filter(q => q);
225
- if (existsCond)
226
- templates.push(existsCond);
227
- templates = templates.concat(funcConds);
228
- templates = templates.concat(computedColConditions);
229
- templates = templates.concat(complexFilters);
230
- /* sorted to ensure duplicate subscription channels are not created due to different condition order */
231
- return {
232
- exists,
233
- condition: templates.sort().join(" AND \n")
234
- };
235
- }
236
- exports.getCondition = getCondition;
@@ -1,20 +0,0 @@
1
- import { AnyObject, SubscribeParams } from "prostgles-types";
2
- import { ExistsFilterConfig, Filter, LocalParams } from "../DboBuilder";
3
- import { TableRule } from "../PublishParser";
4
- import { ViewSubscriptionOptions } from "../PubSubManager/PubSubManager";
5
- import { ViewHandler } from "./ViewHandler";
6
- type Args = {
7
- selectParams: Omit<SubscribeParams, "throttle">;
8
- filter: Filter;
9
- table_rules: TableRule<AnyObject, void> | undefined;
10
- localParams: LocalParams | undefined;
11
- condition: string;
12
- filterOpts: {
13
- where: string;
14
- filter: AnyObject;
15
- exists: ExistsFilterConfig[];
16
- };
17
- };
18
- export declare function getSubscribeRelatedTables(this: ViewHandler, { selectParams, filter, localParams, table_rules, condition, filterOpts }: Args): Promise<ViewSubscriptionOptions>;
19
- export {};
20
- //# sourceMappingURL=getSubscribeRelatedTables.d.ts.map
@@ -1 +0,0 @@
1
- {"version":3,"file":"getSubscribeRelatedTables.d.ts","sourceRoot":"","sources":["getSubscribeRelatedTables.ts"],"names":[],"mappings":"AAAA,OAAO,EAAE,SAAS,EAAU,eAAe,EAAE,MAAM,iBAAiB,CAAC;AACrE,OAAO,EAAE,kBAAkB,EAAE,MAAM,EAAE,WAAW,EAAwB,MAAM,eAAe,CAAC;AAC9F,OAAO,EAAE,SAAS,EAAE,MAAM,kBAAkB,CAAC;AAC7C,OAAO,EAAO,uBAAuB,EAAE,MAAM,gCAAgC,CAAC;AAE9E,OAAO,EAAE,WAAW,EAAE,MAAM,eAAe,CAAC;AAE5C,KAAK,IAAI,GAAG;IACV,YAAY,EAAE,IAAI,CAAC,eAAe,EAAE,UAAU,CAAC,CAAC;IAChD,MAAM,EAAE,MAAM,CAAC;IACf,WAAW,EAAE,SAAS,CAAC,SAAS,EAAE,IAAI,CAAC,GAAG,SAAS,CAAC;IACpD,WAAW,EAAE,WAAW,GAAG,SAAS,CAAC;IACrC,SAAS,EAAE,MAAM,CAAC;IAClB,UAAU,EAAE;QACV,KAAK,EAAE,MAAM,CAAC;QACd,MAAM,EAAE,SAAS,CAAC;QAClB,MAAM,EAAE,kBAAkB,EAAE,CAAC;KAC9B,CAAC;CACH,CAAA;AACD,wBAAsB,yBAAyB,CAAC,IAAI,EAAE,WAAW,EAAE,EAAE,YAAY,EAAE,MAAM,EAAE,WAAW,EAAE,WAAW,EAAE,SAAS,EAAE,UAAU,EAAE,EAAE,IAAI,oCAmKjJ"}