prostgles-server 2.0.173 → 2.0.176
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.
- package/.vscode/settings.json +3 -0
- package/dist/AuthHandler.d.ts +13 -12
- package/dist/AuthHandler.d.ts.map +1 -1
- package/dist/AuthHandler.js +5 -2
- package/dist/AuthHandler.js.map +1 -1
- package/dist/DBSchemaBuilder.d.ts +11 -0
- package/dist/DBSchemaBuilder.d.ts.map +1 -0
- package/dist/DBSchemaBuilder.js +56 -0
- package/dist/DBSchemaBuilder.js.map +1 -0
- package/dist/DboBuilder.d.ts +23 -22
- package/dist/DboBuilder.d.ts.map +1 -1
- package/dist/DboBuilder.js +36 -61
- package/dist/DboBuilder.js.map +1 -1
- package/dist/FileManager.d.ts +2 -2
- package/dist/FileManager.d.ts.map +1 -1
- package/dist/Filtering.d.ts.map +1 -1
- package/dist/Filtering.js.map +1 -1
- package/dist/Prostgles.d.ts +25 -257
- package/dist/Prostgles.d.ts.map +1 -1
- package/dist/Prostgles.js +12 -376
- package/dist/Prostgles.js.map +1 -1
- package/dist/PubSubManager.d.ts +6 -5
- package/dist/PubSubManager.d.ts.map +1 -1
- package/dist/PubSubManager.js.map +1 -1
- package/dist/PublishParser.d.ts +262 -0
- package/dist/PublishParser.d.ts.map +1 -0
- package/dist/PublishParser.js +391 -0
- package/dist/PublishParser.js.map +1 -0
- package/dist/QueryBuilder.d.ts +20 -4
- package/dist/QueryBuilder.d.ts.map +1 -1
- package/dist/QueryBuilder.js.map +1 -1
- package/dist/TableConfig.d.ts +6 -3
- package/dist/TableConfig.d.ts.map +1 -1
- package/dist/TableConfig.js +28 -1
- package/dist/TableConfig.js.map +1 -1
- package/dist/index.d.ts +3 -3
- package/dist/index.d.ts.map +1 -1
- package/dist/index.js +4 -0
- package/dist/index.js.map +1 -1
- package/lib/AuthHandler.ts +25 -19
- package/lib/DBSchemaBuilder.ts +91 -0
- package/lib/DboBuilder.ts +84 -98
- package/lib/FileManager.ts +2 -2
- package/lib/Filtering.ts +3 -3
- package/lib/Prostgles.ts +33 -704
- package/lib/PubSubManager.ts +6 -5
- package/lib/PublishParser.ts +723 -0
- package/lib/QueryBuilder.ts +6 -5
- package/lib/TableConfig.ts +36 -5
- package/lib/index.ts +4 -4
- package/package.json +2 -2
- package/tests/client/PID.txt +1 -1
- package/tests/client/index.js +2 -2
- package/tests/client/index.ts +2 -2
- package/tests/client/package-lock.json +15 -15
- package/tests/client/package.json +1 -1
- package/tests/client_only_queries.js +24 -1
- package/tests/client_only_queries.ts +23 -1
- package/tests/isomorphic_queries.js +3 -0
- package/tests/isomorphic_queries.ts +5 -2
- package/tests/server/DBoGenerated.d.ts +428 -286
- package/tests/server/index.js +1 -14
- package/tests/server/index.ts +5 -19
- package/tests/server/package-lock.json +3 -3
|
@@ -0,0 +1,391 @@
|
|
|
1
|
+
"use strict";
|
|
2
|
+
Object.defineProperty(exports, "__esModule", { value: true });
|
|
3
|
+
exports.PublishParser = void 0;
|
|
4
|
+
const prostgles_types_1 = require("prostgles-types");
|
|
5
|
+
const DboBuilder_1 = require("./DboBuilder");
|
|
6
|
+
const Prostgles_1 = require("./Prostgles");
|
|
7
|
+
const RULE_TO_METHODS = [
|
|
8
|
+
{
|
|
9
|
+
rule: "getColumns",
|
|
10
|
+
sqlRule: "select",
|
|
11
|
+
methods: prostgles_types_1.RULE_METHODS.getColumns,
|
|
12
|
+
no_limits: true,
|
|
13
|
+
allowed_params: [],
|
|
14
|
+
table_only: false,
|
|
15
|
+
hint: ` expecting false | true | undefined`
|
|
16
|
+
},
|
|
17
|
+
{
|
|
18
|
+
rule: "getInfo",
|
|
19
|
+
sqlRule: "select",
|
|
20
|
+
methods: prostgles_types_1.RULE_METHODS.getInfo,
|
|
21
|
+
no_limits: true,
|
|
22
|
+
allowed_params: [],
|
|
23
|
+
table_only: false,
|
|
24
|
+
hint: ` expecting false | true | undefined`
|
|
25
|
+
},
|
|
26
|
+
{
|
|
27
|
+
rule: "insert",
|
|
28
|
+
sqlRule: "insert",
|
|
29
|
+
methods: prostgles_types_1.RULE_METHODS.insert,
|
|
30
|
+
no_limits: { fields: "*" },
|
|
31
|
+
table_only: true,
|
|
32
|
+
allowed_params: ["fields", "forcedData", "returningFields", "validate", "preValidate"],
|
|
33
|
+
hint: ` expecting "*" | true | { fields: string | string[] | {} }`
|
|
34
|
+
},
|
|
35
|
+
{
|
|
36
|
+
rule: "update",
|
|
37
|
+
sqlRule: "update",
|
|
38
|
+
methods: prostgles_types_1.RULE_METHODS.update,
|
|
39
|
+
no_limits: { fields: "*", filterFields: "*", returningFields: "*" },
|
|
40
|
+
table_only: true,
|
|
41
|
+
allowed_params: ["fields", "filterFields", "forcedFilter", "forcedData", "returningFields", "validate", "dynamicFields"],
|
|
42
|
+
hint: ` expecting "*" | true | { fields: string | string[] | {} }`
|
|
43
|
+
},
|
|
44
|
+
{
|
|
45
|
+
rule: "select",
|
|
46
|
+
sqlRule: "select",
|
|
47
|
+
methods: prostgles_types_1.RULE_METHODS.select,
|
|
48
|
+
no_limits: { fields: "*", filterFields: "*" },
|
|
49
|
+
table_only: false,
|
|
50
|
+
allowed_params: ["fields", "filterFields", "forcedFilter", "validate", "maxLimit"],
|
|
51
|
+
hint: ` expecting "*" | true | { fields: ( string | string[] | {} ) }`
|
|
52
|
+
},
|
|
53
|
+
{
|
|
54
|
+
rule: "delete",
|
|
55
|
+
sqlRule: "delete",
|
|
56
|
+
methods: prostgles_types_1.RULE_METHODS.delete,
|
|
57
|
+
no_limits: { filterFields: "*" },
|
|
58
|
+
table_only: true,
|
|
59
|
+
allowed_params: ["filterFields", "forcedFilter", "returningFields", "validate"],
|
|
60
|
+
hint: ` expecting "*" | true | { filterFields: ( string | string[] | {} ) } \n Will use "select", "update", "delete" and "insert" rules`
|
|
61
|
+
},
|
|
62
|
+
{
|
|
63
|
+
rule: "sync",
|
|
64
|
+
sqlRule: "select",
|
|
65
|
+
methods: prostgles_types_1.RULE_METHODS.sync,
|
|
66
|
+
no_limits: null,
|
|
67
|
+
table_only: true,
|
|
68
|
+
allowed_params: ["id_fields", "synced_field", "sync_type", "allow_delete", "throttle", "batch_size"],
|
|
69
|
+
hint: ` expecting "*" | true | { id_fields: string[], synced_field: string }`
|
|
70
|
+
},
|
|
71
|
+
{
|
|
72
|
+
rule: "subscribe",
|
|
73
|
+
sqlRule: "select",
|
|
74
|
+
methods: prostgles_types_1.RULE_METHODS.subscribe,
|
|
75
|
+
no_limits: { throttle: 0 },
|
|
76
|
+
table_only: true,
|
|
77
|
+
allowed_params: ["throttle"],
|
|
78
|
+
hint: ` expecting "*" | true | { throttle: number } \n Will use "select" rules`
|
|
79
|
+
}
|
|
80
|
+
];
|
|
81
|
+
const PubSubManager_1 = require("./PubSubManager");
|
|
82
|
+
class PublishParser {
|
|
83
|
+
constructor(publish, publishMethods, publishRawSQL, dbo, db, prostgles) {
|
|
84
|
+
this.publish = publish;
|
|
85
|
+
this.publishMethods = publishMethods;
|
|
86
|
+
this.publishRawSQL = publishRawSQL;
|
|
87
|
+
this.dbo = dbo;
|
|
88
|
+
this.db = db;
|
|
89
|
+
this.prostgles = prostgles;
|
|
90
|
+
if (!this.dbo || !this.publish)
|
|
91
|
+
throw "INTERNAL ERROR: dbo and/or publish missing";
|
|
92
|
+
}
|
|
93
|
+
async getPublishParams(localParams, clientInfo) {
|
|
94
|
+
if (!this.dbo)
|
|
95
|
+
throw "dbo missing";
|
|
96
|
+
return {
|
|
97
|
+
...(clientInfo || await this.prostgles.authHandler?.getClientInfo(localParams)),
|
|
98
|
+
dbo: this.dbo,
|
|
99
|
+
db: this.db,
|
|
100
|
+
socket: localParams.socket
|
|
101
|
+
};
|
|
102
|
+
}
|
|
103
|
+
async getMethods(socket) {
|
|
104
|
+
let methods = {};
|
|
105
|
+
const publishParams = await this.getPublishParams({ socket });
|
|
106
|
+
const _methods = await applyParamsIfFunc(this.publishMethods, publishParams);
|
|
107
|
+
if (_methods && Object.keys(_methods).length) {
|
|
108
|
+
(0, prostgles_types_1.getKeys)(_methods).map(key => {
|
|
109
|
+
if (_methods[key] && (typeof _methods[key] === "function" || typeof _methods[key].then === "function")) {
|
|
110
|
+
//@ts-ignore
|
|
111
|
+
methods[key] = _methods[key];
|
|
112
|
+
}
|
|
113
|
+
else {
|
|
114
|
+
throw `invalid publishMethods item -> ${key} \n Expecting a function or promise`;
|
|
115
|
+
}
|
|
116
|
+
});
|
|
117
|
+
}
|
|
118
|
+
return methods;
|
|
119
|
+
}
|
|
120
|
+
/**
|
|
121
|
+
* Parses the first level of publish. (If false then nothing if * then all tables and views)
|
|
122
|
+
* @param socket
|
|
123
|
+
* @param user
|
|
124
|
+
*/
|
|
125
|
+
async getPublish(localParams, clientInfo) {
|
|
126
|
+
const publishParams = await this.getPublishParams(localParams, clientInfo);
|
|
127
|
+
let _publish = await applyParamsIfFunc(this.publish, publishParams);
|
|
128
|
+
if (_publish === "*") {
|
|
129
|
+
let publish = {};
|
|
130
|
+
this.prostgles.dboBuilder.tablesOrViews?.map(tov => {
|
|
131
|
+
publish[tov.name] = "*";
|
|
132
|
+
});
|
|
133
|
+
return publish;
|
|
134
|
+
}
|
|
135
|
+
return _publish;
|
|
136
|
+
}
|
|
137
|
+
async getValidatedRequestRuleWusr({ tableName, command, localParams }) {
|
|
138
|
+
const clientInfo = await this.prostgles.authHandler.getClientInfo(localParams);
|
|
139
|
+
return await this.getValidatedRequestRule({ tableName, command, localParams }, clientInfo);
|
|
140
|
+
}
|
|
141
|
+
async getValidatedRequestRule({ tableName, command, localParams }, clientInfo) {
|
|
142
|
+
if (!this.dbo)
|
|
143
|
+
throw "INTERNAL ERROR: dbo is missing";
|
|
144
|
+
if (!command || !tableName)
|
|
145
|
+
throw "command OR tableName are missing";
|
|
146
|
+
let rtm = RULE_TO_METHODS.find(rtms => rtms.methods.includes(command));
|
|
147
|
+
if (!rtm) {
|
|
148
|
+
throw "Invalid command: " + command;
|
|
149
|
+
}
|
|
150
|
+
/* Must be local request -> allow everything */
|
|
151
|
+
if (!localParams || (!localParams.socket && !localParams.httpReq)) {
|
|
152
|
+
return RULE_TO_METHODS.reduce((a, v) => ({
|
|
153
|
+
...a,
|
|
154
|
+
[v.rule]: v.no_limits
|
|
155
|
+
}), {});
|
|
156
|
+
}
|
|
157
|
+
/* Must be from socket. Must have a publish */
|
|
158
|
+
if (!this.publish)
|
|
159
|
+
throw "publish is missing";
|
|
160
|
+
/* Get any publish errors for socket */
|
|
161
|
+
const schm = localParams?.socket?.prostgles?.schema?.[tableName]?.[command];
|
|
162
|
+
if (schm && schm.err)
|
|
163
|
+
throw schm.err;
|
|
164
|
+
let table_rule = await this.getTableRules({ tableName, localParams }, clientInfo);
|
|
165
|
+
if (!table_rule)
|
|
166
|
+
throw "Invalid or disallowed table: " + tableName;
|
|
167
|
+
if (command === "upsert") {
|
|
168
|
+
if (!table_rule.update || !table_rule.insert) {
|
|
169
|
+
throw `Invalid or disallowed command: upsert`;
|
|
170
|
+
}
|
|
171
|
+
}
|
|
172
|
+
if (rtm && table_rule && table_rule[rtm.rule]) {
|
|
173
|
+
return table_rule;
|
|
174
|
+
}
|
|
175
|
+
else
|
|
176
|
+
throw `Invalid or disallowed command: ${tableName}.${command}`;
|
|
177
|
+
}
|
|
178
|
+
async getTableRules({ tableName, localParams }, clientInfo) {
|
|
179
|
+
try {
|
|
180
|
+
if (!localParams || !tableName)
|
|
181
|
+
throw "publish OR socket OR dbo OR tableName are missing";
|
|
182
|
+
let _publish = await this.getPublish(localParams, clientInfo);
|
|
183
|
+
const raw_table_rules = _publish[tableName]; // applyParamsIfFunc(_publish[tableName], localParams, this.dbo, this.db, user);
|
|
184
|
+
if (!raw_table_rules)
|
|
185
|
+
return undefined;
|
|
186
|
+
let parsed_table = {};
|
|
187
|
+
/* Get view or table specific rules */
|
|
188
|
+
const tHandler = this.dbo[tableName];
|
|
189
|
+
if (!tHandler)
|
|
190
|
+
throw `${tableName} could not be found in dbo`;
|
|
191
|
+
const is_view = tHandler.is_view;
|
|
192
|
+
const MY_RULES = RULE_TO_METHODS.filter(r => {
|
|
193
|
+
/** Check PG User privileges */
|
|
194
|
+
const pgUserIsAllowedThis = tHandler.tableOrViewInfo.privileges[r.sqlRule];
|
|
195
|
+
const result = (!is_view || !r.table_only) && pgUserIsAllowedThis;
|
|
196
|
+
if (!pgUserIsAllowedThis && (0, DboBuilder_1.isPlainObject)(raw_table_rules) && raw_table_rules[r.sqlRule]) {
|
|
197
|
+
throw `Your postgres user is not allowed ${r.sqlRule} on table ${tableName}`;
|
|
198
|
+
}
|
|
199
|
+
return result;
|
|
200
|
+
});
|
|
201
|
+
/* All methods allowed. Add no limits for table rules */
|
|
202
|
+
if ([true, "*"].includes(raw_table_rules)) {
|
|
203
|
+
parsed_table = {};
|
|
204
|
+
MY_RULES.map(r => {
|
|
205
|
+
parsed_table[r.rule] = { ...r.no_limits };
|
|
206
|
+
});
|
|
207
|
+
/** Specific rules allowed */
|
|
208
|
+
}
|
|
209
|
+
else if ((0, DboBuilder_1.isPlainObject)(raw_table_rules) && (0, prostgles_types_1.getKeys)(raw_table_rules).length) {
|
|
210
|
+
const allRuleKeys = (0, prostgles_types_1.getKeys)(raw_table_rules);
|
|
211
|
+
const dissallowedRuleKeys = allRuleKeys.filter(m => !raw_table_rules[m]);
|
|
212
|
+
MY_RULES.map(r => {
|
|
213
|
+
/** Unless specifically disabled these are allowed */
|
|
214
|
+
if (["getInfo", "getColumns"].includes(r.rule) && !dissallowedRuleKeys.includes(r.rule)) {
|
|
215
|
+
parsed_table[r.rule] = r.no_limits;
|
|
216
|
+
return;
|
|
217
|
+
}
|
|
218
|
+
/** Add no_limit values for implied/ fully allowed methods */
|
|
219
|
+
if ([true, "*"].includes(raw_table_rules[r.rule]) && r.no_limits) {
|
|
220
|
+
parsed_table[r.rule] = Object.assign({}, r.no_limits);
|
|
221
|
+
/** Carry over detailed config */
|
|
222
|
+
}
|
|
223
|
+
else if ((0, DboBuilder_1.isPlainObject)(raw_table_rules[r.rule])) {
|
|
224
|
+
parsed_table[r.rule] = raw_table_rules[r.rule];
|
|
225
|
+
}
|
|
226
|
+
});
|
|
227
|
+
allRuleKeys.filter(m => parsed_table[m])
|
|
228
|
+
.find((method) => {
|
|
229
|
+
let rm = MY_RULES.find(r => r.rule === method || r.methods.includes(method));
|
|
230
|
+
if (!rm) {
|
|
231
|
+
let extraInfo = "";
|
|
232
|
+
if (is_view && RULE_TO_METHODS.find(r => !is_view && r.rule === method || r.methods.includes(method))) {
|
|
233
|
+
extraInfo = "You've specified table rules to a view\n";
|
|
234
|
+
}
|
|
235
|
+
throw `Invalid rule in publish.${tableName} -> ${method} \n${extraInfo}Expecting any of: ${MY_RULES.flatMap(r => [r.rule, ...r.methods]).join(", ")}`;
|
|
236
|
+
}
|
|
237
|
+
/* Check RULES for invalid params */
|
|
238
|
+
/* Methods do not have params -> They use them from rules */
|
|
239
|
+
if (method === rm.rule) {
|
|
240
|
+
let method_params = (0, prostgles_types_1.getKeys)(parsed_table[method]);
|
|
241
|
+
let iparam = method_params.find(p => !rm?.allowed_params.includes(p));
|
|
242
|
+
if (iparam) {
|
|
243
|
+
throw `Invalid setting in publish.${tableName}.${method} -> ${iparam}. \n Expecting any of: ${rm.allowed_params.join(", ")}`;
|
|
244
|
+
}
|
|
245
|
+
}
|
|
246
|
+
/* Add default params (if missing) */
|
|
247
|
+
if (method === "sync") {
|
|
248
|
+
if ([true, "*"].includes(parsed_table[method])) {
|
|
249
|
+
throw "Invalid sync rule. Expecting { id_fields: string[], synced_field: string } ";
|
|
250
|
+
}
|
|
251
|
+
if (typeof parsed_table[method]?.throttle !== "number") {
|
|
252
|
+
parsed_table[method].throttle = 100;
|
|
253
|
+
}
|
|
254
|
+
if (typeof parsed_table[method]?.batch_size !== "number") {
|
|
255
|
+
parsed_table[method].batch_size = PubSubManager_1.DEFAULT_SYNC_BATCH_SIZE;
|
|
256
|
+
}
|
|
257
|
+
}
|
|
258
|
+
/* Enable subscribe if not explicitly disabled */
|
|
259
|
+
const subKey = "subscribe";
|
|
260
|
+
if (method === "select" && !dissallowedRuleKeys.includes(subKey)) {
|
|
261
|
+
const sr = MY_RULES.find(r => r.rule === subKey);
|
|
262
|
+
if (sr) {
|
|
263
|
+
parsed_table[subKey] = { ...sr.no_limits };
|
|
264
|
+
parsed_table.subscribeOne = { ...sr.no_limits };
|
|
265
|
+
}
|
|
266
|
+
}
|
|
267
|
+
});
|
|
268
|
+
}
|
|
269
|
+
else {
|
|
270
|
+
throw "Unexpected publish";
|
|
271
|
+
}
|
|
272
|
+
const getImpliedMethods = (tableRules) => {
|
|
273
|
+
let res = { ...tableRules };
|
|
274
|
+
/* Add implied methods if not specifically dissallowed */
|
|
275
|
+
MY_RULES.map(r => {
|
|
276
|
+
/** THIS IS A MESS -> some methods cannot be dissallowed (unsync, unsubscribe...) */
|
|
277
|
+
r.methods.forEach(method => {
|
|
278
|
+
var _a;
|
|
279
|
+
const isAllowed = tableRules[r.rule] && tableRules[method] === undefined;
|
|
280
|
+
if (isAllowed) {
|
|
281
|
+
if (method === "updateBatch" && !tableRules.update) {
|
|
282
|
+
}
|
|
283
|
+
else if (method === "upsert" && (!tableRules.update || !tableRules.insert)) {
|
|
284
|
+
}
|
|
285
|
+
else {
|
|
286
|
+
(_a = res)[method] ?? (_a[method] = true);
|
|
287
|
+
}
|
|
288
|
+
}
|
|
289
|
+
});
|
|
290
|
+
});
|
|
291
|
+
return res;
|
|
292
|
+
};
|
|
293
|
+
parsed_table = getImpliedMethods(parsed_table);
|
|
294
|
+
return parsed_table;
|
|
295
|
+
}
|
|
296
|
+
catch (e) {
|
|
297
|
+
throw e;
|
|
298
|
+
}
|
|
299
|
+
}
|
|
300
|
+
/* Prepares schema for client. Only allowed views and commands will be present */
|
|
301
|
+
async getSchemaFromPublish(socket) {
|
|
302
|
+
let schema = {};
|
|
303
|
+
let tables = [];
|
|
304
|
+
try {
|
|
305
|
+
/* Publish tables and views based on socket */
|
|
306
|
+
const clientInfo = await this.prostgles.authHandler?.getClientInfo({ socket });
|
|
307
|
+
let _publish = await this.getPublish(socket, clientInfo);
|
|
308
|
+
if (_publish && Object.keys(_publish).length) {
|
|
309
|
+
let txKey = "tx";
|
|
310
|
+
if (!this.prostgles.opts.transactions)
|
|
311
|
+
txKey = "";
|
|
312
|
+
if (typeof this.prostgles.opts.transactions === "string")
|
|
313
|
+
txKey = this.prostgles.opts.transactions;
|
|
314
|
+
const tableNames = Object.keys(_publish).filter(k => !txKey || txKey !== k);
|
|
315
|
+
await Promise.all(tableNames
|
|
316
|
+
.map(async (tableName) => {
|
|
317
|
+
if (!this.dbo[tableName]) {
|
|
318
|
+
throw `Table ${tableName} does not exist
|
|
319
|
+
Expecting one of: ${this.prostgles.dboBuilder.tablesOrViews?.map(tov => tov.name).join(", ")}
|
|
320
|
+
DBO tables: ${Object.keys(this.dbo).filter(k => this.dbo[k].find).join(", ")}
|
|
321
|
+
`;
|
|
322
|
+
}
|
|
323
|
+
const table_rules = await this.getTableRules({ localParams: { socket }, tableName }, clientInfo);
|
|
324
|
+
if (table_rules && Object.keys(table_rules).length) {
|
|
325
|
+
schema[tableName] = {};
|
|
326
|
+
let methods = [];
|
|
327
|
+
let tableInfo;
|
|
328
|
+
let tableColumns;
|
|
329
|
+
if (typeof table_rules === "object") {
|
|
330
|
+
methods = (0, prostgles_types_1.getKeys)(table_rules);
|
|
331
|
+
}
|
|
332
|
+
await Promise.all(methods.filter(m => m !== "select").map(async (method) => {
|
|
333
|
+
if (method === "sync" && table_rules[method]) {
|
|
334
|
+
/* Pass sync info */
|
|
335
|
+
schema[tableName][method] = table_rules[method];
|
|
336
|
+
}
|
|
337
|
+
else if (table_rules[method]) {
|
|
338
|
+
schema[tableName][method] = {};
|
|
339
|
+
/* Test for issues with the common table CRUD methods () */
|
|
340
|
+
if (Prostgles_1.TABLE_METHODS.includes(method)) {
|
|
341
|
+
let err = null;
|
|
342
|
+
try {
|
|
343
|
+
let valid_table_command_rules = await this.getValidatedRequestRule({ tableName, command: method, localParams: { socket } }, clientInfo);
|
|
344
|
+
await this.dbo[tableName][method]({}, {}, {}, valid_table_command_rules, { socket, has_rules: true, testRule: true });
|
|
345
|
+
}
|
|
346
|
+
catch (e) {
|
|
347
|
+
err = "INTERNAL PUBLISH ERROR";
|
|
348
|
+
schema[tableName][method] = { err };
|
|
349
|
+
throw `publish.${tableName}.${method}: \n -> ${e}`;
|
|
350
|
+
}
|
|
351
|
+
}
|
|
352
|
+
if (method === "getInfo" || method === "getColumns") {
|
|
353
|
+
let tableRules = await this.getValidatedRequestRule({ tableName, command: method, localParams: { socket } }, clientInfo);
|
|
354
|
+
const res = await this.dbo[tableName][method](undefined, undefined, undefined, tableRules, { socket, has_rules: true });
|
|
355
|
+
if (method === "getInfo") {
|
|
356
|
+
tableInfo = res;
|
|
357
|
+
}
|
|
358
|
+
else if (method === "getColumns") {
|
|
359
|
+
tableColumns = res;
|
|
360
|
+
}
|
|
361
|
+
}
|
|
362
|
+
}
|
|
363
|
+
}));
|
|
364
|
+
if (tableInfo && tableColumns) {
|
|
365
|
+
tables.push({
|
|
366
|
+
name: tableName,
|
|
367
|
+
info: tableInfo,
|
|
368
|
+
columns: tableColumns
|
|
369
|
+
});
|
|
370
|
+
}
|
|
371
|
+
}
|
|
372
|
+
return true;
|
|
373
|
+
}));
|
|
374
|
+
}
|
|
375
|
+
}
|
|
376
|
+
catch (e) {
|
|
377
|
+
console.error("Prostgles \nERRORS IN PUBLISH: ", JSON.stringify(e));
|
|
378
|
+
throw e;
|
|
379
|
+
}
|
|
380
|
+
return { schema, tables };
|
|
381
|
+
}
|
|
382
|
+
}
|
|
383
|
+
exports.PublishParser = PublishParser;
|
|
384
|
+
function applyParamsIfFunc(maybeFunc, ...params) {
|
|
385
|
+
if ((maybeFunc !== null && maybeFunc !== undefined) &&
|
|
386
|
+
(typeof maybeFunc === "function" || typeof maybeFunc.then === "function")) {
|
|
387
|
+
return maybeFunc(...params);
|
|
388
|
+
}
|
|
389
|
+
return maybeFunc;
|
|
390
|
+
}
|
|
391
|
+
//# sourceMappingURL=PublishParser.js.map
|
|
@@ -0,0 +1 @@
|
|
|
1
|
+
{"version":3,"file":"PublishParser.js","sourceRoot":"","sources":["../lib/PublishParser.ts"],"names":[],"mappings":"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"}
|
package/dist/QueryBuilder.d.ts
CHANGED
|
@@ -1,6 +1,6 @@
|
|
|
1
1
|
import { Filter, LocalParams, TableHandler } from "./DboBuilder";
|
|
2
|
-
import { TableRule } from "./
|
|
3
|
-
import {
|
|
2
|
+
import { TableRule } from "./PublishParser";
|
|
3
|
+
import { SelectParams, ColumnInfo, PG_COLUMN_UDT_DATA_TYPE, Select } from "prostgles-types";
|
|
4
4
|
export declare type SelectItem = {
|
|
5
5
|
type: "column" | "function" | "aggregation" | "joinedColumn" | "computed";
|
|
6
6
|
getFields: (args?: any[]) => string[] | "*";
|
|
@@ -114,9 +114,25 @@ export declare class SelectItemBuilder {
|
|
|
114
114
|
private addItem;
|
|
115
115
|
private addFunction;
|
|
116
116
|
addColumn: (fieldName: string, selected: boolean) => void;
|
|
117
|
-
parseUserSelect: (userSelect:
|
|
117
|
+
parseUserSelect: (userSelect: Select, joinParse?: ((key: string, val: any, throwErr: (msg: string) => any) => any) | undefined) => Promise<never[] | undefined>;
|
|
118
118
|
}
|
|
119
|
-
export declare function getNewQuery(_this: TableHandler, filter: Filter, selectParams: (
|
|
119
|
+
export declare function getNewQuery(_this: TableHandler, filter: Filter, selectParams: ({
|
|
120
|
+
limit?: number | undefined;
|
|
121
|
+
offset?: number | undefined;
|
|
122
|
+
groupBy?: boolean | undefined;
|
|
123
|
+
returnType?: "values" | "row" | "value" | undefined;
|
|
124
|
+
} & {
|
|
125
|
+
select?: import("prostgles-types").AnyObject | ("" | "*") | {
|
|
126
|
+
[key: string]: string | true | 1 | Record<string, any[]>;
|
|
127
|
+
} | {
|
|
128
|
+
[x: string]: string | true | 1 | Record<string, any[]>;
|
|
129
|
+
} | {
|
|
130
|
+
[x: string]: false | 0;
|
|
131
|
+
} | {
|
|
132
|
+
[x: string]: false | 0;
|
|
133
|
+
} | undefined;
|
|
134
|
+
orderBy?: import("prostgles-types").OrderBy<any> | undefined;
|
|
135
|
+
} & {
|
|
120
136
|
alias?: string | undefined;
|
|
121
137
|
}) | undefined, param3_unused: null | undefined, tableRules: TableRule | undefined, localParams: LocalParams | undefined, columns: ColumnInfo[]): Promise<NewQuery>;
|
|
122
138
|
export declare function makeQuery(_this: TableHandler, q: NewQuery, depth?: number, joinFields?: string[], selectParams?: SelectParams): string;
|
|
@@ -1 +1 @@
|
|
|
1
|
-
{"version":3,"file":"QueryBuilder.d.ts","sourceRoot":"","sources":["../lib/QueryBuilder.ts"],"names":[],"mappings":"AAMA,OAAO,EAAO,MAAM,EAAE,WAAW,EAAiB,YAAY,EAAiC,MAAM,cAAc,CAAC;AACpH,OAAO,EAAE,SAAS,EAAE,MAAM,
|
|
1
|
+
{"version":3,"file":"QueryBuilder.d.ts","sourceRoot":"","sources":["../lib/QueryBuilder.ts"],"names":[],"mappings":"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"}
|