-
Notifications
You must be signed in to change notification settings - Fork 16
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
VCL-ActiveDirectory4Delphi contain DLL hijacking vulnerability #5
Comments
File used to exploit it |
@mh4x0f Thank you very much for your contribution. |
@jmgway, I haven't been able to do it yet. But the project is open to contributions, so if you'd like to do it, we'd be happy to review and accept your PR. |
HelloThanks for answering !Ok fine !Did you test it with FMX ?Jmichel Envoyé de mon iPhoneLe 8 oct. 2024 à 20:59, Zava ***@***.***> a écrit :
@jmgway, I haven't been able to do it yet. But the project is open to contributions, so if you'd like to do it, we'd be happy to review and accept your PR.
—Reply to this email directly, view it on GitHub, or unsubscribe.You are receiving this because you were mentioned.Message ID: ***@***.***>
|
@jmgway |
Impact
High! VCL-ActiveDirectory4Delphi (current version) was discovered to contain a DLL hijacking vulnerability that allows attackers to escalate privileges and execute arbitrary code via a crafted DLL.
Vulnerability
The file
ActiveDirectory.Winapi.DllMapper.pas
has two reference to import external DLL from the Windows OSactiveds.dll
andadsldpc.dll
Here is the current
ActiveDirectory.Winapi.DllMapper.pas
code:ref: https://github.com/EdZava/VCL-ActiveDirectory4Delphi/blob/master/src/Winapi/ActiveDirectory.Winapi.DllMapper.pas#L93
Using the
Process Monitor (procmon)
it possible to see the external import of the binary TestActiveDirectory.exe on runtime execution.highlighted in red, we can see that be default, if you do not set the path complete of variable, the DLL will be stored in the local directory of the executable, which in my case is
C:\Users\mh4x0f\Desktop\activeds.dll
and the result isNAME NOT FOUND
becasue the file .dll" cannot be faulted into the current directory.The vulnerability occurs because the VCL-ActiveDirectory4Delphi not set the complete path into code for import only from
System32/x.dll
POC
The exploration can be simple in this demo I will show only exploit the
activeds.dll
but with same modification is possible to apply foradsldpc.dll
.I checked the source of this project the functions you are using that come from the
data:image/s3,"s3://crabby-images/65126/651262aea39f0cc4c80080d52c66562ab55f39a5" alt="image"
activeds.dll
and i found.But the attacker can find this using some PE file explorer, i used the die.exe (detect it easy) checkout.
After that, I wrote a code .dll and proxy the functions that binary needed to work fine.
Then, i rename the project.dll to
activeds.dll
and moved it to the same path of executableTestActiveDirectory.exe
After that, it was only necessary to execute the binary
TestActiveDirectory.exe
that will see the calc.exe execution the same time.Recommendation
The recommendation is to pass the complete path on System32, the change will force the search file activeds.dll to be in the system directory
C:\Windows\System32\activeds.dll
the same modification can be added foradsldpc.dll
The text was updated successfully, but these errors were encountered: