mirror of
https://github.com/ether/etherpad-lite.git
synced 2025-04-26 10:26:15 -04:00
ExportEtherpad: Support custom subkeys
This commit is contained in:
parent
4b2e2dd9f2
commit
88c0ab8255
4 changed files with 30 additions and 5 deletions
|
@ -15,6 +15,7 @@
|
|||
* limitations under the License.
|
||||
*/
|
||||
|
||||
const assert = require('assert').strict;
|
||||
const authorManager = require('../db/AuthorManager');
|
||||
const hooks = require('../../static/js/pluginfw/hooks');
|
||||
const padManager = require('../db/PadManager');
|
||||
|
@ -34,7 +35,14 @@ exports.getPadRaw = async (padId, readOnlyId) => {
|
|||
for (let i = 0; i <= pad.chatHead; ++i) data[`${pfx}:chat:${i}`] = await pad.getChatMessage(i);
|
||||
const prefixes = await hooks.aCallAll('exportEtherpadAdditionalContent');
|
||||
await Promise.all(prefixes.map(async (prefix) => {
|
||||
data[`${prefix}:${readOnlyId || padId}`] = await pad.db.get(`${prefix}:${padId}`);
|
||||
const srcPfx = `${prefix}:${padId}`;
|
||||
const dstPfx = `${prefix}:${readOnlyId || padId}`;
|
||||
data[dstPfx] = await pad.db.get(srcPfx);
|
||||
assert(!srcPfx.includes('*'));
|
||||
for (const k of await pad.db.findKeys(`${srcPfx}:*`, null)) {
|
||||
assert(k.startsWith(`${srcPfx}:`));
|
||||
data[`${dstPfx}:${k.slice(srcPfx.length + 1)}`] = await pad.db.get(k);
|
||||
}
|
||||
}));
|
||||
return data;
|
||||
};
|
||||
|
|
|
@ -30,24 +30,38 @@ describe(__filename, function () {
|
|||
it('exports custom records', async function () {
|
||||
const pad = await padManager.getPad(padId);
|
||||
await pad.db.set(`custom:${padId}`, 'a');
|
||||
await pad.db.set(`custom:${padId}:`, 'b');
|
||||
await pad.db.set(`custom:${padId}:foo`, 'c');
|
||||
const data = await exportEtherpad.getPadRaw(pad.id, null);
|
||||
assert.equal(data[`custom:${padId}`], 'a');
|
||||
assert.equal(data[`custom:${padId}:`], 'b');
|
||||
assert.equal(data[`custom:${padId}:foo`], 'c');
|
||||
});
|
||||
|
||||
it('export from read-only pad uses read-only ID', async function () {
|
||||
const pad = await padManager.getPad(padId);
|
||||
const readOnlyId = await readOnlyManager.getReadOnlyId(padId);
|
||||
await pad.db.set(`custom:${padId}`, 'a');
|
||||
await pad.db.set(`custom:${padId}:`, 'b');
|
||||
await pad.db.set(`custom:${padId}:foo`, 'c');
|
||||
const data = await exportEtherpad.getPadRaw(padId, readOnlyId);
|
||||
assert.equal(data[`custom:${readOnlyId}`], 'a');
|
||||
assert.equal(data[`custom:${readOnlyId}:`], 'b');
|
||||
assert.equal(data[`custom:${readOnlyId}:foo`], 'c');
|
||||
assert(!(`custom:${padId}` in data));
|
||||
assert(!(`custom:${padId}:` in data));
|
||||
assert(!(`custom:${padId}:foo` in data));
|
||||
});
|
||||
|
||||
it('does not export records from pad with similar ID', async function () {
|
||||
const pad = await padManager.getPad(padId);
|
||||
await pad.db.set(`custom:${padId}x`, 'a');
|
||||
await pad.db.set(`custom:${padId}x:`, 'b');
|
||||
await pad.db.set(`custom:${padId}x:foo`, 'c');
|
||||
const data = await exportEtherpad.getPadRaw(pad.id, null);
|
||||
assert(!(`custom:${padId}x` in data));
|
||||
assert(!(`custom:${padId}x:` in data));
|
||||
assert(!(`custom:${padId}x:foo` in data));
|
||||
});
|
||||
});
|
||||
});
|
||||
|
|
Loading…
Add table
Add a link
Reference in a new issue