소스 검색

Delete 'pcdu.bat'

parv.ashwani 3 달 전
부모
커밋
482d92b0f2
1개의 변경된 파일0개의 추가작업 그리고 452개의 파일을 삭제
  1. 0 452
      pcdu.bat

+ 0 - 452
pcdu.bat

@@ -1,452 +0,0 @@
-@echo off
-setlocal EnableExtensions EnableDelayedExpansion
-
-REM =====================================================
-REM   ____                  _       ____ ____  _   _ 
-REM  |  _ \ __ _ _ ____   _( )___  / ___|  _ \| | | |
-REM  | |_) / _` | '__\ \ / /|// __|| |   | | | | | | |
-REM  |  __/ (_| | |   \ V /  \__ \| |___| |_| | |_| |
-REM  |_|   \__,_|_|    \_/   |___(_)____|____/ \___/ 
-REM                                                   
-REM  Parv's Case Download Utility (PCDU)
-REM  Downloads case files from analysis server
-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   ^|^> Parv's Case Download Utility ^(PCDU^) v1.0
-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 ============================================================ > "%LOGFILE%"
-echo  Parv's Case Download Utility ^(PCDU^) - Download Log >> "%LOGFILE%"
-echo ============================================================ >> "%LOGFILE%"
-echo  Case Number  : %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 [1/5] 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 [2/5] 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 [3/5] 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!...
-            
-            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         [OK] !DEST_FILENAME!
-                echo         [OK] Downloaded: !DEST_FILENAME! >> "%LOGFILE%"
-                set /a CONFIG_COUNT+=1
-            ) else (
-                echo         [--] ns.conf not found
-            )
-        )
-    )
-)
-
-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 [4/5] 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!...
-            
-            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         [OK] !DEST_FILENAME!
-                echo         [OK] Downloaded: !DEST_FILENAME! >> "%LOGFILE%"
-                set /a RUNNING_COUNT+=1
-            ) else (
-                echo         [--] Running config not found
-            )
-        )
-    )
-)
-
-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 [5/5] 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         [OK] !FILENAME!
-                        echo         [OK] 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 : %DEST%
-echo   Log file    : %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