data:image/s3,"s3://crabby-images/f53a6/f53a632da299f717ac4e36d65cc1d72c0a6882e3" alt=""
What are the prerequisites for this lab? Have a working Windows VM whether that's hosted in the cloud or on your machine locally is up to you. Just choose a windows workstation that has internet. We will be using free software or free tiers, so money needed.
Introduction: Automating Security Response with Tines & Slack
In modern security operations, speed and automation are critical for effective incident response. This project explores how we can integrate LimaCharlie (EDR), Tines (SOAR), and Slack to create an efficient automated detection and response workflow. Initially, we used a Tines Page Action to prompt analysts for decisions, but later optimized the process by embedding interactive buttons in Slack for a more seamless experience. Along the way, we tackled string manipulation challenges, ensuring detection details were correctly passed and processed between tools. This hands-on approach not only introduced us to how EDRs generate detections but also demonstrated the power of automation in security operations, reducing response times and improving efficiency. In this series, we’ll walk through each step of the implementation, lessons learned, and how this workflow can be further enhanced for scalability.
Drafting our workflow helps to put things in perspective. Draw.io is a good tool to use for this.
Rough draft of the SOAR EDR playbook.
Story → Tines
Create detection in LimaCharlie – Detect HackTool → Tines → Slack & Email
Slack & Email will contain:
Time
Computer Name
Source IP
Process
Command Line
File Path
Sensor ID
Link to the detection (if applicable)
Tines → Prompt User to isolate the machine (Yes/NO)
If YES:
LimaCharlie should automatically isolate the machine
A message should be sent to Slack
Message: Isolation status with note of “The computer <computer> has been isolated”
If NO:
LimaCharlie will not isolate
Message: Isolation status with note of “The computer <computer> has not been isolated. Please investigate.”
data:image/s3,"s3://crabby-images/87bda/87bda5ed3af33370a543e00129c597718c5af531" alt=""
Part 1: Setup LimaCharlie sensor and exploring the telemetry and benefits of the EDR
I will be using my HomeLab DC for this lab. I have maintained the Homelab I created on this page 2 years ago. You can find it here.
Navigate to LimaCharli.io Click logon.
LimaCharlie is a modern endpoint security platform built on a “security as a service” model, offering tools like Endpoint Detection and Response (EDR), log collection, and automated threat hunting. It’s designed with a pay-as-you-go philosophy—meaning you only pay for what you use—and there’s typically a free trial or limited free tier for getting started. This developer-friendly approach provides unparalleled flexibility and integration options, allowing teams to build exactly the security stack they need without vendor lock-in or rigid annual contracts.
data:image/s3,"s3://crabby-images/e60cc/e60ccd73c37abbede34acfccd47f7a759a468bef" alt=""
Click sign up
data:image/s3,"s3://crabby-images/cc433/cc433716972f5f54ed30e22580a20d9db946f28a" alt=""
Feel free to put whatever you'd like in here.
data:image/s3,"s3://crabby-images/673d2/673d2d8c59bfe4547e36468548d98392f17a704a" alt=""
Click create Organization
data:image/s3,"s3://crabby-images/edce4/edce4b1cd5f3f3402db8f1a3881f7dfcf7592cc8" alt=""
Name the organization at this point but do not choose any templates.
data:image/s3,"s3://crabby-images/26520/26520d10e78f87d7cc0e2dea8bf284ffea1cc0d7" alt=""
You should see this screen but before we crate a sensor we are going to add an installation key.
data:image/s3,"s3://crabby-images/689ae/689aead35fbcbb77d0a9650ba2ee0f3f2179bb90" alt=""
data:image/s3,"s3://crabby-images/5139f/5139f289f602b4fdf53e39ad9ddbb91b63287ff6" alt=""
You can name it the following.
data:image/s3,"s3://crabby-images/0e8aa/0e8aa7a3c43a58c09524e909db4517bbd79f75cf" alt=""
Here we can add a sensor.
data:image/s3,"s3://crabby-images/81a6d/81a6d695f0ec9b652f5a6b46b0576386e1ddc071" alt=""
Next we select the sensor type Endpoint > Windows. The firewall configs necessary are specified.
data:image/s3,"s3://crabby-images/1b72d/1b72d58541e1778014b6299daf7df78f7acaa6d0" alt=""
Now select the installation key that we created.
data:image/s3,"s3://crabby-images/87948/87948818d96d54e0126f35990bfe5c7539af6c79" alt=""
Then it asks for architecture. Verify the architecture of your install by opening cmd and typing in ver or systeminfo
data:image/s3,"s3://crabby-images/53b6f/53b6f8f7b6973f8853e7098da80026bbfb3e07a4" alt=""
data:image/s3,"s3://crabby-images/5853f/5853f35b5e62e6f3bf65fa6d63d801c808e1bee3" alt=""
You can download the exe for the LimaCharlie Endpoint Sensor and then copy it into your server.
data:image/s3,"s3://crabby-images/fcf93/fcf935192b5987f51ee07fa9a98f6263cac324aa" alt=""
In cmd, Navigate to the folder where it is stored on your server and execute by appending the command line argument specified for your sensor executable installation. Like this:
data:image/s3,"s3://crabby-images/0de4b/0de4bdf02db29c9810f0ced09233319306d9c692" alt=""
Select yes for the UAC
data:image/s3,"s3://crabby-images/7c248/7c24893afc9158b87520eb8de20a34467dfe7062" alt=""
We see over here now it is installed.
data:image/s3,"s3://crabby-images/aa4e3/aa4e3c0a487995865e091151235c951a970dbc00" alt=""
However, let's try to find using powershell on the server.
The first command we run is to see the properties we can filter on. Another option would have been Get-Member. From that we see that we can filter on Servicename or it's alias Name
data:image/s3,"s3://crabby-images/dc3df/dc3df91cf767a116e5122a1baf1a3f2c3aed938a" alt=""
Our next command will be. You notice the that the first two attempts did not work. The reason is that name of the service isn't actually Lima. It is the display name. So switching the property that I was filtering on is a troubleshooting step you may have to try in some instances.
data:image/s3,"s3://crabby-images/608d9/608d9f769d6b4a18fe1943305daa347de6b2e36c" alt=""
Below are some other ways that you could have written it.
data:image/s3,"s3://crabby-images/e2946/e294609e706e446a7e8a515b3e8c415ce8573dc2" alt=""
The good news though is that the sensor is running. Click finish below
data:image/s3,"s3://crabby-images/c79fc/c79fc7339a3dc35535bcdab0cf02484a9a95b949" alt=""
You may have to refresh the page for it to populate in the list. Click on it.
data:image/s3,"s3://crabby-images/04a5b/04a5b9f43df8620b8885ee1b60f2b179f5293e86" alt=""
So Lima Charlie is an Endpoint Detection and Response tool, and these tools are important to organizational security through endpoint security. Sensors installed on each endpoint monitors the device and conducts analyze endpoint activity using behavioral detection (suspicious patterns) and signature based detections (known Indicators of Attack).
The analysis is supported by LimaCharlie's cloud platform, which provides up to date threat intelligence, correlation analysis, and a central command for response actions. They also have the potential to respond to these threats through blocking malicious processes or isolating a compromised endpoint from the network. EDR tools like LimaCharlie for example also provides an analyst the opportunity to perform hands on keyboard activity as part of their investigation allowing the remediation of threats in real time.
Let's explore what information or telemetry LimaCharlie is gather that could be helpful to us in understanding how EDRs can be beneficial to us in an investigation. Feel free to explore the various options here.
data:image/s3,"s3://crabby-images/5bd92/5bd924756f9fce578d28937e935da8d7609b5537" alt=""
A few highlights I will share will be console.. Which is where we can go hands on keyboard. Click on the field and press the up or down arrow to cycle through the commands available. Try netstat!
data:image/s3,"s3://crabby-images/a3897/a3897bf7d82c5e7154f49b3b37c0323c96c53d18" alt=""
We can see files on the file system including the download that we just did of the sensor.
data:image/s3,"s3://crabby-images/325d8/325d8530f367abf3ab36668a006d8c94b7443ca8" alt=""
If running Netstat didn't work for you, it didn't work for me either initially.
data:image/s3,"s3://crabby-images/4df0c/4df0cdee5664639afef93041e2d5f32fc94317e3" alt=""
Commands to the console were not working. So I opened powershell(Stop-Service -DisplayName Limacharlie | Start-Service as an administrator or you can go to services and stop and start the service.
data:image/s3,"s3://crabby-images/31407/31407ef003913f7793e92a3e809cbde29268456e" alt=""
data:image/s3,"s3://crabby-images/2b467/2b467d2595e32c3fd5601036c03eaffa74a84454" alt=""
It successfully stops but I realize it errors out starting back so you will have to manually restart it. Start-Service -DisplayName LimaCharlie
data:image/s3,"s3://crabby-images/3f3e1/3f3e160837a410e1056d094451c9503e10404168" alt=""
Let's try Netstat again. Netstat still doesn't work for some strange reason.
data:image/s3,"s3://crabby-images/f6249/f6249f0d5ca8aaa393895be42479e48c016916ab" alt=""
Now let's try OS users.
data:image/s3,"s3://crabby-images/c653a/c653a45efe93d051ee7539058c0a4d3dba1b404d" alt=""
So, in a real world scenario I would probably just reach out to the vendor to help troubleshoot but we have to move on. I sent a support email to the vendor, however, when I tried to load the network tab I noticed this information.
data:image/s3,"s3://crabby-images/bf691/bf691762d3c42416be794451dd91253e8f7353ac" alt=""
So I decided to pivot on events in the docs.
data:image/s3,"s3://crabby-images/54d79/54d797751ae3d38a767a7ad735f9d7cbe2474ff9" alt=""
Navigate back to the previous page.
data:image/s3,"s3://crabby-images/4f509/4f5090adc632853c7067d6c02184a1ce09526017" alt=""
To the default windows collection rules to make sure netstat was included and it was.
data:image/s3,"s3://crabby-images/6dff9/6dff9bf9bca7bb5a108130d3723842d01abb5456" alt=""
I then went back to Sensors List > Sensor we created > Event Collection
data:image/s3,"s3://crabby-images/ef9fa/ef9fabb9c5ea215005f0a0b9532f1b947f96e66a" alt=""
data:image/s3,"s3://crabby-images/38ed3/38ed35e37a125000644b24640455484a47cce8d4" alt=""
Hit refresh and the two highlight boxes above were now listed. Navigating to network page now shows the following output.
data:image/s3,"s3://crabby-images/865a2/865a2fa224a07051d007e909f6169f328a6374a7" alt=""
Another highlight in here that analysts enjoy is the process list and the ability to respond to threats identified in suspicious processes by executing any of the following options.
data:image/s3,"s3://crabby-images/05a9a/05a9af7112384dbd4410b45a69707c34a71bfc99" alt=""
We opened PowerShell from the desktop and we can see that here. The PPID for PowerShell is the PID for Explorer.exe
data:image/s3,"s3://crabby-images/b8f2f/b8f2f25a06c1d1b7b54fe3fe553f66aedec24bf6" alt=""
What happens if I open an admin PowerShell windows from the PowerShell that we have open?
data:image/s3,"s3://crabby-images/1edad/1edad33988eaad5900f8178f876d04e4c5f9942d" alt=""
The EDR shows the new spawned child process of PowerShell.
data:image/s3,"s3://crabby-images/42375/42375b97dc9036c4e3ed605081b3ed1d1d8dad06" alt=""
When you run PowerShell as Administrator (or any console application like cmd.exe), it also often spawns conhost.exe (Console Window Host) as a child process. This is normal and expected behavior in Windows.
Why does conhost.exe appear?
conhost.exe is responsible for providing the graphical console window for command-line applications like PowerShell, Command Prompt (cmd.exe), or other console-based tools.
When you launch PowerShell (or any console application):
PowerShell (or cmd.exe) starts.
Windows creates a console window to display the output.
conhost.exe is spawned to manage the console window—handling input, rendering text, enabling features like window resizing, and processing copy-paste actions.
The PowerShell process (or cmd) is attached to this console window, and conhost.exe acts as a bridge between the command-line process and the graphical interface.
Let's now move on to our final step in Lima Charlie which is creating our custom detection rule for a credential accesss hack tool called Lazagne.
On your Windows machine open edge or download it if you don't have it and navigate to https://github.com/AlessandroZ/LaZagne. Click the latest release. Then download the exe file on the next page.
data:image/s3,"s3://crabby-images/55f9f/55f9f5f8f1a4bd2c5a4ad51d5e74b08ec99395e6" alt=""
data:image/s3,"s3://crabby-images/957fe/957fed81af0a3646cccba2f852be18d247e817a1" alt=""
SmartScreen will pick it up but select keep and then keep anyway.
then keep anyway.
data:image/s3,"s3://crabby-images/8fd49/8fd49c1bb885ebe66599e8fae7addb338f14ddcb" alt=""
data:image/s3,"s3://crabby-images/9a5d8/9a5d8fa297a297beaab3b909bed30e449162ae57" alt=""
It was still blocked. Delete the old one from downloads first. Then go into virus and threat protection
data:image/s3,"s3://crabby-images/7e6af/7e6afb339f0665b2261a03cf1381220d711fed4c" alt=""
Manage settings.
data:image/s3,"s3://crabby-images/1bd83/1bd8348f30a44f87143cf7705e9415601d314ada" alt=""
Temporarily turn of Virus and Threat Protection
data:image/s3,"s3://crabby-images/79155/79155370c19c8b6591453a6def72449e97bf6f1b" alt=""
Now download again. Click keep and keep anyway and it should download successfully this time.
data:image/s3,"s3://crabby-images/47a21/47a2186a574471f6984178f65b55ca1af3445998" alt=""
Let us run it from PowerShell to see how the log details for its execution is written in LimaCharlie. We then will be able to use that info to help us in creating a custom detection rule.
Navigate to the downloads folder in PowerShell. Start typing La then press Tab on the keyboard.
data:image/s3,"s3://crabby-images/c8861/c88618eeb39a23916819b50e029a68662d60b437" alt=""
In LimaCharlie, on the sensor, let us check the timeline to see if we find any activities that correlate to Lazagne execution. Scroll to the bottom since it has the most recent and work your way up a little slowly to see if you find Lazagne process creation. If not you can simply search for Lazagne.
data:image/s3,"s3://crabby-images/ce71f/ce71f4213997b0f45aee15cc0ca8bf222c9321ca" alt=""
Here we see the NEW_PROCESS event For LaZagne.exe being executed, click on the log entry and open a new tab for Lima Charlie (https://app.limacharlie.io/) for us to create a detection.
data:image/s3,"s3://crabby-images/bf9d5/bf9d55b3cd88fb0ea431f74e7ee1497b46ee4eb4" alt=""
You might still be on the sensor page so you will have to go back.
data:image/s3,"s3://crabby-images/2e8b4/2e8b4119680239e9222d65a155a63a49ae5c1fe0" alt=""
Then navigate to detection rules by clicking "Go to Detect & Response rules". Before you do that though, click "View extension" for ext-sigma to get additional detections.
data:image/s3,"s3://crabby-images/7e354/7e354f9e3df33ec555ee1bea5abe1078a6c3ab8f" alt=""
data:image/s3,"s3://crabby-images/63d58/63d5891482feefa603c45d3b746c4c145e825847" alt=""
By subscribing to the available sigma rules we now have more rules.
When creating rules it is a good idea to use a similar rule as a template for our rule. Lets see if we find any credential access related rules. Oops we only have 11 rules which all appear not to be useful.
To the docs we go.
So read this as it gives us an idea of how rules in LimaCharlie work: https://docs.limacharlie.io/docs/detection-and-response
Then we will use one of these examples as a reference or template: https://docs.limacharlie.io/docs/detection-and-response-examples
In the second link, let's use the example for wanna cry as a base for our detection rule
data:image/s3,"s3://crabby-images/64271/64271787b01c2ad57a3ff429b518fbc077eb14d6" alt=""
Select New rule in Detection & Response rules.
We also have a quick example of what a detection rule could look like. Let's populate it with the info from the activity logged from the new process creation of LaZagne
data:image/s3,"s3://crabby-images/82c0d/82c0dd06a0083a82aefe57b5b3cc3dc0a13e082a" alt=""
Your hash would be different but the idea is to paste the hash and relevant fields from the LaZagne new process log in Timeline section in the sensor section . Read the LimaCharlie documentation to get a better understanding of how there logs can be utilized.
Please note that spacing and indentation matter here.
data:image/s3,"s3://crabby-images/69cfd/69cfd7d28a730befac32a4c006ba7e5f6f794dbb" alt=""
Scroll down to the bottom you will see that we can test the target event.
data:image/s3,"s3://crabby-images/2c1eb/2c1ebccaca850fec41669f61f68b558659fe65c7" alt=""
Copy the log.
data:image/s3,"s3://crabby-images/d1a01/d1a01ce91ceb5596c95b8dd08fbf72e37902b1de" alt=""
Paste it to test it.
data:image/s3,"s3://crabby-images/d01d8/d01d8853f86a2ec6e31a4deac71d37ce1001b5df" alt=""
It works.
data:image/s3,"s3://crabby-images/68713/68713a23c29a9480b4bbc0f3244f4f22276adf9b" alt=""
Name it and create.
data:image/s3,"s3://crabby-images/11a83/11a83e735d8d75aa1f78cede8516d2dca534411d" alt=""
Now time to test, execute LaZagne again on the machine.
data:image/s3,"s3://crabby-images/f9e0b/f9e0bc994e467e85a3b12ee3d8239ef4c573d467" alt=""
Go back and we are going to navigate to the detections section.
data:image/s3,"s3://crabby-images/31d79/31d7980bcf288dadb10cdaf94127ca1997eb3bd2" alt=""
data:image/s3,"s3://crabby-images/7299b/7299be10abc9f063042b90c282f3b4da67b0441c" alt=""
We see an alert was triggered here.
data:image/s3,"s3://crabby-images/fb3ca/fb3cae57e0d7d119e724c79b25e9a36b58a446e3" alt=""
Good work!
Check out part 2 below.
Comentários