| 123456789101112131415161718192021222324252627282930313233343536373839404142434445464748495051525354555657585960616263646566676869707172737475767778798081828384858687888990919293949596979899100101102103104105106107108109110111112113114115116117118119120121122123124125126127128129130131132133134135136137138139140141142143144145146147148149150151152153154155156157158159160161162163164165166167168169170171172173174175176177178179180181182183184185186187188189190191192193194195196197198199200201202203204205206207208209210211212213214215216217218219220221222223224225226227228229230231232233234235236237238239240241242243244245246247248249250251252253254255256257258259260261262263264265266267268269270271272273274275276277278279280281282283284285286287288289290291292293294295296297298299300301302303304305306307308309310311312313314315316317318319320321322323324325326327328329330331332333334335336337338339340341342343344345346347348349350351352353354355356357358359360361362363364365366367368369370371372373374375376377378379380381382383384385386387388389390391392393394395396397398399400401402403404405406407408409410411412413414415416417418419420421422423424425426427428429430431432433434435436437438439440441442443444445446 |
- @echo off
- setlocal EnableExtensions EnableDelayedExpansion
- REM =====================================================
- REM getlog - NetScaler Case File Downloader
- REM Downloads case files from sjanalysis.citrite.net
- REM =====================================================
- REM Check for pscp.exe (PuTTY SCP) or scp.exe
- set "SCP_TOOL="
- where pscp.exe >nul 2>&1
- if !ERRORLEVEL! EQU 0 (
- set "SCP_TOOL=pscp.exe"
- set "SCP_TYPE=PSCP"
- ) else (
- where scp.exe >nul 2>&1
- if !ERRORLEVEL! EQU 0 (
- set "SCP_TOOL=scp.exe"
- set "SCP_TYPE=SCP"
- )
- )
- if "%SCP_TOOL%"=="" (
- echo ERROR: Neither pscp.exe nor scp.exe found in PATH.
- echo.
- echo Please install one of the following:
- echo - PuTTY ^(includes pscp.exe^) - https://www.putty.org/
- echo - OpenSSH Client ^(includes scp.exe^) - Built into Windows 10/11
- echo.
- pause
- exit /b 1
- )
- REM =====================================================
- REM Configuration
- REM =====================================================
- set "REMOTE_SERVER=sjanalysis.citrite.net"
- set "REMOTE_BASE_PATH=/upload/ftp"
- REM Prompt for case number if not provided
- if "%~1"=="" (
- set /p CASENO=Enter Case Number:
- ) else (
- set "CASENO=%~1"
- )
- if "%CASENO%"=="" (
- echo ERROR: Case number cannot be empty.
- exit /b 1
- )
- REM Prompt for credentials if not provided
- if "%~2"=="" (
- set /p USERNAME=Enter SSH Username:
- ) else (
- set "USERNAME=%~2"
- )
- if "%USERNAME%"=="" (
- echo ERROR: Username cannot be empty.
- exit /b 1
- )
- if "%~3"=="" (
- echo Enter SSH Password for %USERNAME%@%REMOTE_SERVER%:
- set /p PASSWORD=
- ) else (
- set "PASSWORD=%~3"
- )
- REM =====================================================
- REM Paths
- REM =====================================================
- set "REMOTE_CASE_PATH=%REMOTE_BASE_PATH%/%CASENO%"
- set "DEST=%USERPROFILE%\Downloads\SJLNT\%CASENO%"
- set "LOGFILE=%DEST%\download_%CASENO%.log"
- set "TEMP_LIST=%TEMP%\caselist_%CASENO%.txt"
- set "TEMP_FILTERED=%TEMP%\filtered_%CASENO%.txt"
- set "COLLECTOR_LIST=%TEMP%\collectors_%CASENO%.txt"
- set "ALL_FILES_LIST=%TEMP%\allfiles_%CASENO%.txt"
- echo.
- echo =====================================================
- echo NetScaler Case Download Utility
- echo =====================================================
- echo Case Number : %CASENO%
- echo Remote Server : %REMOTE_SERVER%
- echo Remote Path : %REMOTE_CASE_PATH%
- echo Local Dest : %DEST%
- echo SCP Tool : %SCP_TYPE%
- echo User : %USERNAME%
- echo =====================================================
- echo.
- REM Create destination if missing
- if not exist "%DEST%" (
- mkdir "%DEST%" 2>nul || (
- echo ERROR: Failed to create destination folder: %DEST%
- exit /b 1
- )
- echo Created destination folder.
- )
- REM Create subdirectories for organization
- if not exist "%DEST%\configs" mkdir "%DEST%\configs"
- if not exist "%DEST%\captures" mkdir "%DEST%\captures"
- if not exist "%DEST%\media" mkdir "%DEST%\media"
- REM Initialize log file
- echo Download Log - Case: %CASENO% > "%LOGFILE%"
- echo Date/Time: %DATE% %TIME% >> "%LOGFILE%"
- echo Remote Server: %REMOTE_SERVER% >> "%LOGFILE%"
- echo User: %USERNAME% >> "%LOGFILE%"
- echo ================================================== >> "%LOGFILE%"
- echo. >> "%LOGFILE%"
- REM =====================================================
- REM Test SSH connection and verify case directory
- REM =====================================================
- echo [1/5] Testing SSH connection...
- echo Testing SSH connection... >> "%LOGFILE%"
- if "%SCP_TYPE%"=="PSCP" (
- echo y | plink.exe -batch -pw "%PASSWORD%" %USERNAME%@%REMOTE_SERVER% "test -d %REMOTE_CASE_PATH% && echo OK || echo NOTFOUND" 2>nul | findstr /V /C:"Keyboard" /C:"prompts from server" > "%TEMP_LIST%"
- ) else (
- sshpass -p "%PASSWORD%" ssh -o StrictHostKeyChecking=no -o UserKnownHostsFile=NUL %USERNAME%@%REMOTE_SERVER% "test -d %REMOTE_CASE_PATH% && echo OK || echo NOTFOUND" > "%TEMP_LIST%" 2>&1
- )
- if !ERRORLEVEL! NEQ 0 (
- echo ERROR: SSH connection failed. >> "%LOGFILE%"
- type "%TEMP_LIST%" >> "%LOGFILE%"
- echo ERROR: SSH connection failed.
- echo Check credentials and network connectivity.
- echo See log: %LOGFILE%
- del "%TEMP_LIST%" 2>nul
- pause
- exit /b 1
- )
- findstr /C:"OK" "%TEMP_LIST%" >nul
- if !ERRORLEVEL! NEQ 0 (
- echo ERROR: Case directory not found on server: %REMOTE_CASE_PATH% >> "%LOGFILE%"
- echo ERROR: Case directory not found on server.
- echo Path: %REMOTE_CASE_PATH%
- echo Please verify the case number.
- del "%TEMP_LIST%" 2>nul
- pause
- exit /b 1
- )
- echo Connection successful.
- echo Connection successful. >> "%LOGFILE%"
- REM =====================================================
- REM Single SSH call to get all required info
- REM Collectors + All files in case root
- REM =====================================================
- echo.
- echo [2/5] Scanning case directory...
- echo Scanning case directory... >> "%LOGFILE%"
- if "%SCP_TYPE%"=="PSCP" (
- plink.exe -batch -pw "%PASSWORD%" %USERNAME%@%REMOTE_SERVER% "echo '===COLLECTORS==='; find %REMOTE_CASE_PATH% -maxdepth 1 -type d -name 'collector_*' 2>/dev/null; echo '===FILES==='; find %REMOTE_CASE_PATH% -maxdepth 1 -type f \( -name '*.cap' -o -name '*.pcap' -o -name '*.pcapng' -o -name '*.sslkeys' -o -name '*.keys' -o -name '*.har' -o -name '*.xml' -o -name '*.jpg' -o -name '*.jpeg' -o -name '*.png' -o -name '*.gif' -o -name '*.bmp' -o -name '*.webp' -o -name '*.tiff' -o -name '*.svg' -o -name '*.txt' -o -name '*.log' -o -name '*.csv' -o -name '*.json' \) 2>/dev/null" 2>nul | findstr /V /C:"Keyboard" /C:"prompts from server" > "%ALL_FILES_LIST%"
- ) else (
- sshpass -p "%PASSWORD%" ssh -o StrictHostKeyChecking=no %USERNAME%@%REMOTE_SERVER% "echo '===COLLECTORS==='; find %REMOTE_CASE_PATH% -maxdepth 1 -type d -name 'collector_*' 2>/dev/null; echo '===FILES==='; find %REMOTE_CASE_PATH% -maxdepth 1 -type f \( -name '*.cap' -o -name '*.pcap' -o -name '*.pcapng' -o -name '*.sslkeys' -o -name '*.keys' -o -name '*.har' -o -name '*.xml' -o -name '*.jpg' -o -name '*.jpeg' -o -name '*.png' -o -name '*.gif' -o -name '*.bmp' -o -name '*.webp' -o -name '*.tiff' -o -name '*.svg' -o -name '*.txt' -o -name '*.log' -o -name '*.csv' -o -name '*.json' \) 2>/dev/null" > "%ALL_FILES_LIST%"
- )
- REM Parse collectors from combined output
- set "IN_COLLECTORS=0"
- set "IN_FILES=0"
- echo. > "%COLLECTOR_LIST%"
- echo. > "%TEMP_LIST%"
- for /f "usebackq delims=" %%A in ("%ALL_FILES_LIST%") do (
- set "LINE=%%A"
-
- REM Check for section markers
- echo !LINE! | findstr /C:"===COLLECTORS===" >nul
- if !ERRORLEVEL! EQU 0 (
- set "IN_COLLECTORS=1"
- set "IN_FILES=0"
- ) else (
- echo !LINE! | findstr /C:"===FILES===" >nul
- if !ERRORLEVEL! EQU 0 (
- set "IN_COLLECTORS=0"
- set "IN_FILES=1"
- ) else (
- REM Skip empty lines and filter noise
- if not "!LINE!"=="" (
- echo !LINE! | findstr /C:"Keyboard" /C:"prompts" /C:"authentication" >nul
- if !ERRORLEVEL! NEQ 0 (
- if !IN_COLLECTORS! EQU 1 (
- echo !LINE!>> "%COLLECTOR_LIST%"
- )
- if !IN_FILES! EQU 1 (
- echo !LINE!>> "%TEMP_LIST%"
- )
- )
- )
- )
- )
- )
- REM Count collectors
- set "COLLECTOR_COUNT=0"
- for /f "usebackq delims=" %%A in ("%COLLECTOR_LIST%") do (
- set "LINE=%%A"
- if not "!LINE!"=="" (
- echo !LINE! | findstr /C:"collector_" >nul
- if !ERRORLEVEL! EQU 0 (
- set /a COLLECTOR_COUNT+=1
- for %%B in ("!LINE!") do echo Found: %%~nxB
- echo Found collector: !LINE! >> "%LOGFILE%"
- )
- )
- )
- if %COLLECTOR_COUNT% EQU 0 (
- echo No collector bundles found.
- echo No collector bundles found. >> "%LOGFILE%"
- ) else (
- echo Total collectors found: %COLLECTOR_COUNT%
- )
- REM =====================================================
- REM Download Saved Config (ns.conf from nsconfig folder)
- REM Inside collector bundles only
- REM =====================================================
- echo.
- echo [3/5] Downloading saved configurations ^(ns.conf^)...
- echo Downloading saved configurations... >> "%LOGFILE%"
- set "CONFIG_COUNT=0"
- for /f "usebackq delims=" %%C in ("%COLLECTOR_LIST%") do (
- set "COLLECTOR_PATH=%%C"
-
- REM Skip empty lines and filter noise
- if not "!COLLECTOR_PATH!"=="" (
- echo !COLLECTOR_PATH! | findstr /C:"collector_" >nul
- if !ERRORLEVEL! EQU 0 (
- for %%D in ("!COLLECTOR_PATH!") do set "COLLECTOR_NAME=%%~nxD"
-
- echo Checking !COLLECTOR_NAME! for ns.conf...
-
- set "DEST_FILENAME=ns.conf_!COLLECTOR_NAME!"
-
- if "%SCP_TYPE%"=="PSCP" (
- pscp.exe -batch -pw "%PASSWORD%" -q "%USERNAME%@%REMOTE_SERVER%:!COLLECTOR_PATH!/nsconfig/ns.conf" "%DEST%\configs\!DEST_FILENAME!" >nul 2>&1
- ) else (
- scp -o StrictHostKeyChecking=no -q "%USERNAME%@%REMOTE_SERVER%:!COLLECTOR_PATH!/nsconfig/ns.conf" "%DEST%\configs\!DEST_FILENAME!" 2>nul
- )
-
- if exist "%DEST%\configs\!DEST_FILENAME!" (
- echo Downloaded: !DEST_FILENAME!
- echo Downloaded: !DEST_FILENAME! >> "%LOGFILE%"
- set /a CONFIG_COUNT+=1
- ) else (
- echo ns.conf not found in !COLLECTOR_NAME!
- )
- )
- )
- )
- echo Saved configs downloaded: %CONFIG_COUNT%
- REM =====================================================
- REM Download Running Config (ns_running_config.conf)
- REM Inside collector bundles only
- REM =====================================================
- echo.
- echo [4/5] Downloading running configurations...
- echo Downloading running configurations... >> "%LOGFILE%"
- set "RUNNING_COUNT=0"
- for /f "usebackq delims=" %%C in ("%COLLECTOR_LIST%") do (
- set "COLLECTOR_PATH=%%C"
-
- REM Skip empty lines and filter noise
- if not "!COLLECTOR_PATH!"=="" (
- echo !COLLECTOR_PATH! | findstr /C:"collector_" >nul
- if !ERRORLEVEL! EQU 0 (
- for %%D in ("!COLLECTOR_PATH!") do set "COLLECTOR_NAME=%%~nxD"
-
- echo Checking !COLLECTOR_NAME! for running config...
-
- set "DEST_FILENAME=ns_running_config.conf_!COLLECTOR_NAME!"
-
- if "%SCP_TYPE%"=="PSCP" (
- pscp.exe -batch -pw "%PASSWORD%" -q "%USERNAME%@%REMOTE_SERVER%:!COLLECTOR_PATH!/shell/ns_running_config.conf" "%DEST%\configs\!DEST_FILENAME!" >nul 2>&1
- ) else (
- scp -o StrictHostKeyChecking=no -q "%USERNAME%@%REMOTE_SERVER%:!COLLECTOR_PATH!/shell/ns_running_config.conf" "%DEST%\configs\!DEST_FILENAME!" 2>nul
- )
-
- if exist "%DEST%\configs\!DEST_FILENAME!" (
- echo Downloaded: !DEST_FILENAME!
- echo Downloaded: !DEST_FILENAME! >> "%LOGFILE%"
- set /a RUNNING_COUNT+=1
- ) else (
- echo Running config not found in !COLLECTOR_NAME!
- )
- )
- )
- )
- echo Running configs downloaded: %RUNNING_COUNT%
- REM =====================================================
- REM Download Capture and Media Files
- REM OUTSIDE collector bundles only (case root level)
- REM Using pre-fetched file list
- REM =====================================================
- echo.
- echo [5/5] Downloading files from case directory...
- echo Downloading files from case root... >> "%LOGFILE%"
- set "CAPTURE_COUNT=0"
- set "MEDIA_COUNT=0"
- set "OTHER_COUNT=0"
- for /f "usebackq delims=" %%F in ("%TEMP_LIST%") do (
- set "REMOTE_FILE=%%F"
-
- REM Skip empty lines and filter noise
- if not "!REMOTE_FILE!"=="" (
- echo !REMOTE_FILE! | findstr /C:"Keyboard" /C:"prompts" /C:"authentication" >nul
- if !ERRORLEVEL! NEQ 0 (
- for %%G in ("!REMOTE_FILE!") do (
- set "FILENAME=%%~nxG"
- set "FILEEXT=%%~xG"
- )
-
- if not "!FILENAME!"=="" (
- REM Determine file type and destination
- set "FILE_DEST="
- set "FILE_TYPE="
-
- REM Check if capture file
- echo !FILEEXT! | findstr /I /C:".cap" /C:".pcap" /C:".pcapng" /C:".sslkeys" /C:".keys" /C:".har" >nul
- if !ERRORLEVEL! EQU 0 (
- set "FILE_DEST=%DEST%\captures\!FILENAME!"
- set "FILE_TYPE=capture"
- )
-
- REM Check if image file
- echo !FILEEXT! | findstr /I /C:".jpg" /C:".jpeg" /C:".png" /C:".gif" /C:".bmp" /C:".webp" /C:".tiff" /C:".svg" >nul
- if !ERRORLEVEL! EQU 0 (
- set "FILE_DEST=%DEST%\media\!FILENAME!"
- set "FILE_TYPE=media"
- )
-
- REM Check if other file (txt, log, xml, json, csv)
- echo !FILEEXT! | findstr /I /C:".txt" /C:".log" /C:".xml" /C:".json" /C:".csv" >nul
- if !ERRORLEVEL! EQU 0 (
- set "FILE_DEST=%DEST%\!FILENAME!"
- set "FILE_TYPE=other"
- )
-
- REM Download the file
- if defined FILE_DEST (
- echo Downloading: !FILENAME!
-
- if "%SCP_TYPE%"=="PSCP" (
- pscp.exe -batch -pw "%PASSWORD%" -q "%USERNAME%@%REMOTE_SERVER%:!REMOTE_FILE!" "!FILE_DEST!" >nul 2>&1
- ) else (
- scp -o StrictHostKeyChecking=no -q "%USERNAME%@%REMOTE_SERVER%:!REMOTE_FILE!" "!FILE_DEST!" 2>nul
- )
-
- if exist "!FILE_DEST!" (
- echo Downloaded: !FILENAME!
- echo Downloaded !FILE_TYPE!: !FILENAME! >> "%LOGFILE%"
-
- if "!FILE_TYPE!"=="capture" set /a CAPTURE_COUNT+=1
- if "!FILE_TYPE!"=="media" set /a MEDIA_COUNT+=1
- if "!FILE_TYPE!"=="other" set /a OTHER_COUNT+=1
- )
- )
- )
- )
- )
- )
- echo.
- echo Capture files downloaded: %CAPTURE_COUNT%
- echo Media files downloaded: %MEDIA_COUNT%
- echo Other files downloaded: %OTHER_COUNT%
- REM =====================================================
- REM Cleanup and Summary
- REM =====================================================
- del "%TEMP_LIST%" 2>nul
- del "%TEMP_FILTERED%" 2>nul
- del "%COLLECTOR_LIST%" 2>nul
- del "%ALL_FILES_LIST%" 2>nul
- REM Remove empty directories
- for %%D in (configs captures media) do (
- dir /b "%DEST%\%%D" 2>nul | findstr "." >nul || rmdir "%DEST%\%%D" 2>nul
- )
- echo.
- echo =====================================================
- echo Download Complete - Summary
- echo =====================================================
- echo.
- echo FROM COLLECTOR BUNDLES:
- echo Collector bundles found : %COLLECTOR_COUNT%
- echo Saved configs ^(ns.conf^) : %CONFIG_COUNT%
- echo Running configs : %RUNNING_COUNT%
- echo.
- echo FROM CASE ROOT DIRECTORY:
- echo Capture files ^(pcap,har^) : %CAPTURE_COUNT%
- echo Media files ^(images^) : %MEDIA_COUNT%
- echo Other files ^(xml,txt^) : %OTHER_COUNT%
- echo.
- echo Destination folder:
- echo %DEST%
- echo.
- echo Log file:
- echo %LOGFILE%
- echo.
- REM Write summary to log
- echo. >> "%LOGFILE%"
- echo ================================================== >> "%LOGFILE%"
- echo SUMMARY >> "%LOGFILE%"
- echo ================================================== >> "%LOGFILE%"
- echo FROM COLLECTOR BUNDLES: >> "%LOGFILE%"
- echo Collector bundles found : %COLLECTOR_COUNT% >> "%LOGFILE%"
- echo Saved configs : %CONFIG_COUNT% >> "%LOGFILE%"
- echo Running configs : %RUNNING_COUNT% >> "%LOGFILE%"
- echo. >> "%LOGFILE%"
- echo FROM CASE ROOT DIRECTORY: >> "%LOGFILE%"
- echo Capture files : %CAPTURE_COUNT% >> "%LOGFILE%"
- echo Media files : %MEDIA_COUNT% >> "%LOGFILE%"
- echo Other files : %OTHER_COUNT% >> "%LOGFILE%"
- echo ================================================== >> "%LOGFILE%"
- echo =====================================================
- echo.
- REM Open destination folder
- choice /C YN /M "Open destination folder now?"
- if !ERRORLEVEL! EQU 1 explorer "%DEST%"
- endlocal
- exit /b 0
|