RDP Shadow Session

Click here to view and download the files.

Function: This script opens an RDP shadow session on a remote Windows PC or server for a specified Active user session.

Requirements: The zip file should be extracted to C:\Scripts\Troubleshooting\Shadow2 (or the shortcut modified to reflect the actual location). The "RDP Shadow 2" icon can be dragged to the desktop or other location.

This script does not require a pre-elevated PowerShell console (the script prompts for admin credentials to elevate).

The initiator must have admin rights on the remote PC.

This script requires the remote PC be online and that an active session be present.

Usage: Double-Click the "RDP Shadow 2" shortcut. The script will then prompt for admin credentials (modify the 1st line of the Elevate.ps1 script to personalize).

The script will then prompt for the "Remote PC" and will then identify the active session and attempt to shadow it.

Output: This script will launch an RDP shadow session on the remote PC. The the user prompt to accept the shadow session should be displayed briefly and then auto-accepted and the shadow session connected.

On the initiating PC, a local log file (Shadow.log) will be created/appended for historical reference.

This script uses an overlay in the upper-righthand corner to signify that a shadow session is in progress and when the session is closed, the overlay will be removed.

Additional Details: This is version 2 of this script. (Version one of the script may be included at a later date.)

The previous version displayed a dialog box to notify the user when the session was closed and this version uses an overlay to mimic the behavior that Bomgar uses. This version also auto-accepts the session where the previous version required having the user look for the dialog and click "OK."

This version of the script also uses a file-less approach and does not copy script/filter/graphic/batch files to the remote PC. Instead, the overlay graphic is base64 encoded and embedded in the script. The scheduled task is configured from an embedded xml task definition and the task launches a base64 encoded script. The one concession is that a log is created on the remote PC with some details of the session for help in troubleshooting. The log is located at C:\Temp\sc2.log on the remote PC.

Scripts Breakdown - Overview

There are 3 scripts for the main function of this utility. Each will be listed and discussed. There are also a couple of support scripts and the script that is encoded and added to the Scheduled Task on the remote host which will also be listed and discussed. The support scripts make the Base64 encoding of the image and the Scheduled Task Action script a bit easier to customize.

The elevate.ps1 script prompts you for your admin credentials (See "About" in the site documentation for better understanding). Once this is completed, the script then launches the Shadow2.ps1 script.

The Shadow2.ps1 script prompts for the hostname of the PC/Server you wish to shadow. The script then connects to the remote host and identifies the active session. At this point the script will launch the Remote.ps1 script on the remote host. When that is finished, it then launches the shadow session.

The Remote.ps1 script creates an Event-Based Scheduled Task on the remote host that triggers when an event is logged in the System log corresponding to the connection of a shadow session (EventID=26, Name='Application Popup').

The Scheduled Task waits for the shadow session to connect and then triggers the task action. The task action is an encoded PowerShell command which first looks for the modal dialog asking the user to accept the remote session (and then accepts it for them). It then draws the overlay and checks every 10 seconds for the existence of the RdpSa process running on the host (remote PC or server from our context). When that process is no longer present (because we've closed the session), it closes the overlay providing the visual feedback to the user that the session has ended.

Elevate.ps1

$cred = Get-Credential "<Admin UserName>"

Try { Start-Process -FilePath "C:\Windows\System32\WindowsPowerShell\v1.0\powershell.exe" `

-ArgumentList "C:\Scripts\TroubleShooting\Shadow2\Shadow2.ps1" -Credential $cred }

Catch { [System.Reflection.Assembly]::LoadWithPartialName('System.Windows.Forms');[System.Windows.Forms.MessageBox]::Show("Bad Username or Password") }

This script simply presents the Windows Logon dialog box for admin credentials and then launches the Shadow2.ps1 script with those credentials. Those credentials must have administrator privileges on the remote host. Customize the first line to keep from typing your admin username each time you run the script. UPDATED - The script now verifies the credentials and a pop-up message is shown if the credentials are not valid.

Shadow2.ps1

$ErrorActionPreference = "SilentlyContinue"


# Get the remote host name

$pc = Read-Host "Remote PC"


# Get the active username (for the log) and the session ID (for the connection)

qwinsta /server:$pc | Select -Skip 1 | Foreach { If ($_.SubString(48,6) -like "Active") { [Int]$id = $_.SubString(41,5); $user = $_.SubString(19,9) } }

If (!$user) {

Write-Host "No " -NoNewLine; Write-Host -Fore Red "Active" -NoNewLine; Write-Host " User Session Found to Shadow.`n"

qwinsta /server:$pc

Read-Host "`nEnter to Exit"

Exit

}


# Local Logging

$out = @{}

$out.Add('Hostname:',$pc.ToUpper())

$out.Add('Username:',$user)

$out.Add('DateTime:',(Get-Date))

($out | FT -Auto -HideTableHeaders | Out-String).Trim() | Out-File -Append .\Shadow.log

"-------------------------------" | Out-File -Append .\Shadow.log


# Do the Scheduled Task Thing

Try { Invoke-Command -FilePath ".\Remote.ps1" -ComputerName $pc -EnableNetworkAccess }

Catch { $error[0] }


Start-Sleep 2


mstsc /shadow:$id /v:$pc /f /control

This script prompts the initiator (you) for the hostname of the remote PC or server that you wish to shadow. UPDATED - It then identifies the active user on the host (if one exists). If no active user is found all sessions on the remote host are listed for troubleshooting purposes.

This script then generates a log locally indicating the username and the hostname for this shadow session. This is helpful in the future for users who are not proficient in locating the hostname of their PC. (Once you've walked them through the process, the information will be logged here and you can check the log instead of walking them through the process on subsequent sessions.)

This script then launches the Remote.ps1 script on the remote host and waits for that process to complete and then launches the RDP Shadow Session - connecting you to the active desktop on the remote host.

Remote.ps1

If ($users = (quser)) { $users | Select -Skip 1 | Foreach { If ($_.Substring(46,6) -eq "Active") { $user = ($_.SubString(1,9)).Trim() } } }

[string]$evtStr = @"

<?xml version="1.0" encoding="UTF-16"?>

<Task version="1.3" xmlns="http://schemas.microsoft.com/windows/2004/02/mit/task">

<RegistrationInfo>

<Description>Display Overlay for Shadow Session</Description>

<URI>\Flint\ShadowChk2</URI>

<SecurityDescriptor></SecurityDescriptor>

</RegistrationInfo>

<Triggers>

<EventTrigger>

<Enabled>true</Enabled>

<Subscription>&lt;QueryList&gt;&lt;Query Id="0" Path="System"&gt;&lt;Select Path="System"&gt;*[System[Provider[@Name='Application Popup'] and EventID=26]]&lt;/Select&gt;&lt;/Query&gt;&lt;/QueryList&gt;</Subscription>

</EventTrigger>

</Triggers>

<Principals>

<Principal id="Author">

<UserId>!user!</UserId>

<LogonType>InteractiveToken</LogonType>

<RunLevel>LeastPrivilege</RunLevel>

</Principal>

</Principals>

<Settings>

<MultipleInstancesPolicy>IgnoreNew</MultipleInstancesPolicy>

<DisallowStartIfOnBatteries>true</DisallowStartIfOnBatteries>

<StopIfGoingOnBatteries>true</StopIfGoingOnBatteries>

<AllowHardTerminate>true</AllowHardTerminate>

<StartWhenAvailable>false</StartWhenAvailable>

<RunOnlyIfNetworkAvailable>false</RunOnlyIfNetworkAvailable>

<IdleSettings>

<Duration>PT10M</Duration>

<WaitTimeout>PT1H</WaitTimeout>

<StopOnIdleEnd>true</StopOnIdleEnd>

<RestartOnIdle>false</RestartOnIdle>

</IdleSettings>

<AllowStartOnDemand>true</AllowStartOnDemand>

<Enabled>true</Enabled>

<Hidden>false</Hidden>

<RunOnlyIfIdle>false</RunOnlyIfIdle>

<DisallowStartOnRemoteAppSession>false</DisallowStartOnRemoteAppSession>

<UseUnifiedSchedulingEngine>true</UseUnifiedSchedulingEngine>

<WakeToRun>false</WakeToRun>

<ExecutionTimeLimit>PT72H</ExecutionTimeLimit>

<Priority>7</Priority>

</Settings>

<Actions>

<Exec>

<Command>PowerShell.exe</Command>

<Arguments>-NoLogo -NoProfile -WindowStyle Hidden -Encoded "A d d - T y p e   - A s s e m b l y   S y s t e m . W i n d o w s . F o r m s ,   M i c r o s o f t . V i s u a l B a s i c ;   $ d i a l o g P i d   =   ( g p s   |   w h e r e   {   $ _ . M a i n W i n d o w T i t l e   - M a t c h   " R e m o t e   C o n t r o l   R e q u e s t "   } ) . I d ;   [ M i c r o s o f t . V i s u a l B a s i c . I n t e r a c t i o n ] : : A p p A c t i v a t e ( $ d i a l o g P i d ) ;   [ S y s t e m . W i n d o w s . F o r m s . S e n d K e y s ] : : S e n d W a i t ( " { E n t e r } " ) ;     [ s t r i n g ] $ i m g S t r   =   ' i V B O R w 0 K G g o A A A A N S U h E U g A A A H M A A A B z C A Y A A A C r Q z 3 m A A A A A X N S R 0 I A r s 4 c 6 Q A A A A R n Q U 1 B A A C x j w v 8 Y Q U A A A A J c E h Z c w A A D s M A A A 7 D A c d v q G Q A A B w C S U R B V H h e 7 Z 0 J f F x V v c f P c u + d y W S S y d I m p G t K 2 l K 2 1 0 J B y m M V H 6 I C L g 9 Z n n 4 U Z S k K F j 6 I P F F 4 n 5 D 3 k c 2 K K B W x Z R M R N 3 x P H i J W U D a B s p Q C t X S n p V v 2 z G T 2 u 5 / 3 P 3 d O k k m T y d z Z M h H m 2 0 5 m / u f e u X P m / M 7 y P 9 s d V K F C h S k I F s 8 V i g R j D N 9 9 8 8 0 1 r Y 2 x x m k s X j f d G 6 6 d 5 j E C h O k 1 q k V 8 h g E P J t V g Z n k I I f A O G x 6 E v 8 8 E N Z K K Z E c V a i c U i q J B z T s 4 Y P s i 3 U Z V J B i W o z u N w E B H R 4 f u f N A 4 V M T M k f P P P 5 9 e u q w 2 c G x 9 q D E U k + b W U G u + n 2 q L d B P P k x C b 6 8 F W m 8 J 0 H 2 Y g r M 0 w B q 0 w C O y 8 G c J c w c / G G M G 7 m P O a w t X g m R H C 4 k z p 0 R n Z S Q n q 8 m J z 2 4 a u x n t O 6 v h l 7 9 D b K m S A Q R L + + e 4 V i p 8 l D l v k 6 z / e 1 s m J 9 T R 5 M j H M 6 c S 2 a w h j s i O Q W 5 G K i J b U 0 f b e B I r g 6 n c 6 W 4 4 4 7 Y I b 1 o Q r Y q b R 3 t 5 O j q i N t J z q 2 7 s A W 8 Z p f m S c L N v 2 8 Y p t B J D N i 5 o 4 s c w k 4 h p 6 t z O O 3 g s a T t G t m d a 4 6 t y f v n h 1 R U y A l 8 A D d / / 7 t f U 0 s c J r G y 3 I t B W S q u C m F h D R a F R F m 7 o S 6 P 1 B k 5 v I w r Q / G p j 7 q a v u e / I N K k 7 7 U D O j a 7 l 8 Q m 3 3 P T 5 m L M I 2 k 0 D F K S g k c o T c 2 J l A e 8 J C S C I F Y 1 U z z 7 n q w a d e 5 6 d w d + p D z x V r 1 h i q S T c I c 0 q S i K t o c 3 c C 7 Q 1 D 1 Q p C 2 p j 2 R m p n f e r K h 9 e + K k 6 p i D k M w X 8 W r 6 Y c W k J H W 3 s S a H e I C 4 m h R N L w o H / G Z 7 9 x 3 1 O v i V M c K m I K 1 s e m r Y e + n i X M K Y O h G W h H T x z t G D D A B 8 O 8 R I a T t S 2 f W v H g X 9 a J U 4 a p O E B p h G 4 7 c 2 + d Y s 4 W Z t k x d R O 9 1 x 1 D G 3 s 0 Z I A 3 b S O i J 7 1 N X 1 n + i + d + L U 4 Z R a V k p o P R l K l q L d N C e / r i a F N v S k h w r p n q a W g H I X 8 j T h l D R c w 0 Q r b v W f G y r N g g 5 H 4 Q c m O 3 i j S L C 4 m Y K g X W 7 D / 0 j O / D Y T D H p y J m G t T S 1 p s 2 N o R Z F p h l o 8 7 + B H q n S 0 W q m d J N p 7 6 1 t Q t m X d 3 R 0 c E H c j N S E T O N X t y Y s B H W h D n p M N t G P c E 4 e r s r i e J G S j e D e t + K T l t 0 0 Q U d j 2 U c Y B + i I m Y a N V Q 7 n G K 7 W p i T C o N 2 c S C U R G 9 3 J l F U T w l p Y 2 l v u L r 5 0 9 e s e j T i B G S h I q Z g 2 5 2 f n 9 m q R O 6 n u A w e P m M o H E m i d z o T K K Q K I R G N h A L z z r v m / r X 7 n Q A X V M Q E N t 1 1 / p J W F H 7 R g 4 x 5 I m j y g G Y x J o b p + h K p b i 5 D R I t 6 m y 5 d s e a J 9 U 6 A S z 7 0 Y m 6 8 4 6 L j F l r B v y n I P F Q E T S r J h I Y 2 d S d Q Z 9 R 0 3 F R 4 W F G 5 4 Y a v / + L Z 3 6 f O c M + o K u X V u 7 8 x r 7 W q + 2 O a S U e 1 G x R b O i J 8 R B C 0 P 8 i f G h o y k R A z C R 0 2 x 8 A P y M y y J G y b q Z A M Y / z E Z l 5 i O o 2 9 h R Q n a A j n 4 u I T q g j E C b C c 6 0 j 8 5 T A m / O P n U Y k Y p v g 0 a 8 w 5 4 C V q p r 9 J D f 9 E w W Z z K n R y 0 Z M 6 2 t w Z Q 9 s G d G e G j a P K t f f 4 9 T n X X P D Y Y x n T M h P D Y q 6 7 7 e L W J f W 9 G 7 y S U Q + 9 V B E 6 G e T Q R O X S m o n E 4 a S 9 H L k G g 4 w J 7 R M G D 7 I c m J q J t n f H 0 L u 9 K j J F F H T J 9 x f N v / R c P v C f C s k N p 3 i s X r 5 c P t n f + a t a p h 3 l Z O B R 3 3 4 K w e P l 9 p E G 1 2 / 4 A c e w D V 9 b 5 W M q 5 R G S D w o 4 o z s 9 2 r C Q J l G 2 9 d X M P O f q N b + O p U J y x 2 k z l 7 T E j q w 1 4 h 9 n k 1 o i y w P j J V K 3 Q M i c a 7 G i w A c F u v o T U C I 1 i E Y q 1 / H p r G R t 8 2 e / t e b J f i c g T x w x V Y M p k G s x 4 i M O B + X q D x K 2 I y R 8 w a E G a p L h f c n + w Q S U y C S K i 7 4 k w 9 B 0 e h s v v m L N 0 1 u d g A J w x G y W o 7 s M R l X G c w r P s E P t y g c I v g q E 6 d C J L F M b y f u S E e h L b u l R h / u S P L U T S u O 3 L n / 4 h b V O Q I E 4 Y m 5 E S y N Q 8 e x y P N X y 1 D 4 l Z U h I O u R I T z a g W j y m o e 1 9 K u q O j c R B k / y P 1 q o t P x V m w T h i X t D R o e t M 2 s k 7 H 4 4 n + w E r m c w g i F j l y 6 V q U k P v D y T R n k F 9 u B X T J e 9 r k c Z l y / P p g m T C E Z M T w 5 I z / c M M + L i h T / w A w C w Q c q i z W Q b 4 S o H u Q R X t C h l I + D v c 4 d m f k J s u u m b V q q I O 6 g + X w d 0 3 f u b 0 W T j 4 L F U w x t N G d 7 A z A q X Y M i x n g d H B p d l d 4 X Z x V g G 1 h I 0 V J E H 3 g y 8 M L w e W Y a K + U N L p g g S T k E 7 w D 2 K T S F Q 3 f / K y B 5 9 7 U Z x W N I a T 6 r 7 2 a x u + Z K 7 v k y V E y H Q 5 r c x m g D f o / T r a u D + G d B D U I U P C O 8 E H H R t 7 K o S k / m f k 4 G O O n R a Y f t w j y 2 j x v D q k 0 P I I y a e z B s F z 3 d 6 v o b 1 i a S S v 8 p K e u v / 6 y i / W 3 e I Y R W Z U + g z c d O b 7 A a L O p Q 1 Q M j 1 w a K K P g 2 O 7 u w z 0 8 r a B s n W + M w F 1 C z r p s O l o b n 2 Z l g W D c l H w X P d B G 7 m l T 0 s t h o e H L v k e 9 + j z P l / M d j K d U W L 2 3 f S x B + u x / l V a C 4 l Q A 0 U z i 0 Z 9 Q V t 9 a k v y 3 Z F u m 5 3 S f / h 9 4 E f y E p 5 2 H Y z J q A F X 5 x 3 O m 1 i q M k i P E Q / H 0 D l k Z J x 6 n 1 9 0 + I N H A C W P b P K 1 H j 9 H G j 2 w O 4 m o c Q 3 1 R j T 0 d p f q D A z w W O r E s y M S O P y E K + / 9 V S h 1 V v E Z J e a u m 8 6 + Z g 6 O / I h U E Y Q b Q N A s Y i Z V H N 9 P 5 c a F 1 6 w t 2 + z 8 w b x 7 y 3 m n L F B C z 8 i E e U T Q p M L H X A f C S b Q R + p N h 0 Z + E b l 9 y o G r 2 J 6 9 6 a O 0 L T k C J G N U y a j Z 9 2 e K 7 z 1 y O B H k l u 3 r 3 Y M s S Y Z a d l + 6 4 p I Z P M J d L S D 5 U F 4 2 r a D d U r x E t J S R U r 3 Z c q r + 5 1 E J y R o k Z Q n V d k I v i b k e C M M H o K H r g R G G W n T b U c 5 2 P m A u F O b m A a n x 3 V n f U Q J 2 R t I E B W v 2 K 6 T v i L m G W l F F i 7 l 9 y T r d q S 9 2 O 5 + W m a w Z i S z K Z E m K + c d s X j p 5 G k 9 c L s 7 i 4 q K V 0 1 U C h u C G 2 2 a V Q F A l 9 Z O F 0 K 9 8 p r V w Z J e Y F F 1 x g x b H y p h M b P j e T p W T y 4 3 5 i H M 3 3 N Y q Q s v B c + 8 X e h X L o A Q k z n w g q C g x y d S i s o f e 7 4 s g e m q s a B x u 6 Z p G Y 5 k w y 6 + A N D i X b v 7 T V o t l + b f H K l d d N y i K x M S I Q Z P 2 V P z M + u + A i R 0 o S O u R j y t 5 G Y Z a F w 3 z h L 9 d g 9 T h h F g U L 2 r + 9 P X H 0 y q 5 B 9 M r e K H q v P 0 N v A g S P Q / W 6 J 2 w 4 7 e S Q k C 1 N t a h 1 u g L p w 3 z H x L r n i u C S M k b M H W T 6 2 4 6 G Y g F u N g h h d c 1 6 c K Y w J x 1 w e m Y 0 0 O j t k I j Z 6 h H X m F A K d x 6 I o j f 3 R d G g y k e 4 b N Q 9 G B V H R 8 O X f v T E D H R g u J 3 E y F c l o + P n V z k W Z H Z l J o 1 N i p M 4 R s z E 4 M B G g x H X T p B E E V Z l + X R h T j Z 4 E e 6 6 0 Y P t e m E X j G n Y a A c I y R d Z D a 0 o 5 3 S q y m b L H j 2 j z V c M h G I 6 t J O p N T x O U m G M j j u s D s k 0 l X B g o i r J / o h j l J g x Y r 7 W c I K h I m l L q t 1 0 U T o h s j N p 5 A R h T S r / u P 3 C R Q G i X S z M g t E 1 C 2 0 7 E E G b e x L O H g 8 B 0 6 n v 8 T 2 H n L 4 s q i v d I m y 4 e t 0 V 0 o d F 5 3 8 P n e F H 0 2 r S R p 4 g f W o l 7 Q R + S x k R U j L G i M n 3 M 0 D J X O 9 4 t H w G J V s U 4 D i m Z F J y X j q / + 9 3 5 d C Y J 3 w p O T 1 G c C x 0 6 + 1 u 5 k L 3 J d C F t X a p 5 x L 9 o / o X f X r k y a m H 0 q A h 3 q t f 9 0 J / s i 4 8 U 1 m q o X o + Y M 9 Y H o 4 Q d + f z N p 5 d 8 b H G M m J w o 8 b 7 F n 5 3 p M B f U y F r r T 9 q v 9 A t z U j h m t 3 U q l M p z h V k Q h m 6 h L V C 1 b u t P O t v n e A a F v 7 b m q f v B n s P O / u r Q P o 8 + w 7 / W O Q D V a 3 8 E n J 7 B k W 4 I g T 7 3 s Q s D U L 2 K g D T 8 s l n T T Y 9 Y I M y S M a 6 Y u s X W w 3 e y n G o 2 y 5 A e h 8 + 0 H I c G / l W Y k w F u x r G b I P 0 K z u 2 O s 9 M V R T s G 1 O E V p i k h 6 1 f u m f + J 7 6 T v v G J J e y P U x J E Y d E P 4 / O R Q C e Z / Z z Q f V L 2 m Q a D 9 X I I 7 T x V m y R h X z H V s 3 j 4 Q 0 3 C c I B d i I k j V N m / o a G G V n M 2 3 f n 4 Z 9 G 8 / K s y 8 4 Q u s 9 v b E 0 N a + 5 P B K O Y 5 O q / + w d / 5 Z N x 2 8 h e 6 3 n s W h n p D + 1 r 5 B D Q X B y + X w d 1 F K 0 N F z J + j i Q k k P U K O o X a f x G F f M S 2 9 b 1 T f I q t 5 L j Q T B H x f t J i O T M x L E B y h a p N g N 4 C V m i 9 W E c C E 7 + + J o S 2 8 C J d M c P Y P 6 X t 4 z / a R L Q M g x Y 2 B c 3 L + F 6 i 5 / K + K 7 z U L y N j 4 l x N P o s L k B 5 J l o P h 9 i 6 p O M E 0 s 9 u J L x 4 g a m r z n Z z o 0 T B N R Q f W F 7 + 2 k u l y j k z 0 X e d 4 + s I d p Z w s w P + E p 9 w S R 0 P + K j O v o G V T Z F 5 b m f 6 V i 1 K u M W u k t W / 2 n H l x 5 + 5 b s z Z 7 d d 9 f E 5 A f T R + Q 1 o w Y z s s 2 0 e i R 1 y I t p f J 8 y S k F H M u E W f 5 8 9 u n S B G S e s X 0 a y i D q e N R y N O f g 2 a o I J m R S J R D b o f c R R K 8 l q U S 4 m R h a W e g e r W z 6 1 4 5 P E B 5 6 Q s D K D a j R A P m 0 / 9 8 l X y 2 a D U b m i U o 6 3 C L A m Z x c T + d 6 A m Y s y l E + S h V k 2 Q l n Z L 3 C v f + / L M B p q 8 V J h 5 o a k m 2 g 7 t Z E 8 s t e u K w x B R Y 7 6 W i 6 9 7 4 I 8 7 R V B W q p Q 5 o Q R S d j i j B S 4 G V 8 D L x R S x k 4 V Z E j K K S R T P X g 3 R o L O k b C g D T w B 3 z R t x 4 k x h l o Q 5 U v g / o M + W d 6 m 0 w H P d B U L y L g X X g M O f 4 p 6 G 2 6 / 8 + V / / k g p x x 0 e h T Z W Z u c V Z M e O y P z 6 D x E 4 R V k n I K O b r X Z 6 4 z f C B Y S c o G 3 C l e r l 0 H t v 6 1 c v l e p r 8 o j B z h s + A 8 B s / 7 I Q u y C j P V a p + 8 k A b 5 Q u s c q Y X 1 z g 3 V n L V F I G Y V E I l H S n L K C a f g + t n 1 T k 5 Q Y r E S j Y S J A U j R 3 m x s V i Y O R O C 7 s Q 2 8 F x j f D Z I Y B B l f + f 0 B Z d 1 d L z g Z v Z 2 D I a G N k C + g E 4 c F E 8 X e g Z k b f b q 9 m 9 O E 2 b R y S g m B 6 q R 1 3 g c 3 S 6 M 9 l K j 6 V f f u b Q k G 1 e b S e x y q M l d Z K m x q N B O 7 u i N o / 7 k y N C b h Y g W q z r k w h v v / k 2 P C M q Z 7 c q s L V D g T b d + h Q y + / m L S W b L S O a G Y 2 1 H T G x B Z P n z g S k x C c d W x 3 t 7 5 w i w a z 9 y + P N B I k h c J M y f 4 v O Q e E H J / R H f 6 h E M k v X U / v O r n T 7 8 i z L w 4 9 9 b V B y K 2 p 4 / 3 W d 0 4 Q T y 1 Z 0 v h v G u X b E w o 5 t + V e d s N h k 2 3 k a U U E S b J R W 8 3 2 + y + 0 y R i 5 9 V H 6 w u p 6 D 2 n n R Q B g C b 5 X j t w 6 M y b h V k Q J p G e d z K 6 S y e I E l S y Y b 0 J x e z o 6 F C j y L v B 8 d j c O E E Q 2 S Y a O 0 l Y R a O G a u f A p b M l 1 R j i c Q P t 5 P c x F y v l O B a m U d X b d E m H i 5 s k u Q G S 5 T l e 4 t 1 u V P b L R u t q c O a E W V Q m F J N D m P 2 6 U 8 e 6 d I L A Y z u y m M N W q 1 e v l r 3 Y / J w w X c M H 0 H f 1 x l B X b G R m A 5 7 t s D L t u 1 9 / a O 1 m E V Q w n W Z g k 3 N 9 n t m H P m g C C E V t h / c H S z I S l D X R B 0 n 1 q 8 7 + R j c l E / A Q a 8 E J w d e K l v N O 6 n 3 + B D 8 1 c v M A I a o 9 w S R 6 P z R y z w C O R n 0 v 9 r W h n w m z K E h m Y q f B y O C w E 5 Q l w 3 s l S 9 K s m p I 4 Q V n F Z L a x G X w I 2 8 l 5 L m o S r 2 z L t G F G 0 S J b L 8 d y 7 l v G 4 j p 6 r y + B 4 m n d E B P T W N g 3 6 2 v 5 d k M y 8 W Z s R h g + p X t 4 J C g L f K 3 x f N x b k n Y z q 5 g 7 7 L l 7 G M b h 4 e m w b F U t R H a p v K 8 o 7 e Y T 7 c t 9 j T T 5 C W G 6 g o / y 7 O 6 L o 5 7 4 y H A d Y C e U h h u u f f C J b c I u G r w / H k b e V x 1 P m b e b 2 d I H j n v l 0 v T H s 4 p 5 z u 3 3 D m p M 6 u E j K E 6 7 m Q 2 I r C H J x w u r I B Y q A / M l b M 0 R Z n Y g e t 1 Q v e 4 J 6 a O r V 1 L 1 i l a / 5 H 5 h F h 0 Z m S + l n C A X 6 Q P U S u r h P 1 6 x o u h b K N w 4 K i y G l a e d b O 7 S C Q p I 6 m J w g g q e D v M T / S S K X c X R I Z E 0 0 K 5 + X r 2 O K G k j E u / x L 1 x e 7 F 3 K 6 W x n h 7 z p y M j T x 4 W e s o Q C h w c G i 3 5 7 N 1 c J x R h x b s j n d i Q I U z z t W H 1 b w Q u j J c I u E C + z w v v C + 0 D I 3 t H V K 0 o q d T + 5 4 Y H f b h F m S X h G X r A 5 a V E r h + W p n k O 9 4 f K I + a 7 V s o 4 n k B N Z F 2 J 6 J F b b V m 0 W t I r 7 4 R u u a q w n y W X C z E r Q W W D F 7 2 c u A g C D e H Y l G p b e K s y S A f 1 x P Y k 9 6 1 O D K 9 k T i O 9 Z t R A t + g y T K z E P b T m w L 2 l L Y S e i L n I e j y x m d k E L o 0 / x 7 z 9 O x r a r d s U w L H B 6 E s 7 q 8 y H A a d N j 1 c 2 X Q f X q 6 s a 7 h c J s / J L r p g i O N 8 t R P q z n o t F y j y s x H w 2 e Y N i Y v O M 4 Q W 7 6 m 0 5 k 4 w V N x H p l 6 w y 3 6 3 x 6 Q y r q j I 7 c G Z K j 0 e o n e m e f W P I 9 k U O E q P J m L k 4 Q o W T J c + 3 t R V 1 L 6 0 p M v p A p y e R N r n M e A P 2 p Y / l T y s o N v s C 5 D u u n C X N C N M 1 C e 8 C D T a Y l I v 9 F n t 6 a w 6 / j 8 R Z B J a f K 1 t 6 y E D a c Y T 0 X e l b L R l 0 X 6 j 1 C m E X B l Z g c A 9 G X e B w Z 9 / l d R D a g a D P v u f G b s 4 S Z E 0 t 3 I T 8 l 1 l H C z A z E o w u E T H d 6 4 J n F 5 Y b v 3 b D m k b 0 i a F J 4 2 m 7 t g p I Z H 2 6 K s s D X 0 h 6 D O 4 u 6 o t G 1 m F F c t d X m I 0 F 8 2 6 g L M S l E d p m 0 9 x h h 5 k S S s a W K i x v f J 1 Q T 7 Q s l R 2 3 w M Y m y N d I 8 9 1 5 h T h p X 3 L E m H E P K 9 u F J i W x 1 E q R 8 t W K 6 d v D c 4 F r M N 5 O t 2 y G K O r + / j R s n i F + 5 y Z v f n s k m k s i 6 l J K 3 T 5 0 D C d Q v 7 m v O s R E 2 Y 9 6 W a 6 + / 8 5 d x E T S p G C y 1 o t F t U 1 Q r a 0 u K O S n h + k J f v v P O e B j 5 R h Y w Z Q O + T B W 1 l g r L N f z L e Y l 5 t j A z w l c P d I a 1 9 E 0 + z o + 5 9 M x d 9 o w w J 5 2 4 L b + c c o J 4 I m V H p n j 2 E U V c S 5 t T r i D I S n m H b q o R Q K H m o t + 1 t + d 0 P 5 4 z 5 J 3 N V d j I u r 6 0 Z 1 B F A 6 O W g W A 9 6 j 1 k z J a C y a T H U 7 M e P j y 1 P N V F f p e p 1 b C I h q c L s 2 B y E r M f + 9 / g z 2 4 9 N p n Y M 1 u 0 H T l t u Z t F k 0 d C c z v h Y m p N t 9 B + E D N 9 l V 3 S U 3 / f 1 Q / 9 6 R 1 h l g U D e Y I q k v a 7 7 Y / z t b Q q l s 8 Q Z s H k J K Z i 6 u s t h p n 7 k S D b o 1 U p O b W b C j a P g z S Y M B l 6 I M m C i R E P 1 s R y t 1 H d / N / C L B u n 3 / x z z b R J y g l y 0 2 7 C 8 U O l g a J N F + Y k 5 l 5 P U y 9 0 U f q d X O c i 5 / G 5 u 4 W k z 1 V / c Y h a q k 7 o 4 f H R n g O D 0 K 9 M 8 2 C T S m D l l T / 7 Q 6 8 w y w b G m I V Y d e p n g 1 3 6 F d B H 4 Y M r 2 W R 3 R U 5 i Q s 4 L w 6 c e y G U k S F F s 1 0 4 Q n 2 m R G J t w 1 X c w o q O B t F J p E M / e 6 L T j J 7 0 r k g m Z G S / a f F u H y 6 a o V l Z b f 9 D + z a L c r S U n M X n O 6 0 f V L z u R d O l + V 1 N j M f + p D W F O y K l 0 9 2 E + a j Y I c w w 2 p N I B 6 F c m R E a C P G V r 3 s B 3 r r v r r q Q T M A V 4 m 8 7 a A f F K b V R 2 I a Y k I X I a y a 8 / f j A 5 i c n x I / 0 l / u w 2 5 0 G 7 G Z j T o r m 6 t c w x n t 4 J b 7 E S i f F 7 C I z s E z G o d 3 O i Z v H / p K y p w a d v u f 9 9 c I J 6 b Z d O E K E Y B 6 h e l F 3 n O Y v 5 K p 2 7 g d e y b n M e p a i q T Q q 7 u p + d h q S M 0 0 L O X p G Q i m J D P y H B s B 3 1 N t 5 U y k n n f A D t W A x 5 1 q V q L 4 h r t t o L j o O Y R b l P U M 5 i n t 1 x / w 6 N S Z H U s B U 8 s u U 8 4 v z A T 9 Y x S N 4 f r S N q x v N U z U I 9 U X 1 4 v t K k 3 v U b l b a n U t b U g j I r p 2 U k H t k + 0 m 1 T N B E 5 i w m w G F N S E 7 E u n a A m G s 8 6 B j l f e T e A E T t E m G P o g V I Z B k G H S H o a v r 9 m k m 4 w m C s 9 L P C m 8 8 J N + g A K s V t P b e v 2 C j N v 8 h G T / 2 q f s 5 X N V T U C U I k c n m 0 M U s L y f P h S t c I c h Q G f 0 x l W k S 4 S R 6 W + t / 6 a a H j c M a Y g A R z b a f J b v f L 4 i p p k I r y S J e + M N R X c b u Y l Z j / z v 8 W T 1 e 2 w V R U 1 5 r S h n g k X M k + X o s d m y h e D 4 P g E k 6 a T L n w w P e p p / t Z j J b r P e T F 4 X V 4 2 A M n S 7 X p l B s X o O M + + 8 o i p y P g f N s O 6 W y e I D 1 u 1 o f C E k Z W R N e 5 a W 9 7 2 8 O 7 I 0 O S z Q b y v e 5 T Z f 3 e M K Q r / 0 Z 8 o 8 2 x y H E W X I 0 F M l g q e 2 8 x L z O c S C / h E b C z V b k J A t s j C p 8 z z D G Y c t o J r Y Q X Z 4 6 7 y j i c M 1 B d L / c A L Z C A W 9 0 6 7 f b J u x l s I u q W I H / 1 x U c 8 C d V T l 9 + 0 t a H l q X m J e t n J l d B B 7 t z o 5 L 3 2 1 c S Z A b E l i G U e C / v e W y w + p p v r Y 2 Q O 4 f t e g i q J i P 5 5 J q z Z M j 9 d N S Q / 2 Y H b j O m d N k F M y + X M W q I Q C / 4 Z 2 u F / w P Q 5 5 i c k x L f L 3 V F 8 K H t l K J l A j G Q s f a m 8 f 1 2 M 7 D v f O h 2 u N c c 3 5 j 9 9 0 h z X E f w M H E s Z W P b W 3 l e o 3 Q Y r N W 7 H G 9 T o j m l s n S K a s q k Z W C x o J y l v M A e x 3 5 j b d r g m S J T T z t O p N 4 2 + Y o W j p e F v c B 6 B f G Q L H x 8 k z 1 L O 5 s / W 0 / 0 s d m Z r w 5 o I h a A v g c f W q u / U w q 9 r K f A q 4 q z R r S v P l q T X Y L G h b h 4 s y N T 4 v 3 H j h 7 G X o w B 5 J w Z h M g 0 L l 4 k o m k u J R X P X H O F P 6 M C M K v 5 U S / 5 I + y / h X P 9 F H L + A C B Y M x E 0 U 0 L i Z D x O P b W F u b u t v m E N B k Y 0 o w v 4 4 I G Q 9 M J I w h g h m K R y o j U h n b o 9 q r 4 b N F R g W H U 5 a I R Z x f x h 3 n W l x I T N j o p Z O 6 f b j s Q U 2 Y O x a 8 7 c y S 6 f s i y s t N N 6 z N e 4 l q 3 m J u / / E K T 1 P f u 9 t q q D 6 X N E L u 4 5 V k l s h W m J h I Q g r V R k + c h v N c L Z F 3 N f t o s M G Q b J v P E E C R q 6 h Y D P y y U f 8 g i i 0 S Z s 7 k L S Z f a 9 O D q l 5 1 S q P L k a A K E 8 P X 0 p 4 k 7 c y 7 v 5 m 3 m B w f M l / n J d P t 7 r A K W Y A C 4 a P 5 O 0 E F i f m O P W c L l E n X d 4 y u k A U Q s 0 b S 8 + 6 e F C T m O s + s 9 y 2 G U y N B L s Y g K 2 T H I 7 E 5 j 1 9 / S Y 0 w c 6 I g M a H d N I P I 5 1 S 1 F S e o O E j E b m 7 w a b O F m R M F i c n x M u N l / s z 4 C g C + d a F C / k B 5 k J C N v V j L a / l l w R X j h u + e 9 8 m j a c 9 T O r O R 4 o P 4 E O j C g 6 a j y u m Y Q p s K G A 4 e c z y F q + N j j v E h h o M 4 K G C U m f H Y R G 8 a Y z q z O + M z + s D B 5 x 3 8 N p 5 2 G x O N / 3 n m X U + t F E G u K V j M 3 d 8 + q z X A o t u 2 B O O K Y Z t I N a H G H V p x B Y z 5 j h N + m Z S V 6 T 1 j w i d g o n O d Y y N / M j L m 6 A S n T 3 Q l l i m Z x 8 k B J v H s D w U O X Z r P O u C C x X y o / W L v / K 6 t b w R j k a P i 0 N + 0 h 3 8 l q e B L f + i w E N U j N b P P W / H Q n 5 8 U Q T l R l B S / 9 4 o L W 6 u j O 2 4 1 E W l M v y R m b N T N B t P z I S Z E b v V b Z / G z + c q 7 Y M x w 1 s O a W N o J v e e N E G p j B k U 9 j Z E W m c C / i Y 4 7 s W D Y t s S 8 J 0 H m Q V + V r w E m l m m k v A Y i R n f T 4 o 6 J y W 8 y N + R W p D 4 o z c U g 2 C L E m T N y s N O P A Z C p e V D a v C t x z k k 7 y 4 K P g + O p E J t g m y n + 5 6 6 8 / 0 8 b w J y o o G d k 9 D e c R F 7 7 3 h e W H F / V t Q E i g O N J E 6 3 b E U R 9 C Y v F a 2 e f c v k D z z h O V Y X c G J 2 d J p E 5 S u w k L i R / 3 S s m o A 2 p + l k Q s q A b + n 6 Y K Z u Y l K V + U 5 L f S r Q T x F Q t Z M U 9 D f y e P X l V M R X K J C a / b 5 y f q E 5 f a i C S m o A G L + 4 d q s y b 0 g u 1 p j p l E f P M l n 1 + c G B a + E a g f Q N J l D A Y 0 n 3 N P / x n W K g 1 l S m L m D K S 6 v m C 5 x i U y L 6 Y j n S i v B e v J r 8 X h y v k S V n E D D P a w j 2 f A 1 A q Y 9 A 3 V e X A w 9 e s W j u l N g D 9 M 1 I W M e u J O X f o v g Q q k s O D 1 X N X i 0 M V C q A s Y g Z w s q 0 r m N o I p H r q 7 7 r + Z 7 8 s + x b 2 D w J l E T O u s 7 b 3 o Y p V m d z J v M 0 / E s E V C q Q s Y n Y F Y z F + t 5 C 4 X H / H F W s e C 4 v g C g V S F j H 3 R 6 0 X Q j R w z x W P v L B K B F W o U G E E h P 4 f o l T w u K j f h 0 s A A A A A S U V O R K 5 C Y I I = ' ;     $ i m g   =   [ S y s t e m . D r a w i n g . B i t M a p ] : : F r o m 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   ( @ ( ,   [ C o n v e r t ] : : F r o m B a s e 6 4 S t r i n g ( $ i m g S t r ) ) ) ) ) ;   [ I n t ] $ w L o c   =   ( ( [ W i n d o w s . F o r m s . S c r e e n ] : : P r i m a r y S c r e e n ) . B o u n d s . W i d t h   -   $ i m g . W i d t h )   -   1 5 ;   [ I n t ] $ h L o c   =   1 5 ;     $ e n c T y p e   =   ' d Q B z A G k A b g B n A C A A U w B 5 A H M A d A B l A G 0 A O w A g A A o A d Q B z A G k A b g B n A C A A U w B 5 A H M A d A B l A G 0 A L g B X A G k A b g B k A G 8 A d w B z A C 4 A R g B v A H I A b Q B z A D s A I A A K A A o A c A B 1 A G I A b A B p A G M A I A B j A G w A Y Q B z A H M A I A B U A H I A Y Q B u A H M A R g B v A H I A b Q A g A D o A I A B G A G 8 A c g B t A C A A e w A g A A o A I A A g A H A A c g B v A H Q A Z Q B j A H Q A Z Q B k A C A A b w B 2 A G U A c g B y A G k A Z A B l A C A A Q w B y A G U A Y Q B 0 A G U A U A B h A H I A Y Q B t A H M A I A B D A H I A Z Q B h A H Q A Z Q B Q A G E A c g B h A G 0 A c w A g A H s A I A A K A C A A I A A g A C A A Z w B l A H Q A I A B 7 A C A A C g A g A C A A I A A g A C A A I A B D A H I A Z Q B h A H Q A Z Q B Q A G E A c g B h A G 0 A c w A g A G M A c A A g A D 0 A I A B i A G E A c w B l A C 4 A Q w B y A G U A Y Q B 0 A G U A U A B h A H I A Y Q B t A H M A O w A g A A o A I A A g A C A A I A A g A C A A Y w B w A C 4 A R Q B 4 A F M A d A B 5 A G w A Z Q A g A H w A P Q A g A D A A e A A y A D A A O w A g A A o A I A A g A C A A I A A g A C A A c g B l A H Q A d Q B y A G 4 A I A B j A H A A O w A g A A o A I A A g A C A A I A B 9 A C A A C g A g A C A A f Q A g A A o A f Q A = ' ;   $ t y p e   =   [ T e x t . E n c o d i n g ] : : U n i c o d e . G e t S t r i n g ( [ C o n v e r t ] : : F r o m B a s e 6 4 S t r i n g ( $ e n c T y p e ) ) ;   A d d - T y p e   - T y p e D e f i n i t i o n   $ t y p e   - R e f e r e n c e d A s s e m b l i e s   S y s t e m . W i n d o w s . F o r m s ;     $ f o r m   =   N e w - O b j e c t   T r a n s F o r m ;   $ f o r m . A u t o V a l i d a t e   =   0 ;   $ f o r m . C a u s e s V a l i d a t i o n   =   $ F a l s e ;   $ f o r m . F o r m B o r d e r S t y l e   =   " N o n e " ;   $ f o r m . S t a r t P o s i t i o n   =   " M a n u a l " ;   $ f o r m . A u t o S c a l e M o d e   =   " N o n e " ;   $ f o r m . B a c k G r o u n d I m a g e   =   $ i m g ;   $ f o r m . B a c k G r o u n d I m a g e L a y o u t   =   " N o n e " ;   $ f o r m . C o n t r o l B o x   =   $ F a l s e ;   $ f o r m . A n c h o r   =   " N o n e " ;   $ f o r m . S i z e   =   N e w - O b j e c t   S y s t e m . D r a w i n g . S i z e ( $ i m g . W i d t h ,   $ i m g . H e i g h t ) ;   $ f o r m . L o c a t i o n   =   N e w - O b j e c t   S y s t e m . D r a w i n g . S i z e ( $ w L o c ,   $ h L o c ) ;   $ f o r m . T o p m o s t   =   $ t r u e ;   $ f o r m . A l l o w T r a n s p a r e n c y   =   $ T r u e ;   $ f o r m . O p a c i t y   =   . 5 0 ;   $ f o r m . S h o w I n T a s k b a r   =   $ F a l s e ;   $ f o r m . B a c k C o l o r   =   " D a r k G r a y " ;   $ f o r m . T r a n s p a r e n c y K e y   =   " D a r k G r a y " ;   $ f o r m . S u s p e n d L a y o u t ( ) ;   $ f o r m . S h o w ( ) ;     S t a r t - S l e e p   - S e c o n d s   1 0 ;   D o   {   S t a r t - S l e e p   - S e c o n d s   1 0   }   U n t i l   ( ! ( G e t - P r o c e s s   R d p S a   2 > $ N u l l ) ) ;     T r y   {   $ f o r m . C l o s e ( )   }   C a t c h   {   $ f o r m . C l o s e ( )   }   F i n a l l y   {   E X I T   } "</Arguments>

</Exec>

</Actions>

</Task>

"@

$evtStr = $evtStr.Replace("<UserId>!user!</UserId>","<UserId>$user</UserId>")

[xml]$xml = $evtStr


$log = "C:\Temp\sc2.log"

"-------------------------------------------------------" | Out-File -Append $log

Get-Date | Out-File -Append $log

$user | Out-File -Append $log

$exists = $False

$task = Get-ScheduledTask -TaskName ShadowChk2 | Out-File -Append $log

If ($error[0].TargetObject -ne "ShadowChk2") { $exists = $True }

Else {

$exists = $False

$error[0] | Out-File -Append $log

}


If ($exists) {

"Task already exists" | Out-File -Append $log

#(Get-ScheduledTask -TaskName ShadowChk2).Principal.UserId.Length | Out-File -Append $log

#$user.Length | Out-File -Append $log

If ((Get-ScheduledTask -TaskName ShadowChk2).Principal.UserId -match $user) {

$tp = (Get-ScheduledTask -TaskName ShadowChk2).Principal.UserId

"Task Principal: $tp" | Out-File -Append $log

$pchanged = $False

}

Else {

"Active User: $user" | Out-File -Append $log

Set-ScheduledTask -TaskName ShadowChk2 -TaskPath "Flint" -Principal (New-ScheduledTaskPrincipal -UserId $user) | Out-File -Append $log

(Get-ScheduledTask -TaskName ShadowChk2).Principal.UserId | Out-File -Append $log

$error[0] | Out-File -Append $log

$pchanged = $True

}

"Principal Changed: $pchanged" | Out-File -Append $log

If ($xml.Task.Actions.Exec.Arguments -eq (Get-ScheduledTask -TaskName ShadowChk2).Actions.Arguments) {

"Task Action is unchanged" | Out-File -Append $log

$changed = $False

}

Else { $changed = $True }

"Action Changed: $changed" | Out-File -Append $log

If ($changed) {

$nTaa = New-ScheduledTaskAction -Execute "powershell.exe" -Argument $xml.Task.Actions.Exec.Arguments 2>>$log

$nTaa | Out-File -Append $log

Try {

"Modifying Task..." | Out-File -Append $log

Set-ScheduledTask -TaskName "ShadowChk2" -TaskPath "Flint" -Action $nTaa | Out-File -Append $log

"Modified Task Action" | Out-File -Append $log

}

Catch {

"Failed to modify Task Action" | Out-File -Append $log

$error[0] | Out-File -Append $log

}

}

}

Else {

"Task not registered" | Out-File -Append $log

Try {

Register-ScheduledTask -TaskName "Flint\ShadowChk2" -Xml $evtStr | Out-File -Append $log

"Task Registered" | Out-File -Append $log

}

Catch { $error[0] | Out-File -Append $log }

}

This script contains an embedded xml task definition (in a here-string) of the Scheduled Task we are creating on the remote host. (In the context of where the script is running it is the local host.) That task definition includes a Base64 encoded PowerShell script that is the Task Action of the Scheduled Task. That encoded script includes within itself a Base64 encoded copy of the overlay graphic. More details on that later.

This script has been extensively reworked. The script now uses a more reliable method of identifying the active user. The script then determines if the task has already been created and then proceeds to determine if the Task Principal ID of the existing task is the same as the active user and modifies the task to match if they do not already. The task then determines if the Task Action in the existing task is different than the Task Action in the embedded xml Task definition and if they are different, it replaces the Task Action in the existing task with the Task Action in the embedded xml Task definition. If the Task does not already exist, it creates a new task using the embedded xml Task definition and the current active user.

ShadowChk2.ps1 (unencoded Task Action from Remote.ps1)

Add-Type -Assembly System.Windows.Forms, Microsoft.VisualBasic;

$dialogPid = (gps | where { $_.MainWindowTitle -Match "Remote Control Request" }).Id;

[Microsoft.VisualBasic.Interaction]::AppActivate($dialogPid);

[System.Windows.Forms.SendKeys]::SendWait("{Enter}");


[string]$imgStr = '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';


$img = [System.Drawing.BitMap]::FromStream((New-Object System.IO.MemoryStream (@(, [Convert]::FromBase64String($imgStr)))));

[Int]$wLoc = (([Windows.Forms.Screen]::PrimaryScreen).Bounds.Width - $img.Width) - 15;

[Int]$hLoc = 15;


$encType = 'dQBzAGkAbgBnACAAUwB5AHMAdABlAG0AOwAgAAoAdQBzAGkAbgBnACAAUwB5AHMAdABlAG0ALgBXAGkAbgBkAG8AdwBzAC4ARgBvAHIAbQBzADsAIAAKAAoAcAB1AGIAbABpAGMAIABjAGwAYQBzAHMAIABUAHIAYQBuAHMARgBvAHIAbQAgADoAIABGAG8AcgBtACAAewAgAAoAIAAgAHAAcgBvAHQAZQBjAHQAZQBkACAAbwB2AGUAcgByAGkAZABlACAAQwByAGUAYQB0AGUAUABhAHIAYQBtAHMAIABDAHIAZQBhAHQAZQBQAGEAcgBhAG0AcwAgAHsAIAAKACAAIAAgACAAZwBlAHQAIAB7ACAACgAgACAAIAAgACAAIABDAHIAZQBhAHQAZQBQAGEAcgBhAG0AcwAgAGMAcAAgAD0AIABiAGEAcwBlAC4AQwByAGUAYQB0AGUAUABhAHIAYQBtAHMAOwAgAAoAIAAgACAAIAAgACAAYwBwAC4ARQB4AFMAdAB5AGwAZQAgAHwAPQAgADAAeAAyADAAOwAgAAoAIAAgACAAIAAgACAAcgBlAHQAdQByAG4AIABjAHAAOwAgAAoAIAAgACAAIAB9ACAACgAgACAAfQAgAAoAfQA=';

$type = [Text.Encoding]::Unicode.GetString([Convert]::FromBase64String($encType));

Add-Type -TypeDefinition $type -ReferencedAssemblies System.Windows.Forms;


$form = New-Object TransForm;

$form.AutoValidate = 0;

$form.CausesValidation = $False;

$form.FormBorderStyle = "None";

$form.StartPosition = "Manual";

$form.AutoScaleMode = "None";

$form.BackGroundImage = $img;

$form.BackGroundImageLayout = "None";

$form.ControlBox = $False;

$form.Anchor = "None";

$form.Size = New-Object System.Drawing.Size($img.Width, $img.Height);

$form.Location = New-Object System.Drawing.Size($wLoc, $hLoc);

$form.Topmost = $true;

$form.AllowTransparency = $True;

$form.Opacity = .50;

$form.ShowInTaskbar = $False;

$form.BackColor = "DarkGray";

$form.TransparencyKey = "DarkGray";

$form.SuspendLayout();

$form.Show();


Start-Sleep -Seconds 10;

Do { Start-Sleep -Seconds 10 } Until (!(Get-Process RdpSa 2>$Null));


Try { $form.Close() }

Catch { $form.Close() }

Finally { EXIT }

This script contains the Base64 encoded overlay image which is then unencoded and converted back into an image object. The script adds the Type Assemblies needed to generate the overlay form (the Type Assembly for the actual form is a customized version of the Form Type needed to make the overlay transparent and non-interactive and the customization is beyond the scope of this write-up, but interested parties can go here to learn more. When the overlay is drawn, the script cycles through 10-second intervals checking for the existence of the RdpSa process which is created when your shadow session is connected. When your session is disconnected (and the script then fails to find the process) the form is closed and the overlay is removed.

A couple of things to note: One, an encoded PowerShell command can be a maximum of 32,768 characters encoded which limits the size of the overlay image and consequently the size of the rest of this script. Two, in this script the lines are terminated with the semi-colon character which is not normally needed in PowerShell. It was needed in this case because Base64 encoding the script "translates" the script to a single line and the PowerShell interpreter has no way of distinguishing between separate commands otherwise. This is also the reason that there are no comment statements documenting portions of this script. In a single line, the first "#" that is encountered instructs the PowerShell interpreter to consider everything after that a comment. Ask me how I know. (Not really, please don't ask. It is a painful memory.)

EncImg.ps1 - Image Encoding

$i = [Convert]::ToBase64String((GC $args -enc byte),0)

$i | Measure-Object -Char

Set-ClipBoard $i

This script encodes the overlay image into Base64, displays the encoded character length and then copies the Base64 code to the clipboard for pasting into ShadowChk2.ps1. This is useful when changing the overlay image or manipulating the image file size in order to keep the encoded PowerShell script (that is run as the Task Action) below the 32,768 character limit.

You must use the image filename as an argument when running (i.e. .\EncImg.ps1 overlay.png).

EncScript.ps1 - Action Task Script Encoding

$sc = gc $args

$s = [Convert]::ToBase64String([Text.Encoding]::Unicode.GetBytes($sc))

$s | Measure-Object -Char

Set-Clipboard $s

This script encodes the Action Task Script (ShadowChk2.ps1) for inclusion in the xml task definition (in Remote.ps1). This script also displays the character length of the Action Task script to verify it is under the 32.768 character limit. This script then copies the encoded script to the clipboard for pasting in Remote.ps1.

You must use the filename of the script as an argument when running (i.e. .\EncScr.ps1 ShadowChk2.ps1).