1
0
mirror of https://github.com/laurent22/joplin.git synced 2025-01-08 13:06:15 +02:00
joplin/packages/lib/migrations/20.js
2024-08-02 14:51:49 +01:00

30 lines
853 B
JavaScript

const Resource = require('../models/Resource').default;
const Setting = require('../models/Setting').default;
const shim = require('../shim').default;
const { reg } = require('../registry');
const { fileExtension } = require('../path-utils');
const script = {};
script.exec = async function() {
const stats = await shim.fsDriver().readDirStats(Setting.value('resourceDir'));
let queries = [];
for (const stat of stats) {
if (fileExtension(stat.path) === 'crypted') continue;
const resourceId = Resource.pathToId(stat.path);
if (!resourceId) continue;
queries.push({ sql: 'UPDATE resources SET `size` = ? WHERE id = ?', params: [stat.size, resourceId] });
if (queries.length >= 1000) {
await reg.db().transactionExecBatch(queries);
queries = [];
}
}
await reg.db().transactionExecBatch(queries);
};
module.exports = script;