-
-
Notifications
You must be signed in to change notification settings - Fork 679
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
Should Input Validation be Level 1 #2476
Comments
Although discussed, the provided arguments were a bit one-sided. Some may think, that security is only confidentiality and maybe availability, ignoring the integrity and data quality part. Some may also think, that input validation is a defense or replacement for output encoding, but although it may have a defensive effect in certain cases, it is not - building the output is a completely separate topic. Why are applications made? To provide some automated solutions to satisfy the business need. And it is not possible to achieve that without input validation.
The number of different validation rules is not usually that large. |
Yes I deliberately wanted to let you set out your own arguments rather than me paraphrasing them, apologies if that was not clear. |
Maybe we need a specific requirement to validate an email address as there is a specific security purpose for this, it doesn't justify the full "input validation for everything" in the requirements above. Same for phone if there is a security purpose, otherwise this is a functionality thing and not a first priority for security.
These are functionality issues, maybe should be a priority for QA but not a first priority for security.
Not convinced this should be used for any security function as it is so hard to change. As such, not a first priority for security.
Covered by 11.1.3 |
Any input validation which causes the business pain, the business will have already implemented and we don't need to mandate. For anything which doesn't cause them pain, trying to convince them that this is an essential business need is not a job for ASVS 5.0 L1. |
So in short, you say, that if the data in the application is trash, it is not a security issue? And taking into account #2476 - you don't care about data quality, but you want to protect it with cryptography? (for further comments from here I could get another notice through other channels :) ) |
I agree. Before accepting an email address, especially as part of authentication, I suggest:
|
I think that there is an important mindset point to consider here. Firstly, if there is data that we are specifically basing security controls on then we need to ensure that is collected correctly. But that is a relatively minor subset of the data we are collecting. My reasoning below relates to the rest of the data. In the software industry, there is a long time attitude that security is it's own special thing and not part of the software requirements. I literally had a client tell me this week that their engineering organization sees performance as a key quality indicator but not security. From their perspective, poor response times would be considered a bug but security vulnerabilities would not be. Once a security vulnerability is exploited, only then is it considered a bug to be fixed. As a software security professional, my job is to try and promote the importance of changing that mindset to implement key security controls. I want L1 to be a primary tool for doing that. Do I care about rubbish data in the application? Yes. Could rubbish data be considered a security issue? In theory, yes. Is it my primary concern? No. Why not? Because my main concern is things that will get our data stolen or messed up on a wide scale. If someone enters junk data and it breaks the functionality of the application, then someone else like a quality manager or a product manager or application owner will be the person to push for it to be fixed. It is not a battle that a security person needs to fight. Security people have too many other battles to fight and certainly no one is going to say, "why didn't security tell us not accept addresses in a phone number field?" However, what they will say is, why didn't security tell us that using "Base64 encryption" on that data that got stolen out of our database was not secure. |
The problem is - do not have input validation for the list of data that is not "critical for security" you proposed to remove the input validation from everything, opening up quite a security hole.
It is normal, that engineers sees security differently and it is often philosophical question. Using this attitude - inserting ' and " to some field that causes error in executing SQL query or incorrect output when building an HTML, it's just a bug till not exploited as SQL injection or "XSS".
what? |
In general I can see why good input validation is not a L1 control. Stopping injection attacks is usually about escaping, encoding and parameterization. Input validation is usually a secondary defense. |
Well, details, but let me repeat that: #2476 (comment)
And the point is: if you measure input validation level as "secondary defense" for output encoding, then it does not take into account the data quality and business-logic area, where it is actually is important and pre-condition to achieve the application providing the business needs. |
I agree with most of your thoughts in the thread, Elar.
|
I have proposed it some time ago (too lazy to search where exactly), but it was not agreed back then - but I do it again. As input validation is for data quality, that the application can make any decision based on trusted data, we should move input validation to "business logic" section, and maybe rename it to just "logic". Why this proposal: to send a clear message that input validation is not a defense against injection attacks and it is part of the application logic. This seems to be really underestimated, undervalued and misinterpreted here as well. We are going to have another "potentially heated" discussion on how to re-order chapters - so I think can we start with:
And on topic: the data used by the application for any decision, it must be trusted. To have a trusted data, we need to have input validation - so for me it is a clear L1 situation. If there is some data that is not used as a base info for making any decision, it can (maybe) be left out from this priority, but how to draw the line here is a good question. |
I find this direction interesting.
I don't love this idea... I would make the following suggestions:
|
One option is to have 5.1.1, |
I think the problem is that many things could fit into Defensive Coding but I prefer to keep it for things which we really can't fit anywhere else. These requirements are all around untrusted content used in a specific, security sensitive way, and therefore I prefer to keep them here |
Entire point is to not have input validation as part of current V5. If to keep some here and some there, it is even more confusing. I would say, that 5.1.1 is not a input validation as such. It is more how the programming language, framework or whatever takes the input processes the input. Validation is - accept or reject it, I think it is not perfect match for input validation and belongs to defensive coding. This is my proposal despite what will happen with all other changes here. V5.1.5 is not just a technical input validation - it relies on logic and a defined list to define, what is a trusted and allowed destination. V5.1.6 it is a technical check, but during a building the header. It may involve more than one input or other logic - just that the combined length that is used in one header field value can not exceed defined limit. It is a question of program code logic and fits to defensive coding. |
I don't see this move as taking input validation out of V5, I see this as reframing several input validation requirements to focus more on the use of the inputs in business/security logic which is why we have the move. I think that the primary chapter for untrusted content should still be V5. Again, I think that you could argue that almost any requirement implemented at the code level could go into V10 but I only want to put those in there that are strictly related to coding principles (ideally language specific) and don't really fit anywhere else. With that being said...
I can accept that this is a little language specific so maybe fits better in V10
5.1.5 sounds like classic "accept or reject it" validation so I think this should stay put.
This is not language specific but rather a conceptual question of how you incorporate untrusted content into a header. I still think it is more about input than logic but I am not strongly opinionated. |
@elarlang do you agree with my levels and changes on 5.1.3, 5.1.4 and 5.1.7? |
In big picture yes, but some wording need to be improved and moving requirements can not be done out of context (without taking everything else into account). next meeting. |
Discussed with @elarlang and @tghosth to open a PR (and a new issue) as per the points below.
|
As it is merged now - is it something to solve in scope of this issue or it can be closed? |
We currently have an explanation of the thinking around L1 which can be found here.
There are a few major areas where we have differing opinions about whether a particular type of control falls into the category of L1 for version 5.0.
This issue is to discuss input validation requirements from the current section 5.1
The currently disputed requirements are 5.1.3, 5.1.4,and 5.1.7 (ignore the level marking below). 5.1.5 is a different discussion and it is agreed that the others in this section are not L1)
I personally believe that these requirements do not belong in L1 for the following reasons:
The text was updated successfully, but these errors were encountered: