prostgles-server 4.2.183 → 4.2.185
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/.github/workflows/main.yml +15 -15
- package/.prettierignore +2 -0
- package/README.md +1 -1
- package/dist/Auth/AuthHandler.d.ts +1 -1
- package/dist/Auth/AuthHandler.d.ts.map +1 -1
- package/dist/Auth/AuthHandler.js +64 -32
- package/dist/Auth/AuthHandler.js.map +1 -1
- package/dist/Auth/AuthTypes.d.ts +15 -1
- package/dist/Auth/AuthTypes.d.ts.map +1 -1
- package/dist/Auth/getSafeReturnURL.d.ts.map +1 -1
- package/dist/Auth/getSafeReturnURL.js.map +1 -1
- package/dist/Auth/sendEmail.d.ts.map +1 -1
- package/dist/Auth/sendEmail.js +6 -6
- package/dist/Auth/sendEmail.js.map +1 -1
- package/dist/Auth/setAuthProviders.d.ts +1 -1
- package/dist/Auth/setAuthProviders.d.ts.map +1 -1
- package/dist/Auth/setAuthProviders.js +15 -8
- package/dist/Auth/setAuthProviders.js.map +1 -1
- package/dist/Auth/setEmailProvider.d.ts.map +1 -1
- package/dist/Auth/setEmailProvider.js +23 -4
- package/dist/Auth/setEmailProvider.js.map +1 -1
- package/dist/Auth/setupAuthRoutes.d.ts.map +1 -1
- package/dist/Auth/setupAuthRoutes.js +27 -9
- package/dist/Auth/setupAuthRoutes.js.map +1 -1
- package/dist/DBEventsManager.d.ts.map +1 -1
- package/dist/DBEventsManager.js +24 -19
- package/dist/DBEventsManager.js.map +1 -1
- package/dist/DBSchemaBuilder.d.ts.map +1 -1
- package/dist/DBSchemaBuilder.js +18 -5
- package/dist/DBSchemaBuilder.js.map +1 -1
- package/dist/DboBuilder/DboBuilder.d.ts.map +1 -1
- package/dist/DboBuilder/DboBuilder.js +7 -2
- package/dist/DboBuilder/DboBuilder.js.map +1 -1
- package/dist/DboBuilder/DboBuilderTypes.d.ts +4 -4
- package/dist/DboBuilder/DboBuilderTypes.d.ts.map +1 -1
- package/dist/DboBuilder/DboBuilderTypes.js.map +1 -1
- package/dist/DboBuilder/QueryBuilder/Functions.d.ts +2 -2
- package/dist/DboBuilder/QueryBuilder/Functions.d.ts.map +1 -1
- package/dist/DboBuilder/QueryBuilder/Functions.js +293 -173
- package/dist/DboBuilder/QueryBuilder/Functions.js.map +1 -1
- package/dist/DboBuilder/QueryBuilder/QueryBuilder.d.ts +2 -2
- package/dist/DboBuilder/QueryBuilder/QueryBuilder.d.ts.map +1 -1
- package/dist/DboBuilder/QueryBuilder/QueryBuilder.js +52 -29
- package/dist/DboBuilder/QueryBuilder/QueryBuilder.js.map +1 -1
- package/dist/DboBuilder/QueryBuilder/getJoinQuery.d.ts.map +1 -1
- package/dist/DboBuilder/QueryBuilder/getJoinQuery.js +51 -32
- package/dist/DboBuilder/QueryBuilder/getJoinQuery.js.map +1 -1
- package/dist/DboBuilder/QueryBuilder/getNewQuery.d.ts.map +1 -1
- package/dist/DboBuilder/QueryBuilder/getNewQuery.js +48 -25
- package/dist/DboBuilder/QueryBuilder/getNewQuery.js.map +1 -1
- package/dist/DboBuilder/QueryBuilder/getSelectQuery.d.ts +1 -1
- package/dist/DboBuilder/QueryBuilder/getSelectQuery.d.ts.map +1 -1
- package/dist/DboBuilder/QueryBuilder/getSelectQuery.js +32 -23
- package/dist/DboBuilder/QueryBuilder/getSelectQuery.js.map +1 -1
- package/dist/DboBuilder/QueryStreamer.d.ts +2 -2
- package/dist/DboBuilder/QueryStreamer.d.ts.map +1 -1
- package/dist/DboBuilder/QueryStreamer.js +68 -23
- package/dist/DboBuilder/QueryStreamer.js.map +1 -1
- package/dist/DboBuilder/TableHandler/DataValidator.d.ts +1 -1
- package/dist/DboBuilder/TableHandler/DataValidator.d.ts.map +1 -1
- package/dist/DboBuilder/TableHandler/DataValidator.js +79 -43
- package/dist/DboBuilder/TableHandler/DataValidator.js.map +1 -1
- package/dist/DboBuilder/TableHandler/TableHandler.d.ts.map +1 -1
- package/dist/DboBuilder/TableHandler/TableHandler.js +39 -15
- package/dist/DboBuilder/TableHandler/TableHandler.js.map +1 -1
- package/dist/DboBuilder/TableHandler/delete.d.ts.map +1 -1
- package/dist/DboBuilder/TableHandler/delete.js +44 -13
- package/dist/DboBuilder/TableHandler/delete.js.map +1 -1
- package/dist/DboBuilder/TableHandler/insert.d.ts.map +1 -1
- package/dist/DboBuilder/TableHandler/insert.js +81 -22
- package/dist/DboBuilder/TableHandler/insert.js.map +1 -1
- package/dist/DboBuilder/TableHandler/insertTest.d.ts.map +1 -1
- package/dist/DboBuilder/TableHandler/insertTest.js.map +1 -1
- package/dist/DboBuilder/TableHandler/onDeleteFromFileTable.d.ts +1 -1
- package/dist/DboBuilder/TableHandler/onDeleteFromFileTable.d.ts.map +1 -1
- package/dist/DboBuilder/TableHandler/onDeleteFromFileTable.js +7 -4
- package/dist/DboBuilder/TableHandler/onDeleteFromFileTable.js.map +1 -1
- package/dist/DboBuilder/TableHandler/runInsertUpdateQuery.d.ts.map +1 -1
- package/dist/DboBuilder/TableHandler/runInsertUpdateQuery.js +24 -5
- package/dist/DboBuilder/TableHandler/runInsertUpdateQuery.js.map +1 -1
- package/dist/DboBuilder/TableHandler/update.d.ts.map +1 -1
- package/dist/DboBuilder/TableHandler/update.js +16 -4
- package/dist/DboBuilder/TableHandler/update.js.map +1 -1
- package/dist/DboBuilder/TableHandler/updateBatch.d.ts.map +1 -1
- package/dist/DboBuilder/TableHandler/updateBatch.js +33 -10
- package/dist/DboBuilder/TableHandler/updateBatch.js.map +1 -1
- package/dist/DboBuilder/TableHandler/updateFile.d.ts.map +1 -1
- package/dist/DboBuilder/TableHandler/updateFile.js +24 -6
- package/dist/DboBuilder/TableHandler/updateFile.js.map +1 -1
- package/dist/DboBuilder/TableHandler/upsert.d.ts.map +1 -1
- package/dist/DboBuilder/TableHandler/upsert.js +22 -6
- package/dist/DboBuilder/TableHandler/upsert.js.map +1 -1
- package/dist/DboBuilder/ViewHandler/ViewHandler.d.ts +5 -5
- package/dist/DboBuilder/ViewHandler/ViewHandler.d.ts.map +1 -1
- package/dist/DboBuilder/ViewHandler/ViewHandler.js +64 -36
- package/dist/DboBuilder/ViewHandler/ViewHandler.js.map +1 -1
- package/dist/DboBuilder/ViewHandler/count.d.ts.map +1 -1
- package/dist/DboBuilder/ViewHandler/count.js +21 -7
- package/dist/DboBuilder/ViewHandler/count.js.map +1 -1
- package/dist/DboBuilder/ViewHandler/find.d.ts.map +1 -1
- package/dist/DboBuilder/ViewHandler/find.js +76 -22
- package/dist/DboBuilder/ViewHandler/find.js.map +1 -1
- package/dist/DboBuilder/ViewHandler/getExistsCondition.d.ts.map +1 -1
- package/dist/DboBuilder/ViewHandler/getExistsCondition.js +19 -10
- package/dist/DboBuilder/ViewHandler/getExistsCondition.js.map +1 -1
- package/dist/DboBuilder/ViewHandler/getExistsFilters.d.ts.map +1 -1
- package/dist/DboBuilder/ViewHandler/getExistsFilters.js +12 -5
- package/dist/DboBuilder/ViewHandler/getExistsFilters.js.map +1 -1
- package/dist/DboBuilder/ViewHandler/getInfo.d.ts.map +1 -1
- package/dist/DboBuilder/ViewHandler/getInfo.js +27 -9
- package/dist/DboBuilder/ViewHandler/getInfo.js.map +1 -1
- package/dist/DboBuilder/ViewHandler/getTableJoinQuery.d.ts +2 -2
- package/dist/DboBuilder/ViewHandler/getTableJoinQuery.d.ts.map +1 -1
- package/dist/DboBuilder/ViewHandler/getTableJoinQuery.js +42 -23
- package/dist/DboBuilder/ViewHandler/getTableJoinQuery.js.map +1 -1
- package/dist/DboBuilder/ViewHandler/parseComplexFilter.d.ts.map +1 -1
- package/dist/DboBuilder/ViewHandler/parseComplexFilter.js +22 -9
- package/dist/DboBuilder/ViewHandler/parseComplexFilter.js.map +1 -1
- package/dist/DboBuilder/ViewHandler/parseFieldFilter.d.ts +4 -4
- package/dist/DboBuilder/ViewHandler/parseFieldFilter.d.ts.map +1 -1
- package/dist/DboBuilder/ViewHandler/parseFieldFilter.js +13 -11
- package/dist/DboBuilder/ViewHandler/parseFieldFilter.js.map +1 -1
- package/dist/DboBuilder/ViewHandler/parseJoinPath.d.ts +1 -1
- package/dist/DboBuilder/ViewHandler/parseJoinPath.d.ts.map +1 -1
- package/dist/DboBuilder/ViewHandler/parseJoinPath.js +44 -29
- package/dist/DboBuilder/ViewHandler/parseJoinPath.js.map +1 -1
- package/dist/DboBuilder/ViewHandler/prepareSortItems.d.ts.map +1 -1
- package/dist/DboBuilder/ViewHandler/prepareSortItems.js +36 -27
- package/dist/DboBuilder/ViewHandler/prepareSortItems.js.map +1 -1
- package/dist/DboBuilder/ViewHandler/prepareWhere.d.ts.map +1 -1
- package/dist/DboBuilder/ViewHandler/prepareWhere.js +16 -12
- package/dist/DboBuilder/ViewHandler/prepareWhere.js.map +1 -1
- package/dist/DboBuilder/ViewHandler/size.d.ts.map +1 -1
- package/dist/DboBuilder/ViewHandler/size.js +24 -7
- package/dist/DboBuilder/ViewHandler/size.js.map +1 -1
- package/dist/DboBuilder/ViewHandler/subscribe.d.ts.map +1 -1
- package/dist/DboBuilder/ViewHandler/subscribe.js +40 -12
- package/dist/DboBuilder/ViewHandler/subscribe.js.map +1 -1
- package/dist/DboBuilder/ViewHandler/validateViewRules.d.ts.map +1 -1
- package/dist/DboBuilder/ViewHandler/validateViewRules.js +20 -5
- package/dist/DboBuilder/ViewHandler/validateViewRules.js.map +1 -1
- package/dist/DboBuilder/dboBuilderUtils.d.ts.map +1 -1
- package/dist/DboBuilder/dboBuilderUtils.js +18 -7
- package/dist/DboBuilder/dboBuilderUtils.js.map +1 -1
- package/dist/DboBuilder/getColumns.d.ts.map +1 -1
- package/dist/DboBuilder/getColumns.js +22 -7
- package/dist/DboBuilder/getColumns.js.map +1 -1
- package/dist/DboBuilder/getCondition.d.ts.map +1 -1
- package/dist/DboBuilder/getCondition.js +43 -30
- package/dist/DboBuilder/getCondition.js.map +1 -1
- package/dist/DboBuilder/getSubscribeRelatedTables.d.ts.map +1 -1
- package/dist/DboBuilder/getSubscribeRelatedTables.js +38 -27
- package/dist/DboBuilder/getSubscribeRelatedTables.js.map +1 -1
- package/dist/DboBuilder/getTablesForSchemaPostgresSQL.d.ts.map +1 -1
- package/dist/DboBuilder/getTablesForSchemaPostgresSQL.js +9 -9
- package/dist/DboBuilder/getTablesForSchemaPostgresSQL.js.map +1 -1
- package/dist/DboBuilder/insertNestedRecords.d.ts +3 -3
- package/dist/DboBuilder/insertNestedRecords.d.ts.map +1 -1
- package/dist/DboBuilder/insertNestedRecords.js +79 -44
- package/dist/DboBuilder/insertNestedRecords.js.map +1 -1
- package/dist/DboBuilder/parseUpdateRules.d.ts.map +1 -1
- package/dist/DboBuilder/parseUpdateRules.js +38 -14
- package/dist/DboBuilder/parseUpdateRules.js.map +1 -1
- package/dist/DboBuilder/prepareShortestJoinPaths.d.ts.map +1 -1
- package/dist/DboBuilder/prepareShortestJoinPaths.js +56 -31
- package/dist/DboBuilder/prepareShortestJoinPaths.js.map +1 -1
- package/dist/DboBuilder/runSQL.d.ts.map +1 -1
- package/dist/DboBuilder/runSQL.js +41 -21
- package/dist/DboBuilder/runSQL.js.map +1 -1
- package/dist/DboBuilder/runTransaction.d.ts +1 -1
- package/dist/DboBuilder/runTransaction.d.ts.map +1 -1
- package/dist/DboBuilder/runTransaction.js +2 -2
- package/dist/DboBuilder/runTransaction.js.map +1 -1
- package/dist/DboBuilder/sqlErrCodeToMsg.d.ts.map +1 -1
- package/dist/DboBuilder/sqlErrCodeToMsg.js +297 -38
- package/dist/DboBuilder/sqlErrCodeToMsg.js.map +1 -1
- package/dist/DboBuilder/uploadFile.d.ts.map +1 -1
- package/dist/DboBuilder/uploadFile.js +33 -9
- package/dist/DboBuilder/uploadFile.js.map +1 -1
- package/dist/Event_Trigger_Tags.d.ts +1 -1
- package/dist/Event_Trigger_Tags.d.ts.map +1 -1
- package/dist/Event_Trigger_Tags.js +1 -1
- package/dist/Event_Trigger_Tags.js.map +1 -1
- package/dist/FileManager/FileManager.d.ts.map +1 -1
- package/dist/FileManager/FileManager.js +6 -3
- package/dist/FileManager/FileManager.js.map +1 -1
- package/dist/FileManager/getValidatedFileType.d.ts.map +1 -1
- package/dist/FileManager/getValidatedFileType.js +18 -16
- package/dist/FileManager/getValidatedFileType.js.map +1 -1
- package/dist/FileManager/initFileManager.d.ts.map +1 -1
- package/dist/FileManager/initFileManager.js +7 -1
- package/dist/FileManager/initFileManager.js.map +1 -1
- package/dist/FileManager/upload.d.ts +1 -1
- package/dist/FileManager/upload.d.ts.map +1 -1
- package/dist/FileManager/upload.js +3 -3
- package/dist/FileManager/upload.js.map +1 -1
- package/dist/FileManager/uploadStream.d.ts +1 -1
- package/dist/FileManager/uploadStream.d.ts.map +1 -1
- package/dist/FileManager/uploadStream.js +6 -7
- package/dist/FileManager/uploadStream.js.map +1 -1
- package/dist/Filtering.d.ts +3 -3
- package/dist/Filtering.d.ts.map +1 -1
- package/dist/Filtering.js +70 -37
- package/dist/Filtering.js.map +1 -1
- package/dist/JSONBValidation/validate_jsonb_schema_sql.d.ts.map +1 -1
- package/dist/JSONBValidation/validate_jsonb_schema_sql.js +1 -4
- package/dist/JSONBValidation/validate_jsonb_schema_sql.js.map +1 -1
- package/dist/JSONBValidation/validation.d.ts.map +1 -1
- package/dist/JSONBValidation/validation.js +46 -24
- package/dist/JSONBValidation/validation.js.map +1 -1
- package/dist/Logging.d.ts +2 -2
- package/dist/Logging.d.ts.map +1 -1
- package/dist/PostgresNotifListenManager.d.ts.map +1 -1
- package/dist/PostgresNotifListenManager.js +20 -22
- package/dist/PostgresNotifListenManager.js.map +1 -1
- package/dist/Prostgles.d.ts +1 -1
- package/dist/Prostgles.d.ts.map +1 -1
- package/dist/Prostgles.js +37 -11
- package/dist/Prostgles.js.map +1 -1
- package/dist/ProstglesTypes.d.ts.map +1 -1
- package/dist/ProstglesTypes.js +6 -1
- package/dist/ProstglesTypes.js.map +1 -1
- package/dist/PubSubManager/PubSubManager.d.ts.map +1 -1
- package/dist/PubSubManager/PubSubManager.js +10 -5
- package/dist/PubSubManager/PubSubManager.js.map +1 -1
- package/dist/PubSubManager/addSub.d.ts.map +1 -1
- package/dist/PubSubManager/addSub.js +4 -6
- package/dist/PubSubManager/addSub.js.map +1 -1
- package/dist/PubSubManager/addSync.d.ts.map +1 -1
- package/dist/PubSubManager/addSync.js +10 -6
- package/dist/PubSubManager/addSync.js.map +1 -1
- package/dist/PubSubManager/getCreatePubSubManagerError.d.ts.map +1 -1
- package/dist/PubSubManager/getCreatePubSubManagerError.js +3 -1
- package/dist/PubSubManager/getCreatePubSubManagerError.js.map +1 -1
- package/dist/PubSubManager/getPubSubManagerInitQuery.d.ts.map +1 -1
- package/dist/PubSubManager/getPubSubManagerInitQuery.js +8 -8
- package/dist/PubSubManager/getPubSubManagerInitQuery.js.map +1 -1
- package/dist/PubSubManager/initPubSubManager.d.ts.map +1 -1
- package/dist/PubSubManager/initPubSubManager.js +7 -9
- package/dist/PubSubManager/initPubSubManager.js.map +1 -1
- package/dist/PubSubManager/notifListener.d.ts.map +1 -1
- package/dist/PubSubManager/notifListener.js +23 -12
- package/dist/PubSubManager/notifListener.js.map +1 -1
- package/dist/PubSubManager/orphanTriggerCheck.d.ts.map +1 -1
- package/dist/PubSubManager/orphanTriggerCheck.js.map +1 -1
- package/dist/PubSubManager/pushSubData.d.ts.map +1 -1
- package/dist/PubSubManager/pushSubData.js +1 -1
- package/dist/PubSubManager/pushSubData.js.map +1 -1
- package/dist/PublishParser/PublishParser.d.ts +1 -1
- package/dist/PublishParser/PublishParser.d.ts.map +1 -1
- package/dist/PublishParser/PublishParser.js +25 -14
- package/dist/PublishParser/PublishParser.js.map +1 -1
- package/dist/PublishParser/getFileTableRules.d.ts.map +1 -1
- package/dist/PublishParser/getFileTableRules.js +23 -16
- package/dist/PublishParser/getFileTableRules.js.map +1 -1
- package/dist/PublishParser/getSchemaFromPublish.d.ts.map +1 -1
- package/dist/PublishParser/getSchemaFromPublish.js +39 -16
- package/dist/PublishParser/getSchemaFromPublish.js.map +1 -1
- package/dist/PublishParser/getTableRulesWithoutFileTable.d.ts.map +1 -1
- package/dist/PublishParser/getTableRulesWithoutFileTable.js +42 -22
- package/dist/PublishParser/getTableRulesWithoutFileTable.js.map +1 -1
- package/dist/PublishParser/publishTypesAndUtils.d.ts.map +1 -1
- package/dist/PublishParser/publishTypesAndUtils.js +5 -1
- package/dist/PublishParser/publishTypesAndUtils.js.map +1 -1
- package/dist/RestApi.d.ts +1 -1
- package/dist/RestApi.d.ts.map +1 -1
- package/dist/RestApi.js +1 -1
- package/dist/RestApi.js.map +1 -1
- package/dist/SchemaWatch/SchemaWatch.d.ts +2 -2
- package/dist/SchemaWatch/SchemaWatch.d.ts.map +1 -1
- package/dist/SchemaWatch/SchemaWatch.js +11 -9
- package/dist/SchemaWatch/SchemaWatch.js.map +1 -1
- package/dist/SchemaWatch/getValidatedWatchSchemaType.d.ts.map +1 -1
- package/dist/SchemaWatch/getValidatedWatchSchemaType.js +3 -3
- package/dist/SchemaWatch/getValidatedWatchSchemaType.js.map +1 -1
- package/dist/SchemaWatch/getWatchSchemaTagList.d.ts.map +1 -1
- package/dist/SchemaWatch/getWatchSchemaTagList.js +12 -6
- package/dist/SchemaWatch/getWatchSchemaTagList.js.map +1 -1
- package/dist/SyncReplication.d.ts.map +1 -1
- package/dist/SyncReplication.js +84 -42
- package/dist/SyncReplication.js.map +1 -1
- package/dist/TableConfig/TableConfig.d.ts +5 -5
- package/dist/TableConfig/TableConfig.d.ts.map +1 -1
- package/dist/TableConfig/TableConfig.js +18 -5
- package/dist/TableConfig/TableConfig.js.map +1 -1
- package/dist/TableConfig/getColumnDefinitionQuery.d.ts +2 -2
- package/dist/TableConfig/getColumnDefinitionQuery.d.ts.map +1 -1
- package/dist/TableConfig/getColumnDefinitionQuery.js +20 -9
- package/dist/TableConfig/getColumnDefinitionQuery.js.map +1 -1
- package/dist/TableConfig/getConstraintDefinitionQueries.d.ts +3 -3
- package/dist/TableConfig/getConstraintDefinitionQueries.d.ts.map +1 -1
- package/dist/TableConfig/getConstraintDefinitionQueries.js +12 -7
- package/dist/TableConfig/getConstraintDefinitionQueries.js.map +1 -1
- package/dist/TableConfig/getFutureTableSchema.d.ts +1 -1
- package/dist/TableConfig/getFutureTableSchema.d.ts.map +1 -1
- package/dist/TableConfig/getFutureTableSchema.js +6 -4
- package/dist/TableConfig/getFutureTableSchema.js.map +1 -1
- package/dist/TableConfig/getPGIndexes.d.ts.map +1 -1
- package/dist/TableConfig/getPGIndexes.js.map +1 -1
- package/dist/TableConfig/getTableColumnQueries.d.ts +1 -1
- package/dist/TableConfig/getTableColumnQueries.d.ts.map +1 -1
- package/dist/TableConfig/getTableColumnQueries.js +38 -19
- package/dist/TableConfig/getTableColumnQueries.js.map +1 -1
- package/dist/TableConfig/initTableConfig.d.ts.map +1 -1
- package/dist/TableConfig/initTableConfig.js +91 -43
- package/dist/TableConfig/initTableConfig.js.map +1 -1
- package/dist/index.d.ts.map +1 -1
- package/dist/index.js.map +1 -1
- package/dist/initProstgles.d.ts.map +1 -1
- package/dist/initProstgles.js +14 -10
- package/dist/initProstgles.js.map +1 -1
- package/dist/onSocketConnected.d.ts.map +1 -1
- package/dist/onSocketConnected.js +38 -16
- package/dist/onSocketConnected.js.map +1 -1
- package/dist/runClientRequest.d.ts.map +1 -1
- package/dist/runClientRequest.js +33 -14
- package/dist/runClientRequest.js.map +1 -1
- package/dist/shortestPath.d.ts.map +1 -1
- package/dist/shortestPath.js +1 -1
- package/dist/shortestPath.js.map +1 -1
- package/dist/typeTests/dboTypeCheck.js.map +1 -1
- package/examples/full-example-typescript/DBoGenerated.d.ts +112 -54
- package/examples/full-example-typescript/DBoGenerated.js +3 -3
- package/examples/full-example-typescript/home.html +28 -26
- package/examples/full-example-typescript/index.d.ts +1 -1
- package/examples/full-example-typescript/index.js +80 -53
- package/examples/full-example-vanilla/home.html +151 -125
- package/examples/server/javascript/index.js +17 -19
- package/lib/Auth/AuthHandler.ts +234 -155
- package/lib/Auth/AuthTypes.ts +27 -4
- package/lib/Auth/getSafeReturnURL.ts +35 -21
- package/lib/Auth/sendEmail.ts +34 -31
- package/lib/Auth/setAuthProviders.ts +94 -71
- package/lib/Auth/setEmailProvider.ts +45 -27
- package/lib/Auth/setupAuthRoutes.ts +164 -100
- package/lib/DBEventsManager.ts +87 -65
- package/lib/DBSchemaBuilder.ts +62 -28
- package/lib/DboBuilder/DboBuilder.ts +45 -21
- package/lib/DboBuilder/DboBuilderTypes.ts +99 -95
- package/lib/DboBuilder/QueryBuilder/Functions.ts +862 -580
- package/lib/DboBuilder/QueryBuilder/QueryBuilder.ts +202 -141
- package/lib/DboBuilder/QueryBuilder/getJoinQuery.ts +199 -124
- package/lib/DboBuilder/QueryBuilder/getNewQuery.ts +209 -148
- package/lib/DboBuilder/QueryBuilder/getSelectQuery.ts +101 -75
- package/lib/DboBuilder/QueryBuilder/prepareHaving.ts +10 -5
- package/lib/DboBuilder/QueryStreamer.ts +207 -100
- package/lib/DboBuilder/TableHandler/DataValidator.ts +253 -148
- package/lib/DboBuilder/TableHandler/TableHandler.ts +155 -60
- package/lib/DboBuilder/TableHandler/delete.ts +82 -29
- package/lib/DboBuilder/TableHandler/insert.ts +177 -81
- package/lib/DboBuilder/TableHandler/insertTest.ts +13 -7
- package/lib/DboBuilder/TableHandler/onDeleteFromFileTable.ts +35 -21
- package/lib/DboBuilder/TableHandler/runInsertUpdateQuery.ts +95 -45
- package/lib/DboBuilder/TableHandler/update.ts +54 -14
- package/lib/DboBuilder/TableHandler/updateBatch.ts +59 -21
- package/lib/DboBuilder/TableHandler/updateFile.ts +57 -26
- package/lib/DboBuilder/TableHandler/upsert.ts +58 -13
- package/lib/DboBuilder/ViewHandler/ViewHandler.ts +264 -121
- package/lib/DboBuilder/ViewHandler/count.ts +56 -25
- package/lib/DboBuilder/ViewHandler/find.ts +153 -68
- package/lib/DboBuilder/ViewHandler/getExistsCondition.ts +59 -32
- package/lib/DboBuilder/ViewHandler/getExistsFilters.ts +31 -19
- package/lib/DboBuilder/ViewHandler/getInfo.ts +47 -16
- package/lib/DboBuilder/ViewHandler/getTableJoinQuery.ts +91 -57
- package/lib/DboBuilder/ViewHandler/parseComplexFilter.ts +51 -29
- package/lib/DboBuilder/ViewHandler/parseFieldFilter.ts +35 -29
- package/lib/DboBuilder/ViewHandler/parseJoinPath.ts +130 -76
- package/lib/DboBuilder/ViewHandler/prepareSortItems.ts +140 -92
- package/lib/DboBuilder/ViewHandler/prepareWhere.ts +66 -26
- package/lib/DboBuilder/ViewHandler/size.ts +56 -22
- package/lib/DboBuilder/ViewHandler/subscribe.ts +122 -46
- package/lib/DboBuilder/ViewHandler/validateViewRules.ts +39 -14
- package/lib/DboBuilder/dboBuilderUtils.ts +41 -18
- package/lib/DboBuilder/getColumns.ts +44 -12
- package/lib/DboBuilder/getCondition.ts +120 -79
- package/lib/DboBuilder/getSubscribeRelatedTables.ts +144 -83
- package/lib/DboBuilder/getTablesForSchemaPostgresSQL.ts +61 -44
- package/lib/DboBuilder/insertNestedRecords.ts +370 -235
- package/lib/DboBuilder/parseUpdateRules.ts +117 -61
- package/lib/DboBuilder/prepareShortestJoinPaths.ts +115 -56
- package/lib/DboBuilder/runSQL.ts +135 -74
- package/lib/DboBuilder/runTransaction.ts +27 -16
- package/lib/DboBuilder/sqlErrCodeToMsg.ts +502 -244
- package/lib/DboBuilder/uploadFile.ts +67 -31
- package/lib/Event_Trigger_Tags.ts +6 -4
- package/lib/FileManager/FileManager.ts +53 -21
- package/lib/FileManager/getValidatedFileType.ts +79 -35
- package/lib/FileManager/initFileManager.ts +21 -9
- package/lib/FileManager/upload.ts +21 -19
- package/lib/FileManager/uploadStream.ts +33 -34
- package/lib/Filtering.ts +249 -197
- package/lib/JSONBValidation/validate_jsonb_schema_sql.ts +2 -7
- package/lib/JSONBValidation/validation.ts +147 -82
- package/lib/Logging.ts +107 -97
- package/lib/PostgresNotifListenManager.ts +96 -63
- package/lib/Prostgles.ts +106 -35
- package/lib/ProstglesTypes.ts +31 -9
- package/lib/PubSubManager/PubSubManager.ts +62 -27
- package/lib/PubSubManager/addSub.ts +56 -37
- package/lib/PubSubManager/addSync.ts +50 -33
- package/lib/PubSubManager/getCreatePubSubManagerError.ts +29 -21
- package/lib/PubSubManager/getPubSubManagerInitQuery.ts +45 -27
- package/lib/PubSubManager/initPubSubManager.ts +27 -18
- package/lib/PubSubManager/notifListener.ts +77 -59
- package/lib/PubSubManager/orphanTriggerCheck.ts +5 -4
- package/lib/PubSubManager/pushSubData.ts +11 -9
- package/lib/PublishParser/PublishParser.ts +102 -44
- package/lib/PublishParser/getFileTableRules.ts +97 -54
- package/lib/PublishParser/getSchemaFromPublish.ts +146 -74
- package/lib/PublishParser/getTableRulesWithoutFileTable.ts +101 -51
- package/lib/PublishParser/publishTypesAndUtils.ts +74 -23
- package/lib/RestApi.ts +10 -2
- package/lib/SchemaWatch/SchemaWatch.ts +52 -34
- package/lib/SchemaWatch/createSchemaWatchEventTrigger.ts +1 -1
- package/lib/SchemaWatch/getValidatedWatchSchemaType.ts +32 -22
- package/lib/SchemaWatch/getWatchSchemaTagList.ts +24 -16
- package/lib/SyncReplication.ts +376 -190
- package/lib/TableConfig/TableConfig.ts +200 -136
- package/lib/TableConfig/getColumnDefinitionQuery.ts +65 -44
- package/lib/TableConfig/getConstraintDefinitionQueries.ts +41 -25
- package/lib/TableConfig/getFutureTableSchema.ts +31 -21
- package/lib/TableConfig/getPGIndexes.ts +7 -4
- package/lib/TableConfig/getTableColumnQueries.ts +101 -54
- package/lib/TableConfig/initTableConfig.ts +192 -101
- package/lib/index.ts +6 -5
- package/lib/initProstgles.ts +57 -51
- package/lib/onSocketConnected.ts +75 -40
- package/lib/runClientRequest.ts +148 -79
- package/lib/shortestPath.ts +80 -76
- package/lib/typeTests/DBoGenerated.d.ts +5 -1
- package/lib/typeTests/dboTypeCheck.ts +8 -8
- package/package.json +1 -1
|
@@ -6,79 +6,113 @@ type getTableJoinsArgs = {
|
|
|
6
6
|
type: "INNER" | "LEFT" | "EXISTS";
|
|
7
7
|
finalWhere?: string;
|
|
8
8
|
path: ParsedJoinPath[];
|
|
9
|
-
}
|
|
10
|
-
export const getTableJoinQuery = ({
|
|
11
|
-
|
|
9
|
+
};
|
|
10
|
+
export const getTableJoinQuery = ({
|
|
11
|
+
path,
|
|
12
|
+
type,
|
|
13
|
+
rootTableAlias,
|
|
14
|
+
finalWhere,
|
|
15
|
+
}: getTableJoinsArgs): { targetAlias: string; query: string } => {
|
|
12
16
|
const [firstPath] = path;
|
|
13
|
-
if(!firstPath){
|
|
17
|
+
if (!firstPath) {
|
|
14
18
|
throw `Cannot create join query for empty path`;
|
|
15
19
|
}
|
|
16
20
|
const aliasSufix = "jd";
|
|
17
|
-
const getTableAlias = (table: string, pathIndex: number) =>
|
|
18
|
-
|
|
19
|
-
const query = path.map(({ table, on }, i) => {
|
|
20
|
-
if(!on) throw "on missing";
|
|
21
|
-
const tableName = table;
|
|
22
|
-
const tableAlias = getTableAlias(table, i);
|
|
23
|
-
const prevTableAlias = i === 0? rootTableAlias : getTableAlias(path[i-1]!.table, i-1);
|
|
21
|
+
const getTableAlias = (table: string, pathIndex: number) =>
|
|
22
|
+
asName(`${aliasSufix}_${pathIndex}_${table}`);
|
|
24
23
|
|
|
25
|
-
|
|
24
|
+
const query = path
|
|
25
|
+
.map(({ table, on }, i) => {
|
|
26
|
+
if (!on) throw "on missing";
|
|
27
|
+
const tableName = table;
|
|
28
|
+
const tableAlias = getTableAlias(table, i);
|
|
29
|
+
const prevTableAlias =
|
|
30
|
+
i === 0 ? rootTableAlias : getTableAlias(path[i - 1]!.table, i - 1);
|
|
26
31
|
|
|
27
|
-
|
|
28
|
-
|
|
29
|
-
|
|
30
|
-
|
|
31
|
-
|
|
32
|
+
const onCondition = getJoinOnCondition({
|
|
33
|
+
on,
|
|
34
|
+
leftAlias: prevTableAlias,
|
|
35
|
+
rightAlias: tableAlias,
|
|
36
|
+
});
|
|
32
37
|
|
|
33
|
-
|
|
34
|
-
|
|
35
|
-
|
|
36
|
-
|
|
37
|
-
|
|
38
|
-
`WHERE (${getJoinOnCondition({
|
|
39
|
-
on: firstPath.on,
|
|
40
|
-
leftAlias: rootTableAlias,
|
|
41
|
-
rightAlias: getTableAlias(firstPath.table, 0)
|
|
42
|
-
})})` : "";
|
|
38
|
+
const isExists = type === "EXISTS";
|
|
39
|
+
const joinType = isExists ? "INNER" : type;
|
|
40
|
+
const keyword = `${joinType} JOIN`;
|
|
41
|
+
const isLast = i === path.length - 1;
|
|
42
|
+
const isFirst = !i;
|
|
43
43
|
|
|
44
|
-
|
|
45
|
-
|
|
46
|
-
|
|
47
|
-
|
|
48
|
-
|
|
49
|
-
|
|
50
|
-
|
|
51
|
-
|
|
52
|
-
|
|
53
|
-
|
|
54
|
-
|
|
55
|
-
|
|
56
|
-
].filter(v=>v).join("\n");
|
|
57
|
-
}
|
|
44
|
+
/**
|
|
45
|
+
* rootTable joins to first path
|
|
46
|
+
* first path joins to target table through inner joins
|
|
47
|
+
*/
|
|
48
|
+
const whereJoinCondition =
|
|
49
|
+
isLast && isExists
|
|
50
|
+
? `WHERE (${getJoinOnCondition({
|
|
51
|
+
on: firstPath.on,
|
|
52
|
+
leftAlias: rootTableAlias,
|
|
53
|
+
rightAlias: getTableAlias(firstPath.table, 0),
|
|
54
|
+
})})`
|
|
55
|
+
: "";
|
|
58
56
|
|
|
59
|
-
|
|
60
|
-
|
|
61
|
-
|
|
62
|
-
|
|
63
|
-
|
|
57
|
+
const tableSelect =
|
|
58
|
+
isExists && isLast
|
|
59
|
+
? [
|
|
60
|
+
`(`,
|
|
61
|
+
` SELECT *`,
|
|
62
|
+
` FROM ${tableName}`,
|
|
63
|
+
finalWhere ? ` WHERE ${finalWhere}` : "",
|
|
64
|
+
`)`,
|
|
65
|
+
]
|
|
66
|
+
.filter((v) => v)
|
|
67
|
+
.join("\n")
|
|
68
|
+
: tableName;
|
|
69
|
+
if (isExists && isFirst) {
|
|
70
|
+
return [
|
|
71
|
+
`SELECT 1`,
|
|
72
|
+
`FROM ${tableSelect} ${tableAlias}`,
|
|
73
|
+
whereJoinCondition,
|
|
74
|
+
]
|
|
75
|
+
.filter((v) => v)
|
|
76
|
+
.join("\n");
|
|
77
|
+
}
|
|
64
78
|
|
|
65
|
-
|
|
79
|
+
return [
|
|
80
|
+
`${keyword} ${tableSelect} ${tableAlias}`,
|
|
81
|
+
` ON ${onCondition}`,
|
|
82
|
+
whereJoinCondition,
|
|
83
|
+
]
|
|
84
|
+
.filter((v) => v)
|
|
85
|
+
.join("\n");
|
|
86
|
+
})
|
|
87
|
+
.join("\n");
|
|
66
88
|
|
|
67
89
|
return {
|
|
68
90
|
query,
|
|
69
|
-
targetAlias: getTableAlias(path.at(-1)!.table, path.length - 1)
|
|
70
|
-
}
|
|
71
|
-
}
|
|
91
|
+
targetAlias: getTableAlias(path.at(-1)!.table, path.length - 1),
|
|
92
|
+
};
|
|
93
|
+
};
|
|
72
94
|
|
|
73
95
|
type GetJoinOnConditionArgs = {
|
|
74
96
|
on: Record<string, string>[];
|
|
75
|
-
leftAlias: string;
|
|
97
|
+
leftAlias: string;
|
|
76
98
|
rightAlias: string;
|
|
77
99
|
getLeftColName?: (col: string) => string;
|
|
78
100
|
getRightColName?: (col: string) => string;
|
|
79
|
-
}
|
|
80
|
-
export const getJoinOnCondition = ({
|
|
81
|
-
|
|
82
|
-
|
|
83
|
-
|
|
84
|
-
|
|
101
|
+
};
|
|
102
|
+
export const getJoinOnCondition = ({
|
|
103
|
+
on,
|
|
104
|
+
leftAlias,
|
|
105
|
+
rightAlias,
|
|
106
|
+
getLeftColName = asName,
|
|
107
|
+
getRightColName = asName,
|
|
108
|
+
}: GetJoinOnConditionArgs) => {
|
|
109
|
+
return on
|
|
110
|
+
.map((constraint) =>
|
|
111
|
+
Object.entries(constraint)
|
|
112
|
+
.map(([leftCol, rightCol]) => {
|
|
113
|
+
return `${leftAlias}.${getLeftColName(leftCol)} = ${rightAlias}.${getRightColName(rightCol)}`;
|
|
114
|
+
})
|
|
115
|
+
.join(" AND "),
|
|
116
|
+
)
|
|
117
|
+
.join(" OR ");
|
|
118
|
+
};
|
|
@@ -1,5 +1,9 @@
|
|
|
1
1
|
import { AnyObject, isObject } from "prostgles-types";
|
|
2
|
-
import {
|
|
2
|
+
import {
|
|
3
|
+
FILTER_OPERANDS,
|
|
4
|
+
FILTER_OPERAND_TO_SQL_OPERAND,
|
|
5
|
+
parseFilterRightValue,
|
|
6
|
+
} from "../../Filtering";
|
|
3
7
|
import { FUNCTIONS, parseFunction } from "../QueryBuilder/Functions";
|
|
4
8
|
import { asNameAlias, parseFunctionObject } from "../QueryBuilder/QueryBuilder";
|
|
5
9
|
import { TableSchemaColumn } from "../DboBuilderTypes";
|
|
@@ -12,7 +16,7 @@ type Args = {
|
|
|
12
16
|
tableAlias: string | undefined;
|
|
13
17
|
allowed_colnames: string[];
|
|
14
18
|
columns: TableSchemaColumn[];
|
|
15
|
-
}
|
|
19
|
+
};
|
|
16
20
|
|
|
17
21
|
/* Parse complex filters
|
|
18
22
|
{
|
|
@@ -30,67 +34,85 @@ export const parseComplexFilter = ({
|
|
|
30
34
|
allowed_colnames,
|
|
31
35
|
columns,
|
|
32
36
|
}: Args) => {
|
|
33
|
-
|
|
34
37
|
/**
|
|
35
38
|
* { $funcName: [arg1, arg2] }
|
|
36
39
|
* { $column: "column_name" }
|
|
37
40
|
*/
|
|
38
41
|
const getFuncQuery = (funcData: AnyObject): string => {
|
|
39
|
-
if(isObject(funcData) && "$column" in funcData){
|
|
40
|
-
const column = funcData["$column"]
|
|
41
|
-
if(typeof column !== "string"){
|
|
42
|
+
if (isObject(funcData) && "$column" in funcData) {
|
|
43
|
+
const column = funcData["$column"];
|
|
44
|
+
if (typeof column !== "string") {
|
|
42
45
|
throw `expecting: \n { $column: "column_name" } received:\n ${JSON.stringify(funcData)}`;
|
|
43
46
|
}
|
|
44
|
-
if(!allowed_colnames.includes(column)){
|
|
47
|
+
if (!allowed_colnames.includes(column)) {
|
|
45
48
|
throw `Dissallowed or Invalid column ${column}. Allowed columns: ${allowed_colnames}`;
|
|
46
49
|
}
|
|
47
|
-
return asNameAlias(column, tableAlias)
|
|
50
|
+
return asNameAlias(column, tableAlias);
|
|
48
51
|
}
|
|
49
52
|
const { funcName, args } = parseFunctionObject(funcData);
|
|
50
|
-
const funcDef = parseFunction({
|
|
51
|
-
|
|
52
|
-
|
|
53
|
+
const funcDef = parseFunction({
|
|
54
|
+
func: funcName,
|
|
55
|
+
args,
|
|
56
|
+
functions: FUNCTIONS,
|
|
57
|
+
allowedFields: allowed_colnames,
|
|
58
|
+
});
|
|
59
|
+
return funcDef.getQuery({
|
|
60
|
+
args,
|
|
61
|
+
tableAlias,
|
|
62
|
+
allColumns: columns,
|
|
63
|
+
allowedFields: allowed_colnames,
|
|
64
|
+
});
|
|
65
|
+
};
|
|
53
66
|
|
|
54
67
|
const complexFilter = filter[complexFilterKey];
|
|
55
68
|
if (!Array.isArray(complexFilter)) {
|
|
56
|
-
throw `Invalid $filter. Must contain an array of at least element but got: ${JSON.stringify(complexFilter)}
|
|
57
|
-
}
|
|
69
|
+
throw `Invalid $filter. Must contain an array of at least element but got: ${JSON.stringify(complexFilter)} `;
|
|
70
|
+
}
|
|
58
71
|
const [leftFilter, comparator, rightFilterOrValue] = complexFilter;
|
|
59
72
|
|
|
60
73
|
const leftVal = getFuncQuery(leftFilter);
|
|
61
74
|
let result = leftVal;
|
|
62
75
|
if (comparator) {
|
|
63
|
-
if (
|
|
76
|
+
if (
|
|
77
|
+
typeof comparator !== "string" ||
|
|
78
|
+
!allowedComparators.includes(comparator as any)
|
|
79
|
+
) {
|
|
64
80
|
throw `Invalid $filter. comparator ${JSON.stringify(comparator)} is not valid. Expecting one of: ${allowedComparators}`;
|
|
65
81
|
}
|
|
66
82
|
if (!rightFilterOrValue) {
|
|
67
83
|
throw "Invalid $filter. Expecting a value or function after the comparator";
|
|
68
84
|
}
|
|
69
|
-
const maybeValidComparator =
|
|
85
|
+
const maybeValidComparator =
|
|
86
|
+
comparator as keyof typeof FILTER_OPERAND_TO_SQL_OPERAND;
|
|
70
87
|
const sqlOperand = FILTER_OPERAND_TO_SQL_OPERAND[maybeValidComparator];
|
|
71
|
-
if(!sqlOperand){
|
|
88
|
+
if (!sqlOperand) {
|
|
72
89
|
throw `Invalid $filter. comparator ${comparator} is not valid. Expecting one of: ${allowedComparators}`;
|
|
73
90
|
}
|
|
74
91
|
|
|
75
|
-
let rightVal = isObject(rightFilterOrValue)
|
|
76
|
-
getFuncQuery(rightFilterOrValue)
|
|
77
|
-
parseFilterRightValue(rightFilterOrValue, {
|
|
78
|
-
|
|
79
|
-
|
|
80
|
-
|
|
81
|
-
if(
|
|
82
|
-
|
|
83
|
-
|
|
92
|
+
let rightVal = isObject(rightFilterOrValue)
|
|
93
|
+
? getFuncQuery(rightFilterOrValue)
|
|
94
|
+
: parseFilterRightValue(rightFilterOrValue, {
|
|
95
|
+
selectItem: undefined,
|
|
96
|
+
expect: ["$in", "$nin"].includes(comparator) ? "csv" : undefined,
|
|
97
|
+
});
|
|
98
|
+
if (
|
|
99
|
+
maybeValidComparator === "$between" ||
|
|
100
|
+
maybeValidComparator === "$notBetween"
|
|
101
|
+
) {
|
|
102
|
+
if (!Array.isArray(rightVal) || rightVal.length !== 2) {
|
|
84
103
|
throw "Between filter expects an array of two values";
|
|
85
104
|
}
|
|
86
105
|
rightVal = asValue(rightVal[0]) + " AND " + asValue(rightVal[1]);
|
|
87
106
|
}
|
|
88
|
-
if (leftVal === rightVal){
|
|
89
|
-
throw
|
|
107
|
+
if (leftVal === rightVal) {
|
|
108
|
+
throw (
|
|
109
|
+
"Invalid $filter. Cannot compare two identical function signatures: " +
|
|
110
|
+
JSON.stringify(leftFilter)
|
|
111
|
+
);
|
|
90
112
|
}
|
|
91
|
-
|
|
113
|
+
|
|
92
114
|
result += ` ${sqlOperand} ${rightVal}`;
|
|
93
115
|
}
|
|
94
116
|
|
|
95
117
|
return result;
|
|
96
|
-
}
|
|
118
|
+
};
|
|
@@ -1,33 +1,34 @@
|
|
|
1
1
|
import { FieldFilter, getKeys } from "prostgles-types";
|
|
2
2
|
import { isPlainObject } from "../DboBuilder";
|
|
3
3
|
|
|
4
|
-
/**
|
|
5
|
-
* Filter string array
|
|
6
|
-
* @param {FieldFilter} fieldParams - { col1: 0, col2: 0 } | { col1: true, col2: true } | "*" | ["key1", "key2"] | []
|
|
7
|
-
* @param {boolean} allow_empty - allow empty select. defaults to true
|
|
8
|
-
*/
|
|
4
|
+
/**
|
|
5
|
+
* Filter string array
|
|
6
|
+
* @param {FieldFilter} fieldParams - { col1: 0, col2: 0 } | { col1: true, col2: true } | "*" | ["key1", "key2"] | []
|
|
7
|
+
* @param {boolean} allow_empty - allow empty select. defaults to true
|
|
8
|
+
*/
|
|
9
9
|
export const parseFieldFilter = <AllowedKeys extends string[]>(
|
|
10
|
-
fieldParams: FieldFilter<Record<AllowedKeys[number], any>> = "*",
|
|
11
|
-
allow_empty = true,
|
|
12
|
-
all_cols: AllowedKeys
|
|
10
|
+
fieldParams: FieldFilter<Record<AllowedKeys[number], any>> = "*",
|
|
11
|
+
allow_empty = true,
|
|
12
|
+
all_cols: AllowedKeys,
|
|
13
13
|
): AllowedKeys | [""] => {
|
|
14
|
-
|
|
15
|
-
|
|
16
|
-
const all_fields = all_cols;// || this.column_names.slice(0);
|
|
14
|
+
if (!all_cols) throw "all_cols missing";
|
|
15
|
+
const all_fields = all_cols; // || this.column_names.slice(0);
|
|
17
16
|
let colNames: AllowedKeys = [] as any;
|
|
18
17
|
const initialParams = JSON.stringify(fieldParams);
|
|
19
18
|
|
|
20
19
|
if (fieldParams) {
|
|
21
|
-
|
|
22
20
|
/*
|
|
23
21
|
"field1, field2, field4" | "*"
|
|
24
22
|
*/
|
|
25
23
|
if (typeof fieldParams === "string") {
|
|
26
|
-
fieldParams = fieldParams.split(",").map(k => k.trim());
|
|
24
|
+
fieldParams = fieldParams.split(",").map((k) => k.trim());
|
|
27
25
|
}
|
|
28
26
|
|
|
29
27
|
/* string[] */
|
|
30
|
-
if (
|
|
28
|
+
if (
|
|
29
|
+
Array.isArray(fieldParams) &&
|
|
30
|
+
!fieldParams.find((f) => typeof f !== "string")
|
|
31
|
+
) {
|
|
31
32
|
/*
|
|
32
33
|
["*"]
|
|
33
34
|
*/
|
|
@@ -55,14 +56,15 @@ export const parseFieldFilter = <AllowedKeys extends string[]>(
|
|
|
55
56
|
{ field1: false, field2: false } = all fields except field1 and field2
|
|
56
57
|
*/
|
|
57
58
|
} else if (isPlainObject(fieldParams)) {
|
|
58
|
-
|
|
59
59
|
if (!getKeys(fieldParams).length) {
|
|
60
60
|
return [] as unknown as typeof all_fields; //all_fields.slice(0) as typeof all_fields;
|
|
61
61
|
}
|
|
62
62
|
|
|
63
|
-
const keys = getKeys(
|
|
64
|
-
|
|
65
|
-
|
|
63
|
+
const keys = getKeys(
|
|
64
|
+
fieldParams as {
|
|
65
|
+
[key: string]: boolean | 0 | 1;
|
|
66
|
+
},
|
|
67
|
+
) as AllowedKeys;
|
|
66
68
|
if (keys[0] === "") {
|
|
67
69
|
if (allow_empty) {
|
|
68
70
|
return [""];
|
|
@@ -73,23 +75,27 @@ export const parseFieldFilter = <AllowedKeys extends string[]>(
|
|
|
73
75
|
|
|
74
76
|
validate(keys);
|
|
75
77
|
|
|
76
|
-
keys.forEach(key => {
|
|
78
|
+
keys.forEach((key) => {
|
|
77
79
|
const allowedVals = [true, false, 0, 1];
|
|
78
|
-
if (!allowedVals.includes((fieldParams as any)[key]))
|
|
79
|
-
|
|
80
|
-
|
|
81
|
-
const allowed = keys.filter(key => (fieldParams as any)[key]),
|
|
82
|
-
disallowed = keys.filter(key => !(fieldParams as any)[key]);
|
|
80
|
+
if (!allowedVals.includes((fieldParams as any)[key]))
|
|
81
|
+
throw `Invalid field selection value for: { ${key}: ${(fieldParams as any)[key]} }. \n Allowed values: ${allowedVals.join(" OR ")}`;
|
|
82
|
+
});
|
|
83
83
|
|
|
84
|
+
const allowed = keys.filter((key) => (fieldParams as any)[key]),
|
|
85
|
+
disallowed = keys.filter((key) => !(fieldParams as any)[key]);
|
|
84
86
|
|
|
85
87
|
if (disallowed && disallowed.length) {
|
|
86
|
-
return all_fields.filter(
|
|
88
|
+
return all_fields.filter(
|
|
89
|
+
(col) => !disallowed.includes(col),
|
|
90
|
+
) as typeof all_fields;
|
|
87
91
|
} else {
|
|
88
92
|
return [...allowed] as any;
|
|
89
93
|
}
|
|
90
|
-
|
|
91
94
|
} else {
|
|
92
|
-
throw
|
|
95
|
+
throw (
|
|
96
|
+
" Unrecognised field filter.\nExpecting any of: string | string[] | { [field]: boolean } \n Received -> " +
|
|
97
|
+
initialParams
|
|
98
|
+
);
|
|
93
99
|
}
|
|
94
100
|
|
|
95
101
|
validate(colNames);
|
|
@@ -97,9 +103,9 @@ export const parseFieldFilter = <AllowedKeys extends string[]>(
|
|
|
97
103
|
return colNames as any;
|
|
98
104
|
|
|
99
105
|
function validate(cols: AllowedKeys) {
|
|
100
|
-
const bad_keys = cols.filter(col => !all_fields.includes(col));
|
|
106
|
+
const bad_keys = cols.filter((col) => !all_fields.includes(col));
|
|
101
107
|
if (bad_keys && bad_keys.length) {
|
|
102
108
|
throw "\nUnrecognised or illegal fields: " + bad_keys.join(", ");
|
|
103
109
|
}
|
|
104
110
|
}
|
|
105
|
-
}
|
|
111
|
+
};
|