Description
Summary
Hi, i am a full time Pentester , was conducting an internal web application pentest on a client who was using the pimcore CMS , and after the OSINT phase i discovered potential employees emails, i succesfully enumerated valid accounts from those emails via the Forgot password function , and then used password spraying to gain access .
contact: [email protected]
Details
-> error message discloses existing accounts and leads to user enumeration on the target via "Forgot password" function. since no generic error message is being implemented.
PoC
data:image/s3,"s3://crabby-images/4a729/4a729ca116312a30050b85eaa43472da8a61fee9" alt="image"
we enter first a valid account email address adn we click on submit
data:image/s3,"s3://crabby-images/eaf65/eaf65e298966cb100068f6ab1e59bbe3ed6f3916" alt="image"
we get a green message that validates that the account exists and that a login link has been sent to our email
data:image/s3,"s3://crabby-images/faa6c/faa6cb3548e9077cfaa2f19dd7f747ea0109896f" alt="image"
now we go back and we will use a random email from temp-mail to test with a non existant account
data:image/s3,"s3://crabby-images/bbd15/bbd151e772be43d8f76ef1480e540d1bc5582533" alt="image"
data:image/s3,"s3://crabby-images/8d46d/8d46df7a28013b118d874c8c60914d962488de22" alt="image"
once we click on submit we get an error in red that a problem occured
data:image/s3,"s3://crabby-images/3ea4b/3ea4b82b92705fde59c38f2cf47044b58a3217e3" alt="image"
the poc of the user enumeration stops here , but here is a screenshot of me logging into the portal after password spraying against enumerated emails
data:image/s3,"s3://crabby-images/1cdc3/1cdc3822d55e86795e88ac3caa4d3aeab3288b75" alt="image"
Impact
user enumeration is a confidentiality threat , that could potentially lead to an attacker to enumerate valid accounts and maybe taking over accounts in case combined with credential stuffing on an organisation .
A remedition would be to change the error message in both cases ( valid and invalid emails ) to what we call a "synchronised error " it would be for example : " if the given email address is linked to an account , then a login link would be sent to that email " or something along those lines
Description
Summary
Hi, i am a full time Pentester , was conducting an internal web application pentest on a client who was using the pimcore CMS , and after the OSINT phase i discovered potential employees emails, i succesfully enumerated valid accounts from those emails via the Forgot password function , and then used password spraying to gain access .
contact: [email protected]
Details
-> error message discloses existing accounts and leads to user enumeration on the target via "Forgot password" function. since no generic error message is being implemented.
PoC
data:image/s3,"s3://crabby-images/4a729/4a729ca116312a30050b85eaa43472da8a61fee9" alt="image"
we enter first a valid account email address adn we click on submit
data:image/s3,"s3://crabby-images/eaf65/eaf65e298966cb100068f6ab1e59bbe3ed6f3916" alt="image"
we get a green message that validates that the account exists and that a login link has been sent to our email
data:image/s3,"s3://crabby-images/faa6c/faa6cb3548e9077cfaa2f19dd7f747ea0109896f" alt="image"
now we go back and we will use a random email from temp-mail to test with a non existant account
data:image/s3,"s3://crabby-images/bbd15/bbd151e772be43d8f76ef1480e540d1bc5582533" alt="image"
once we click on submit we get an error in red that a problem occured
data:image/s3,"s3://crabby-images/3ea4b/3ea4b82b92705fde59c38f2cf47044b58a3217e3" alt="image"
the poc of the user enumeration stops here , but here is a screenshot of me logging into the portal after password spraying against enumerated emails
data:image/s3,"s3://crabby-images/1cdc3/1cdc3822d55e86795e88ac3caa4d3aeab3288b75" alt="image"
Impact
user enumeration is a confidentiality threat , that could potentially lead to an attacker to enumerate valid accounts and maybe taking over accounts in case combined with credential stuffing on an organisation .
A remedition would be to change the error message in both cases ( valid and invalid emails ) to what we call a "synchronised error " it would be for example : " if the given email address is linked to an account , then a login link would be sent to that email " or something along those lines