Browse Source

Merge pull request #5832 from nocodb/fix/5814-reusing-tablename

fix: Clear alias cache when renaming table/view
pull/5839/head
Pranav C 2 years ago committed by GitHub
parent
commit
f81ed92e2d
No known key found for this signature in database
GPG Key ID: 4AEE18F83AFDEB23
  1. 12
      packages/nocodb/src/models/Model.ts
  2. 17
      packages/nocodb/src/models/View.ts
  3. 1
      packages/nocodb/src/modules/datas/helpers.ts
  4. 2
      packages/nocodb/tests/unit/rest/tests/viewRow.test.ts

12
packages/nocodb/src/models/Model.ts

@ -570,13 +570,25 @@ export default class Model implements TableType {
// get existing cache // get existing cache
const key = `${CacheScope.MODEL}:${tableId}`; const key = `${CacheScope.MODEL}:${tableId}`;
const o = await NocoCache.get(key, CacheGetType.TYPE_OBJECT); const o = await NocoCache.get(key, CacheGetType.TYPE_OBJECT);
let oldModel = { ...o };
// update alias // update alias
if (o) { if (o) {
o.title = title; o.title = title;
o.table_name = table_name; o.table_name = table_name;
// set cache // set cache
await NocoCache.set(key, o); await NocoCache.set(key, o);
} else {
oldModel = await this.get(tableId);
} }
// delete alias cache
await NocoCache.del(
`${CacheScope.MODEL}:${oldModel.project_id}:${oldModel.base_id}:${oldModel.title}`,
);
await NocoCache.del(
`${CacheScope.MODEL}:${oldModel.project_id}:${oldModel.title}`,
);
// set meta // set meta
return await ncMeta.metaUpdate( return await ncMeta.metaUpdate(
null, null,

17
packages/nocodb/src/models/View.ts

@ -1,3 +1,4 @@
import { title } from 'process';
import { isSystemColumn, UITypes, ViewTypes } from 'nocodb-sdk'; import { isSystemColumn, UITypes, ViewTypes } from 'nocodb-sdk';
import Noco from '../Noco'; import Noco from '../Noco';
import { import {
@ -165,13 +166,19 @@ export default class View implements ViewType {
], ],
}, },
); );
if (view) {
await NocoCache.set(
`${CacheScope.VIEW}:${fk_model_id}:${view.id}`,
view,
);
view.meta = parseMetaProp(view); view.meta = parseMetaProp(view);
// todo: cache - titleOrId can be viewId so we need a different scope here // todo: cache - titleOrId can be viewId so we need a different scope here
await NocoCache.set( await NocoCache.set(
`${CacheScope.VIEW}:${fk_model_id}:${titleOrId}`, `${CacheScope.VIEW}:${fk_model_id}:${titleOrId}`,
view.id, view.id,
); );
await NocoCache.set(`${CacheScope.VIEW}:${fk_model_id}:${view.id}`, view); }
return view && new View(view); return view && new View(view);
} }
return viewId && this.get(viewId?.id || viewId); return viewId && this.get(viewId?.id || viewId);
@ -952,6 +959,7 @@ export default class View implements ViewType {
// get existing cache // get existing cache
const key = `${CacheScope.VIEW}:${viewId}`; const key = `${CacheScope.VIEW}:${viewId}`;
let o = await NocoCache.get(key, CacheGetType.TYPE_OBJECT); let o = await NocoCache.get(key, CacheGetType.TYPE_OBJECT);
let oldView = { ...o };
if (o) { if (o) {
// update data // update data
o = { o = {
@ -963,8 +971,15 @@ export default class View implements ViewType {
} }
// set cache // set cache
await NocoCache.set(key, o); await NocoCache.set(key, o);
} else {
oldView = await this.get(viewId);
} }
// reset alias cache
await NocoCache.del(
`${CacheScope.VIEW}:${oldView.fk_model_id}:${oldView.title}`,
);
// if meta data defined then stringify it // if meta data defined then stringify it
if ('meta' in updateObj) { if ('meta' in updateObj) {
updateObj.meta = stringifyMetaProp(updateObj); updateObj.meta = stringifyMetaProp(updateObj);

1
packages/nocodb/src/modules/datas/helpers.ts

@ -43,6 +43,7 @@ export async function getViewAndModelByAliasOrId(param: {
fk_model_id: model.id, fk_model_id: model.id,
})); }));
if (!model) NcError.notFound('Table not found'); if (!model) NcError.notFound('Table not found');
if (param.viewName && !view) NcError.notFound('View not found');
return { model, view }; return { model, view };
} }

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

@ -780,7 +780,7 @@ function viewRowTests() {
.send({ .send({
title: 'Test', title: 'Test',
}) })
.expect(400); .expect(404);
}; };
it('Create table row grid wrong grid id', async function () { it('Create table row grid wrong grid id', async function () {

Loading…
Cancel
Save