> For the complete documentation index, see [llms.txt](https://docs.devolutions.net/llms.txt). Markdown versions of documentation pages are available by appending `.md` to page URLs; this page is available as [Markdown](https://docs.devolutions.net/rdm/fr/knowledge-base/how-to-articles/convert-virtual-folders-in-remote-desktop-manager.md).

# Convertir des dossiers virtuels dans Remote Desktop Manager

### Méthode manuelle

La suppression des dossiers virtuels peut être effectuée en modifiant manuellement chaque dossier virtuel, en enregistrant les modifications et en les convertissant en dossiers réels. Cependant, ce processus devient fastidieux lorsqu'il s'agit d'un grand nombre de dossiers virtuels, car il nécessite de convertir chacun d'eux manuellement.

### Méthode PowerShell

{% hint style="danger" %}
Avant de procéder avec la méthode PowerShell, veuillez prendre note de ce qui suit :

* Cette méthode supprime tous les dossiers virtuels dans les coffres de l'espace de travail.
* Supprimez les dossiers en double avant d'exécuter le script PowerShell à partir de la nouvelle entrée.
  {% endhint %}

1. Lancez Remote Desktop Manager en tant qu'administrateur en faisant un clic droit sur l'application et en choisissant ***Exécuter en tant qu'administrateur***.
2. Sélectionnez les coffres de l'espace de travail à partir desquels vous souhaitez convertir tous les dossiers virtuels dans le ***Volet de navigation***.
3. Ajoutez une nouvelle entrée.
4. Accédez à ***Session – PowerShell*** pour créer une entrée de session PowerShell.

   <figure><img src="https://cdnweb.devolutions.net/docs/docs_en_kb_KB6014.png" alt=""><figcaption></figcaption></figure>
5. Nommez l'entrée et choisissez le dossier dans lequel vous souhaitez la créer.
6. Définissez l'entrée sur ***Script intégré***.

   <figure><img src="https://cdnweb.devolutions.net/docs/docs_en_kb_KB6020.png" alt=""><figcaption></figcaption></figure>
7. Cliquez sur ***Modifier le script intégré***.

   <figure><img src="https://cdnweb.devolutions.net/docs/docs_en_kb_KB6019.png" alt=""><figcaption></figcaption></figure>
8. Ajoutez le script suivant :

   ```powershell
   # Check if Remote Desktop Manager PS module is installed

   if (-not (Get-Module Devolutions.PowerShell -ListAvailable)) {

      Install-Module Devolutions.PowerShell -Scope CurrentUser

   }

   $beforeAllGroups = Get-Date

   $vaults = Get-RDMVault

   foreach ($vault in $vaults) {

      Set-RDMCurrentRepository -Repository $vault

      $vaultname = $vault.Name

      Write-Host "Current Vault is $vaultname"

      # Get all entries' folder path

      $sessions = Get-RDMSession

      $allGroups = @()

      foreach ($session in $sessions) {

          # Split the group folder location for each shortcut

          $tempFolder = $session.Group

          $shortcuts = $tempFolder.split(';')

          foreach ($shortcut in $shortcuts) {

              $folder = $shortcut

              if ($folder) {

                  $levels = $folder.split('\')

                  $nblevels = 1

                  $Groupfolder = ""

                  foreach ($level in $levels) {

                     $name = $level

                      if ($nblevels -eq 1) {

                          $Groupfolder = $name

                      } else {

                          $Groupfolder = "$Groupfolder\$name"

                      }

                      $item = New-Object PSObject -Property @{

                          Name = $name

                          Group = $Groupfolder

                          Levels = $nbLevels

                      }

                      $allGroups += $item

                      $nblevels++

                  }

              }

          }

      }

      # Get all folders that exist in the database

      $groups = Get-RDMSession | Where-Object { $_.ConnectionType -eq "Group" }

      $realGroups = @()

      foreach ($group in $groups) {

          # Split the group folder location for each shortcut

          $tempFolder = $group.Group

          $shortcuts = $tempFolder.split(';')

          foreach ($shortcut in $shortcuts) {

              $folder = $group.Group

              if ($folder) {

                  $levels = $folder.split('\')

                  $nbLevels = $levels.Count

                  $name = $group.Name

                  $item = New-Object PSObject -Property @{

                      Name = $name

                      Group = $folder

                      Levels = $nbLevels

                  }

                  $realGroups += $item

              }

          }

      }

      # Sort arrays and extract virtual folders

      $realGroups = $realGroups | Sort-Object -Property Levels, Name, Group -Unique

      $allGroups = $allGroups | Sort-Object -Property Levels, Name, Group -Unique

      $results = $allGroups | Where-Object { $realGroups.Group -notcontains $_.Group }

      $results = $results | Sort-Object -Property Levels, Name, Group -Unique

      # Convert virtual folders in the database

      foreach ($group in $results) {

          $name = $group.Name

          $folder = $group.Group

          try {

              $session = New-RDMSession -Name $name -Group $folder -Type Group -SetSession -ErrorAction Stop

              Update-RDMUI

          } catch {

              # Split the parent folder

              $tempFolder = $folder.Replace("\$name", '')

              $parents = $tempFolder.split('\')

              foreach ($parent in $parents) {

                  try {

                      $exist = Get-RDMSession -Name $parent -ErrorAction Stop

                  } catch {

                      $name = $parent

                      $index = $parents.IndexOf($parent)

                      $folder = ""

                      for ($item = 0; $item -le $index; $item++) {

                          if ($item -gt 0) {

                              $folder += "\"

                          }

                          $folder += $parents[$item]

                      }

                      $session = New-RDMSession -Name $name -Group $folder -Type Group -SetSession

                      Update-RDMUI

                      Write-Host "Virtual folder $name has been successfully created in the database!"

                  }

              }

              $name = $group.Name

              $folder = $group.Group

              $session = New-RDMSession -Name $name -Group $folder -Type Group -SetSession

              Update-RDMUI

          }

          Write-Host "Virtual folder $name has been successfully created in the database!"

      }

   }

   $afterCreatingGroups = Get-Date

   Write-Host "Time taken to convert virtual folders: $(($afterCreatingGroups).Subtract($beforeAllGroups).Seconds) second(s)"
   ```
9. Cliquez sur ***OK*** pour appliquer le script.
10. Cliquez sur ***OK*** pour enregistrer les paramètres de l'entrée et fermer la fenêtre.
11. Cliquez sur ***Ouvrir la session*** pour exécuter l'entrée.

    <figure><img src="https://cdnweb.devolutions.net/docs/docs_en_kb_KB6018.png" alt=""><figcaption></figcaption></figure>

Le script convertira maintenant tous les dossiers virtuels dans les coffres de l'espace de travail.


---

# Agent Instructions
This documentation is published with GitBook. GitBook is the documentation platform designed so that both humans and AI agents can read, navigate, and reason over technical content effectively. Learn more at gitbook.com.

## Querying This Documentation
If you need additional information that is not directly available in this page, you can query the documentation dynamically by asking a question.

Perform an HTTP GET request on the current page URL with the `ask` query parameter:

```
GET https://docs.devolutions.net/rdm/fr/knowledge-base/how-to-articles/convert-virtual-folders-in-remote-desktop-manager.md?ask=<question>
```

The question should be specific, self-contained, and written in natural language.
The response will contain a direct answer to the question and relevant excerpts and sources from the documentation.

Use this mechanism when the answer is not explicitly present in the current page, you need clarification or additional context, or you want to retrieve related documentation sections.
