-
-
Notifications
You must be signed in to change notification settings - Fork 677
New issue
Have a question about this project? Sign up for a free GitHub account to open an issue and contact its maintainers and the community.
By clicking “Sign up for GitHub”, you agree to our terms of service and privacy statement. We’ll occasionally send you account related emails.
Already on GitHub? Sign in to your account
Discussion: Too much and/or sensitive information in (mostly API) responses #934
Comments
Category and requirement text - probably direction should be current requirement 8.1.3:
|
I do not think it's enough to say "just minimize parameters, etc". What you're really asking is that we only include data in JSON (1) that the user has access to and (2) that the application actually needs. And I'm confused, the original post is about responses, but the last comment was about requests? |
8.1.3 was taken as an example, where (to what category) to place it in ASVS. Requirement itself is for response. |
I personally see this as a pure access control requirement. And it's a core principle. I suggest 4.1 or 4.3 |
Yes, part of that is authorization problem and initially I was thinking about this problem more like V4.* problem. I have seen examples where frontend needs list of titles, but entire entity datasets are provided ended up responses with size of many MB. |
I am with you 100% and think this is a great idea for a new requirement! Even if the user has access to the data, it should not be sent to the client unless the user has access AND the app actually needs that data! :) |
+1 on this requirement, I actually saw a badly designed/implemented app where the whole API is sending everything to the front-end to make the application's response "faster" but it ended up including a bunch of sensitive information that should never be there in the first place. |
Should "sensitive" be inserted into ASVS Level 1 to mirror the use of the term "sensitive" within the description of ASVS Level 2? |
todo, check requirement 13.1.3 as potential duplicate or place to merge, if we can find some solution here:
|
This is not a problem with API’s it's a problem with any Url due to referrer headers, logs, browser history and similar.
|
this is what you described, is covered by 8.3.1
the problem is not the method how sensitive data is sent to client, the problem is the fact that sensitive data is exposed to the client. |
Access control part maybe can be merged to current 1.4.5 (this one need to be moved to V4): |
Which of the following problem options are we suggesting that this is:
|
V4 Access Control at the JSON attribute level, i.e. you can get the user's firstname and last name but not their password hash, even if it is in the same conceptual object/entity. Business Logic - Verify that data pagination is enforced at the server side so that the amount of data that can be accessed at once is limited, matching the limit enforced at the front-end. Too many fields (which the user is permitted to access) seems a little too specific and niche and probably not a serious issue. @set-reminder 5 weeks @tghosth to look at this. |
⏰ Reminder
|
@elarlang should we work on this now or wait for the full access control reorg? |
We can work on this now but I prefer we take one topic and cover it all at once. Otherwise at the moment I should put my time (again) to investigate all the background and history for give answer and then it waits again few months... and we need to start again from the start. |
Problem 1 - the application returns data, the user does not need to see - unintended (potentially sensitive) information leakage It is not an authorization decision problem - a user may have access to read the object (e. g. user), but not the served attribute of that object (e. g. password hash) Needs a separate requirement. The requirement can be in V4 or V8. Problem 2 - possible to ask too many rows to the output - bypassing anti-automation, resource-demanding response building (potential DoS vector) In general, it's a missing (business logic) input validation problem and seems to be covered by:
To have a separate requirement to say "validate the rows-per-page parameter" seems a bit too detailed, but at the same time, it is a really widespread problem (based on my experience). Problem 3 - too much (not needed) data in the output - resource-demanding response buildng (potential DoS vector) We have the requirement:
Although pointed out problem is not how to avoid the call to resource-demanding response building, but how to avoid that such unnecessary resource-wasting functionality as potential Denial-of-Service vectors exist. Do we consider the problem covered by 11.2.2 or is it worth separate mention somehow? |
I read this thread carefully. I think the access control issue is really important and should go into the access control re-org. The performance issue to too much data is a DOS issue that is really easy to fix. I don't think DOS is a really big deal in most apps, even though it is in some. I would suggest we focus on the access control issue and drop DOS issues for the sake of brevity. I think the access control issues is super critical. The DOS issues described is rarely very critical (but can be on a rare occasion). |
Does the 4th bullet of this comment solve this @elarlang?
Yeah I think that is covered by 11.1.3 and you could also argue that it is covered by the updated 5.1.3.
Feels like this is covered by 11.2.2 and maybe also the updated 5.1.3. |
The linked requirement is added to V1.4 Access Control Architecture via #2065 / #2123
I would say that is not cover the problem statement:
1.4.7 asks to describe the attributes, based on what you going to make access control decisions. "Problem 1" needs to point out attributes, that you can or can not see/access. |
Ok well hopefully @EnigmaRosa will see this as part of here work on V4, and make sure that the access control requirements cover all the various dimensions that I mentioned here: #2065 (comment)
|
As I pointed out previously (#934 (comment)) - if we talk about V4 as "access control decisions", then the requirement is not a V4 requirement. But I'm not sure there is better place for that. A seed for future development:
|
I would think that the language in 1.4.7, specifically "documentation defines the rules for access controls" meets the dimensions @tghosth pointed out. I don't know if those points can go unsaid, if we should outline them in guidance, or create another verification requirement surrounding the dimensions (which I feel would be redundant). With regards to the specific concern @elarlang posed, I like the requirement he proposed as a 4.1.x or 4.2.x |
Ok so let's leave the dimensions in section guidance for either 1.4.x or 4.x.x. Can you open a PR for that @EnigmaRosa? @elarlang I'd be comfortable for your proposed requirement to go into 4.1.x or 4.2.x as Shanni suggested. Do you agree? |
Well, it expects that V4.1 and V4.2 have clear definition, what kind of requirements belong there (#2139). By principle, returning too much data is not about an authorization decision, but just an incorrect behavior from the application. It is pretty much the same problem as mass parameter assignment (ASVS v4.0.3-5.1.2) that we placed to "V10.4 Defensive Coding" as V10.4.4. |
Should section guidance go right before the verification requirements? @elarlang I didn't realize we now have a defensive coding section, your requirement might fit in there more. |
See my comment in @2139 #2139 (comment) |
@elarlang can you PR your suggestion into V10.4 as I think that is a sensible suggestion |
Goes in via #2155 , changed "see" to "access" from previous proposal.
|
* #934 - return only data that user has permission to access * Wording tweaks --------- Co-authored-by: Josh Grossman <[email protected]>
Had it in my todo-list but as WSTG has this topic under discussion I make link/placeholder here as well:
OWASP/wstg#727 by @pinkLagoon
Problem: in response from an application there is too much information which may be also sensitive. Happens, when developers are JSON-encoding entire dataset or object and give it for HTTP response.
Risks:
Lists in the beginning are small, but if someone "is testing" with every field with max-length value (text fields getting problematic quite fast) - like few hundred MB to download by API most likely is causing some problems for serving the content or handling the content on the client side - availability loss.
Proposal:
The text was updated successfully, but these errors were encountered: