mirror of https://github.com/nocodb/nocodb
Pranav C
11 months ago
2 changed files with 68 additions and 0 deletions
@ -0,0 +1,66 @@
|
||||
import { UITypes } from 'nocodb-sdk'; |
||||
import { Logger } from '@nestjs/common'; |
||||
import type { NcUpgraderCtx } from './NcUpgrader'; |
||||
import type { MetaService } from '~/meta/meta.service'; |
||||
import { MetaTable } from '~/utils/globals'; |
||||
import { Column, Model } from '~/models'; |
||||
|
||||
// An upgrader for upgrading created_at and updated_at columns
|
||||
// to system column and convert to new uidt CreateTime and LastModifiedTime
|
||||
|
||||
const logger = new Logger('XcdbCreatedAndUpdatedTimeUpgrader'); |
||||
|
||||
async function upgradeModels({ |
||||
ncMeta, |
||||
source, |
||||
}: { |
||||
ncMeta: MetaService; |
||||
source: any; |
||||
}) { |
||||
const models = await Model.list( |
||||
{ |
||||
base_id: source.base_id, |
||||
source_id: source.id, |
||||
}, |
||||
ncMeta, |
||||
); |
||||
|
||||
await Promise.all( |
||||
models.map(async (model: any) => { |
||||
const columns = await model.getColumns(ncMeta); |
||||
for (const column of columns) { |
||||
if (column.column_name === 'created_at') { |
||||
await Column.update(column.id, { |
||||
uidt: UITypes.CreateTime, |
||||
system: true, |
||||
}); |
||||
} |
||||
if (column.uidt === 'updated_at') { |
||||
await Column.update(column.id, { |
||||
uidt: UITypes.LastModifiedTime, |
||||
system: true, |
||||
}); |
||||
} |
||||
} |
||||
logger.log(`Upgraded model ${model.name} from source ${source.name}`); |
||||
}), |
||||
); |
||||
} |
||||
|
||||
// database to virtual relation and create an index for it
|
||||
export default async function ({ ncMeta }: NcUpgraderCtx) { |
||||
// get all xcdb sources
|
||||
const sources = await ncMeta.metaList2(null, null, MetaTable.BASES, { |
||||
condition: { |
||||
is_meta: 1, |
||||
}, |
||||
orderBy: {}, |
||||
}); |
||||
|
||||
// iterate and upgrade each base
|
||||
for (const source of sources) { |
||||
logger.log(`Upgrading source ${source.name}`); |
||||
// update the meta props
|
||||
await upgradeModels({ ncMeta, source }); |
||||
} |
||||
} |
Loading…
Reference in new issue