-
Notifications
You must be signed in to change notification settings - Fork 153
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
Monitoring DLL Running in Another process #168
Comments
I see what you mean - yes, submit the exe and dll together in a zip, and use zip package. |
you don't need to specify |
If there is only one exe it should get picked altho I have a feeling I may have broken this with recent expansion of package to inclyde a dll (alone) in a zip. I will double check. |
so the zip package will inject the DLL into the exe file, and then capemon will be able to monitor the actions of the DLL as it executes inside the DLL? |
No this depends on the exe either statically or dynamically importing the dll. Injection of a dll is rarely dependent on a particular target process in malware. |
What is the specific situation? What is the nature of this combination of exe and dll? |
For instance malicious DLL's that hook browser functions that enable the malware to render anything on screen, or read the user's input. Is there any way in CAPE to monitor the process of this DLL as it's executing in the browser (ie. hooking the PR_READ and PR_WRITE functions)? |
I think in this scenario we rely on the malware to do its own injection of the dll into the browser (requiring the 'dropper' to be submitted) and ensure the monitor dll is loaded in the browser first. |
How can I configure the monitor dll is loaded in the browser executable? Because wouldn't it default to loading inside the submitted binary (or rundll)? |
Otherwise this could be achieved by writing a package to do it. |
Sorry I missed your question. You don't need to configure anything to ensure the monitor is loaded into the browser, as the monitor in the process which does the injection of the malicious dll will catch the injection and ensure the monitor is loaded in the browser process first. This all happens automatically already. The monitor in the injecting process catches the injection in hooks and uses the pipe("PROCESS:..."); call to alert the analyzer that a new process requires the monitor, and the analyzer injects the monitor before the malware has injected its dll. If you are interested you can find these calls inside the relevant hooks such as the hook for CreateRemoteThread (classic dll injection) in hook_thread.c |
From what I understand, your're saying that if the malware that's injected with the monitor creates a new process createRemoteThread, then the monitor will also be injected into this new process. I think I may have been unclear but the scenario I'm describing is if the malware overwrites the AppInit registry key, and then gets loaded into say browser.exe everytime browser.exe is executed. So the injection into the process does not happen when the malware is run, but rather, only when the process itself is run (through way of AppInit). Is there a configuration setting for CAPE to analyze this type of scenario? If not I will gladly contribute a package to implement it |
1 similar comment
From what I understand, your're saying that if the malware that's injected with the monitor creates a new process createRemoteThread, then the monitor will also be injected into this new process. I think I may have been unclear but the scenario I'm describing is if the malware overwrites the AppInit registry key, and then gets loaded into say browser.exe everytime browser.exe is executed. So the injection into the process does not happen when the malware is run, but rather, only when the process itself is run (through way of AppInit). Is there a configuration setting for CAPE to analyze this type of scenario? If not I will gladly contribute a package to implement it |
This is indeed an interesting scenario! We can tackle it together if you like, let me give some thought about how it might work. I will need to dig into this AppInit mechanism a bit as ideally we would want to use the real Windows mechanism, but trigger it ourselves. |
How about a package that registers the supplied DLL with AppInit then just opens the browser? |
Or we could inject it using with writeProcMemory->loadLIbrary->createRemoteThread? Whichever one is easier to implement, as long as we can get the malicious DLL loaded into the target process somehow. By the way is there a way to modify registry values from Python or does that functionality need to be implemented in native code? |
We could, I've implemented this type of injection in Loader.c if you want to have a look. But as I said, I think if you are testing something that is normally launched via a Windows mechanism, it would be best to use this mechanism rather than another implementation that may differ. I haven't looked into how AppInit performs injection but this is key. |
It may, for example, be that the Windows loader loads the AppInit DLLs as part of its startup routine, which is what the malware developers may depend upon to do their hooking. If we inject using a remote thread, this will come much later in the process life and may be too late to work with the hooking mechanism, thus the sample won't behave properly. |
Ah yes good point. And I think the AppInit DLL's gets loaded by user32.dll when that gets loaded into a process |
Should this be implemented as an auxiliary module since it needs to run before the analyzer executes the targeted binary? |
I haven't had time to look into this mechanism myself, but if this mechanism causes a dll to be loaded into all processes, then if set up accordingly in advance, it should be loaded in an IE process that is launched by the 'ie' package. So I would start with this simple test. Set the AppInit mechanism up, snapshot the state, then use that snapshot as the beginning of a typical run with IE, and see if the analysis catches the loading of the AppInit dll. If it does, then the challenge would shift to making a package which first created the relevant AppInit registry key, then subsequently launches the process. This shouldn't be so hard. If the loading of the dll is missed (or doesn't occur) then we'll need to work out why not, there are things we can try in that eventuality too. |
Did you have any luck getting the AppInit registry key set? Let me know if you need any help integrating this into a package. |
I have the part done for setting registry keys, the next part I want to do
is to allow the user to filter API calls based on where they came from.
Have been busy with exams these past 2 weeks but will definitely work on
this during christmas break.
I think I can implement a package for injecting a DLL into another process,
and it would take the dll and the process as arguments. Then I think
implementing return address filtering separately would make more sense, was
thinking at the point in the monitor where it writes the return address to
Mongo, add a line in there that also gets the name of the DLL that's loaded
at that address using getModuleInformation(). Then we can change some logic
in the front-end so that users can use this package and then only filter
for calls with return address being the target DLL.
…On Mon, Dec 3, 2018 at 2:12 AM kevoreilly ***@***.***> wrote:
Did you have any luck getting the AppInit registry key set? Let me know if
you need any help integrating this into a package.
—
You are receiving this because you authored the thread.
Reply to this email directly, view it on GitHub
<#168 (comment)>, or mute
the thread
<https://github.com/notifications/unsubscribe-auth/AJfxzQEMNNulTPGtcs-3uki8-Mulm03uks5u1TFlgaJpZM4XhADH>
.
|
Actually that last part is a little iffy
…On Mon, Dec 3, 2018 at 2:27 PM John Peng` ***@***.***> wrote:
I have the part done for setting registry keys, the next part I want to do
is to allow the user to filter API calls based on where they came from.
Have been busy with exams these past 2 weeks but will definitely work on
this during christmas break.
I think I can implement a package for injecting a DLL into another
process, and it would take the dll and the process as arguments. Then I
think implementing return address filtering separately would make more
sense, was thinking at the point in the monitor where it writes the return
address to Mongo, add a line in there that also gets the name of the DLL
that's loaded at that address using getModuleInformation(). Then we can
change some logic in the front-end so that users can use this package and
then only filter for calls with return address being the target DLL.
On Mon, Dec 3, 2018 at 2:12 AM kevoreilly ***@***.***>
wrote:
> Did you have any luck getting the AppInit registry key set? Let me know
> if you need any help integrating this into a package.
>
> —
> You are receiving this because you authored the thread.
> Reply to this email directly, view it on GitHub
> <#168 (comment)>, or mute
> the thread
> <https://github.com/notifications/unsubscribe-auth/AJfxzQEMNNulTPGtcs-3uki8-Mulm03uks5u1TFlgaJpZM4XhADH>
> .
>
|
One thing I've learned over the years is that it's wise to break things down into pieces, so let's get this AppInit package done first before tackling this other idea. Another classic gem of wisdom is many hands make light work! So if you are happy to show me what you've done so far, perhaps with a smattering of relevant malware samples, perhaps I can help drive it to completion...! |
Ah yes u are right sometimes I get a little too ahead of myself. Below code shud load VIRUS.EXE into every process that also loads user32, by way of LoadAppInitDLL, test on Win7 v6.2:
After running the above, the process to be injected will be provided by the user as a parameter, and the package will hook/start that process. Then once analysis is complete, find a way to filter out the results by only looking for calls made by the DLL. And then stopping the analysis after the DLL has finished executing (not sure best way to do this). What do you think? |
Thanks - do you have a sample I can test this with? |
Yep I have a small DLL that pops a text box in DLLMain. https://drive.google.com/file/d/1I_tMZb22xbPMj4v5DNP5EZowWoQylXs4/view?usp=sharing So just download the DLL, and change the dllpath variable in the script to point to the downloaded file. Run the script, and then afterwards, any program you open (ie. calculator, browser, etc.) should pop a text box. Note: I actually posted the wrong version of the script it shud be as follows:
|
Fix office template for BinGraph graphs
Is there currently functionality in CAPE to run a dll in a specific process, instead of passing it to rundll?
The text was updated successfully, but these errors were encountered: