-
Notifications
You must be signed in to change notification settings - Fork 63
/
Copy pathZipRipper.cmd
1102 lines (1056 loc) · 55.7 KB
/
ZipRipper.cmd
1
2
3
4
5
6
7
8
9
10
11
12
13
14
15
16
17
18
19
20
21
22
23
24
25
26
27
28
29
30
31
32
33
34
35
36
37
38
39
40
41
42
43
44
45
46
47
48
49
50
51
52
53
54
55
56
57
58
59
60
61
62
63
64
65
66
67
68
69
70
71
72
73
74
75
76
77
78
79
80
81
82
83
84
85
86
87
88
89
90
91
92
93
94
95
96
97
98
99
100
101
102
103
104
105
106
107
108
109
110
111
112
113
114
115
116
117
118
119
120
121
122
123
124
125
126
127
128
129
130
131
132
133
134
135
136
137
138
139
140
141
142
143
144
145
146
147
148
149
150
151
152
153
154
155
156
157
158
159
160
161
162
163
164
165
166
167
168
169
170
171
172
173
174
175
176
177
178
179
180
181
182
183
184
185
186
187
188
189
190
191
192
193
194
195
196
197
198
199
200
201
202
203
204
205
206
207
208
209
210
211
212
213
214
215
216
217
218
219
220
221
222
223
224
225
226
227
228
229
230
231
232
233
234
235
236
237
238
239
240
241
242
243
244
245
246
247
248
249
250
251
252
253
254
255
256
257
258
259
260
261
262
263
264
265
266
267
268
269
270
271
272
273
274
275
276
277
278
279
280
281
282
283
284
285
286
287
288
289
290
291
292
293
294
295
296
297
298
299
300
301
302
303
304
305
306
307
308
309
310
311
312
313
314
315
316
317
318
319
320
321
322
323
324
325
326
327
328
329
330
331
332
333
334
335
336
337
338
339
340
341
342
343
344
345
346
347
348
349
350
351
352
353
354
355
356
357
358
359
360
361
362
363
364
365
366
367
368
369
370
371
372
373
374
375
376
377
378
379
380
381
382
383
384
385
386
387
388
389
390
391
392
393
394
395
396
397
398
399
400
401
402
403
404
405
406
407
408
409
410
411
412
413
414
415
416
417
418
419
420
421
422
423
424
425
426
427
428
429
430
431
432
433
434
435
436
437
438
439
440
441
442
443
444
445
446
447
448
449
450
451
452
453
454
455
456
457
458
459
460
461
462
463
464
465
466
467
468
469
470
471
472
473
474
475
476
477
478
479
480
481
482
483
484
485
486
487
488
489
490
491
492
493
494
495
496
497
498
499
500
501
502
503
504
505
506
507
508
509
510
511
512
513
514
515
516
517
518
519
520
521
522
523
524
525
526
527
528
529
530
531
532
533
534
535
536
537
538
539
540
541
542
543
544
545
546
547
548
549
550
551
552
553
554
555
556
557
558
559
560
561
562
563
564
565
566
567
568
569
570
571
572
573
574
575
576
577
578
579
580
581
582
583
584
585
586
587
588
589
590
591
592
593
594
595
596
597
598
599
600
601
602
603
604
605
606
607
608
609
610
611
612
613
614
615
616
617
618
619
620
621
622
623
624
625
626
627
628
629
630
631
632
633
634
635
636
637
638
639
640
641
642
643
644
645
646
647
648
649
650
651
652
653
654
655
656
657
658
659
660
661
662
663
664
665
666
667
668
669
670
671
672
673
674
675
676
677
678
679
680
681
682
683
684
685
686
687
688
689
690
691
692
693
694
695
696
697
698
699
700
701
702
703
704
705
706
707
708
709
710
711
712
713
714
715
716
717
718
719
720
721
722
723
724
725
726
727
728
729
730
731
732
733
734
735
736
737
738
739
740
741
742
743
744
745
746
747
748
749
750
751
752
753
754
755
756
757
758
759
760
761
762
763
764
765
766
767
768
769
770
771
772
773
774
775
776
777
778
779
780
781
782
783
784
785
786
787
788
789
790
791
792
793
794
795
796
797
798
799
800
801
802
803
804
805
806
807
808
809
810
811
812
813
814
815
816
817
818
819
820
821
822
823
824
825
826
827
828
829
830
831
832
833
834
835
836
837
838
839
840
841
842
843
844
845
846
847
848
849
850
851
852
853
854
855
856
857
858
859
860
861
862
863
864
865
866
867
868
869
870
871
872
873
874
875
876
877
878
879
880
881
882
883
884
885
886
887
888
889
890
891
892
893
894
895
896
897
898
899
900
901
902
903
904
905
906
907
908
909
910
911
912
913
914
915
916
917
918
919
920
921
922
923
924
925
926
927
928
929
930
931
932
933
934
935
936
937
938
939
940
941
942
943
944
945
946
947
948
949
950
951
952
953
954
955
956
957
958
959
960
961
962
963
964
965
966
967
968
969
970
971
972
973
974
975
976
977
978
979
980
981
982
983
984
985
986
987
988
989
990
991
992
993
994
995
996
997
998
999
1000
@ECHO OFF
REM Begin dynamic alternate wordlist info - expected format is UTF-8 .txt file inside a 7z archive -or- direct link to unarchived UTF-8 .txt file
SET WORDLISTNAME="Cyclone"
SET WORDLISTADDR="https://download.weakpass.com/wordlists/1928/cyclone_hk.txt.7z"
REM End dynamic alternate wordlist info -> Click John's mouth on the GUI to access this option <-
REM Resource Links - 7zr is used to extract 7za CLI from 7zExtra
SET "DL_LOGO=https://raw.githubusercontent.com/illsk1lls/ZipRipper/main/.resources/zipripper.png"
SET "DL_JTR=https://github.com/openwall/john-packages/releases/download/bleeding/winX64_1_JtR.7z"
SET "DL_7ZR=https://www.7-zip.org/a/7zr.exe"
SET "DL_7ZEXTRA=https://www.7-zip.org/a/7z2300-extra.7z"
SET "DL_PERLPORTABLE=https://strawberryperl.com/download/5.16.3.1/strawberry-perl-5.16.3.1-64bit-portable.zip"
REM Supported GPUs
SET NVIDIA_CARDS=GeForce,RTX,A800,T1000,Quadro
SET AMD_CARDS=RadeonRX,RadeonPro
REM Filenames and Folders - Tempfolders in %ProgramData%
SET "LOGO=%ProgramData%\zipripper.png"
SET "RESUMEDATAFOLDER=%AppData%\ZR-InProgress"
SET RESUMEDATAFILES=pwhash,john.pot,john.rec,john.*.rec,john.log,password.lst
SET TEMPFILES=zr-offline.txt,7zExtra.7z,7zr.exe,perlportable.zip,winX64_1_JtR.7z,zipripper.png,launcher.ZipRipper
SET TEMPFOLDERS=JtR,ztmp
REM Everything except resume data is cleaned up when ZipRipper is closed properly.
CALL :SINGLEINSTANCE
IF NOT "%PROCESSOR_ARCHITECTURE%"=="AMD64" (
IF NOT "%PROCESSOR_ARCHITEW6432%"=="AMD64" (
ECHO FOR USE WITH x64 SYSTEMS ONLY
ECHO/
PAUSE
GOTO :EOF
) ELSE (
ECHO UNABLE TO LAUNCH IN x86 MODE
ECHO/
PAUSE
GOTO :EOF
)
)
IF NOT "%~2"=="" (
ECHO Multiple files are not supported. Double-click the script and use the GUI to select a file...
ECHO/
PAUSE
GOTO :EOF
)
IF NOT EXIST "%~dp0zr-offline.txt" (
SET OFFLINE=0
CALL :CHECKCONNECTION ONLINE
SETLOCAL ENABLEDELAYEDEXPANSION
IF !ONLINE! EQU 0 (
ENDLOCAL
CALL :CENTERWINDOW
ECHO Internet connection not detected...
ECHO/
ECHO ^[zr-offline.txt^] must be in the same folder as ZipRipper for offline mode.
ECHO/
ECHO Click JtR on John's hat on an internet connected machine to create a local
ECHO copy of ^[zr-offline.txt^]
ECHO/
PAUSE
GOTO :EOF
)
ENDLOCAL
) ELSE (
SET OFFLINE=1
)
>nul 2>&1 REG ADD HKCU\Software\classes\.ZipRipper\shell\runas\command /f /ve /d "CMD /x /d /r SET \"f0=1\"&CALL \"%%2\" %%3"
IF /I NOT "%~dp0" == "%ProgramData%\" (
CALL :CLEANUP STARTUP
ECHO|(SET /p="%~dp0")>"%ProgramData%\launcher.ZipRipper"
>nul 2>&1 COPY /Y "%~f0" "%ProgramData%"
IF EXIST "%~dp0zr-offline.txt" (
>nul 2>&1 COPY /Y "%~dp0zr-offline.txt" "%ProgramData%"
)
>nul 2>&1 FLTMC && (
TITLE Re-Launching...
START "" /min "%ProgramData%\launcher.ZipRipper" "%ProgramData%\%~nx0"
EXIT /b
) || (
IF NOT "%f0%"=="1" (
TITLE Re-Launching...
START "" /min /high "%ProgramData%\launcher.ZipRipper" "%ProgramData%\%~nx0"
EXIT /b
)
)
)
SET "NATIVE=ZIP,RAR"
SET "PERL=7z,PDF"
SET GPU=0
SET ALLOWSTART=0
CALL :CHECKWIN
CALL :CHECKGPU
IF EXIST "%ProgramData%\JtR" (
>nul 2>&1 RD "%ProgramData%\JtR" /S /Q
)
>nul 2>&1 ATTRIB -h "%ProgramData%\BIT*.tmp"
IF EXIST "%ProgramData%\BIT*.tmp" (
>nul 2>&1 DEL "%ProgramData%\BIT*.tmp" /F /Q
)
CALL :CENTERWINDOW
IF "%OFFLINE%"=="1" (
CALL :OFFLINEMODE
)
IF "%~1"=="" (
ECHO USE THE GUI TO PROCEED
:MAIN
SET "ACTION="
SET "WORDLIST="
CALL :MAINMENU ACTION WORDLIST
SETLOCAL ENABLEDELAYEDEXPANSION
IF "!ACTION!"=="Offline" (
ENDLOCAL
CALL :BUILD RELAUNCH
SET /p OFOLDER=<"%ProgramData%\launcher.ZipRipper"
SETLOCAL ENABLEDELAYEDEXPANSION
IF /I "!RELAUNCH!"=="Yes" (
TITLE Re-Launching...
START "" /min "%ProgramData%\launcher.ZipRipper" "!OFOLDER!%~nx0"
ENDLOCAL
EXIT /b
) ELSE (
ENDLOCAL
CALL :CLEANUP
GOTO :EOF
)
)
SETLOCAL ENABLEDELAYEDEXPANSION
IF NOT "!ACTION!"=="Start" (
ENDLOCAL
CALL :CLEANUP
)
IF !WORDLIST! EQU 1 (
CALL :CHECKCONNECTION ONLINE
IF !ONLINE! EQU 1 (
SET "LMSG=%WORDLISTNAME:"=% wordlist selected - The wordlist will be included in the resume data"
CALL :LISTMESSAGE "!LMSG!" "Wordlist Information:"
) ELSE (
SET "LMSG=Internet connection unavailable - Automatic retrieval of %WORDLISTNAME:"=% wordlist is not possible. Default and Custom wordlist options are available."
CALL :LISTMESSAGE "!LMSG!" "Warning:"
CALL :RESETWORDLIST
GOTO :MAIN
)
)
IF !WORDLIST! EQU 2 (
SET "LMSG=Custom wordlist selected - The wordlist will be included in the resume data - Please select a wordlist file"
CALL :LISTMESSAGE "!LMSG!" "Wordlist Information:"
FOR /F "usebackq tokens=* delims=" %%# IN (`POWERSHELL -nop -c "Add-Type -AssemblyName System.Windows.Forms;$^=New-Object System.Windows.Forms.OpenFileDialog -Property @{InitialDirectory='';Title='Select a Custom wordlist - (A text file with UTF-8 encoding)';Filter='All Supported (*.txt;*.lst)|*.txt;*.lst|TXT (*.txt)|*.txt|LST (*.lst)|*.lst'};$null=$^.ShowDialog();$Quoted='"^""' + $^^.Filename + '"^""';$Quoted"`) DO (
SET LISTNAME=%%#
)
IF NOT !LISTNAME!=="" (
IF NOT EXIST !LISTNAME! (
CALL :RESETWORDLIST
GOTO :MAIN
)
CALL :GETSIZE !LISTNAME! LISTSIZE
IF !LISTSIZE! EQU 0 (
CALL :ENABLEBRUTE BRUTEENABLED
IF /I "!BRUTEENABLED!"=="Yes" (
SET LISTNAME=BRUTE
) ELSE (
CALL :RESETWORDLIST
GOTO :MAIN
)
)
) ELSE (
CALL :RESETWORDLIST
GOTO :MAIN
)
)
SET "LMSG=Please select a password protected ZIP, RAR, 7z, or PDF file"
CALL :LISTMESSAGE "!LMSG!" "Select a target file:"
SETLOCAL DISABLEDELAYEDEXPANSION
CALL :GETFILE FILENAME
SETLOCAL ENABLEDELAYEDEXPANSION
IF !FILENAME!=="" (
IF DEFINED LISTNAME CALL :RESETWORDLIST
ENDLOCAL
GOTO :MAIN
)
TITLE Re-Launching...
CALL :SETTERMINAL
START "" "%ProgramData%\launcher.ZipRipper" "%ProgramData%\%~nx0" "!FILENAME:"=""!"
CALL :RESTORETERMINAL
ENDLOCAL
EXIT /b
)
FOR %%# IN (%NATIVE%) DO (
IF /I "%~x1"==".%%#" (
SET ALLOWSTART=1
SET ISPERL=0
)
)
FOR %%# IN (%PERL%) DO (
IF /I "%~x1"==".%%#" (
SET ALLOWSTART=1
SET ISPERL=1
)
)
IF NOT "%ALLOWSTART%"=="1" (
CALL :CLEANUP
GOTO :EOF
)
>nul 2>&1 REG DELETE HKCU\Software\classes\.ZipRipper\ /F
>nul 2>&1 DEL "%ProgramData%\launcher.ZipRipper" /F /Q
SET "FILETYPE=%~x1"
SET "TitleName=[ZIP-Ripper] - [Initializing] - [OpenCL #STATUS] - #RUNMODE Mode"
SETLOCAL ENABLEDELAYEDEXPANSION
IF !GPU! GEQ 1 (
ENDLOCAL
SET "TitleName=%TitleName:#STATUS=AVAILABLE%"
) ELSE (
ENDLOCAL
SET "TitleName=%TitleName:Initializing=CPU Mode%"
SET "TitleName=%TitleName:#STATUS=UNAVAILABLE%"
)
SETLOCAL ENABLEDELAYEDEXPANSION
IF !OFFLINE! EQU 0 (
ENDLOCAL
SET "TitleName=%TitleName:#RUNMODE=Online%"
) ELSE (
ENDLOCAL
SET "TitleName=%TitleName:#RUNMODE=Offline%"
)
TITLE %TitleName%
IF %OFFLINE% EQU 0 (
SETLOCAL ENABLEDELAYEDEXPANSION
IF !WORDLIST! EQU 1 (
<NUL set /p=Please Wait...
CALL :WORDLISTFILEINFO
IF !wListOuter!=="" (
SET wListOuter=!LISTNAME!
)
CALL :SINGLEDOWNLOAD %WORDLISTADDR% !wListOuter! "Downloading %WORDLISTNAME:"=% wordlist..."
CALL :ONLINEMODE
ECHO Ready
ECHO/
) ELSE (
<NUL set /p=Please Wait...
CALL :ONLINEMODE
ECHO Ready
ECHO/
)
) ELSE (
IF !WORDLIST! EQU 1 (
CALL :WORDLISTFILEINFO
IF !wListOuter!=="" (
SET wListOuter=!LISTNAME!
)
CALL :SINGLEDOWNLOAD %WORDLISTADDR% !wListOuter! "Downloading %WORDLISTNAME:"=% wordlist..."
)
)
CALL :GETJTRREADY
SETLOCAL DISABLEDELAYEDEXPANSION
ECHO Done
ECHO/
PUSHD "%ProgramData%\JtR\run"
REN john.conf john.defaultconf
POWERSHELL -nop -c "$^=gc john.defaultconf|%%{$_.Replace('SingleMaxBufferAvailMem = N','SingleMaxBufferAvailMem = Y').Replace('MaxKPCWarnings = 10','MaxKPCWarnings = 0')}|sc john.conf">nul 2>&1
SET "FLAG="
SET RESUME=0
CALL :GETMD5 "%~1" MD5
IF EXIST "%RESUMEDATAFOLDER%\%MD5%" (
CALL :RESUMEDECIDE ISRESUME
SETLOCAL ENABLEDELAYEDEXPANSION
IF /I "!ISRESUME!"=="Yes" (
SETLOCAL DISABLEDELAYEDEXPANSION
>nul 2>&1 MOVE /Y "%RESUMEDATAFOLDER%\%MD5%\*.*" "%ProgramData%\JtR\run\"
CALL :CHECKRESUMENAME "%~1"
SET RESUME=1
GOTO :STARTJTR
) ELSE (
SETLOCAL DISABLEDELAYEDEXPANSION
>nul 2>&1 RD "%RESUMEDATAFOLDER%\%MD5%" /S /Q
)
)
IF %~z1 GEQ 200000000 (
<NUL set /p=Creating password hash - This can take a few minutes on large files...
) ELSE (
<NUL set /p=Creating password hash...
)
SET PROTECTED=1
SET HSIZE=0
SET "FORKS="
CALL :HASH%FILETYPE% "%~1"
SETLOCAL ENABLEDELAYEDEXPANSION
IF NOT "!PROTECTED!"=="1" (
ENDLOCAL
CALL :NOTSUPPORTED "%~1" "%ERRORMSG%"
CALL :CLEANUP
GOTO :EOF
)
IF "!COMMON!"=="1" (
<NUL set /p=Enabling FAST PDF Mode ^[Length=8^]...
CALL :WAIT 1
ECHO Ready
CALL :WAIT 2
) ELSE (
IF DEFINED LISTNAME (
IF !WORDLIST! EQU 2 (
IF "!LISTNAME!"=="BRUTE" (
<NUL set /p=Enabling BruteForce Mode...
CALL :WAIT 1
ECHO Ready
) ELSE (
<NUL set /p=Preparing Custom wordlist!FORKS!...
>nul 2>&1 COPY /Y !LISTNAME! "%ProgramData%\JtR\run\password.lst"
ECHO Loaded
)
) ELSE (
<NUL set /p=Preparing %WORDLISTNAME:"=% wordlist!FORKS!...
>nul 2>&1 MOVE /Y !LISTNAME! "%ProgramData%\JtR\run\password.lst"
ECHO Loaded
)
ENDLOCAL
CALL :WAIT 2
) ELSE (
<NUL set /p=Using Default wordlist!FORKS!...
ENDLOCAL
CALL :WAIT 1
ECHO Loaded
CALL :WAIT 2
)
)
:STARTJTR
CLS
ECHO Running JohnTheRipper...
ECHO/
IF "%RESUME%"=="1" (
<NUL set /p=Resuming Session...
CALL :SETSTATUSANDFLAGS
john --restore
) ELSE (
SETLOCAL ENABLEDELAYEDEXPANSION
IF "!COMMON!"=="1" (
john "%ProgramData%\JtR\run\pwhash" !FLAG!
) ELSE (
IF "!LISTNAME!"=="BRUTE" (
john "%ProgramData%\JtR\run\pwhash" --incremental=ASCII.chr !FLAG!
) ELSE (
john --wordlist="%ProgramData%\JtR\run\password.lst" --rules=single,all "%ProgramData%\JtR\run\pwhash" !FLAG!
)
)
ENDLOCAL
)
CALL :GETSIZE "%ProgramData%\JtR\run\john.pot" POTSIZE
CALL :SAVELOCATION UserDesktop
SETLOCAL ENABLEDELAYEDEXPANSION
IF !POTSIZE! GEQ 1 (
ENDLOCAL
ECHO/
<NUL set /p=Generating Password File...
CALL :SAVEFILE "%~1"
IF EXIST "%RESUMEDATAFOLDER%\%MD5%" (
>nul 2>&1 RD "%RESUMEDATAFOLDER%\%MD5%" /S /Q
)
ECHO Done
ECHO/
ECHO Passwords saved to: "%UserDesktop%\ZipRipper-Passwords.txt"
CALL :DISPLAYFOUNDPW
) ELSE (
ENDLOCAL
ECHO/
CALL :SETRESUME "%~1"
)
ECHO/
PAUSE
POPD
CALL :CLEANUP
GOTO :EOF
:GETMD5
SET "MD5FILE=%~1"
FOR /F "usebackq tokens=* delims=" %%# IN (`POWERSHELL -nop -c "$^=Resolve-Path '%MD5FILE:'=''%';$md5=new-object -TypeName System.Security.Cryptography.MD5CryptoServiceProvider;$f=[System.IO.File]::Open($^,[System.IO.Filemode]::Open,[System.IO.FileAccess]::Read);try{[System.BitConverter]::ToString($md5.ComputeHash($f)).Replace('-','').ToLower()}finally{$f.Dispose()}"`) DO (
SET %2=%%#
)
EXIT /b
:RESUMEDECIDE
FOR /F "usebackq tokens=* delims=" %%# IN (`POWERSHELL -nop -c "Add-Type -AssemblyName System.Windows.Forms;$^={$Notify=[PowerShell]::Create().AddScript({$Audio=New-Object System.Media.SoundPlayer;$Audio.SoundLocation=$env:WinDir + '\Media\Windows Notify System Generic.wav';$Audio.playsync()});$rs=[RunspaceFactory]::CreateRunspace();$rs.ApartmentState="^""STA"^"";$rs.ThreadOptions="^""ReuseThread"^"";$rs.Open();$Notify.Runspace=$rs;$Notify.BeginInvoke()};&$^;[System.Windows.Forms.MessageBox]::Show('Would you like to resume the job? (Click NO to clear the resume data and start over)', 'Resume Data Found',4,32,0,131072)"`) DO (
SET %1=%%#
)
EXIT /b
:SETRESUME
IF NOT EXIST "%ProgramData%\JtR\run\john.rec" (
ECHO Resume is UNAVAILABLE for this file ;^(
) ELSE (
ECHO Resume is available for the next session...
IF NOT EXIST "%RESUMEDATAFOLDER%\%MD5%" (
MD "%RESUMEDATAFOLDER%\%MD5%"
)
FOR %%# IN (%RESUMEDATAFILES%) DO (
IF /I EXIST "%ProgramData%\JtR\run\%%#" (
>nul 2>&1 MOVE /Y "%ProgramData%\JtR\run\%%#" "%RESUMEDATAFOLDER%\%MD5%"
)
)
)
EXIT /b
:WAIT
SET /A TIMER=%~1+1
>nul 2>&1 PING 127.0.0.1 -n %TIMER%
EXIT /b
:NOTSUPPORTED
CLS
IF "%PROTECTED%"=="2" (
ECHO UNHANDLED ERROR!
ECHO/
ECHO|(SET /p="%~2"&ECHO/)
) ELSE (
ECHO|(SET /p="%~1 %~2"&ECHO/)
)
ECHO/
PAUSE
EXIT /b
:ONLINEMODE
SET P=3
SET PT=11
IF "%ISPERL%"=="1" (
SET P=4
SET PT=8
SET "PERL2=$info.Text=' Downloading Portable Perl';Update-Gui;downloadFile '%DL_PERLPORTABLE%' '%ProgramData%\perlportable.zip';"
)
POWERSHELL -nop -c "Add-Type -AssemblyName PresentationFramework, System.Drawing, System.Windows.Forms, WindowsFormsIntegration;[xml]$xaml='<Window xmlns="^""http://schemas.microsoft.com/winfx/2006/xaml/presentation"^"" xmlns:x="^""http://schemas.microsoft.com/winfx/2006/xaml"^"" Title="^"" Initializing..."^"" Height="^""75"^"" Width="^""210"^"" WindowStartupLocation="^""CenterScreen"^"" WindowStyle="^""None"^"" Topmost="^""True"^"" Background="^""#333333"^"" AllowsTransparency="^""True"^""><Canvas><TextBlock Name="^""Info"^"" Canvas.Top="^""3"^"" Text="^"" Initializing..."^"" Foreground="^""#eeeeee"^"" FontWeight="^""Bold"^""/><ProgressBar Canvas.Left="^""5"^"" Canvas.Top="^""28"^"" Width="^""200"^"" Height="^""3"^"" Name="^""Progress"^"" Foreground="^""#FF0000"^""/><TextBlock Name="^""Info2"^"" Canvas.Top="^""38"^"" Text="^"" Getting Resources (Online Mode)"^"" Foreground="^""#eeeeee"^"" FontWeight="^""Bold"^""/><ProgressBar Canvas.Left="^""5"^"" Canvas.Top="^""63"^"" Width="^""200"^"" Height="^""3"^"" Name="^""Progress2"^"" Foreground="^""#FF0000"^""/></Canvas><Window.TaskbarItemInfo><TaskbarItemInfo/></Window.TaskbarItemInfo></Window>';$reader=(New-Object System.Xml.XmlNodeReader $xaml);$form=[Windows.Markup.XamlReader]::Load($reader);$bitmap=New-Object System.Windows.Media.Imaging.BitmapImage;$bitmap='%LOGO:'=''%';$form.Icon=$bitmap;$form.TaskbarItemInfo.Overlay=$bitmap;$form.TaskbarItemInfo.Description=$form.Title;$form.Add_Closing({[System.Windows.Forms.Application]::Exit();Stop-Process $pid});$progressBar=$form.FindName("^""Progress"^"");$progressTotal=$form.FindName("^""Progress2"^"");$info=$form.FindName("^""Info"^"");$info2=$form.FindName("^""Info2"^"");function Update-Gui(){$form.Dispatcher.Invoke([Windows.Threading.DispatcherPriority]::Background, [action]{})};function GetResources(){$info.Text=' Initializing...';$progressTotal.Value=%PT%;Update-Gui;$info.Text=' Downloading 7zr Standalone';Update-Gui;downloadFile '%DL_7ZR%' '%ProgramData%\7zr.exe';$info.Text=' Downloading 7za Console';Update-Gui;downloadFile '%DL_7ZEXTRA%' '%ProgramData%\7zExtra.7z';$info.Text=' Downloading JohnTheRipper';Update-Gui;downloadFile '%DL_JTR%' '%ProgramData%\winX64_1_JtR.7z';%PERL2%$progressTotal.Value=100;$info.Text="^"" Ready..."^"";Update-Gui};function DownloadFile($url,$targetFile){$uri=New-Object "^""System.Uri"^"" "^""$url"^"";$request=[System.Net.HttpWebRequest]::Create($uri);$request.set_Timeout(15000);$response=$request.GetResponse();$totalLength=[System.Math]::Floor($response.get_ContentLength()/1024);$responseStream=$response.GetResponseStream();$targetStream=New-Object -TypeName System.IO.FileStream -ArgumentList $targetFile, Create;$buffer=new-object byte[] 10KB;$count=$responseStream.Read($buffer,0,$buffer.length);$downloadedBytes=$count;while ($count -gt 0){$targetStream.Write($buffer, 0, $count);$count=$responseStream.Read($buffer,0,$buffer.length);$downloadedBytes=$downloadedBytes + $count;$roundedPercent=[int]((([System.Math]::Floor($downloadedBytes/1024)) / $totalLength) * 100);$progressBar.Value=$roundedPercent;if($totalP -ge %P%){$progressTotal.Value++;$totalP=0};if($progressBar.Value -ne $lastpercent){$lastpercent=$progressBar.Value;$totalP++;Update-Gui}};$targetStream.Flush();$targetStream.Close();$targetStream.Dispose();$responseStream.Dispose()};$form.Add_ContentRendered({GetResources;$form.Close()});$form.Show();$appContext=New-Object System.Windows.Forms.ApplicationContext;[void][System.Windows.Forms.Application]::Run($appContext)">nul
EXIT /b
:OFFLINEMODE
SET NEEDED=7zr.exe,7zExtra.7z,winX64_1_JtR.7z,perlportable.zip,zipripper.png
SET EXTRACT=0
<NUL set /p=Offline mode enabled
FOR %%# IN (%NEEDED%) DO (
IF /I NOT EXIST "%~dp0%%#" (
SET EXTRACT=1
)
)
IF NOT "%EXTRACT%"=="1" (
<NUL set /p=, checking resources...
) ELSE (
<NUL set /p=, preparing resources...
PUSHD "%~dp0"
POWERSHELL -nop -c "Add-Type -AssemblyName PresentationFramework, System.Drawing, System.Windows.Forms, WindowsFormsIntegration;[xml]$xaml='<Window xmlns="^""http://schemas.microsoft.com/winfx/2006/xaml/presentation"^"" xmlns:x="^""http://schemas.microsoft.com/winfx/2006/xaml"^"" Title="^"" Initializing..."^"" Height="^""37"^"" Width="^""210"^"" WindowStartupLocation="^""CenterScreen"^"" WindowStyle="^""None"^"" Topmost="^""True"^"" Background="^""#333333"^"" AllowsTransparency="^""True"^""><Canvas><TextBlock Name="^""Info"^"" Canvas.Top="^""10"^"" Canvas.Left="^""23"^"" Text="^"" Initializing... (Offline Mode)"^"" Foreground="^""#eeeeee"^"" FontWeight="^""Bold"^""/></Canvas></Window>';$reader=(New-Object System.Xml.XmlNodeReader $xaml);$form=[Windows.Markup.XamlReader]::Load($reader);$form.Add_Closing({[System.Windows.Forms.Application]::Exit();Stop-Process $pid});function ExtractFile(){&expand -R zr-offline.txt -F:* .};$form.Add_ContentRendered({ExtractFile;$form.Close()});$form.Show();$appContext=New-Object System.Windows.Forms.ApplicationContext;[void][System.Windows.Forms.Application]::Run($appContext)">nul
POPD
)
ECHO Done
ECHO/
EXIT /b
:GETJTRREADY
<NUL set /p=Extracting required dependencies...
>nul 2>&1 "%ProgramData%\7zr.exe" x -y "%ProgramData%\winX64_1_JtR.7z" -o"%ProgramData%\"
>nul 2>&1 "%ProgramData%\7zr.exe" x -y "%ProgramData%\7zExtra.7z" -o"%ProgramData%\JtR\"
IF EXIST !wListOuter! (
CALL :EXTENSION !wListOuter! WLEXT
IF /I "!WLEXT!"==".7z" (
"%ProgramData%\7zr.exe" x -y !wListOuter! -o"%ProgramData%\">nul
>nul 2>&1 DEL !wListOuter! /F /Q
)
)
IF "%ISPERL%"=="1" (
"%ProgramData%\JtR\7za.exe" x -y "%ProgramData%\perlportable.zip" -o"%ProgramData%\JtR\run">nul
)
FOR %%# IN (perlportable.zip,zr-offline.txt,winX64_1_JtR.7z,7zr.exe,7zExtra.7z) DO (
IF /I EXIST "%ProgramData%\%%#" (
>nul 2>&1 DEL "%ProgramData%\%%#" /F /Q
)
)
EXIT /b
:CHECKWIN
FOR /F "usebackq skip=2 tokens=3,4" %%# IN (`REG QUERY "HKLM\SOFTWARE\Microsoft\Windows NT\CurrentVersion" /v ProductName 2^>nul`) DO (
IF "%%# %%$"=="Windows 7" (
ECHO/
ECHO Windows 7 detected.
ECHO/
ECHO SYSTEM NOT SUPPORTED
ECHO/
PAUSE
GOTO :EOF
)
)
EXIT /b
:CHECKRESUMENAME
SETLOCAL ENABLEDELAYEDEXPANSION
FOR /F "tokens=1 delims=:/" %%# IN ("!pwhash!") DO (
ENDLOCAL
IF NOT "%~nx1"=="%%#" (
SET ALT=1
SET "OLDNAME=%%#"
) ELSE (
SET ALT=0
)
)
SET "NEWNAME=%~nx1"
IF "%ALT%"=="1" (
POWERSHELL -nop -c "Add-Type -AssemblyName System.Windows.Forms;$^={$Notify=[PowerShell]::Create().AddScript({$Audio=New-Object System.Media.SoundPlayer;$Audio.SoundLocation=$env:WinDir + '\Media\Windows Notify System Generic.wav';$Audio.playsync()});$rs=[RunspaceFactory]::CreateRunspace();$rs.ApartmentState="^""STA"^"";$rs.ThreadOptions="^""ReuseThread"^"";$rs.Open();$Notify.Runspace=$rs;$Notify.BeginInvoke()};&$^;[System.Windows.Forms.MessageBox]::Show("^""This file has been renamed since the initial session. The filename will be updated in the saved session data.`n`nInitial file name: %OLDNAME%`n`nCurrent file name: %~nx1`n`nIt is recommended that you do not change the file name after the initial session to avoid potential issues, but it is not a requirement, and the session is able to resume anyway..."^"", 'WARNING: File name change detected!',0,0,0,131072);$update=[System.IO.File]::ReadAllText('%ProgramData%\JtR\run\pwhash').Replace('%OLDNAME:'=''%','%NEWNAME:'=''%');[System.IO.File]::WriteAllText('%ProgramData%\JtR\run\pwhash', $update)">nul
)
EXIT /b
:HASH.ZIP
zip2john "%~1">"%ProgramData%\JtR\run\pwhash" 2>"%ProgramData%\JtR\run\statusout"
SET /p pwhash=< pwhash
FOR /F %%# IN ("%ProgramData%\JtR\run\pwhash") DO (
SET HSIZE=%%~z#
)
IF %HSIZE% EQU 0 (
SET PROTECTED=0
FOR /F "usebackq tokens=*" %%# IN (`TYPE "%ProgramData%\JtR\run\statusout" ^| findstr /I /C^:"Did not find"`) DO (
SET "ERRORMSG=encryption type is not supported.. (not a ZIPfile)"
)
FOR /F "usebackq tokens=*" %%# IN (`TYPE "%ProgramData%\JtR\run\statusout" ^| findstr /I /C^:"non-handled"`) DO (
SET "ERRORMSG=encryption type is not supported.. unable to obtain hash."
)
FOR /F "usebackq tokens=*" %%# IN (`TYPE "%ProgramData%\JtR\run\statusout" ^| findstr /I /C^:"is not encrypted"`) DO (
SET "ERRORMSG=is not password protected.."
)
IF NOT DEFINED ERRORMSG (
SET PROTECTED=2
SET /p ERRORMSG=< "%ProgramData%\JtR\run\statusout"
)
)
CALL :SETSTATUSANDFLAGS
EXIT /b
:HASH.RAR
rar2john "%~1">"%ProgramData%\JtR\run\pwhash" 2>"%ProgramData%\JtR\run\statusout"
SET /p pwhash=< pwhash
FOR /F %%# IN ("%ProgramData%\JtR\run\pwhash") DO (
SET HSIZE=%%~z#
)
IF %HSIZE% EQU 0 (
SET PROTECTED=0
FOR /F "usebackq tokens=*" %%# IN (`TYPE "%ProgramData%\JtR\run\statusout" ^| findstr /I /C^:"Did not find"`) DO (
SET "ERRORMSG=is not password protected.."
)
FOR /F "usebackq tokens=*" %%# IN (`TYPE "%ProgramData%\JtR\run\statusout" ^| findstr /I /C^:"not supported"`) DO (
SET "ERRORMSG=encryption type is not supported.. (old filetype)"
)
IF NOT DEFINED ERRORMSG (
SET PROTECTED=2
SET /p ERRORMSG=< "%ProgramData%\JtR\run\statusout"
)
) ELSE (
FOR /F "tokens=4 delims=*" %%# IN (pwhash) DO (
IF "%%#"=="00000000" (
SET PROTECTED=0
SET "ERRORMSG=encryption type is not supported.."
)
)
)
CALL :SETSTATUSANDFLAGS
EXIT /b
:HASH.7z
CALL "%ProgramData%\JtR\run\portableshell.bat" "%ProgramData%\JtR\run\7z2john.pl" "%~1">"%ProgramData%\JtR\run\pwhash" 2>"%ProgramData%\JtR\run\statusout"
SET /p pwhash=< pwhash
FOR /F %%# IN ("%ProgramData%\JtR\run\pwhash") DO (
SET HSIZE=%%~z#
)
IF %HSIZE% EQU 0 (
FOR /F "usebackq tokens=*" %%# IN (`TYPE statusout ^| findstr /I /C^:"no AES"`) DO (
SET PROTECTED=0
SET "ERRORMSG=is not password protected.."
)
IF NOT DEFINED ERRORMSG (
SET PROTECTED=2
SET /p ERRORMSG=< "%ProgramData%\JtR\run\statusout"
)
) ELSE (
FOR /F "usebackq tokens=*" %%# IN (`TYPE statusout ^| findstr /I /C^:"not supported"`) DO (
SET PROTECTED=0
SET "ERRORMSG=encryption type is not supported.."
)
)
CALL :SETSTATUSANDFLAGS
EXIT /b
:HASH.PDF
CALL "%ProgramData%\JtR\run\portableshell.bat" "%ProgramData%\JtR\run\pdf2john.pl" "%~1">"%ProgramData%\JtR\run\pwhash" 2>nul
POWERSHELL -nop -c "$^=[regex]::Match((gc pwhash),'^(.+\/)(?i)(.*\.pdf)(.+$)');$^.Groups[2].value+$^.Groups[3].value|sc pwhash">nul 2>&1
SET /p pwhash=< pwhash
FOR /F %%# IN ("%ProgramData%\JtR\run\pwhash") DO (
SET HSIZE=%%~z#
)
IF %HSIZE% LSS 8000 (
FOR /F "usebackq tokens=*" %%# IN (`TYPE pwhash ^| findstr /I /C^:"not encrypted!"`) DO (
SET PROTECTED=0
SET "ERRORMSG=is not password protected.."
)
)
CALL :SETSTATUSANDFLAGS
EXIT /b
:SETSTATUSANDFLAGS
ECHO Done
ECHO/
IF /I "%FILETYPE%"==".zip" (
SETLOCAL ENABLEDELAYEDEXPANSION
FOR /F "tokens=2 delims=$" %%# IN ("!pwhash!") DO (
ENDLOCAL
IF /I "%%#"=="zip" (
SETLOCAL ENABLEDELAYEDEXPANSION
IF NOT "!ZIPCHECKED!"=="1" (
IF !GPU! GEQ 1 (
ENDLOCAL
SET "FLAG=--format=ZIP-opencl"
CALL :OPENCLENABLED
) ELSE (
ENDLOCAL
CALL :NOOPENCL
IF NOT "%RESUME%"=="1" (
CALL :CPUMODESPLIT
)
)
) ELSE (
ENDLOCAL
)
SET ZIPCHECKED=1
)
IF /I "%%#"=="zip2" (
SETLOCAL ENABLEDELAYEDEXPANSION
IF NOT "!ZIPCHECKED!"=="1" (
IF !GPU! GEQ 1 (
ENDLOCAL
SET "FLAG=--format=ZIP-opencl"
CALL :OPENCLENABLED
) ELSE (
ENDLOCAL
CALL :NOOPENCL
IF NOT "%RESUME%"=="1" (
CALL :CPUMODESPLIT
)
)
) ELSE (
ENDLOCAL
)
SET ZIPCHECKED=1
)
IF /I "%%#"=="zip3" (
SETLOCAL ENABLEDELAYEDEXPANSION
IF NOT "!ZIPCHECKED!"=="1" (
IF !GPU! GEQ 1 (
ENDLOCAL
SET "FLAG=--format=ZIP-opencl"
CALL :OPENCLENABLED
) ELSE (
ENDLOCAL
CALL :NOOPENCL
IF NOT "%RESUME%"=="1" (
CALL :CPUMODESPLIT
)
)
) ELSE (
ENDLOCAL
)
SET ZIPCHECKED=1
)
IF /I "%%#"=="pkzip" (
CALL :NOOPENCL pkzip
IF NOT "%RESUME%"=="1" (
CALL :CPUMODESPLIT
)
)
IF /I "%%#"=="pkzip2" (
CALL :NOOPENCL pkzip2
IF NOT "%RESUME%"=="1" (
CALL :CPUMODESPLIT
)
)
)
)
IF /I "%FILETYPE%"==".rar" (
SETLOCAL ENABLEDELAYEDEXPANSION
IF !GPU! GEQ 1 (
ENDLOCAL
SETLOCAL ENABLEDELAYEDEXPANSION
FOR /F "tokens=2 delims=$" %%# IN ("!pwhash!") DO (
ENDLOCAL
IF /I "%%#"=="rar" (
SET "FLAG=--format=rar-opencl"
CALL :OPENCLENABLED
)
IF /I "%%#"=="rar3" (
SET "FLAG=--format=rar-opencl"
CALL :OPENCLENABLED
)
IF /I "%%#"=="rar5" (
SET "FLAG=--format=RAR5-opencl"
CALL :OPENCLENABLED
)
)
) ELSE (
ENDLOCAL
CALL :NOOPENCL
IF NOT "%RESUME%"=="1" (
CALL :CPUMODESPLIT
)
)
)
IF /I "%FILETYPE%"==".7z" (
SETLOCAL ENABLEDELAYEDEXPANSION
IF !GPU! GEQ 1 (
ENDLOCAL
SET "FLAG=--format=7z-opencl"
CALL :OPENCLENABLED
) ELSE (
ENDLOCAL
CALL :NOOPENCL
IF NOT "%RESUME%"=="1" (
CALL :CPUMODESPLIT
)
)
)
IF /I "%FILETYPE%"==".pdf" (
CALL :COMMONPDF COMMON
SETLOCAL ENABLEDELAYEDEXPANSION
IF !GPU! GEQ 1 (
IF "!COMMON!"=="1" (
ENDLOCAL
SET "FLAG=--format=pdf-opencl --mask=?8?l?l?l?d -8=?l?u --mask-internal-target=0 --min-length=8 --max-length=8"
) ELSE (
ENDLOCAL
SET "FLAG=--format=pdf-opencl"
)
CALL :OPENCLENABLED
) ELSE (
IF "!COMMON!"=="1" (
ENDLOCAL
SET "FLAG=--mask=?8?l?l?l?d -8=?l?u --min-length=8 --max-length=8"
) ELSE (
ENDLOCAL
IF NOT "%RESUME%"=="1" (
CALL :CPUMODESPLIT
)
)
CALL :NOOPENCL
)
)
EXIT /b
:OPENCLENABLED
SET "TitleName=%TitleName:Initializing=GPU Mode%"
SET "TitleName=%TitleName:AVAILABLE=ENABLED%"
TITLE %TitleName%
EXIT /b
:NOOPENCL
SET "TitleName=%TitleName:Initializing=CPU Mode%"
IF "%~1"=="" (
SET "TitleName=%TitleName:AVAILABLE=UNAVAILABLE%"
) ELSE (
SET "TitleName=%TitleName:AVAILABLE=UNSUPPORTED Filetype%"
)
TITLE %TitleName%
EXIT /b
:GETSIZE
SET "%2=%~z1"
IF %~z1==[] (
SET "%2=0"
)
EXIT /b
:TRIMWHITESPACE
SETLOCAL ENABLEDELAYEDEXPANSION
SET TRIM=%*
FOR /f "tokens=1*" %%# in ("!TRIM!") DO (
ENDLOCAL
SET "%1=%%$"
)
EXIT /b
:WRITEPASSWORD
FOR /F "tokens=2 delims=:" %%# IN (john.pot) DO (
ECHO|(SET /p="%%# - [%~nx1]"&ECHO/)>>"%UserDesktop%\ZipRipper-Passwords.txt"
EXIT /b
)
EXIT /b
:CHECKLENGTH
(
SETLOCAL ENABLEDELAYEDEXPANSION
(SET^ L=!%~1!)
IF DEFINED L (
SET "LENGTH=1"
FOR %%P IN (4096 2048 1024 512 256 128 64 32 16 8 4 2 1) DO (
IF "!L:~%%P,1!" NEQ "" (
SET /A "LENGTH+=%%P"
SET "L=!L:~%%P!"
)
)
) ELSE (
SET LENGTH=0
)
)
(
ENDLOCAL
SET "%~2=%LENGTH%"
EXIT /b
)
:EXTENSION
SET %2=%~x1
EXIT /b
:RENAMEOLD
IF EXIST "%UserDesktop%\ZipRipper-Passwords.%R%.txt" (
SET /A R+=1
GOTO :RENAMEOLD
) ELSE (
REN "%UserDesktop%\ZipRipper-Passwords.txt" "ZipRipper-Passwords.%R%.txt"
)
EXIT /b
:DISPLAYFOUNDPW
CALL :SETTERMINAL
START /min "Loading Results..." POWERSHELL -nop -c "Add-Type -AssemblyName System.Windows.Forms;$^={$Notify=[PowerShell]::Create().AddScript({$Audio=New-Object System.Media.SoundPlayer;$Audio.SoundLocation=$env:WinDir + '\Media\Windows Notify System Generic.wav';$Audio.playsync()});$rs=[RunspaceFactory]::CreateRunspace();$rs.ApartmentState="^""STA"^"";$rs.ThreadOptions="^""ReuseThread"^"";$rs.Open();$Notify.Runspace=$rs;$Notify.BeginInvoke()};&$^;$Msg=@();foreach($line in Get-Content '%UserDesktop%\ZipRipper-Passwords.txt'){if($null -eq $Msg){$Msg+=$line}else{$Msg+=$line + "^""`n"^""}};$Msg+="^""Save Location:`n"^"";$Msg+="^"""^"""^""%UserDesktop%\ZipRipper-Passwords.txt"^"""^"""^"";[System.Windows.Forms.MessageBox]::Show($Msg, 'Message from ZIP-Ripper',0,0,0,131072)">nul
CALL :RESTORETERMINAL
EXIT /b
:CHECKCONNECTION
FOR /F "usebackq tokens=* delims=" %%# IN (`POWERSHELL -nop -c "$ProgressPreference='SilentlyContinue';irm http://www.msftncsi.com/ncsi.txt;$ProgressPreference='Continue'"`) DO (
IF "%%#"=="Microsoft NCSI" (
SET "%1=1"
) ELSE (
SET "%1=0"
)
)
EXIT /b
:SINGLEINSTANCE
TASKLIST /V /NH /FI "imagename eq cmd.exe"|FINDSTR /I /C^:"ZIP-Ripper">nul
IF NOT %errorlevel%==1 (
POWERSHELL -nop -c "Add-Type -AssemblyName System.Windows.Forms;$^={$Notify=[PowerShell]::Create().AddScript({$Audio=New-Object System.Media.SoundPlayer;$Audio.SoundLocation=$env:WinDir + '\Media\Windows Notify System Generic.wav';$Audio.playsync()});$rs=[RunspaceFactory]::CreateRunspace();$rs.ApartmentState="^""STA"^"";$rs.ThreadOptions="^""ReuseThread"^"";$rs.Open();$Notify.Runspace=$rs;$Notify.BeginInvoke()};&$^;[System.Windows.Forms.MessageBox]::Show("^""ZipRipper is already running!"^"", 'ERROR:',0,16,0,131072)">nul&EXIT
)
TITLE [ZIP-Ripper] Launching...
EXIT /b
:CENTERWINDOW
>nul 2>&1 POWERSHELL -nop -c "$w=Add-Type -Name WAPI -PassThru -MemberDefinition '[DllImport("^""user32.dll"^"")]public static extern void SetProcessDPIAware();[DllImport("^""shcore.dll"^"")]public static extern void SetProcessDpiAwareness(int value);[DllImport("^""kernel32.dll"^"")]public static extern IntPtr GetConsoleWindow();[DllImport("^""user32.dll"^"")]public static extern void GetWindowRect(IntPtr hwnd,int[] rect);[DllImport("^""user32.dll"^"")]public static extern void GetClientRect(IntPtr hwnd, int[] rect);[DllImport("^""user32.dll"^"")]public static extern void GetMonitorInfoW(IntPtr hMonitor, int[] lpmi);[DllImport("^""user32.dll"^"")]public static extern IntPtr MonitorFromWindow(IntPtr hwnd, int dwFlags);[DllImport("^""user32.dll"^"")]public static extern int SetWindowPos(IntPtr hwnd,IntPtr hwndAfterZ,int x,int y,int w,int h,int flags);';$PROCESS_PER_MONITOR_DPI_AWARE=2;try{$w::SetProcessDpiAwareness($PROCESS_PER_MONITOR_DPI_AWARE)}catch{$w::SetProcessDPIAware()}$hwnd=$w::GetConsoleWindow();$moninf=[int[]]::new(10);$moninf[0]=40;$MONITOR_DEFAULTTONEAREST=2;$w::GetMonitorInfoW($w::MonitorFromWindow($hwnd, $MONITOR_DEFAULTTONEAREST), $moninf);$monwidth=$moninf[7]-$moninf[5];$monheight=$moninf[8]-$moninf[6];$wrect=[int[]]::new(4);$w::GetWindowRect($hwnd, $wrect);$winwidth=$wrect[2]-$wrect[0];$winheight=$wrect[3]-$wrect[1];$x=[int][math]::Round($moninf[5]+$monwidth/2-$winwidth/2);$y=[int][math]::Round($moninf[6]+$monheight/2-$winheight/2);$SWP_NOSIZE=0x0001;$SWP_NOZORDER=0x0004;exit [int]($w::SetWindowPos($hwnd,[IntPtr]::Zero,$x,$y,0,0,$SWP_NOSIZE -bOr $SWP_NOZORDER) -eq 0)"
EXIT /b
:GETFILE
FOR /F "usebackq tokens=* delims=" %%# IN (`POWERSHELL -nop -c "Add-Type -AssemblyName System.Windows.Forms;$^=New-Object System.Windows.Forms.OpenFileDialog -Property @{InitialDirectory='';Title='Select a password protected ZIP, RAR, 7z or PDF...';Filter='All Supported (*.zip;*.rar;*.7z;*.pdf)|*.zip;*.rar;*.7z;*.pdf|ZIP (*.zip)|*.zip|RAR (*.rar)|*.rar|7-Zip (*.7z)|*.7z|PDF (*.pdf)|*.pdf'};$null=$^.ShowDialog();$Quoted='"^""' + $^^.Filename + '"^""';$Quoted"`) DO (
SET "%1=%%#"
)
EXIT /b
:WORDLISTFILEINFO
FOR /F "usebackq tokens=1,2" %%# IN (`POWERSHELL "$^=[regex]::Match('%WORDLISTADDR:"=%', '.*\/((.*)\..*)$');$^.Groups[1].Value+' '+$^.Groups[2].Value"`) DO (
CALL :EXTENSION %%# EXT
IF /I NOT "!EXT!"==".7z" (
IF /I "!EXT!"==".txt" (
SET wListOuter=""
SET wListInner="%%#"
)
) ELSE (
SET wListOuter="%%#"
SET CHECK="%%$"
IF /I "!CHECK:~-5,-1!"==".txt" (
SET wListInner="%%$"
) ELSE (
SET wListInner="%%$.txt"
)
)
)
SET LISTNAME="%ProgramData%\!wListInner:"=!"
IF NOT !wListOuter!=="" (
SET wListOuter="%ProgramData%\!wListOuter:"=!"
)
EXIT /b
:RESETWORDLIST
SET "LISTNAME="
CALL :LISTMESSAGE "Wordlist settings reset to default" "Wordlist Info:"
EXIT /b
:LISTMESSAGE
POWERSHELL -nop -c "Add-Type -AssemblyName System.Windows.Forms;$^={$Notify=[PowerShell]::Create().AddScript({$Audio=New-Object System.Media.SoundPlayer;$Audio.SoundLocation=$env:WinDir + '\Media\Windows Notify System Generic.wav';$Audio.playsync()});$rs=[RunspaceFactory]::CreateRunspace();$rs.ApartmentState="^""STA"^"";$rs.ThreadOptions="^""ReuseThread"^"";$rs.Open();$Notify.Runspace=$rs;$Notify.BeginInvoke()};&$^;[System.Windows.Forms.MessageBox]::Show("^""%~1"^"", '%~2',0,64,0,131072)">nul
EXIT /b
:ENABLEBRUTE
FOR /F "usebackq tokens=* delims=" %%# IN (`POWERSHELL -nop -c "Add-Type -AssemblyName System.Windows.Forms;$^={$Notify=[PowerShell]::Create().AddScript({$Audio=New-Object System.Media.SoundPlayer;$Audio.SoundLocation=$env:WinDir + '\Media\Windows Notify System Generic.wav';$Audio.playsync()});$rs=[RunspaceFactory]::CreateRunspace();$rs.ApartmentState="^""STA"^"";$rs.ThreadOptions="^""ReuseThread"^"";$rs.Open();$Notify.Runspace=$rs;$Notify.BeginInvoke()};&$^;[System.Windows.Forms.MessageBox]::Show('Would you like to enable bruteforce mode? (Click NO to restore default settings and return to the menu)', 'The selected wordlist file is empty',4,32,0,131072)"`) DO (
SET %1=%%#
)>nul
EXIT /b
:SINGLEDOWNLOAD
POWERSHELL -nop -c "Add-Type -AssemblyName PresentationFramework, System.Drawing, System.Windows.Forms, WindowsFormsIntegration;[xml]$xaml='<Window xmlns="^""http://schemas.microsoft.com/winfx/2006/xaml/presentation"^"" xmlns:x="^""http://schemas.microsoft.com/winfx/2006/xaml"^"" Title="^"" %~3"^"" Height="^""37"^"" Width="^""210"^"" WindowStartupLocation="^""CenterScreen"^"" WindowStyle="^""None"^"" Topmost="^""True"^"" Background="^""#333333"^"" AllowsTransparency="^""True"^""><Canvas><TextBlock Name="^""Info"^"" Canvas.Top="^""3"^"" Text="^"" %~3"^"" Foreground="^""#eeeeee"^"" FontWeight="^""Bold"^""/><ProgressBar Canvas.Left="^""5"^"" Canvas.Top="^""28"^"" Width="^""200"^"" Height="^""3"^"" Name="^""Progress"^"" Foreground="^""#FF0000"^""/></Canvas></Window>';$reader=(New-Object System.Xml.XmlNodeReader $xaml);$form=[Windows.Markup.XamlReader]::Load($reader);$form.Add_Closing({[System.Windows.Forms.Application]::Exit();Stop-Process $pid});$progressBar=$form.FindName("^""Progress"^"");function Update-Gui (){$form.Dispatcher.Invoke([Windows.Threading.DispatcherPriority]::Background, [action]{})};function DownloadFile($url,$targetFile){$uri=New-Object "^""System.Uri"^"" "^""$url"^"";$request=[System.Net.HttpWebRequest]::Create($uri);$request.set_Timeout(15000);$response=$request.GetResponse();$totalLength=[System.Math]::Floor($response.get_ContentLength()/1024);$responseStream=$response.GetResponseStream();$targetStream=New-Object -TypeName System.IO.FileStream -ArgumentList $targetFile, Create;$buffer=new-object byte[] 10KB;$count=$responseStream.Read($buffer,0,$buffer.length);$downloadedBytes=$count;while ($count -gt 0){$targetStream.Write($buffer,0,$count);$count=$responseStream.Read($buffer,0,$buffer.length);$downloadedBytes=$downloadedBytes+$count;$roundedPercent=[int]((([System.Math]::Floor($downloadedBytes/1024))/$totalLength)*100);$progressBar.Value=$roundedPercent;if($progressBar.Value -ne $lastpercent){$lastpercent=$progressBar.Value;Update-Gui}};$targetStream.Flush();$targetStream.Close();$targetStream.Dispose();$responseStream.Dispose()};$form.Add_ContentRendered({downloadFile '%~1' '%~2';Sleep 1;$form.Close()});$form.Show();$appContext=New-Object System.Windows.Forms.ApplicationContext;[void][System.Windows.Forms.Application]::Run($appContext)"
EXIT /b
:MAINMENU
IF /I NOT EXIST "%LOGO%" (
CALL :SINGLEDOWNLOAD "%DL_LOGO%" "%LOGO%" "Initializing..."
)
FOR /F "usebackq delims=, tokens=1,2*" %%# IN (`POWERSHELL -nop -c "Add-Type -AssemblyName PresentationFramework, System.Drawing, System.Windows.Forms, WindowsFormsIntegration;function wlist(){Switch($showL){0{$D.Visibility="^""Visible"^"";$R.Visibility="^""Visible"^"";$C.Visibility="^""Visible"^"";$global:showL="^""1"^""}1{$D.Visibility="^""Collapsed"^"";$R.Visibility="^""Collapsed"^"";$C.Visibility="^""Collapsed"^"";$global:showL="^""0"^""}}};[xml]$xaml='<Window xmlns="^""http://schemas.microsoft.com/winfx/2006/xaml/presentation"^"" xmlns:x="^""http://schemas.microsoft.com/winfx/2006/xaml"^"" WindowStartupLocation="^""CenterScreen"^"" WindowStyle="^""None"^"" Background="^""Transparent"^"" AllowsTransparency="^""True"^"" Width="^""285"^"" Height="^""324"^""><Window.Resources><ControlTemplate x:Key="^""nM"^"" TargetType="^""Button"^""><Border Background="^""{TemplateBinding Background}"^"" BorderBrush="^""{TemplateBinding BorderBrush}"^"" BorderThickness="^""{TemplateBinding BorderThickness}"^""><ContentPresenter HorizontalAlignment="^""{TemplateBinding HorizontalContentAlignment}"^"" VerticalAlignment="^""{TemplateBinding VerticalContentAlignment}"^""/></Border><ControlTemplate.Triggers><Trigger Property="^""IsEnabled"^"" Value="^""False"^""><Setter Property="^""Background"^"" Value="^""{x:Static SystemColors.ControlLightBrush}"^""/><Setter Property="^""Foreground"^"" Value="^""{x:Static SystemColors.GrayTextBrush}"^""/></Trigger></ControlTemplate.Triggers></ControlTemplate></Window.Resources><Grid><Grid.RowDefinitions><RowDefinition Height="^""298"^""/><RowDefinition Height="^""*"^""/></Grid.RowDefinitions><Grid.Background><ImageBrush ImageSource="^""%LOGO%"^""/></Grid.Background><Grid.Triggers><EventTrigger RoutedEvent="^""Loaded"^""><BeginStoryboard><Storyboard><DoubleAnimation Storyboard.TargetProperty="^""Background.Opacity"^"" From="^""0"^"" To="^""1"^"" Duration="^""0:0:1"^""/></Storyboard></BeginStoryboard></EventTrigger></Grid.Triggers><Canvas Grid.Row="^""0"^""><Button x:Name="^""Offline"^"" Canvas.Left="^""141"^"" Canvas.Top="^""56"^"" Height="^""16"^"" Width="^""26"^"" ToolTip="^""Create [zr-offline.txt]"^"" Template="^""{StaticResource nM}"^""/><Button x:Name="^""Cleanup"^"" Canvas.Left="^""138"^"" Canvas.Top="^""154"^"" Height="^""20"^"" Width="^""20"^"" ToolTip="^""Clear Resume Cache"^"" Template="^""{StaticResource nM}"^""/><Button Name="^""List"^"" Canvas.Left="^""143"^"" Canvas.Top="^""116"^"" Height="^""10"^"" Width="^""15"^"" ToolTip="^""Select Wordlist"^"" Template="^""{StaticResource nM}"^"" Opacity="^""0"^""></Button><Button Name="^""Default"^"" Canvas.Left="^""123"^"" Canvas.Top="^""130"^"" FontSize="^""11"^"" Foreground="^""#eeeeee"^"" Background="^""#333333"^"" Height="^""18"^"" Width="^""55"^"" Visibility="^""Collapsed"^"" HorizontalContentAlignment="^""Left"^"" Template="^""{StaticResource nM}"^"" Opacity="^""0.9"^"">Default</Button><Button Name="^""WL"^"" Canvas.Left="^""123"^"" Canvas.Top="^""147"^"" FontSize="^""11"^"" Foreground="^""#eeeeee"^"" Background="^""#333333"^"" Height="^""18"^"" Width="^""55"^"" Visibility="^""Collapsed"^"" HorizontalContentAlignment="^""Left"^"" Template="^""{StaticResource nM}"^"" Opacity="^""0.9"^"">%WORDLISTNAME:"=%</Button><Button Name="^""Custom"^"" Canvas.Left="^""123"^"" Canvas.Top="^""164"^"" FontSize="^""11"^"" Foreground="^""#eeeeee"^"" Background="^""#333333"^"" Height="^""18"^"" Width="^""55"^"" Visibility="^""Collapsed"^"" HorizontalContentAlignment="^""Left"^"" Template="^""{StaticResource nM}"^"" Opacity="^""0.9"^"">Custom</Button></Canvas><Canvas Grid.Row="^""1"^""><Button x:Name="^""Start"^"" Height="^""22"^"" Width="^""65"^"" Content="^""Start"^"" ToolTip="^""Click to Begin..."^"" Template="^""{StaticResource nM}"^""><Button.Triggers><EventTrigger RoutedEvent="^""Loaded"^""><BeginStoryboard><Storyboard><DoubleAnimation From="^""40"^"" To="^""65"^"" Duration="^""0:0:1"^"" Storyboard.TargetProperty="^""(Canvas.Left)"^"" AutoReverse="^""False"^""/><DoubleAnimation Storyboard.TargetProperty="^""Opacity"^"" From="^""0"^"" To="^""1"^"" Duration="^""0:0:2"^""/></Storyboard></BeginStoryboard></EventTrigger></Button.Triggers></Button></Canvas><Canvas Grid.Row="^""1"^""><Button x:Name="^""Quit"^"" Height="^""22"^"" Width="^""65"^"" Content="^""Quit"^"" ToolTip="^""Click to Exit"^"" Template="^""{StaticResource nM}"^""><Button.Triggers><EventTrigger RoutedEvent="^""Loaded"^""><BeginStoryboard><Storyboard><DoubleAnimation From="^""40"^"" To="^""65"^"" Duration="^""0:0:1"^"" Storyboard.TargetProperty="^""(Canvas.Right)"^"" AutoReverse="^""False"^""/><DoubleAnimation Storyboard.TargetProperty="^""Opacity"^"" From="^""0"^"" To="^""1"^"" Duration="^""0:0:2"^""/></Storyboard></BeginStoryboard></EventTrigger></Button.Triggers></Button></Canvas></Grid><Window.TaskbarItemInfo><TaskbarItemInfo/></Window.TaskbarItemInfo></Window>';$reader=(New-Object System.Xml.XmlNodeReader $xaml);$window=[Windows.Markup.XamlReader]::Load($reader);$window.Title='ZipRipper';$bitmap=New-Object System.Windows.Media.Imaging.BitmapImage;$bitmap='%LOGO:'=''%';$window.Icon=$bitmap;$window.TaskbarItemInfo.Overlay=$bitmap;$window.TaskbarItemInfo.Description=$window.Title;$window.Add_Closing({[System.Windows.Forms.Application]::Exit();Stop-Process $pid});$L=$Window.FindName("^""List"^"");$D=$Window.FindName("^""Default"^"");$R=$Window.FindName("^""WL"^"");$C=$Window.FindName("^""Custom"^"");$L.Add_Click({wlist});$D.Add_MouseEnter({$D.Background="^""#eeeeee"^"";$D.Foreground="^""#333333"^""});$D.Add_MouseLeave({$D.Background="^""#333333"^"";$D.Foreground="^""#eeeeee"^""});$D.Add_Click({$global:list='0';wlist});$R.Add_MouseEnter({$R.Background="^""#eeeeee"^"";$R.Foreground="^""#333333"^""});$R.Add_MouseLeave({$R.Background="^""#333333"^"";$R.Foreground="^""#eeeeee"^""});$R.Add_Click({$global:list='1';wlist});$C.Add_MouseEnter({$C.Background="^""#eeeeee"^"";$C.Foreground="^""#333333"^""});$C.Add_MouseLeave({$C.Background="^""#333333"^"";$C.Foreground="^""#eeeeee"^""});$C.Add_Click({$global:list='2';wlist});$b=$Window.FindName("^""Start"^"");$b.Background = "^""#333333"^"";$b.Foreground="^""#eeeeee"^"";$b.FontSize="^""12"^"";$b.FontWeight="^""Bold"^"";$b.Add_MouseEnter({$b.Background="^""#eeeeee"^"";$b.Foreground="^""#333333"^""});$b.Add_MouseLeave({$b.Background="^""#333333"^"";$b.Foreground="^""#eeeeee"^""});$b.Add_Click({write-host "^""Start,$list"^"";Exit});$b2=$Window.FindName("^""Quit"^"");$b2.Background="^""#333333"^"";$b2.Foreground="^""#eeeeee"^"";$b2.FontSize="^""12"^"";$b2.FontWeight="^""Bold"^"";$b2.Add_MouseEnter({$b2.Background="^""#eeeeee"^"";$b2.Foreground="^""#333333"^""});$b2.Add_MouseLeave({$b2.Background="^""#333333"^"";$b2.Foreground="^""#eeeeee"^""});$b2.Add_Click({write-host 'Quit';Exit});$b3=$Window.FindName("^""Offline"^"");$b3.Opacity="^""0"^"";$b3.Add_Click({$b3m=New-Object -ComObject Wscript.Shell;$b3a=$b3m.Popup('Create [zr-offline.txt] for Offline Mode?',0,'Offline Mode Builder',0x1);if($b3a -eq 1){write-host 'Offline';Exit}});$b4=$Window.FindName("^""Cleanup"^"");$b4.Opacity="^""0"^"";$b4.Add_Click({$b4m=New-Object -ComObject Wscript.Shell;$b4a=$b4m.Popup('Cleanup ALL resume data?',0,'Clear InProgress Jobs',0x1);if($b4a -eq 1){if(Test-Path -Path '%AppData:'=''%\ZR-InProgress'){Remove-Item '%AppData:'=''%\ZR-InProgress' -Recurse -force -ErrorAction SilentlyContinue;$b4m2=New-Object -ComObject Wscript.Shell;$b4m2.Popup('ALL Jobs Cleared',0,'Clear InProgress Jobs',0x0)} else {$b4m3=New-Object -ComObject Wscript.Shell;$b4m3.Popup('There are no jobs to clear',0,'Clear InProgress Jobs',0x0)}}});$list='0';$showL='0';$window.add_MouseLeftButtonDown({if($showL -eq 1){wlist};$window.DragMove()});$window.Show();$appContext=New-Object System.Windows.Forms.ApplicationContext;[void][System.Windows.Forms.Application]::Run($appContext)"`) DO (
SET "%1=%%#"
IF NOT "%%$"=="" (
SET "%2=%%$"
)
)
EXIT /b
:CLEANUP
FOR %%# IN (%TEMPFILES%) DO (
IF /I EXIST "%ProgramData%\%%#" (
>nul 2>&1 DEL "%ProgramData%\%%#" /F /Q
)
)
FOR %%# IN (%TEMPFOLDERS%) DO (
IF /I EXIST "%ProgramData%\%%#\*" (
>nul 2>&1 RD "%ProgramData%\%%#" /S /Q
)
)
IF "%~1"=="" (
>nul 2>&1 REG DELETE HKCU\Software\classes\.ZipRipper\ /F
(GOTO) 2>nul&DEL "%~f0"/F /Q>nul&EXIT
)
EXIT /b
:BUILD
IF EXIST "%ProgramData%\ztmp\*" (
>nul 2>&1 RD "%ProgramData%\ztmp" /S /Q
)
>nul 2>&1 MD "%ProgramData%\ztmp"
>nul 2>&1 COPY /Y "%ProgramData%\zipripper.png" "%ProgramData%\ztmp\104"
PUSHD "%ProgramData%\ztmp"
(
ECHO .new Cabinet
ECHO .Set Cabinet=ON
ECHO .Set CabinetFileCountThreshold=0
ECHO .Set ChecksumWidth=1
ECHO .Set ClusterSize=CDROM
ECHO .Set LongSourceFileNames=ON
ECHO .Set CompressionType=LZX
ECHO .Set CompressionLevel=7
ECHO .Set CompressionMemory=21
ECHO .Set DiskDirectoryTemplate=
ECHO .Set FolderFileCountThreshold=0
ECHO .Set FolderSizeThreshold=0
ECHO .Set GenerateInf=ON
ECHO .Set InfFileName=nul
ECHO .Set MaxCabinetSize=0
ECHO .Set MaxDiskFileCount=0
ECHO .Set MaxDiskSize=0
ECHO .Set MaxErrors=0
ECHO .Set ReservePerCabinetSize=0
ECHO .Set ReservePerDataBlockSize=0
ECHO .Set ReservePerFolderSize=0
ECHO .Set RptFileName=nul
ECHO .Set UniqueFiles=ON
ECHO .Set SourceDir=.
ECHO 100 "7zExtra.7z"
ECHO 101 "7zr.exe"
ECHO 102 "perlportable.zip"
ECHO 103 "winX64_1_JtR.7z"
ECHO 104 "zipripper.png"
)>"%ProgramData%\ztmp\offline.config"
POWERSHELL -nop -c "Add-Type -AssemblyName PresentationFramework, System.Drawing, System.Windows.Forms, WindowsFormsIntegration;[xml]$xaml='<Window xmlns="^""http://schemas.microsoft.com/winfx/2006/xaml/presentation"^"" xmlns:x="^""http://schemas.microsoft.com/winfx/2006/xaml"^"" Title="^""Building [zr-offline.txt]"^"" Height="^""75"^"" Width="^""210"^"" WindowStartupLocation="^""CenterScreen"^"" WindowStyle="^""None"^"" Topmost="^""True"^"" Background="^""#333333"^"" AllowsTransparency="^""True"^""><Canvas><TextBlock Name="^""Info"^"" Canvas.Top="^""3"^"" Text="^"" Initializing..."^"" Foreground="^""#eeeeee"^"" FontWeight="^""Bold"^""/><ProgressBar Canvas.Left="^""5"^"" Canvas.Top="^""28"^"" Width="^""200"^"" Height="^""3"^"" Name="^""Progress"^"" Foreground="^""#FF0000"^""/><TextBlock Name="^""Info2"^"" Canvas.Top="^""38"^"" Text="^"" Getting Resources (Stage 1/2)"^"" Foreground="^""#eeeeee"^"" FontWeight="^""Bold"^""/><ProgressBar Canvas.Left="^""5"^"" Canvas.Top="^""63"^"" Width="^""200"^"" Height="^""3"^"" Name="^""Progress2"^"" Foreground="^""#FF0000"^""/></Canvas><Window.TaskbarItemInfo><TaskbarItemInfo/></Window.TaskbarItemInfo></Window>';$reader=(New-Object System.Xml.XmlNodeReader $xaml);$form=[Windows.Markup.XamlReader]::Load($reader);$bitmap=New-Object System.Windows.Media.Imaging.BitmapImage;$bitmap='%ProgramData%\zipripper.png';$form.Icon=$bitmap;$form.TaskbarItemInfo.Overlay=$bitmap;$form.TaskbarItemInfo.Description=$form.Title;$form.Add_Closing({[System.Windows.Forms.Application]::Exit();Stop-Process $pid});$progressBar=$form.FindName("^""Progress"^"");$progressTotal=$form.FindName("^""Progress2"^"");$info=$form.FindName("^""Info"^"");$info2=$form.FindName("^""Info2"^"");function Update-Gui (){$form.Dispatcher.Invoke([Windows.Threading.DispatcherPriority]::Background, [action]{})};function Build () {$info.Text=' Downloading 7zr Standalone';Update-Gui;downloadFile '%DL_7ZR%' '%ProgramData%\ztmp\101';$info.Text=' Downloading 7za Console';Update-Gui;downloadFile '%DL_7ZEXTRA%' '%ProgramData%\ztmp\100';$info.Text=' Downloading JohnTheRipper';Update-Gui;downloadFile '%DL_JTR%' '%ProgramData%\ztmp\103';$info.Text=' Downloading Portable Perl';Update-Gui;downloadFile '%DL_PERLPORTABLE%' '%ProgramData%\ztmp\102';$progressBar.Value=0;$info.Text=' Merging resources'; $info2.Text=' Building zr-offline.txt (Stage 2/2)';$pass=1;Update-Gui;makecab.exe /F '%ProgramData%\ztmp\offline.config' /D Compress='OFF' /D CabinetNameTemplate='%ProgramData%\ztmp\zr-offline.txt'| out-string -stream | Select-String -Pattern "^""(\d{1,3})(?=[.]\d{1,2}%%)"^"" -AllMatches | ForEach-Object { $_.Matches.Value } | foreach {$progressBar.Value=$_;if($totalP2 -ge 6){$progressTotal.Value=$progressTotal.Value + 1;$totalP2=0};if($progressBar.Value -ne $lastpercent){$lastpercent=$progressBar.Value;$totalP2++};if($progressBar.Value -ge 100){$pass++};if($pass -eq 2){$info.Text="^"" Building data file"^"";if($progressBar.Value -eq 99){$pass++}};if($pass -eq 3){$info.Text="^"" Purging Cache"^""};if($progressBar.Value -ne $lastpercent2){$lastpercent2=$progressBar.Value;Update-Gui}};$progressBar.Value=100;$m=([IO.File]::ReadAllLines('%ProgramData%\launcher.ZipRipper')).Replace('"^""','');Move-Item -Path '%ProgramData%\ztmp\zr-offline.txt' -Destination "^""$m"^"" -Force;$progressTotal.Value=100;$info.Text="^"" Build Completed!"^"";Update-Gui;Sleep 3};function DownloadFile($url,$targetFile){$uri=New-Object "^""System.Uri"^"" "^""$url"^"";$request=[System.Net.HttpWebRequest]::Create($uri);$request.set_Timeout(15000);$response=$request.GetResponse();$totalLength=[System.Math]::Floor($response.get_ContentLength()/1024);$responseStream=$response.GetResponseStream();$targetStream=New-Object -TypeName System.IO.FileStream -ArgumentList $targetFile, Create;$buffer=new-object byte[] 10KB;$count=$responseStream.Read($buffer,0,$buffer.length);$downloadedBytes=$count;while ($count -gt 0){$targetStream.Write($buffer, 0, $count);$count=$responseStream.Read($buffer,0,$buffer.length);$downloadedBytes=$downloadedBytes + $count;$roundedPercent=[int]((([System.Math]::Floor($downloadedBytes/1024))/$totalLength)*100);$progressBar.Value=$roundedPercent;if($totalP -ge 7){$progressTotal.Value++;$totalP=0};if($progressBar.Value -ne $lastpercent){$lastpercent=$progressBar.Value;$totalP++;Update-Gui}};$targetStream.Flush();$targetStream.Close();$targetStream.Dispose();$responseStream.Dispose()};$form.Add_ContentRendered({Build;$form.Close()});$form.Show();$appContext=New-Object System.Windows.Forms.ApplicationContext;[void][System.Windows.Forms.Application]::Run($appContext)">nul
POPD
>nul 2>&1 RD "%ProgramData%\ztmp" /S /Q
FOR /F "usebackq tokens=* delims=" %%# IN (`POWERSHELL -nop -c "Add-Type -AssemblyName System.Windows.Forms;$^={$Notify=[PowerShell]::Create().AddScript({$Audio=New-Object System.Media.SoundPlayer;$Audio.SoundLocation=$env:WinDir + '\Media\Windows Notify System Generic.wav';$Audio.playsync()});$rs=[RunspaceFactory]::CreateRunspace();$rs.ApartmentState="^""STA"^"";$rs.ThreadOptions="^""ReuseThread"^"";$rs.Open();$Notify.Runspace=$rs;$Notify.BeginInvoke()};&$^;[System.Windows.Forms.MessageBox]::Show('Re-launch ZipRipper in Offline Mode?', 'Build Complete.',4,32,0,131072)"`) DO (
SET %1=%%#
)
EXIT /b
:COMMONPDF
FOR /F "usebackq tokens=* delims=" %%# IN (`POWERSHELL -nop -c "Add-Type -AssemblyName System.Windows.Forms;$Msg+='Would you like ZipRipper to attempt the most commonly used';$Msg+="^""`n"^"";$Msg+='PDF ecryption key masking? [Length=8]';$Msg+="^""`n"^"";$Msg+="^""`n"^"";$Msg+='To run ZipRipper with user selected/default options click NO';$Msg+="^""`n"^"";$Msg+="^""`n"^"";$Msg+='(This only takes a few minutes for GPU users, but CPU can take ~4+hrs)';$^={$Notify=[PowerShell]::Create().AddScript({$Audio=New-Object System.Media.SoundPlayer;$Audio.SoundLocation=$env:WinDir + '\Media\Windows Notify System Generic.wav';$Audio.playsync()});$rs=[RunspaceFactory]::CreateRunspace();$rs.ApartmentState="^""STA"^"";$rs.ThreadOptions="^""ReuseThread"^"";$rs.Open();$Notify.Runspace=$rs;$Notify.BeginInvoke()};&$^;[System.Windows.Forms.MessageBox]::Show($Msg, 'Enable FAST PDF Mode?',4,32,0,131072)"`) DO (
IF /I "%%#"=="Yes" (
SET %1=1
)
)
EXIT /b
:CPUMODESPLIT
FOR /F "usebackq tokens=* delims=" %%# IN (`POWERSHELL -nop -c "Add-Type -AssemblyName System.Windows.Forms;$Msg+='Would you like to split the wordlist?';$Msg+="^""`n"^"";$Msg+="^""`n"^"";$Msg+='WARNING - There may be up to a 60 second delay from when a password is found, before the remaining lists are halted.';$Msg+="^""`n"^"";$Msg+="^""`n"^"";$Msg+='To split the wordlist click YES';$Msg+="^""`n"^"";$Msg+="^""`n"^"";$Msg+='To run ZipRipper in default mode click NO (If this is your first attempt you should click NO)';$^={$Notify=[PowerShell]::Create().AddScript({$Audio=New-Object System.Media.SoundPlayer;$Audio.SoundLocation=$env:WinDir + '\Media\Windows Notify System Generic.wav';$Audio.playsync()});$rs=[RunspaceFactory]::CreateRunspace();$rs.ApartmentState="^""STA"^"";$rs.ThreadOptions="^""ReuseThread"^"";$rs.Open();$Notify.Runspace=$rs;$Notify.BeginInvoke()};&$^;[System.Windows.Forms.MessageBox]::Show($Msg, 'CPU Mode Detected',4,32,0,131072)"`) DO (
IF /I "%%#"=="Yes" (
FOR /F "usebackq skip=3 tokens=*" %%# in (`POWERSHELL -nop -c "Get-CIMInstance -ClassName 'Win32_Processor' | ft 'NumberOfCores'"`) DO (
SET "FORKS= [Split: Forks=%%#]"
SET "FLAG=--fork=%%#"
)
)
)
EXIT /b
:CHECKGPU
FOR /F "usebackq skip=3 tokens=2,3" %%# IN (`POWERSHELL -nop -c "Get-CIMInstance -query 'select * from Win32_VideoController' | ft Name"`) DO (
FOR %%$ IN (%NVIDIA_CARDS%) DO (
IF /I "%%#"=="%%$" (
IF EXIST "%WinDir%\System32\OpenCL.dll" (
SET GPU=1
)
)
)
SETLOCAL ENABLEDELAYEDEXPANSION
IF NOT "!GPU!"=="1" (
ENDLOCAL
IF /I "%%#"=="Radeon" (
CALL :OFFERCPUMODE
SETLOCAL ENABLEDELAYEDEXPANSION