Bienvenue à Blogs CodeS-SourceS Identification | Inscription | Aide

Blog Technique de Romelard Fabrice

Les dernières Actualités de Romelard Fabrice (Alias fabrice69 ou F___) principalement autour des technologies Microsoft

Actualités

  • Toutes les actualités et informations sur les technologies Microsoft principalement autour de .NET et SQL Server

Archives

SharePoint : Script PowerShell pour ajouter une personne comme administrateur de toutes les collections de sites d’une ferme

Nous avons déjà présenter la gestion des sites inutilisés dans SharePoint :

Cette fonctionnalité permet d’alerter tous les administrateurs de chaque collection de sites inutilisée via Email. La question vient maintenant pour le gestionnaire de la ferme.

En effet, il est très courant que ces messages soient directement détectés comme SPAM par les outils de messagerie. Ainsi, les messages partent chaque jour pour rien dans ce contexte et le nettoyage des collections ne se fait pas pour autant.

La solution est donc d’ajouter le gestionnaire de la ferme comme administrateur de chaque collection de sites, ce qui est simple pour une ferme avec un petit nombre de collections, mais qui devient fastidieux pour une grosse ferme.

La méthode pour une collection donnée est d’aller dans :

  • “Sites Settings” > “Site collection administrators”

A cette fin, j’ai développé un script PowerShell permettant de faire l’ajout d’un utilisateur donné comme administrateur de toutes les collections de site d’une Web Application donnée :

function AddLoginAsSiteCollAdmin([string]$SiteCollectionURL, [string]$LoginNewAdmin)
{
    [System.Reflection.Assembly]::LoadWithPartialName("Microsoft.SharePoint") > $null
    $site = new-object Microsoft.SharePoint.SPSite($SiteCollectionURL)
    $web = $site.openweb()

    #Debugging - show SiteCollectionURL
    Write-Host "SiteCollectionURL", $SiteCollectionURL

    $siteCollUsers = $web.SiteUsers

    $siteCollUsers.Add($LoginNewAdmin, "", "", "")
    Write-Host "  ADMIN ADDED: ", $LoginNewAdmin
    $web.Update()
    $myuser = $siteCollUsers[$LoginNewAdmin]
    $myuser.IsSiteAdmin = $TRUE
    $myuser.Update()

    $web.Update()
    $web.Dispose()
    $site.Dispose()
}
function AddSiteCollAdminForAllCollections([string]$WebAppURL, [string]$LoginNewSiteAdmin)
{

    [System.Reflection.Assembly]::LoadWithPartialName("Microsoft.SharePoint") > $null

    $Thesite = new-object Microsoft.SharePoint.SPSite($WebAppURL)
    $oApp = $Thesite.WebApplication

    foreach ($Sites in $oApp.Sites)
    {
        $mySubweb = $Sites.RootWeb
        $TempRelativeURL = $mySubweb.Url
        AddLoginAsSiteCollAdmin $TempRelativeURL $LoginNewSiteAdmin
    }

}
function StartProcess()
{
    # Create the stopwatch
    [System.Diagnostics.Stopwatch] $sw;
    $sw = New-Object System.Diagnostics.StopWatch
    $sw.Start()
    cls
    $usertoreplaceinsiteadmin = "DOMAIN\LoginUser"
   
    AddSiteCollAdminForAllCollections "http://myWebApplication” $usertoreplaceinsiteadmin

    $sw.Stop()

    # Write the compact output to the screen
    write-host $usertoreplaceinsiteadmin, " Login add as Site Collection Admin in Time: ", $sw.Elapsed.ToString()   
}

StartProcess

Ce script est ajouté au projet CodePlex “SharePoint Management PowerShell scripts” dans le groupe de scripts :

Romelard Fabrice [MVP]

Ce post vous a plu ? Ajoutez le dans vos favoris pour ne pas perdre de temps à le retrouver le jour où vous en aurez besoin :
Posted: jeudi 6 octobre 2011 14:37 par ROMELARD Fabrice

Commentaires

Pas de commentaires

Les commentaires anonymes sont désactivés

Les 10 derniers blogs postés

- La feuille de route NON-OFFICIELLE d’Office 365 – De MS Ignite 2015 à MS Ignite 2016 par Le blog de Patrick [MVP Office 365] le 07-23-2015, 14:04

- 24 heures de conférence en ligne #Collab365 ! par Le blog de Patrick [MVP Office 365] le 07-21-2015, 18:12

- « Festival Clin d‘Œil » à Reims par Blog de Jérémy Jeanson le 07-03-2015, 14:43

- Que peut-on gagner à avoir des applications accessibles ? par Blog de Jérémy Jeanson le 07-03-2015, 14:26

- SharePoint 2007: Forcer le mode compatibilité depuis IIS par Blog Technique de Romelard Fabrice le 07-01-2015, 16:41

- [VBA] Manipuler un SQL Server sans risque par Blog de Jérémy Jeanson le 06-13-2015, 11:48

- Témoignage sur le rôle d’architecte logiciel par Blog de Jérémy Jeanson le 06-13-2015, 11:34

- NCrafts : Machine learning the F# way par Aurélien GALTIER le 06-04-2015, 11:22

- Configuration de Workflow Manager 1.0 pour SharePoint 2013 et ses soucis. par The Mit's Blog le 06-01-2015, 18:04

- TFS 2013 : Migration d’une ferme TFS 2005 vers 2013 sans Upgrade par Blog Technique de Romelard Fabrice le 06-01-2015, 11:22