Accéder au contenu principal

SharePoint : Comment Supprimer les anciennes versions des fichiers des WorkFlow SharePoint Designer 2007

 Il s’agit d’un cas assez spécifique, mais qui mérite de s’y attarder. En effet, lorsque l’on développe un Workflow sur SharePoint Designer 2007, l’outil a tendance à créer un très grand nombre de versions du fichier sur lequel on travaille (ASPX, XOML, …) :

image

Dans l’exemple ci-dessus, un des fichier du WorkFlow en question possède 740 versions du même fichier, qui sont devenus inutiles puisque le WF est en release depuis bien longtemps. En revanche, avec un poids de 11 kb chacun, le poids total de ce fichier dans SharePoint est de : 740 * 11 kb = env 8 MB, ce qui est confirmé par la page de “Space Allocation de la collection” :

image

Si on multiplie ce cas par le nombre de fichiers de ce WorkFlow, on arrive très vite à une taille non négligeable qui est désormais inutile.

La solution est donc bien évidemment de supprimer ces versions inutiles, mais ceci est impossible par le site SharePoint lui même, car en cliquant sur le lien “Versions” de la page ci-dessus (comme pour tous les autres Items), vous aurez une erreur :

image

Il faut donc passer par SharePoint Designer, avec le bouton droit de la sours et “Version History” :

image

Le fait est que cette étape est relativement longue par le volume de versions (750 existant dans ce cas). Quoi qu’il en soit, on peut alors choisir une des versions et cliquer sur “Delete” :

image

Cette étape peut mettre entre 30 secondes à 2 minutes pour se supprimer, donc multiplié par 740, ca commence a fait un moment pour une tâche qui n’est pas du tout intéressante.

Solution :

La solution est comme souvent de passer par le modèle objet et dans notre cas (besoin “oneshot”), un script PowerShell convient parfaitement.

Il faut donc simplement transmettre l’adresse du fichier et demander au moteur SharePoint de supprimer toutes les SPFile.Versions de celui-ci, via la commande “DeleteAll” :

Le script est volontairement ultra simple pour rester facilement compréhensible et adaptable à d’autre besoins.

function CleanVersionSPDWFFiles([string]$SiteURL, [string]$WebURL, [string]$WFFolderRelativeURL, [string]$WFFileName)
{
    [System.Reflection.Assembly]::LoadWithPartialName("Microsoft.SharePoint") > $null

    $site = new-object Microsoft.SharePoint.SPSite($SiteURL)
    $web = $site.openweb($WebURL)
    Write-Host " -------------------------------------- "
    Write-Host "Web URL", $web.URL

    [Microsoft.SharePoint.SPFolder]$wfFolder = $Web.GetFolder($WFFolderRelativeURL);
    [Microsoft.SharePoint.SPFile]$xomlFile = $wfFolder.Files[$WFFileName]

    Write-Host ""
    Write-Host "MyFile URL: ", $xomlFile.Url

    Write-Host "  Version Count Before Delete: ", $xomlFile.Versions.Count

    $xomlFile.Versions.DeleteAll()

    Write-Host "  Version Count After Delete: ", $xomlFile.Versions.Count

    Write-Host " -------------------------------------- "
    $web.Dispose()
    $site.Dispose()
}

CleanVersionSPDWFFiles “http://MyWebApplication/sites/MyCollection” "/sites/MyCollection/myWeb/” "Workflows/MyWorkFlow" "MyFileToCleanUp.aspx"

Afin d’avoir l’adresse du folder ou se trouve le fichier ASPX, il suffit d’éditer les propriétés du fichier ASPX depuis SharePoint Designer (ou via l'e mode Explorateur Windows).

Une fois exécuté, en quelques secondes d’exécution du script :

image

Le fichier ne possède plus que la version en cours

image

Cela vous permet donc de nettoyer un peu le site SharePoint en ne conservant que les fichiers utiles dans ce cas précis.

Romelard Fabrice [MVP]

Commentaires

Posts les plus consultés de ce blog

Série de vidéos sur le montage d'une serre horticole ACD

 Episode 1: Préparation du terrain Episode 2: Montage de la serre en elle même Episode 3: Finalisation avec le montage électrique alimentant la serre Bon visionnage Fab

Présentation des outils utiles pour l'entretien de ses haies vives

Afin de gérer les haies vives, il est nécessaire d'avoir recourt à un matériel adapté. Les solutions à batteries sont bien adaptées pour un usage personnel avec des dimensions raisonnables. Ainsi dans mon cas précis, j'utilise les outils suivants de la Gamme Ryobi 18V ONE+ électroportatif: Petit taille-haies simple mais efficace -  RYOBI OHT1855R Un modèle plus puissant qui fonctionne très bien -  RYOBI RY18HTX60A Pour les parties hautes de vos haies, voici un outil très utile -  RYOBI OPT1845 Enfin lorsque vous devez élaguer certains arbres ou certaines partie hautes de vos haies, ce dernier outil est très utile -  RYOBI OPP1820 Ces outils font parti maintenant de mon arsenal de base pour maintenir notre maison chaque saison de taille. Fab

Série de Videos sur Home Assistant intégrant la production Photovoltaïque

 Un certain nombre de vidéos sont en ligne pour intégrer sa production photovoltaïque dans Home Assistant en partant de la base. Installation de Home Assistant: On peut ensuite intégrer les composant des Micro-Onduleurs Enphase, mais aussi les batteries Enphase: Ou encore le composant de contrôle Ecojoko: Ce qui permet alors de faire des comparaisons entre les valeurs capturées: Des videos seront encore publiés dans les prochaines semaines sur différents aspects de cette solution. Fab