Roundup Tracker - Issues

Issue 2551315

classification
Allow admin settable max number of rows to be returned by rest interface
Type: behavior Severity: normal
Components: Documentation, Web interface, API Versions: 2.5.0
process
Status: fixed fixed
:
: : rouilj
Priority: :

Created on 2024-02-12 20:32 by rouilj, last changed 2025-01-19 21:01 by rouilj.

Messages
msg7939 Author: [hidden] (rouilj) Date: 2024-02-12 20:32
First step to handling:

 https://owasp.org/API-Security/editions/2023/en/0xa4-unrestricted-resource-consumption/

If the user requests @page_size > limit, interpret as though the limit has been
used.

OWASP includes cpu use, memory use etc. Some of these can be handled by ulimit settings
when running under gnuicorn or uwsgi. When running in a container similar memory and cpu
limits can be set.

Note that there is no limit AFAIK on the number of rows that can be retrieved via the web
interface either.
msg8118 Author: [hidden] (rouilj) Date: 2024-07-18 02:57
This can be done using interfaces.py with:

  from roundup.rest import RestfulInstance
  RestfulInstance.max_response_row_size = 25

which limits the number of rows returned to 24 (one less than the setting).

With this in place:

   https://example.net/demo/rest/data/issue?@page_size=25

returns:

  {
    "error": {
        "status": 400,
        "msg": "Page size 25 must be less than admin limit on query result size: 25."
    }
  }

I think this is sufficient. I don't expect it to be used often. The default
limit is 10M rows.
History
Date User Action Args
2025-01-19 21:01:07rouiljsetstatus: open -> fixed
resolution: remind -> fixed
2024-07-18 02:57:41rouiljsetstatus: new -> open
resolution: remind
messages: + msg8118
components: + Documentation
versions: + 2.5.0
2024-02-12 20:32:28rouiljcreate