@saltcorn/server 1.1.4-alpha.0 → 1.1.4-alpha.2
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/CHANGELOG.md +7 -0
- package/auth/resetpw.js +8 -5
- package/docs/assets/search.js +1 -1
- package/docs/classes/_saltcorn_common_code.Relation.html +8 -8
- package/docs/classes/_saltcorn_common_code.RelationsFinder.html +5 -5
- package/docs/classes/_saltcorn_data.models.Crash-1.html +18 -18
- package/docs/classes/_saltcorn_data.models.EventLog-1.html +19 -19
- package/docs/classes/_saltcorn_data.models.Field.html +71 -71
- package/docs/classes/_saltcorn_data.models.FieldRepeat-1.html +17 -17
- package/docs/classes/_saltcorn_data.models.File-1.html +48 -48
- package/docs/classes/_saltcorn_data.models.Form-1.html +38 -38
- package/docs/classes/_saltcorn_data.models.Library.html +13 -13
- package/docs/classes/_saltcorn_data.models.Page.html +33 -23
- package/docs/classes/_saltcorn_data.models.PageGroup-1.html +28 -33
- package/docs/classes/_saltcorn_data.models.Plugin.html +25 -25
- package/docs/classes/_saltcorn_data.models.Role.html +9 -9
- package/docs/classes/_saltcorn_data.models.Table-1.html +101 -91
- package/docs/classes/_saltcorn_data.models.TableConstraint-1.html +14 -14
- package/docs/classes/_saltcorn_data.models.Trigger.html +45 -35
- package/docs/classes/_saltcorn_data.models.User-1.html +48 -48
- package/docs/classes/_saltcorn_data.models.View-1.html +61 -51
- package/docs/classes/_saltcorn_data.models.Workflow-1.html +17 -17
- package/docs/classes/_saltcorn_data.models.WorkflowRun.html +35 -35
- package/docs/classes/_saltcorn_data.models.WorkflowStep.html +25 -25
- package/docs/classes/_saltcorn_data.models.WorkflowTrace.html +18 -18
- package/docs/classes/_saltcorn_mobile_builder.MobileBuilder.html +36 -36
- package/docs/enums/_saltcorn_common_code.RelationType.html +7 -7
- package/docs/enums/_saltcorn_common_code.ViewDisplayType.html +4 -4
- package/docs/functions/_saltcorn_admin_models.backup.create_backup.html +1 -1
- package/docs/functions/_saltcorn_admin_models.backup.create_csv_from_rows.html +1 -1
- package/docs/functions/_saltcorn_admin_models.backup.restore.html +1 -1
- package/docs/functions/_saltcorn_admin_models.pack.add_to_menu.html +1 -1
- package/docs/functions/_saltcorn_admin_models.pack.can_install_pack.html +1 -1
- package/docs/functions/_saltcorn_admin_models.pack.fetch_available_packs.html +1 -1
- package/docs/functions/_saltcorn_admin_models.pack.fetch_pack_by_name.html +1 -1
- package/docs/functions/_saltcorn_admin_models.pack.install_pack.html +1 -1
- package/docs/functions/_saltcorn_admin_models.pack.library_pack.html +1 -1
- package/docs/functions/_saltcorn_admin_models.pack.model_instance_pack.html +1 -1
- package/docs/functions/_saltcorn_admin_models.pack.model_pack.html +1 -1
- package/docs/functions/_saltcorn_admin_models.pack.page_group_pack.html +1 -1
- package/docs/functions/_saltcorn_admin_models.pack.page_pack.html +1 -1
- package/docs/functions/_saltcorn_admin_models.pack.plugin_pack.html +1 -1
- package/docs/functions/_saltcorn_admin_models.pack.role_pack.html +1 -1
- package/docs/functions/_saltcorn_admin_models.pack.table_pack.html +1 -1
- package/docs/functions/_saltcorn_admin_models.pack.trigger_pack.html +1 -1
- package/docs/functions/_saltcorn_admin_models.pack.uninstall_pack.html +1 -1
- package/docs/functions/_saltcorn_admin_models.pack.view_pack.html +1 -1
- package/docs/functions/_saltcorn_admin_models.tenant.copy_tenant_template.html +1 -1
- package/docs/functions/_saltcorn_admin_models.tenant.create_tenant.html +1 -1
- package/docs/functions/_saltcorn_admin_models.tenant.deleteTenant.html +1 -1
- package/docs/functions/_saltcorn_admin_models.tenant.domain_sanitize.html +1 -1
- package/docs/functions/_saltcorn_admin_models.tenant.eachTenant.html +1 -1
- package/docs/functions/_saltcorn_admin_models.tenant.getAllTenantRows.html +1 -1
- package/docs/functions/_saltcorn_admin_models.tenant.getAllTenants.html +1 -1
- package/docs/functions/_saltcorn_admin_models.tenant.insertTenant.html +1 -1
- package/docs/functions/_saltcorn_admin_models.tenant.switchToTenant.html +1 -1
- package/docs/functions/_saltcorn_common_code.buildTableCaches.html +1 -1
- package/docs/functions/_saltcorn_common_code.parseLegacyRelation.html +1 -1
- package/docs/functions/_saltcorn_common_code.parseRelationPath.html +1 -1
- package/docs/functions/_saltcorn_data.models.config.check_email_mask.html +1 -1
- package/docs/functions/_saltcorn_data.models.config.deleteConfig.html +1 -1
- package/docs/functions/_saltcorn_data.models.config.getAllConfig.html +1 -1
- package/docs/functions/_saltcorn_data.models.config.getConfig.html +1 -1
- package/docs/functions/_saltcorn_data.models.config.get_base_url.html +1 -1
- package/docs/functions/_saltcorn_data.models.config.get_latest_npm_version.html +1 -1
- package/docs/functions/_saltcorn_data.models.config.remove_from_menu.html +1 -1
- package/docs/functions/_saltcorn_data.models.config.save_menu_items.html +1 -1
- package/docs/functions/_saltcorn_data.models.config.setConfig.html +1 -1
- package/docs/functions/_saltcorn_data.models.discovery.discover_tables.html +1 -1
- package/docs/functions/_saltcorn_data.models.discovery.discoverable_tables.html +1 -1
- package/docs/functions/_saltcorn_data.models.discovery.findType.html +1 -1
- package/docs/functions/_saltcorn_data.models.discovery.get_existing_views.html +1 -1
- package/docs/functions/_saltcorn_data.models.discovery.implement_discovery.html +1 -1
- package/docs/functions/_saltcorn_data.models.email.getMailTransport.html +1 -1
- package/docs/functions/_saltcorn_data.models.email.send_verification_email.html +1 -1
- package/docs/functions/_saltcorn_data.models.email.viewToEmailHtml.html +1 -1
- package/docs/functions/_saltcorn_data.models.expression.apply_calculated_fields.html +1 -1
- package/docs/functions/_saltcorn_data.models.expression.apply_calculated_fields_stored.html +1 -1
- package/docs/functions/_saltcorn_data.models.expression.eval_expression.html +1 -1
- package/docs/functions/_saltcorn_data.models.expression.expressionValidator.html +1 -1
- package/docs/functions/_saltcorn_data.models.expression.get_async_expression_function.html +1 -1
- package/docs/functions/_saltcorn_data.models.expression.get_expression_function.html +1 -1
- package/docs/functions/_saltcorn_data.models.expression.jsexprToWhere.html +1 -1
- package/docs/functions/_saltcorn_data.models.expression.recalculate_for_stored.html +1 -1
- package/docs/functions/_saltcorn_data.models.expression.transform_for_async.html +1 -1
- package/docs/functions/_saltcorn_data.models.layout.eachView.html +1 -1
- package/docs/functions/_saltcorn_data.models.layout.getStringsForI18n.html +1 -1
- package/docs/functions/_saltcorn_data.models.layout.getViews.html +1 -1
- package/docs/functions/_saltcorn_data.models.layout.translateLayout.html +1 -1
- package/docs/functions/_saltcorn_data.models.layout.traverse.html +1 -1
- package/docs/functions/_saltcorn_data.models.layout.traverseSync.html +1 -1
- package/docs/functions/_saltcorn_data.models.random.all_views.html +1 -1
- package/docs/functions/_saltcorn_data.models.random.fill_table_row.html +1 -1
- package/docs/functions/_saltcorn_data.models.random.initial_view.html +1 -1
- package/docs/functions/_saltcorn_data.models.random.random_table.html +1 -1
- package/docs/functions/_saltcorn_db_common.buildInsertBulkSql.html +2 -2
- package/docs/functions/_saltcorn_db_common.buildInsertSql.html +2 -2
- package/docs/functions/_saltcorn_db_common.doCount.html +2 -2
- package/docs/functions/_saltcorn_db_common.doDeleteWhere.html +2 -2
- package/docs/functions/_saltcorn_db_common.doListScTables.html +2 -2
- package/docs/functions/_saltcorn_db_common.doListTables.html +2 -2
- package/docs/functions/_saltcorn_db_common.doListUserDefinedTables.html +2 -2
- package/docs/functions/_saltcorn_db_common.do_add_index.html +2 -2
- package/docs/functions/_saltcorn_db_common.do_drop_index.html +2 -2
- package/docs/functions/_saltcorn_db_common.ftsFieldsSqlExpr.html +2 -2
- package/docs/functions/_saltcorn_db_common.mkSelectOptions.html +2 -2
- package/docs/functions/_saltcorn_db_common.mkVal.html +2 -2
- package/docs/functions/_saltcorn_db_common.mkWhere.html +2 -2
- package/docs/functions/_saltcorn_db_common.multi_tenant.enable_multi_tenant.html +3 -2
- package/docs/functions/{_saltcorn_db_common.single_tenant.enable_multi_tenant.html → _saltcorn_db_common.multi_tenant.getRequestContext.html} +16 -15
- package/docs/functions/_saltcorn_db_common.multi_tenant.getTenantSchema.html +3 -2
- package/docs/functions/_saltcorn_db_common.multi_tenant.init.html +3 -2
- package/docs/functions/_saltcorn_db_common.multi_tenant.is_it_multi_tenant.html +3 -2
- package/docs/functions/_saltcorn_db_common.multi_tenant.runWithTenant.html +5 -5
- package/docs/functions/_saltcorn_db_common.orderByIsObject.html +2 -2
- package/docs/functions/_saltcorn_db_common.orderByIsOperator.html +2 -2
- package/docs/functions/_saltcorn_db_common.prefixFieldsInWhere.html +2 -2
- package/docs/functions/_saltcorn_db_common.reprAsJson.html +2 -2
- package/docs/functions/_saltcorn_db_common.sqlBinOp.html +2 -2
- package/docs/functions/_saltcorn_db_common.sqlFun.html +2 -2
- package/docs/functions/_saltcorn_db_common.sqlsanitize.html +2 -2
- package/docs/functions/_saltcorn_db_common.sqlsanitizeAllowDots.html +2 -2
- package/docs/functions/_saltcorn_db_common.subSelectWhere.html +2 -2
- package/docs/functions/_saltcorn_mobile_builder.common_build_utils.androidFeatures.html +1 -1
- package/docs/functions/_saltcorn_mobile_builder.common_build_utils.androidPermissions.html +1 -1
- package/docs/functions/_saltcorn_mobile_builder.common_build_utils.buildTablesFile.html +1 -1
- package/docs/functions/_saltcorn_mobile_builder.common_build_utils.copyPrepopulatedDb.html +1 -1
- package/docs/functions/_saltcorn_mobile_builder.common_build_utils.copyServerFiles.html +1 -1
- package/docs/functions/_saltcorn_mobile_builder.common_build_utils.copyShareExtFiles.html +1 -1
- package/docs/functions/_saltcorn_mobile_builder.common_build_utils.copySiteLogo.html +1 -1
- package/docs/functions/_saltcorn_mobile_builder.common_build_utils.copyTranslationFiles.html +1 -1
- package/docs/functions/_saltcorn_mobile_builder.common_build_utils.createSqliteDb.html +1 -1
- package/docs/functions/_saltcorn_mobile_builder.common_build_utils.decodeProvisioningProfile.html +1 -1
- package/docs/functions/_saltcorn_mobile_builder.common_build_utils.extractDomain.html +1 -1
- package/docs/functions/_saltcorn_mobile_builder.common_build_utils.generateAndroidVersionCode.html +1 -1
- package/docs/functions/_saltcorn_mobile_builder.common_build_utils.modifyAndroidManifest.html +1 -1
- package/docs/functions/_saltcorn_mobile_builder.common_build_utils.modifyConfigXml.html +1 -1
- package/docs/functions/_saltcorn_mobile_builder.common_build_utils.modifyGradleConfig.html +1 -1
- package/docs/functions/_saltcorn_mobile_builder.common_build_utils.modifyInfoPlist.html +1 -1
- package/docs/functions/_saltcorn_mobile_builder.common_build_utils.modifyXcodeProjectFile.html +1 -1
- package/docs/functions/_saltcorn_mobile_builder.common_build_utils.prepAppIcon.html +1 -1
- package/docs/functions/_saltcorn_mobile_builder.common_build_utils.prepareAppIcon.html +1 -1
- package/docs/functions/_saltcorn_mobile_builder.common_build_utils.prepareBuildDir.html +1 -1
- package/docs/functions/_saltcorn_mobile_builder.common_build_utils.prepareExportOptionsPlist.html +1 -1
- package/docs/functions/_saltcorn_mobile_builder.common_build_utils.prepareSplashIcon.html +1 -1
- package/docs/functions/_saltcorn_mobile_builder.common_build_utils.prepareSplashPage.html +1 -1
- package/docs/functions/_saltcorn_mobile_builder.common_build_utils.writeCapacitorConfig.html +1 -1
- package/docs/functions/_saltcorn_mobile_builder.common_build_utils.writeCfgFile.html +1 -1
- package/docs/functions/_saltcorn_mobile_builder.common_build_utils.writeDataExtractionRules.html +1 -1
- package/docs/functions/_saltcorn_mobile_builder.common_build_utils.writeNetworkSecurityConfig.html +1 -1
- package/docs/functions/_saltcorn_mobile_builder.common_build_utils.writePodfile.html +1 -1
- package/docs/functions/_saltcorn_mobile_builder.common_build_utils.writePrivacyInfo.html +1 -1
- package/docs/functions/_saltcorn_mobile_builder.package_bundle_utils.bundleMobileAppCode.html +1 -1
- package/docs/functions/_saltcorn_mobile_builder.package_bundle_utils.bundlePackagesAndPlugins.html +1 -1
- package/docs/functions/_saltcorn_mobile_builder.package_bundle_utils.copyMobileAppDirs.html +1 -1
- package/docs/functions/_saltcorn_mobile_builder.package_bundle_utils.copyPublicDirs.html +1 -1
- package/docs/functions/_saltcorn_sqlite.add_index.html +3 -2
- package/docs/functions/_saltcorn_sqlite.add_unique_constraint.html +3 -2
- package/docs/functions/_saltcorn_sqlite.begin.html +3 -2
- package/docs/functions/_saltcorn_sqlite.changeConnection.html +3 -2
- package/docs/functions/_saltcorn_sqlite.close.html +3 -2
- package/docs/functions/_saltcorn_sqlite.commit.html +3 -2
- package/docs/functions/_saltcorn_sqlite.count.html +3 -2
- package/docs/functions/_saltcorn_sqlite.deleteWhere.html +3 -2
- package/docs/functions/_saltcorn_sqlite.dropTable.html +3 -2
- package/docs/functions/_saltcorn_sqlite.dropTables.html +3 -2
- package/docs/functions/_saltcorn_sqlite.drop_index.html +3 -2
- package/docs/functions/_saltcorn_sqlite.drop_reset_schema.html +3 -2
- package/docs/functions/_saltcorn_sqlite.drop_unique_constraint.html +3 -2
- package/docs/functions/_saltcorn_sqlite.getVersion.html +3 -2
- package/docs/functions/_saltcorn_sqlite.get_db_filepath.html +3 -2
- package/docs/functions/_saltcorn_sqlite.get_sql_logging.html +3 -2
- package/docs/functions/_saltcorn_sqlite.init.html +3 -2
- package/docs/functions/_saltcorn_sqlite.insert.html +3 -2
- package/docs/functions/_saltcorn_sqlite.listScTables.html +3 -2
- package/docs/functions/_saltcorn_sqlite.listTables.html +3 -2
- package/docs/functions/_saltcorn_sqlite.listUserDefinedTables.html +3 -2
- package/docs/functions/_saltcorn_sqlite.query.html +3 -2
- package/docs/functions/_saltcorn_sqlite.rollback.html +3 -2
- package/docs/functions/_saltcorn_sqlite.select.html +3 -2
- package/docs/functions/_saltcorn_sqlite.selectMaybeOne.html +3 -2
- package/docs/functions/_saltcorn_sqlite.selectOne.html +3 -2
- package/docs/functions/_saltcorn_sqlite.set_sql_logging.html +3 -2
- package/docs/functions/_saltcorn_sqlite.slugify.html +3 -2
- package/docs/functions/_saltcorn_sqlite.sql_log.html +3 -2
- package/docs/functions/_saltcorn_sqlite.update.html +3 -2
- package/docs/functions/_saltcorn_sqlite.updateWhere.html +3 -2
- package/docs/functions/_saltcorn_sqlite.withTransaction.html +96 -0
- package/docs/functions/_saltcorn_sqlite_mobile.add_index.html +1 -1
- package/docs/functions/_saltcorn_sqlite_mobile.add_unique_constraint.html +1 -1
- package/docs/functions/_saltcorn_sqlite_mobile.count.html +1 -1
- package/docs/functions/_saltcorn_sqlite_mobile.deleteWhere.html +1 -1
- package/docs/functions/_saltcorn_sqlite_mobile.drop_index.html +1 -1
- package/docs/functions/_saltcorn_sqlite_mobile.drop_reset_schema.html +1 -1
- package/docs/functions/_saltcorn_sqlite_mobile.drop_unique_constraint.html +1 -1
- package/docs/functions/_saltcorn_sqlite_mobile.init.html +1 -1
- package/docs/functions/_saltcorn_sqlite_mobile.insert.html +1 -1
- package/docs/functions/_saltcorn_sqlite_mobile.insertRows.html +1 -1
- package/docs/functions/_saltcorn_sqlite_mobile.listScTables.html +1 -1
- package/docs/functions/_saltcorn_sqlite_mobile.listTables.html +1 -1
- package/docs/functions/_saltcorn_sqlite_mobile.listUserDefinedTables.html +1 -1
- package/docs/functions/_saltcorn_sqlite_mobile.query.html +1 -1
- package/docs/functions/_saltcorn_sqlite_mobile.select.html +1 -1
- package/docs/functions/_saltcorn_sqlite_mobile.selectMaybeOne.html +1 -1
- package/docs/functions/_saltcorn_sqlite_mobile.selectOne.html +1 -1
- package/docs/functions/_saltcorn_sqlite_mobile.setConnectionObject.html +1 -1
- package/docs/functions/_saltcorn_sqlite_mobile.tableExists.html +1 -1
- package/docs/functions/_saltcorn_sqlite_mobile.time.html +1 -1
- package/docs/functions/_saltcorn_sqlite_mobile.update.html +1 -1
- package/docs/functions/_saltcorn_types.ModelAbstracts.abstract_field.instanceOfField.html +1 -1
- package/docs/functions/_saltcorn_types.ModelAbstracts.abstract_page.instanceOfPage.html +1 -1
- package/docs/functions/_saltcorn_types.ModelAbstracts.abstract_view.instanceOfView.html +1 -1
- package/docs/functions/_saltcorn_types.Types.base_types.instanceOWithHtmlFile.html +1 -1
- package/docs/functions/_saltcorn_types.Types.common_types.instanceOfErrorMsg.html +1 -1
- package/docs/functions/_saltcorn_types.Types.common_types.instanceOfSuccessMsg.html +1 -1
- package/docs/functions/_saltcorn_types.Types.common_types.instanceOfType.html +1 -1
- package/docs/functions/_saltcorn_types.generators.generateBool.html +1 -1
- package/docs/functions/_saltcorn_types.generators.generateString.html +1 -1
- package/docs/functions/_saltcorn_types.generators.num_between.html +1 -1
- package/docs/functions/_saltcorn_types.generators.oneOf.html +1 -1
- package/docs/interfaces/_saltcorn_mobile_builder.common_build_utils.ScCapacitorConfig.html +10 -10
- package/docs/interfaces/_saltcorn_types.ModelAbstracts.abstract_field.AbstractField.html +14 -14
- package/docs/interfaces/_saltcorn_types.ModelAbstracts.abstract_field.AbstractFieldRepeat.html +3 -3
- package/docs/interfaces/_saltcorn_types.ModelAbstracts.abstract_form.AbstractForm.html +26 -26
- package/docs/interfaces/_saltcorn_types.ModelAbstracts.abstract_page.AbstractPage.html +7 -7
- package/docs/interfaces/_saltcorn_types.ModelAbstracts.abstract_role.AbstractRole.html +3 -3
- package/docs/interfaces/_saltcorn_types.ModelAbstracts.abstract_table.AbstractTable.html +7 -7
- package/docs/interfaces/_saltcorn_types.ModelAbstracts.abstract_trigger.AbstractTrigger.html +16 -16
- package/docs/interfaces/_saltcorn_types.ModelAbstracts.abstract_view.AbstractView.html +10 -10
- package/docs/interfaces/_saltcorn_types.ModelAbstracts.abstract_workflow.AbstractWorkflow.html +13 -13
- package/docs/modules/_saltcorn_admin_models.backup.html +1 -1
- package/docs/modules/_saltcorn_admin_models.html +1 -1
- package/docs/modules/_saltcorn_admin_models.pack.html +1 -1
- package/docs/modules/_saltcorn_admin_models.tenant.html +1 -1
- package/docs/modules/_saltcorn_common_code.html +1 -1
- package/docs/modules/_saltcorn_data.html +3 -3
- package/docs/modules/_saltcorn_data.models.Crash.html +2 -2
- package/docs/modules/_saltcorn_data.models.EventLog.html +2 -2
- package/docs/modules/_saltcorn_data.models.FieldRepeat.html +2 -2
- package/docs/modules/_saltcorn_data.models.File.html +2 -2
- package/docs/modules/_saltcorn_data.models.Form.html +2 -2
- package/docs/modules/_saltcorn_data.models.PageGroup.html +2 -2
- package/docs/modules/_saltcorn_data.models.Table.html +2 -2
- package/docs/modules/_saltcorn_data.models.TableConstraint.html +2 -2
- package/docs/modules/_saltcorn_data.models.User.html +2 -2
- package/docs/modules/_saltcorn_data.models.View.html +2 -2
- package/docs/modules/_saltcorn_data.models.Workflow.html +2 -2
- package/docs/modules/_saltcorn_data.models.config.html +1 -1
- package/docs/modules/_saltcorn_data.models.discovery.html +1 -1
- package/docs/modules/_saltcorn_data.models.email.html +1 -1
- package/docs/modules/_saltcorn_data.models.expression.html +1 -1
- package/docs/modules/_saltcorn_data.models.html +1 -1
- package/docs/modules/_saltcorn_data.models.layout.html +1 -1
- package/docs/modules/_saltcorn_data.models.random.html +1 -1
- package/docs/modules/_saltcorn_data.models.scheduler.html +1 -1
- package/docs/modules/_saltcorn_data.plugin_helper.html +1 -1
- package/docs/modules/_saltcorn_data.utils.html +1 -1
- package/docs/modules/_saltcorn_db_common.html +7 -7
- package/docs/modules/_saltcorn_db_common.multi_tenant.html +4 -2
- package/docs/modules/_saltcorn_markup.html +2 -2
- package/docs/modules/_saltcorn_mobile_builder.common_build_utils.html +1 -1
- package/docs/modules/_saltcorn_mobile_builder.html +1 -1
- package/docs/modules/_saltcorn_mobile_builder.package_bundle_utils.html +1 -1
- package/docs/modules/_saltcorn_sqlite.html +4 -2
- package/docs/modules/_saltcorn_sqlite_mobile.html +1 -1
- package/docs/modules/_saltcorn_types.ModelAbstracts.abstract_field.html +1 -1
- package/docs/modules/_saltcorn_types.ModelAbstracts.abstract_form.html +1 -1
- package/docs/modules/_saltcorn_types.ModelAbstracts.abstract_library.html +1 -1
- package/docs/modules/_saltcorn_types.ModelAbstracts.abstract_page.html +1 -1
- package/docs/modules/_saltcorn_types.ModelAbstracts.abstract_plugin.html +1 -1
- package/docs/modules/_saltcorn_types.ModelAbstracts.abstract_role.html +1 -1
- package/docs/modules/_saltcorn_types.ModelAbstracts.abstract_table.html +1 -1
- package/docs/modules/_saltcorn_types.ModelAbstracts.abstract_trigger.html +1 -1
- package/docs/modules/_saltcorn_types.ModelAbstracts.abstract_view.html +1 -1
- package/docs/modules/_saltcorn_types.ModelAbstracts.abstract_workflow.html +1 -1
- package/docs/modules/_saltcorn_types.ModelAbstracts.html +1 -1
- package/docs/modules/_saltcorn_types.Types.base_types.html +1 -1
- package/docs/modules/_saltcorn_types.Types.common_types.html +1 -1
- package/docs/modules/_saltcorn_types.Types.html +1 -1
- package/docs/modules/_saltcorn_types.generators.html +1 -1
- package/docs/modules/_saltcorn_types.html +1 -1
- package/docs/types/_saltcorn_data.models.Crash.CrashCfg.html +1 -1
- package/docs/types/_saltcorn_data.models.EventLog.EventLogCfg.html +1 -1
- package/docs/types/_saltcorn_data.models.FieldRepeat.FieldRepeatCfg.html +1 -1
- package/docs/types/_saltcorn_data.models.File.FileCfg.html +1 -1
- package/docs/types/_saltcorn_data.models.Form.AdditionalButton.html +1 -1
- package/docs/types/_saltcorn_data.models.Form.FormCfg.html +1 -1
- package/docs/types/_saltcorn_data.models.PageGroup.ScreenInfoParams.html +1 -1
- package/docs/types/_saltcorn_data.models.Table.ChildRelations.html +1 -1
- package/docs/types/_saltcorn_data.models.Table.ParentRelations.html +1 -1
- package/docs/types/_saltcorn_data.models.Table.RelationData.html +1 -1
- package/docs/types/_saltcorn_data.models.TableConstraint.TableConstraintCfg.html +1 -1
- package/docs/types/_saltcorn_data.models.User.UserCfg.html +1 -1
- package/docs/types/_saltcorn_data.models.View.FindViewsPred.html +1 -1
- package/docs/types/_saltcorn_data.models.Workflow.WorkflowCfg.html +1 -1
- package/docs/types/_saltcorn_db_common.AggregationOptions.html +2 -2
- package/docs/types/_saltcorn_db_common.CoordOpts.html +2 -2
- package/docs/types/_saltcorn_db_common.DatabaseClient.html +111 -0
- package/docs/types/_saltcorn_db_common.JoinField.html +2 -2
- package/docs/types/_saltcorn_db_common.JoinFields.html +2 -2
- package/docs/types/_saltcorn_db_common.JoinOptions.html +2 -2
- package/docs/types/_saltcorn_db_common.JsonPath.html +2 -2
- package/docs/types/_saltcorn_db_common.JsonPathElem.html +2 -2
- package/docs/types/_saltcorn_db_common.Operator.html +2 -2
- package/docs/types/_saltcorn_db_common.PrimaryKeyValue.html +2 -2
- package/docs/types/_saltcorn_db_common.Row.html +2 -2
- package/docs/types/_saltcorn_db_common.SelectOptions.html +5 -3
- package/docs/types/_saltcorn_db_common.SqlAndValues.html +2 -2
- package/docs/types/_saltcorn_db_common.SubselectOptions.html +2 -2
- package/docs/types/_saltcorn_db_common.Value.html +2 -2
- package/docs/types/_saltcorn_db_common.Where.html +2 -2
- package/docs/types/_saltcorn_mobile_builder.IosCfg.html +1 -1
- package/docs/types/_saltcorn_types.ModelAbstracts.abstract_field.FieldCfg.html +1 -1
- package/docs/types/_saltcorn_types.ModelAbstracts.abstract_field.InputType.html +1 -1
- package/docs/types/_saltcorn_types.ModelAbstracts.abstract_form.AdditionalButton.html +1 -1
- package/docs/types/_saltcorn_types.ModelAbstracts.abstract_library.LibraryCfg.html +1 -1
- package/docs/types/_saltcorn_types.ModelAbstracts.abstract_library.LibraryPack.html +1 -1
- package/docs/types/_saltcorn_types.ModelAbstracts.abstract_page.PageCfg.html +1 -1
- package/docs/types/_saltcorn_types.ModelAbstracts.abstract_page.PagePack.html +1 -1
- package/docs/types/_saltcorn_types.ModelAbstracts.abstract_plugin.PluginCfg.html +1 -1
- package/docs/types/_saltcorn_types.ModelAbstracts.abstract_plugin.PluginPack.html +1 -1
- package/docs/types/_saltcorn_types.ModelAbstracts.abstract_role.RoleCfg.html +1 -1
- package/docs/types/_saltcorn_types.ModelAbstracts.abstract_role.RolePack.html +1 -1
- package/docs/types/_saltcorn_types.ModelAbstracts.abstract_table.TableCfg.html +3 -3
- package/docs/types/_saltcorn_types.ModelAbstracts.abstract_table.TablePack.html +1 -1
- package/docs/types/_saltcorn_types.ModelAbstracts.abstract_trigger.TriggerCfg.html +1 -1
- package/docs/types/_saltcorn_types.ModelAbstracts.abstract_trigger.TriggerPack.html +1 -1
- package/docs/types/_saltcorn_types.ModelAbstracts.abstract_view.ViewCfg.html +1 -1
- package/docs/types/_saltcorn_types.ModelAbstracts.abstract_view.ViewPack.html +1 -1
- package/docs/types/_saltcorn_types.ModelAbstracts.abstract_workflow.ConfigWorkflowStep.html +1 -1
- package/docs/types/_saltcorn_types.ModelAbstracts.abstract_workflow.RunResult.html +1 -1
- package/docs/types/_saltcorn_types.Types.base_types.Action.html +1 -1
- package/docs/types/_saltcorn_types.Types.base_types.AuthenticationMethod.html +1 -1
- package/docs/types/_saltcorn_types.Types.base_types.CapacitorPlugin.html +1 -1
- package/docs/types/_saltcorn_types.Types.base_types.CodePagePack.html +1 -1
- package/docs/types/_saltcorn_types.Types.base_types.Column.html +1 -1
- package/docs/types/_saltcorn_types.Types.base_types.ConnectedObjects.html +1 -1
- package/docs/types/_saltcorn_types.Types.base_types.CopilotSkill.html +1 -1
- package/docs/types/_saltcorn_types.Types.base_types.FieldLike.html +1 -1
- package/docs/types/_saltcorn_types.Types.base_types.FieldView.html +1 -1
- package/docs/types/_saltcorn_types.Types.base_types.Header.html +1 -1
- package/docs/types/_saltcorn_types.Types.base_types.JoinFieldOption.html +1 -1
- package/docs/types/_saltcorn_types.Types.base_types.Layout.html +1 -1
- package/docs/types/_saltcorn_types.Types.base_types.MobileConfig.html +1 -1
- package/docs/types/_saltcorn_types.Types.base_types.ModelPattern.html +1 -1
- package/docs/types/_saltcorn_types.Types.base_types.Pack.html +1 -1
- package/docs/types/_saltcorn_types.Types.base_types.Plugin.html +1 -1
- package/docs/types/_saltcorn_types.Types.base_types.PluginFunction.html +1 -1
- package/docs/types/_saltcorn_types.Types.base_types.PluginLayout.html +1 -1
- package/docs/types/_saltcorn_types.Types.base_types.PluginRoute.html +1 -1
- package/docs/types/_saltcorn_types.Types.base_types.PluginSourceType.html +1 -1
- package/docs/types/_saltcorn_types.Types.base_types.PluginType.html +1 -1
- package/docs/types/_saltcorn_types.Types.base_types.PluginWrap.html +1 -1
- package/docs/types/_saltcorn_types.Types.base_types.PluginWrapArg.html +1 -1
- package/docs/types/_saltcorn_types.Types.base_types.RelationOption.html +1 -1
- package/docs/types/_saltcorn_types.Types.base_types.Req.html +1 -1
- package/docs/types/_saltcorn_types.Types.base_types.Res.html +1 -1
- package/docs/types/_saltcorn_types.Types.base_types.RouteAction.html +1 -1
- package/docs/types/_saltcorn_types.Types.base_types.RunExtra.html +1 -1
- package/docs/types/_saltcorn_types.Types.base_types.TableProvider.html +1 -1
- package/docs/types/_saltcorn_types.Types.base_types.TableQuery.html +1 -1
- package/docs/types/_saltcorn_types.Types.base_types.Tablely.html +1 -1
- package/docs/types/_saltcorn_types.Types.base_types.ViewTemplate.html +1 -1
- package/docs/types/_saltcorn_types.Types.common_types.ErrorMessage.html +1 -1
- package/docs/types/_saltcorn_types.Types.common_types.GenObj.html +1 -1
- package/docs/types/_saltcorn_types.Types.common_types.ReqRes.html +1 -1
- package/docs/types/_saltcorn_types.Types.common_types.ResultMessage.html +1 -1
- package/docs/types/_saltcorn_types.Types.common_types.SuccessMessage.html +1 -1
- package/docs/types/_saltcorn_types.Types.common_types.Type.html +1 -1
- package/docs/variables/_saltcorn_data.db.html +1 -1
- package/docs/variables/_saltcorn_data.migrations.html +1 -1
- package/docs/variables/_saltcorn_data.models.config.available_languages.html +1 -1
- package/docs/variables/_saltcorn_data.models.config.configTypes.html +1 -1
- package/docs/variables/_saltcorn_data.models.scheduler.runScheduler.html +1 -1
- package/docs/variables/_saltcorn_data.plugin_helper.run_action_column.html +1 -1
- package/docs/variables/_saltcorn_data.utils.NotAuthorized.html +1 -1
- package/docs/variables/_saltcorn_data.utils.sleep.html +1 -1
- package/docs/variables/_saltcorn_db_common.multi_tenant.tenantNamespace.html +4 -3
- package/locales/en.json +2 -0
- package/package.json +9 -9
- package/routes/actions.js +11 -2
- package/routes/admin.js +18 -7
- package/routes/api.js +49 -40
- package/routes/fields.js +54 -53
- package/routes/list.js +3 -1
- package/routes/menu.js +10 -8
- package/routes/models.js +4 -2
- package/routes/packs.js +19 -8
- package/routes/page.js +17 -13
- package/routes/page_groupedit.js +8 -0
- package/routes/pageedit.js +10 -1
- package/routes/registry.js +3 -1
- package/routes/sync.js +60 -72
- package/routes/tables.js +129 -90
- package/routes/utils.js +27 -17
- package/routes/viewedit.js +18 -2
- package/tests/auth.test.js +1 -1
- package/docs/functions/_saltcorn_db_common.single_tenant.getTenantSchema.html +0 -109
- package/docs/functions/_saltcorn_db_common.single_tenant.init.html +0 -115
- package/docs/functions/_saltcorn_db_common.single_tenant.is_it_multi_tenant.html +0 -109
- package/docs/functions/_saltcorn_db_common.single_tenant.runWithTenant.html +0 -129
- package/docs/modules/_saltcorn_db_common.single_tenant.html +0 -115
package/routes/sync.js
CHANGED
|
@@ -24,7 +24,7 @@ router.get(
|
|
|
24
24
|
})
|
|
25
25
|
);
|
|
26
26
|
|
|
27
|
-
const getSyncRows = async (syncInfo, table, syncUntil,
|
|
27
|
+
const getSyncRows = async (syncInfo, table, syncUntil, user) => {
|
|
28
28
|
const tblName = table.name;
|
|
29
29
|
const pkName = table.pk_name;
|
|
30
30
|
const minRole = table.min_role_read;
|
|
@@ -50,17 +50,17 @@ const getSyncRows = async (syncInfo, table, syncUntil, client, user) => {
|
|
|
50
50
|
}
|
|
51
51
|
const schema = db.getTenantSchemaPrefix();
|
|
52
52
|
if (!syncInfo.syncFrom) {
|
|
53
|
-
const { rows } = await
|
|
53
|
+
const { rows } = await db.query(
|
|
54
54
|
`select
|
|
55
55
|
info_tbl.ref "_sync_info_tbl_ref_",
|
|
56
56
|
info_tbl.last_modified "_sync_info_tbl_last_modified_",
|
|
57
57
|
info_tbl.deleted "_sync_info_tbl_deleted_",
|
|
58
58
|
data_tbl.*
|
|
59
59
|
from ${schema}"${db.sqlsanitize(
|
|
60
|
-
|
|
61
|
-
|
|
62
|
-
|
|
63
|
-
|
|
60
|
+
tblName
|
|
61
|
+
)}_sync_info" "info_tbl" right join "${db.sqlsanitize(
|
|
62
|
+
tblName
|
|
63
|
+
)}" "data_tbl"
|
|
64
64
|
on info_tbl.ref = data_tbl."${db.sqlsanitize(
|
|
65
65
|
pkName
|
|
66
66
|
)}" and info_tbl.deleted = false
|
|
@@ -77,17 +77,17 @@ const getSyncRows = async (syncInfo, table, syncUntil, client, user) => {
|
|
|
77
77
|
}
|
|
78
78
|
return rows;
|
|
79
79
|
} else {
|
|
80
|
-
const { rows } = await
|
|
80
|
+
const { rows } = await db.query(
|
|
81
81
|
`select
|
|
82
82
|
info_tbl.ref "_sync_info_tbl_ref_",
|
|
83
83
|
info_tbl.last_modified "_sync_info_tbl_last_modified_",
|
|
84
84
|
info_tbl.deleted "_sync_info_tbl_deleted_",
|
|
85
85
|
data_tbl.*
|
|
86
86
|
from ${schema}"${db.sqlsanitize(
|
|
87
|
-
|
|
88
|
-
|
|
89
|
-
|
|
90
|
-
|
|
87
|
+
tblName
|
|
88
|
+
)}_sync_info" "info_tbl" join ${schema}"${db.sqlsanitize(
|
|
89
|
+
tblName
|
|
90
|
+
)}" "data_tbl"
|
|
91
91
|
on info_tbl.ref = data_tbl."${db.sqlsanitize(pkName)}"
|
|
92
92
|
where date_trunc('milliseconds', info_tbl.last_modified) > to_timestamp(${
|
|
93
93
|
new Date(syncInfo.syncFrom).valueOf() / 1000.0
|
|
@@ -117,7 +117,6 @@ const getSyncRows = async (syncInfo, table, syncUntil, client, user) => {
|
|
|
117
117
|
router.post(
|
|
118
118
|
"/load_changes",
|
|
119
119
|
error_catcher(async (req, res) => {
|
|
120
|
-
const result = {};
|
|
121
120
|
const { syncInfos, loadUntil } = req.body || {};
|
|
122
121
|
if (!loadUntil) {
|
|
123
122
|
getState().log(2, `POST /load_changes: loadUntil is missing`);
|
|
@@ -128,62 +127,55 @@ router.post(
|
|
|
128
127
|
return res.status(400).json({ error: "syncInfos is missing" });
|
|
129
128
|
}
|
|
130
129
|
const role = req.user ? req.user.role_id : 100;
|
|
131
|
-
const client = await db.getClient();
|
|
132
|
-
let rowLimit = 1000;
|
|
133
130
|
try {
|
|
134
|
-
await
|
|
135
|
-
|
|
136
|
-
const
|
|
137
|
-
|
|
138
|
-
const
|
|
139
|
-
|
|
140
|
-
|
|
141
|
-
table
|
|
142
|
-
loadUntil,
|
|
143
|
-
|
|
144
|
-
|
|
145
|
-
|
|
146
|
-
|
|
147
|
-
|
|
148
|
-
|
|
149
|
-
|
|
150
|
-
(
|
|
151
|
-
|
|
152
|
-
|
|
153
|
-
|
|
154
|
-
} else if (table.ownership_formula) {
|
|
155
|
-
rows = rows.filter((row) => table.is_owner(req.user, row));
|
|
131
|
+
const result = await db.withTransaction(async () => {
|
|
132
|
+
let rowLimit = 1000;
|
|
133
|
+
const result = {};
|
|
134
|
+
|
|
135
|
+
for (const [tblName, syncInfo] of Object.entries(syncInfos)) {
|
|
136
|
+
const table = Table.findOne({ name: tblName });
|
|
137
|
+
if (!table) throw new Error(`The table '${tblName}' does not exists`);
|
|
138
|
+
const pkName = table.pk_name;
|
|
139
|
+
let rows = await getSyncRows(syncInfo, table, loadUntil, req.user);
|
|
140
|
+
if (!rows) continue;
|
|
141
|
+
if (role > table.min_role_read) {
|
|
142
|
+
if (
|
|
143
|
+
role === 100 ||
|
|
144
|
+
(!table.ownership_field_id && !table.ownership_formula)
|
|
145
|
+
)
|
|
146
|
+
continue;
|
|
147
|
+
else if (table.ownership_field_id) {
|
|
148
|
+
} else if (table.ownership_formula) {
|
|
149
|
+
rows = rows.filter((row) => table.is_owner(req.user, row));
|
|
150
|
+
}
|
|
156
151
|
}
|
|
152
|
+
if (rows.length > rowLimit) {
|
|
153
|
+
rows.splice(rowLimit);
|
|
154
|
+
}
|
|
155
|
+
rowLimit -= rows.length;
|
|
156
|
+
result[tblName] = {
|
|
157
|
+
rows,
|
|
158
|
+
maxLoadedId: rows.length > 0 ? rows[rows.length - 1][pkName] : 0,
|
|
159
|
+
};
|
|
157
160
|
}
|
|
158
|
-
|
|
159
|
-
|
|
160
|
-
}
|
|
161
|
-
rowLimit -= rows.length;
|
|
162
|
-
result[tblName] = {
|
|
163
|
-
rows,
|
|
164
|
-
maxLoadedId: rows.length > 0 ? rows[rows.length - 1][pkName] : 0,
|
|
165
|
-
};
|
|
166
|
-
}
|
|
167
|
-
await client.query("COMMIT");
|
|
161
|
+
return result;
|
|
162
|
+
});
|
|
168
163
|
res.json(result);
|
|
169
164
|
} catch (error) {
|
|
170
|
-
await client.query("ROLLBACK");
|
|
171
165
|
getState().log(2, `POST /load_changes: '${error.message}'`);
|
|
172
166
|
res.status(400).json({ error: error.message || error });
|
|
173
|
-
} finally {
|
|
174
|
-
client.release(true);
|
|
175
167
|
}
|
|
176
168
|
})
|
|
177
169
|
);
|
|
178
170
|
|
|
179
|
-
const getDelRows = async (tblName, syncFrom, syncUntil
|
|
171
|
+
const getDelRows = async (tblName, syncFrom, syncUntil) => {
|
|
180
172
|
const schema = db.getTenantSchemaPrefix();
|
|
181
|
-
const dbRes = await
|
|
173
|
+
const dbRes = await db.query(
|
|
182
174
|
`select *
|
|
183
175
|
from (
|
|
184
176
|
select ref, max(last_modified) from ${schema}"${db.sqlsanitize(
|
|
185
|
-
|
|
186
|
-
|
|
177
|
+
tblName
|
|
178
|
+
)}_sync_info"
|
|
187
179
|
group by ref, deleted having deleted = true) as alias
|
|
188
180
|
where alias.max < to_timestamp(${syncUntil.valueOf() / 1000.0})
|
|
189
181
|
and alias.max > to_timestamp(${syncFrom.valueOf() / 1000.0})`
|
|
@@ -203,31 +195,27 @@ router.post(
|
|
|
203
195
|
"/deletes",
|
|
204
196
|
error_catcher(async (req, res) => {
|
|
205
197
|
const { syncInfos, syncTimestamp } = req.body || {};
|
|
206
|
-
const client = await db.getClient();
|
|
207
198
|
try {
|
|
208
|
-
await
|
|
209
|
-
|
|
210
|
-
|
|
211
|
-
|
|
212
|
-
|
|
213
|
-
|
|
214
|
-
|
|
215
|
-
|
|
216
|
-
|
|
217
|
-
|
|
218
|
-
|
|
219
|
-
|
|
220
|
-
|
|
199
|
+
const result = await db.withTransaction(async () => {
|
|
200
|
+
const syncUntil = new Date(syncTimestamp);
|
|
201
|
+
const result = {
|
|
202
|
+
deletes: {},
|
|
203
|
+
};
|
|
204
|
+
for (const [tblName, syncInfo] of Object.entries(syncInfos)) {
|
|
205
|
+
if (syncInfo.syncFrom) {
|
|
206
|
+
result.deletes[tblName] = await getDelRows(
|
|
207
|
+
tblName,
|
|
208
|
+
new Date(syncInfo.syncFrom),
|
|
209
|
+
syncUntil
|
|
210
|
+
);
|
|
211
|
+
}
|
|
221
212
|
}
|
|
222
|
-
|
|
223
|
-
|
|
213
|
+
return result;
|
|
214
|
+
});
|
|
224
215
|
res.json(result);
|
|
225
216
|
} catch (error) {
|
|
226
|
-
await client.query("ROLLBACK");
|
|
227
217
|
getState().log(2, `POST /sync/deletes: '${error.message}'`);
|
|
228
218
|
res.status(400).json({ error: error.message || error });
|
|
229
|
-
} finally {
|
|
230
|
-
client.release(true);
|
|
231
219
|
}
|
|
232
220
|
})
|
|
233
221
|
);
|
package/routes/tables.js
CHANGED
|
@@ -373,6 +373,7 @@ router.post(
|
|
|
373
373
|
.map((t) => t.table_name);
|
|
374
374
|
const pack = await discover_tables(tableNames);
|
|
375
375
|
await implement_discovery(pack);
|
|
376
|
+
await getState().refresh_tables();
|
|
376
377
|
req.flash(
|
|
377
378
|
"success",
|
|
378
379
|
req.__("Discovered tables: %s", tableNames.join(", "))
|
|
@@ -469,6 +470,7 @@ router.post(
|
|
|
469
470
|
req.flash("error", parse_res.error);
|
|
470
471
|
res.redirect(`/table/create-from-csv`);
|
|
471
472
|
} else {
|
|
473
|
+
await getState().refresh_tables();
|
|
472
474
|
Trigger.emitEvent(
|
|
473
475
|
"AppChange",
|
|
474
476
|
`Table ${parse_res.table.name}`,
|
|
@@ -1247,11 +1249,15 @@ router.post(
|
|
|
1247
1249
|
res.redirect(`/table/provider-cfg/${table.id}`);
|
|
1248
1250
|
} else {
|
|
1249
1251
|
delete rest.provider_name;
|
|
1250
|
-
|
|
1251
|
-
|
|
1252
|
-
|
|
1253
|
-
|
|
1252
|
+
let table;
|
|
1253
|
+
await db.withTransaction(async () => {
|
|
1254
|
+
table = await Table.create(name, rest);
|
|
1255
|
+
Trigger.emitEvent("AppChange", `Table ${name}`, req.user, {
|
|
1256
|
+
entity_type: "Table",
|
|
1257
|
+
entity_name: name,
|
|
1258
|
+
});
|
|
1254
1259
|
});
|
|
1260
|
+
await getState().refresh_tables();
|
|
1255
1261
|
req.flash("success", req.__(`Table %s created`, name));
|
|
1256
1262
|
res.redirect(`/table/${table.id}`);
|
|
1257
1263
|
}
|
|
@@ -1299,8 +1305,10 @@ router.post(
|
|
|
1299
1305
|
rest.ownership_formula = rest.ownership_field_id.replace("Fml:", "");
|
|
1300
1306
|
rest.ownership_field_id = null;
|
|
1301
1307
|
} else rest.ownership_formula = null;
|
|
1302
|
-
await
|
|
1303
|
-
|
|
1308
|
+
await db.withTransaction(async () => {
|
|
1309
|
+
await table.update(rest);
|
|
1310
|
+
});
|
|
1311
|
+
await getState().refresh_tables();
|
|
1304
1312
|
if (!req.xhr) {
|
|
1305
1313
|
if (!old_versioned && rest.versioned)
|
|
1306
1314
|
req.flash(
|
|
@@ -1344,16 +1352,22 @@ router.post(
|
|
|
1344
1352
|
res.redirect(`/table`);
|
|
1345
1353
|
return;
|
|
1346
1354
|
}
|
|
1347
|
-
const views = await View.find(
|
|
1348
|
-
t.id ? { table_id: t.id } : { exttable_name: t.name }
|
|
1349
|
-
);
|
|
1350
|
-
for (const view of views) await view.delete();
|
|
1351
|
-
if (t.id) {
|
|
1352
|
-
const triggers = await Trigger.find({ table_id: t.id });
|
|
1353
|
-
for (const trig of triggers) await trig.delete();
|
|
1354
|
-
}
|
|
1355
1355
|
try {
|
|
1356
|
-
await
|
|
1356
|
+
await db.withTransaction(async () => {
|
|
1357
|
+
const views = await View.find(
|
|
1358
|
+
t.id ? { table_id: t.id } : { exttable_name: t.name }
|
|
1359
|
+
);
|
|
1360
|
+
for (const view of views) await view.delete();
|
|
1361
|
+
if (t.id) {
|
|
1362
|
+
const triggers = await Trigger.find({ table_id: t.id });
|
|
1363
|
+
for (const trig of triggers) await trig.delete();
|
|
1364
|
+
}
|
|
1365
|
+
|
|
1366
|
+
await t.delete();
|
|
1367
|
+
});
|
|
1368
|
+
await getState().refresh_tables();
|
|
1369
|
+
await getState().refresh_views();
|
|
1370
|
+
await getState().refresh_triggers();
|
|
1357
1371
|
req.flash("success", req.__(`Table %s deleted`, t.name));
|
|
1358
1372
|
res.redirect(`/table`);
|
|
1359
1373
|
} catch (err) {
|
|
@@ -1414,12 +1428,15 @@ router.post(
|
|
|
1414
1428
|
}
|
|
1415
1429
|
}
|
|
1416
1430
|
try {
|
|
1417
|
-
await
|
|
1418
|
-
|
|
1419
|
-
|
|
1420
|
-
|
|
1421
|
-
|
|
1431
|
+
await db.withTransaction(async () => {
|
|
1432
|
+
await t.delete();
|
|
1433
|
+
req.flash("success", req.__(`Table %s deleted`, t.name));
|
|
1434
|
+
Trigger.emitEvent("AppChange", `Table ${t.name} deleted`, req.user, {
|
|
1435
|
+
entity_type: "Table",
|
|
1436
|
+
entity_name: t.name,
|
|
1437
|
+
});
|
|
1422
1438
|
});
|
|
1439
|
+
await getState().refresh_tables();
|
|
1423
1440
|
res.redirect(`/table`);
|
|
1424
1441
|
} catch (err) {
|
|
1425
1442
|
req.flash("error", err.message);
|
|
@@ -1444,7 +1461,10 @@ router.post(
|
|
|
1444
1461
|
return;
|
|
1445
1462
|
}
|
|
1446
1463
|
try {
|
|
1447
|
-
await
|
|
1464
|
+
await db.withTransaction(async () => {
|
|
1465
|
+
await t.delete(true);
|
|
1466
|
+
});
|
|
1467
|
+
await getState().refresh_tables();
|
|
1448
1468
|
req.flash(
|
|
1449
1469
|
"success",
|
|
1450
1470
|
req.__(`Table %s forgotten. You can now discover it.`, t.name)
|
|
@@ -1850,11 +1870,15 @@ router.post(
|
|
|
1850
1870
|
.filter((f) => form.values[f]);
|
|
1851
1871
|
configuration.errormsg = form.values.errormsg;
|
|
1852
1872
|
} else configuration = form.values;
|
|
1853
|
-
await
|
|
1854
|
-
|
|
1855
|
-
|
|
1856
|
-
|
|
1873
|
+
await db.withTransaction(async () => {
|
|
1874
|
+
await TableConstraint.create({
|
|
1875
|
+
table_id: table.id,
|
|
1876
|
+
type,
|
|
1877
|
+
configuration,
|
|
1878
|
+
});
|
|
1857
1879
|
});
|
|
1880
|
+
await getState().refresh_tables();
|
|
1881
|
+
|
|
1858
1882
|
Trigger.emitEvent(
|
|
1859
1883
|
"AppChange",
|
|
1860
1884
|
`Constraint ${type} on table ${table?.name}`,
|
|
@@ -1943,8 +1967,12 @@ router.post(
|
|
|
1943
1967
|
form.validate(req.body || {});
|
|
1944
1968
|
if (form.hasErrors) req.flash("error", req.__("An error occurred"));
|
|
1945
1969
|
else {
|
|
1946
|
-
await
|
|
1970
|
+
await db.withTransaction(async () => {
|
|
1971
|
+
await table.rename(form.values.name);
|
|
1972
|
+
});
|
|
1973
|
+
await getState().refresh_tables();
|
|
1947
1974
|
}
|
|
1975
|
+
|
|
1948
1976
|
res.redirect(`/table/${table.id}`);
|
|
1949
1977
|
})
|
|
1950
1978
|
);
|
|
@@ -1962,7 +1990,10 @@ router.post(
|
|
|
1962
1990
|
error_catcher(async (req, res) => {
|
|
1963
1991
|
const { id } = req.params;
|
|
1964
1992
|
const cons = await TableConstraint.findOne({ id });
|
|
1965
|
-
await
|
|
1993
|
+
await db.withTransaction(async () => {
|
|
1994
|
+
await cons.delete();
|
|
1995
|
+
});
|
|
1996
|
+
await getState().refresh_tables();
|
|
1966
1997
|
res.redirect(`/table/constraints/${cons.table_id}`);
|
|
1967
1998
|
})
|
|
1968
1999
|
);
|
|
@@ -2216,10 +2247,12 @@ router.post(
|
|
|
2216
2247
|
const table = Table.findOne({ name });
|
|
2217
2248
|
|
|
2218
2249
|
try {
|
|
2219
|
-
await
|
|
2250
|
+
await db.withTransaction(async () => {
|
|
2251
|
+
await table.deleteRows({}, req.user, true);
|
|
2252
|
+
});
|
|
2220
2253
|
req.flash("success", req.__("Deleted all rows"));
|
|
2221
2254
|
} catch (e) {
|
|
2222
|
-
console.error(e)
|
|
2255
|
+
console.error(e);
|
|
2223
2256
|
req.flash("error", e.message);
|
|
2224
2257
|
}
|
|
2225
2258
|
|
|
@@ -2382,6 +2415,7 @@ router.post(
|
|
|
2382
2415
|
const workflow = get_provider_workflow(table, req);
|
|
2383
2416
|
const wfres = await workflow.run(req.body || {}, req);
|
|
2384
2417
|
respondWorkflow(table, workflow, wfres, req, res);
|
|
2418
|
+
await getState().refresh_tables();
|
|
2385
2419
|
})
|
|
2386
2420
|
);
|
|
2387
2421
|
|
|
@@ -2397,7 +2431,10 @@ router.post(
|
|
|
2397
2431
|
res.redirect(`/table`);
|
|
2398
2432
|
return;
|
|
2399
2433
|
}
|
|
2400
|
-
await
|
|
2434
|
+
await db.withTransaction(async () => {
|
|
2435
|
+
await table.repairCompositePrimary();
|
|
2436
|
+
});
|
|
2437
|
+
await getState().refresh_tables();
|
|
2401
2438
|
res.redirect(`/table/${table.id}`);
|
|
2402
2439
|
})
|
|
2403
2440
|
);
|
|
@@ -2415,68 +2452,70 @@ router.post(
|
|
|
2415
2452
|
res.redirect(`/table`);
|
|
2416
2453
|
return;
|
|
2417
2454
|
}
|
|
2418
|
-
|
|
2419
|
-
const
|
|
2420
|
-
|
|
2421
|
-
|
|
2422
|
-
|
|
2423
|
-
|
|
2424
|
-
|
|
2425
|
-
|
|
2426
|
-
|
|
2427
|
-
|
|
2428
|
-
|
|
2429
|
-
|
|
2430
|
-
|
|
2431
|
-
|
|
2432
|
-
|
|
2433
|
-
|
|
2434
|
-
|
|
2435
|
-
|
|
2436
|
-
|
|
2437
|
-
|
|
2438
|
-
|
|
2439
|
-
|
|
2440
|
-
|
|
2441
|
-
|
|
2442
|
-
|
|
2443
|
-
|
|
2444
|
-
|
|
2445
|
-
|
|
2446
|
-
|
|
2447
|
-
|
|
2448
|
-
|
|
2449
|
-
|
|
2450
|
-
|
|
2451
|
-
|
|
2452
|
-
|
|
2453
|
-
|
|
2454
|
-
|
|
2455
|
-
|
|
2456
|
-
|
|
2457
|
-
|
|
2458
|
-
|
|
2459
|
-
|
|
2460
|
-
|
|
2461
|
-
|
|
2462
|
-
|
|
2463
|
-
|
|
2464
|
-
|
|
2455
|
+
await db.withTransaction(async () => {
|
|
2456
|
+
const initial_view = async (table, viewtemplate) => {
|
|
2457
|
+
const configuration = await initial_config_all_fields(
|
|
2458
|
+
viewtemplate === "Edit"
|
|
2459
|
+
)({ table_id: table.id });
|
|
2460
|
+
//console.log(configuration);
|
|
2461
|
+
const name = `${viewtemplate} ${table.name}`;
|
|
2462
|
+
const view = await View.create({
|
|
2463
|
+
name,
|
|
2464
|
+
configuration,
|
|
2465
|
+
viewtemplate,
|
|
2466
|
+
table_id: table.id,
|
|
2467
|
+
min_role: 100,
|
|
2468
|
+
});
|
|
2469
|
+
return view;
|
|
2470
|
+
};
|
|
2471
|
+
const list = await initial_view(table, "List");
|
|
2472
|
+
const edit = await initial_view(table, "Edit");
|
|
2473
|
+
const show = await initial_view(table, "Show");
|
|
2474
|
+
await View.update(
|
|
2475
|
+
{
|
|
2476
|
+
configuration: {
|
|
2477
|
+
...list.configuration,
|
|
2478
|
+
columns: [
|
|
2479
|
+
...list.configuration.columns,
|
|
2480
|
+
{
|
|
2481
|
+
type: "ViewLink",
|
|
2482
|
+
view: `Own:Show ${table.name}`,
|
|
2483
|
+
view_name: `Show ${table.name}`,
|
|
2484
|
+
link_style: "",
|
|
2485
|
+
view_label: "Show",
|
|
2486
|
+
header_label: "Show",
|
|
2487
|
+
},
|
|
2488
|
+
{
|
|
2489
|
+
type: "ViewLink",
|
|
2490
|
+
view: `Own:Edit ${table.name}`,
|
|
2491
|
+
view_name: `Edit ${table.name}`,
|
|
2492
|
+
link_style: "",
|
|
2493
|
+
view_label: "Edit",
|
|
2494
|
+
header_label: "Edit",
|
|
2495
|
+
},
|
|
2496
|
+
{
|
|
2497
|
+
type: "Action",
|
|
2498
|
+
action_name: "Delete",
|
|
2499
|
+
action_style: "btn-primary",
|
|
2500
|
+
},
|
|
2501
|
+
],
|
|
2502
|
+
view_to_create: `Edit ${table.name}`,
|
|
2503
|
+
},
|
|
2465
2504
|
},
|
|
2466
|
-
|
|
2467
|
-
|
|
2468
|
-
|
|
2469
|
-
|
|
2470
|
-
|
|
2471
|
-
|
|
2472
|
-
|
|
2473
|
-
|
|
2474
|
-
|
|
2505
|
+
list.id
|
|
2506
|
+
);
|
|
2507
|
+
await View.update(
|
|
2508
|
+
{
|
|
2509
|
+
configuration: {
|
|
2510
|
+
...edit.configuration,
|
|
2511
|
+
view_when_done: `List ${table.name}`,
|
|
2512
|
+
destination_type: "View",
|
|
2513
|
+
},
|
|
2475
2514
|
},
|
|
2476
|
-
|
|
2477
|
-
|
|
2478
|
-
);
|
|
2479
|
-
|
|
2515
|
+
edit.id
|
|
2516
|
+
);
|
|
2517
|
+
});
|
|
2518
|
+
await getState().refresh_views();
|
|
2480
2519
|
res.redirect(`/table/${table.id}`);
|
|
2481
2520
|
})
|
|
2482
2521
|
);
|
package/routes/utils.js
CHANGED
|
@@ -164,7 +164,7 @@ const set_custom_http_headers = (res, req, state) => {
|
|
|
164
164
|
validateHeaderName(k);
|
|
165
165
|
validateHeaderValue(k, val);
|
|
166
166
|
res.header(k, val);
|
|
167
|
-
} catch (e) {
|
|
167
|
+
} catch (e) {
|
|
168
168
|
Crash.create(e, { url: "/", headers: {} });
|
|
169
169
|
}
|
|
170
170
|
}
|
|
@@ -200,7 +200,26 @@ const get_tenant_from_req = (req, hostPartsOffset) => {
|
|
|
200
200
|
* @param {function} next
|
|
201
201
|
*/
|
|
202
202
|
const setTenant = (req, res, next) => {
|
|
203
|
-
|
|
203
|
+
let wrap =
|
|
204
|
+
req.method === "POST" && !db.isSQLite
|
|
205
|
+
? (f) => {
|
|
206
|
+
db.getClient().then((client) => {
|
|
207
|
+
let released = false;
|
|
208
|
+
res.on("finish", function () {
|
|
209
|
+
if (!released) client.release();
|
|
210
|
+
released = true;
|
|
211
|
+
});
|
|
212
|
+
res.on("close", function () {
|
|
213
|
+
if (!released) client.release();
|
|
214
|
+
released = true;
|
|
215
|
+
});
|
|
216
|
+
f(client);
|
|
217
|
+
});
|
|
218
|
+
}
|
|
219
|
+
: (f) => {
|
|
220
|
+
f(null);
|
|
221
|
+
};
|
|
222
|
+
wrap((client) => {
|
|
204
223
|
// for a saltcorn mobile request use 'req.user.tenant'
|
|
205
224
|
if (req.smr) {
|
|
206
225
|
if (
|
|
@@ -212,7 +231,7 @@ const setTenant = (req, res, next) => {
|
|
|
212
231
|
setLanguage(req, res);
|
|
213
232
|
next();
|
|
214
233
|
} else {
|
|
215
|
-
db.runWithTenant(req.user.tenant, () => {
|
|
234
|
+
db.runWithTenant({ tenant: req.user.tenant, req, client }, () => {
|
|
216
235
|
setLanguage(req, res, state);
|
|
217
236
|
state.log(5, `${req.method} ${req.originalUrl}`);
|
|
218
237
|
next();
|
|
@@ -230,7 +249,7 @@ const setTenant = (req, res, next) => {
|
|
|
230
249
|
setLanguage(req, res);
|
|
231
250
|
next();
|
|
232
251
|
} else {
|
|
233
|
-
db.runWithTenant(other_domain, () => {
|
|
252
|
+
db.runWithTenant({ tenant: other_domain, req, client }, () => {
|
|
234
253
|
setLanguage(req, res, state);
|
|
235
254
|
if (state.logLevel >= 5)
|
|
236
255
|
state.log(
|
|
@@ -251,7 +270,7 @@ const setTenant = (req, res, next) => {
|
|
|
251
270
|
setLanguage(req, res);
|
|
252
271
|
next();
|
|
253
272
|
} else {
|
|
254
|
-
db.runWithTenant(ten, () => {
|
|
273
|
+
db.runWithTenant({ tenant: ten, req, client }, () => {
|
|
255
274
|
setLanguage(req, res, state);
|
|
256
275
|
if (state.logLevel >= 5)
|
|
257
276
|
state.log(
|
|
@@ -267,17 +286,7 @@ const setTenant = (req, res, next) => {
|
|
|
267
286
|
}
|
|
268
287
|
}
|
|
269
288
|
}
|
|
270
|
-
}
|
|
271
|
-
const state = getState();
|
|
272
|
-
setLanguage(req, res, state);
|
|
273
|
-
state.log(
|
|
274
|
-
5,
|
|
275
|
-
`${req.method} ${req.originalUrl}${
|
|
276
|
-
state.getConfig("log_ip_address", false) ? ` IP=${req.ip}` : ""
|
|
277
|
-
}`
|
|
278
|
-
);
|
|
279
|
-
next();
|
|
280
|
-
}
|
|
289
|
+
});
|
|
281
290
|
};
|
|
282
291
|
|
|
283
292
|
/**
|
|
@@ -504,7 +513,7 @@ const sendHtmlFile = async (req, res, file) => {
|
|
|
504
513
|
.sendWrap(req.__("An error occurred"), req.__("File not found"));
|
|
505
514
|
}
|
|
506
515
|
} catch (e) {
|
|
507
|
-
console.error(e)
|
|
516
|
+
console.error(e);
|
|
508
517
|
return res
|
|
509
518
|
.status(404)
|
|
510
519
|
.sendWrap(
|
|
@@ -531,6 +540,7 @@ const setRole = async (req, res, model) => {
|
|
|
531
540
|
roleRow && page
|
|
532
541
|
? req.__(`Minimum role for %s updated to %s`, page.name, roleRow.role)
|
|
533
542
|
: req.__(`Minimum role updated`);
|
|
543
|
+
if (model.state_refresh) await model.state_refresh();
|
|
534
544
|
if (!req.xhr) {
|
|
535
545
|
req.flash("success", message);
|
|
536
546
|
res.redirect("/pageedit");
|