From 9a49252ae7a588cedb85cd3298fdd7ba1746dada Mon Sep 17 00:00:00 2001 From: mike12345567 Date: Thu, 25 Feb 2021 15:21:08 +0000 Subject: [PATCH] Updating link controller to manage existing column comparison a bit better. --- .../src/db/linkedRows/LinkController.js | 19 +++++++++++++++++-- 1 file changed, 17 insertions(+), 2 deletions(-) diff --git a/packages/server/src/db/linkedRows/LinkController.js b/packages/server/src/db/linkedRows/LinkController.js index b01d5eede5..b629c4b1f0 100644 --- a/packages/server/src/db/linkedRows/LinkController.js +++ b/packages/server/src/db/linkedRows/LinkController.js @@ -3,7 +3,6 @@ const { IncludeDocs, getLinkDocuments } = require("./linkUtils") const { generateLinkID } = require("../utils") const Sentry = require("@sentry/node") const { FieldTypes, RelationshipTypes } = require("../../constants") -const { isEqual } = require("lodash") /** * Creates a new link document structure which can be put to the database. It is important to @@ -133,6 +132,19 @@ class LinkController { } } + /** + * Returns whether the two schemas are equal (in the important parts, not a pure equality check) + */ + areSchemasEqual(schema1, schema2) { + const compareFields = ["name", "type", "tableId", "fieldName", "autocolumn"] + for (let field of compareFields) { + if (schema1[field] !== schema2[field]) { + return false + } + } + return true + } + // all operations here will assume that the table // this operation is related to has linked rows /** @@ -315,7 +327,10 @@ class LinkController { } // check the linked table to make sure we aren't overwriting an existing column const existingSchema = linkedTable.schema[field.fieldName] - if (existingSchema != null && !isEqual(existingSchema, linkConfig)) { + if ( + existingSchema != null && + !this.areSchemasEqual(existingSchema, linkConfig) + ) { throw new Error("Cannot overwrite existing column.") } // create the link field in the other table