Browse Source

fix: link audit - handle if relation is between non-pk columns

pull/8367/head
Pranav C 5 months ago
parent
commit
3eaa2d984c
  1. 40
      packages/nocodb/src/db/BaseModelSqlv2.ts
  2. 2
      packages/nocodb/tests/unit/rest/tests/column.test.ts

40
packages/nocodb/src/db/BaseModelSqlv2.ts

@ -2190,7 +2190,7 @@ class BaseModelSqlv2 {
)) as LinkToAnotherRecordColumn; )) as LinkToAnotherRecordColumn;
const mmTable = await relColOptions.getMMModel(this.context); const mmTable = await relColOptions.getMMModel(this.context);
const assocBaseModel = await Model.getBaseModelSQL(this.context,{ const assocBaseModel = await Model.getBaseModelSQL(this.context, {
id: mmTable.id, id: mmTable.id,
dbDriver: this.dbDriver, dbDriver: this.dbDriver,
}); });
@ -2407,7 +2407,7 @@ class BaseModelSqlv2 {
const childView = await relColOptions.getChildView(this.context); const childView = await relColOptions.getChildView(this.context);
const childBaseModel = await Model.getBaseModelSQL(this.context,{ const childBaseModel = await Model.getBaseModelSQL(this.context, {
dbDriver: this.dbDriver, dbDriver: this.dbDriver,
model: childTable, model: childTable,
}); });
@ -2476,7 +2476,7 @@ class BaseModelSqlv2 {
dbDriver: this.dbDriver, dbDriver: this.dbDriver,
model: childTable, model: childTable,
}); });
const childBaseModel = await Model.getBaseModelSQL(this.context,{ const childBaseModel = await Model.getBaseModelSQL(this.context, {
dbDriver: this.dbDriver, dbDriver: this.dbDriver,
model: childTable, model: childTable,
}); });
@ -2580,7 +2580,7 @@ class BaseModelSqlv2 {
await relColOptions.getChildColumn(this.context) await relColOptions.getChildColumn(this.context)
).getModel(this.context); ).getModel(this.context);
const parentBaseModel = await Model.getBaseModelSQL(this.context,{ const parentBaseModel = await Model.getBaseModelSQL(this.context, {
dbDriver: this.dbDriver, dbDriver: this.dbDriver,
model: parentTable, model: parentTable,
}); });
@ -2646,11 +2646,11 @@ class BaseModelSqlv2 {
).getModel(this.context); ).getModel(this.context);
const childView = await relColOptions.getChildView(this.context); const childView = await relColOptions.getChildView(this.context);
const parentBaseModel = await Model.getBaseModelSQL(this.context,{ const parentBaseModel = await Model.getBaseModelSQL(this.context, {
dbDriver: this.dbDriver, dbDriver: this.dbDriver,
model: parentTable, model: parentTable,
}); });
const childBaseModel = await Model.getBaseModelSQL(this.context,{ const childBaseModel = await Model.getBaseModelSQL(this.context, {
dbDriver: this.dbDriver, dbDriver: this.dbDriver,
model: childTable, model: childTable,
}); });
@ -5587,12 +5587,12 @@ class BaseModelSqlv2 {
await childTable.getColumns(this.context); await childTable.getColumns(this.context);
await parentTable.getColumns(this.context); await parentTable.getColumns(this.context);
const parentBaseModel = await Model.getBaseModelSQL(this.context,{ const parentBaseModel = await Model.getBaseModelSQL(this.context, {
model: parentTable, model: parentTable,
dbDriver: this.dbDriver, dbDriver: this.dbDriver,
}); });
const childBaseModel = await Model.getBaseModelSQL(this.context,{ const childBaseModel = await Model.getBaseModelSQL(this.context, {
dbDriver: this.dbDriver, dbDriver: this.dbDriver,
model: childTable, model: childTable,
}); });
@ -5654,7 +5654,7 @@ class BaseModelSqlv2 {
const vParentCol = await colOptions.getMMParentColumn(this.context); const vParentCol = await colOptions.getMMParentColumn(this.context);
const vTable = await colOptions.getMMModel(this.context); const vTable = await colOptions.getMMModel(this.context);
const assocBaseModel = await Model.getBaseModelSQL(this.context,{ const assocBaseModel = await Model.getBaseModelSQL(this.context, {
model: vTable, model: vTable,
dbDriver: this.dbDriver, dbDriver: this.dbDriver,
}); });
@ -5722,6 +5722,7 @@ class BaseModelSqlv2 {
{ {
const linkedHmRowObj = await this.execAndParse( const linkedHmRowObj = await this.execAndParse(
this.dbDriver(childTn) this.dbDriver(childTn)
.select(childTable.primaryKeys.map((pk) => pk.column_name))
.select(`${childTable.table_name}.${childColumn.column_name}`) .select(`${childTable.table_name}.${childColumn.column_name}`)
.where(_wherePk(childTable.primaryKeys, childId)), .where(_wherePk(childTable.primaryKeys, childId)),
null, null,
@ -5729,7 +5730,7 @@ class BaseModelSqlv2 {
); );
const oldRowId = linkedHmRowObj const oldRowId = linkedHmRowObj
? Object.values(linkedHmRowObj)?.[0] ? linkedHmRowObj?.[childTable.primaryKey?.column_name]
: null; : null;
if (oldRowId) { if (oldRowId) {
@ -5834,6 +5835,7 @@ class BaseModelSqlv2 {
} else { } else {
const linkedHmRowObj = await this.execAndParse( const linkedHmRowObj = await this.execAndParse(
this.dbDriver(childTn) this.dbDriver(childTn)
.select(childTable.primaryKeys.map((pk) => pk.column_name))
.select(childColumn.column_name) .select(childColumn.column_name)
.where(_wherePk(childTable.primaryKeys, rowId)), .where(_wherePk(childTable.primaryKeys, rowId)),
null, null,
@ -5841,7 +5843,7 @@ class BaseModelSqlv2 {
); );
const oldChildRowId = linkedHmRowObj const oldChildRowId = linkedHmRowObj
? Object.values(linkedHmRowObj)?.[0] ? linkedHmRowObj[childTable.primaryKeys[0]?.column_name]
: null; : null;
if (oldChildRowId) { if (oldChildRowId) {
@ -5913,6 +5915,7 @@ class BaseModelSqlv2 {
// 1. check current row is linked with another child // 1. check current row is linked with another child
linkedCurrentOoRowObj = await this.execAndParse( linkedCurrentOoRowObj = await this.execAndParse(
this.dbDriver(childTn) this.dbDriver(childTn)
.select(childTable.primaryKeys.map((pk) => pk.column_name))
.select(childColumn.column_name) .select(childColumn.column_name)
.where(_wherePk(childTable.primaryKeys, rowId)), .where(_wherePk(childTable.primaryKeys, rowId)),
null, null,
@ -5920,7 +5923,7 @@ class BaseModelSqlv2 {
); );
const oldChildRowId = linkedCurrentOoRowObj const oldChildRowId = linkedCurrentOoRowObj
? Object.values(linkedCurrentOoRowObj)?.[0] ? linkedCurrentOoRowObj[childTable.primaryKeys[0]?.column_name]
: null; : null;
if (oldChildRowId) { if (oldChildRowId) {
@ -6062,6 +6065,7 @@ class BaseModelSqlv2 {
// 2. check current child is linked with another row cell // 2. check current child is linked with another row cell
linkedOoRowObj = await this.execAndParse( linkedOoRowObj = await this.execAndParse(
this.dbDriver(childTn) this.dbDriver(childTn)
.select(childColumn.column_name)
.select(childColumn.column_name) .select(childColumn.column_name)
.where(_wherePk(childTable.primaryKeys, childId)), .where(_wherePk(childTable.primaryKeys, childId)),
null, null,
@ -6260,12 +6264,12 @@ class BaseModelSqlv2 {
await childTable.getColumns(this.context); await childTable.getColumns(this.context);
await parentTable.getColumns(this.context); await parentTable.getColumns(this.context);
const parentBaseModel = await Model.getBaseModelSQL(this.context,{ const parentBaseModel = await Model.getBaseModelSQL(this.context, {
model: parentTable, model: parentTable,
dbDriver: this.dbDriver, dbDriver: this.dbDriver,
}); });
const childBaseModel = await Model.getBaseModelSQL(this.context,{ const childBaseModel = await Model.getBaseModelSQL(this.context, {
dbDriver: this.dbDriver, dbDriver: this.dbDriver,
model: childTable, model: childTable,
}); });
@ -6304,7 +6308,7 @@ class BaseModelSqlv2 {
const vChildCol = await colOptions.getMMChildColumn(this.context); const vChildCol = await colOptions.getMMChildColumn(this.context);
const vParentCol = await colOptions.getMMParentColumn(this.context); const vParentCol = await colOptions.getMMParentColumn(this.context);
const vTable = await colOptions.getMMModel(this.context); const vTable = await colOptions.getMMModel(this.context);
const assocBaseModel = await Model.getBaseModelSQL(this.context,{ const assocBaseModel = await Model.getBaseModelSQL(this.context, {
model: vTable, model: vTable,
dbDriver: this.dbDriver, dbDriver: this.dbDriver,
}); });
@ -7367,12 +7371,12 @@ class BaseModelSqlv2 {
await childTable.getColumns(this.context); await childTable.getColumns(this.context);
await parentTable.getColumns(this.context); await parentTable.getColumns(this.context);
const childBaseModel = await Model.getBaseModelSQL(this.context,{ const childBaseModel = await Model.getBaseModelSQL(this.context, {
model: childTable, model: childTable,
dbDriver: this.dbDriver, dbDriver: this.dbDriver,
}); });
const parentBaseModel = await Model.getBaseModelSQL(this.context,{ const parentBaseModel = await Model.getBaseModelSQL(this.context, {
model: childTable, model: childTable,
dbDriver: this.dbDriver, dbDriver: this.dbDriver,
}); });
@ -7757,7 +7761,7 @@ class BaseModelSqlv2 {
await childTable.getColumns(this.context); await childTable.getColumns(this.context);
await parentTable.getColumns(this.context); await parentTable.getColumns(this.context);
const childBaseModel = await Model.getBaseModelSQL(this.context,{ const childBaseModel = await Model.getBaseModelSQL(this.context, {
model: childTable, model: childTable,
dbDriver: this.dbDriver, dbDriver: this.dbDriver,
}); });

2
packages/nocodb/tests/unit/rest/tests/column.test.ts

@ -23,7 +23,7 @@ function columnTests() {
}, },
]; ];
describe('Advance Column', () => { describe('Advanced Column', () => {
beforeEach(async function () { beforeEach(async function () {
console.time('#### columnTypeSpecificTests'); console.time('#### columnTypeSpecificTests');
context = await init(true); context = await init(true);

Loading…
Cancel
Save