feat: refs #7524 wip remote hooks
gitea/salix/pipeline/pr-dev This commit looks good Details

This commit is contained in:
Jorge Penadés 2024-08-07 10:12:54 +02:00
parent b3b7e9c213
commit b64b91e50f
1 changed files with 22 additions and 10 deletions

View File

@ -28,21 +28,33 @@ module.exports = function(Self) {
};
});
/*
* Intercept GET request for find
*/
this.beforeRemote('find', async ctx => {
isSelect = true;
const filter = ctx.args.filter || {};
if (filter.limit === undefined) {
filter.limit = this.app.orm.selectLimit;
const defaultLimit = this.app.orm.selectLimit;
const filter = ctx.args.filter || {limit: defaultLimit};
if (filter.limit > defaultLimit) {
filter.limit = defaultLimit;
ctx.args.filter = filter;
}
});
this.observe('loaded', async({data}) => {
if (!isSelect) return;
const length = Array.isArray(data) ? data.length : data ? 1 : 0;
this.afterRemote('find', async({result}) => {
const length = Array.isArray(result) ? result.length : result ? 1 : 0;
if (length >= this.app.orm.selectLimit) throw new UserError('Too many records');
});
this.beforeRemote('filter', async ctx => {
const defaultLimit = this.app.orm.selectLimit;
const filter = ctx.args.filter || {limit: defaultLimit};
if (filter.limit > defaultLimit) {
filter.limit = defaultLimit;
ctx.args.filter = filter;
}
});
this.afterRemote('filter', async({result}) => {
const length = Array.isArray(result) ? result.length : result ? 1 : 0;
if (length >= this.app.orm.selectLimit) throw new UserError('Too many records');
});