Merge pull request #842 from andresmrm/list-api-endpoints

Add API enpoints to create, delete and get lists.
This commit is contained in:
Tomas Bures 2020-05-27 21:02:24 +02:00 committed by GitHub
commit ebfbe30aa0
No known key found for this signature in database
GPG key ID: 4AEE18F83AFDEB23
4 changed files with 187 additions and 0 deletions

View file

@ -121,6 +121,32 @@ async function getByCid(context, cid) {
});
}
async function getByNamespaceIdTx(tx, context, namespaceId) {
// FIXME - this methods is rather suboptimal if there are many lists. It quite needs permission caching in shares.js
const rows = await tx('lists').where('namespace', namespaceId);
await shares.enforceEntityPermissionTx(tx, context, 'namespace', namespaceId, 'view');
const allowed = [];
for (const list of rows) {
try {
await shares.enforceEntityPermissionTx(tx, context, 'list', list.id, 'view');
} catch(e) {
continue
}
allowed.push(list);
}
return allowed;
}
async function getByNamespaceId(context, namespaceId) {
return await knex.transaction(async tx => {
return getByNamespaceIdTx(tx, context, namespaceId);
});
}
async function _validateAndPreprocess(tx, entity) {
await namespaceHelpers.validateEntity(tx, entity);
enforce(entity.unsubscription_mode >= UnsubscriptionMode.MIN && entity.unsubscription_mode <= UnsubscriptionMode.MAX, 'Unknown unsubscription mode');
@ -283,6 +309,7 @@ module.exports.getById = getById;
module.exports.getByIdWithListFields = getByIdWithListFields;
module.exports.getByCidTx = getByCidTx;
module.exports.getByCid = getByCid;
module.exports.getByNamespaceId = getByNamespaceId;
module.exports.create = create;
module.exports.updateWithConsistencyCheck = updateWithConsistencyCheck;
module.exports.remove = remove;