PowerShell : scripts complets
Aller à la navigation
Aller à la recherche
Script de manipulation de fichiers
Dans ce script, le but est de venir en aide à l'utilisatrice "Micheline"; celle-ci a besoin de récupérer des fichiers et de vérifier sa connexion à Internet.
Il contient différents exemples intéressants de boucle, conditions, etc...
#Ce script est à placer dans le dossier "Travail".
###1 - Lister et afficher les fichier de ce répertoire
gci -r .
###2 - Il y'a trop de fichiers... Afficher seulement les .docx et .html
gci -r | Where-Object {$_.extension -eq ".docx" -or $_.Extension -eq ".html"}
###3 - Afficher Seulement les fichiers ultérieurs au 01/01/2019
#(Le résultat va dans le tableau nommé "fichiers")
$fichiers = gci -r | Where-Object {$_.extension -eq ".docx" -or $_.Extension -eq ".html" -and $_.LastWriteTime -gt "01/01/2019"}
###4 - On ajoute le fichier top secret de Micheline
#On le met d'abord dans la variable $secret
$secret = gci -r | Where-Object {$_.Name -eq "secret.txt"}
#On affiche les fichiers concernés par la sauvegarde
Write-Host "Les fichiers qui seront sauvegardés sont :"; $fichiers; $secret
###5 - Création de l'archive : je pars du fichier secret.txt, puis je mets mon archive à jour avec les autres fichiers
#Création de l'archive
Compress-Archive -LiteralPath $secret.FullName -CompressionLevel Fastest -DestinationPath .\ArchiveMicheline.zip
#Remplissage de l'archive et affichage d'un message d'avertissement
foreach ($file in $fichiers){
Compress-Archive -Path $file.fullname -Update -DestinationPath .\ArchiveMicheline.zip
}
Write-Host "Archive créée"
###6 - Vérifier le processus WINWORD, le tuer si il est présent
#Ce bloc teste si WINWORD est présent et le tue si c'est le cas
#L'argument -ErrorAction sert à ne pas afficher les messages d'erreur (Nous affichons le résultat nous-même)
if(Get-Process -name WINWORD -ErrorAction 'SilentlyContinue'){
Stop-Process -name WINWORD; Write-Host "WINWORD stoppé"}
else{
Write-Host "WINWORD n'est pas en cours d'exécution"}
###7 - Mettre une liste de sites dans un tableau et les tester un par un
#Liste de mes sites
$sites = @("google.com", "portal.office.com", "microsoft.com", "pcastuces.com", "aidermicheline.com")
#Ce bloc teste un à un les sites et affiche le résultat
foreach ($site in $sites){
if (Test-Connection -ComputerName $site -ErrorAction 'SilentlyContinue'){
Write-Host $site, "OK"}
else{
Write-Host $site, "KO"}
}
Script de création d'OU et d'utilisateurs
Ce script a pour but de créer des OUs et des utilisateurs sur un contrôleur de domaine. Les OUs sont d'abord créés, puis les utilisateurs, tous destinés à l'OU "ENG". Ce script est destiné au controleur de domaine du domaine "lpasr.loc". Il est plutôt efficace :)
Les OUs et utilisateurs apparaissent ensuite dans le centre de contrôle Active Directory :
###TP Création d'annuaire
#Pour ce TP je pars d'un serveur Windows Server 2012 R2 en version d'essai
#Celui-ci est déjà Domain Controller du domaine lpasr.loc
###0 - Import du module
Import-Module ActiveDirectory
###1 - Création des OU
$OUsRacine = @("FRA", "ALL", "ENG", "ESP") #OUs de premier niveau
$OUsENG = @("Compta", "DSI", "Secu", "DRH") #OUs situées dans ENG
#Création des OU de premier niveau
foreach ($ou in $OUsRacine){
New-ADOrganizationalUnit -name $ou -Path "DC=lpasr, DC=loc" -ProtectedFromAccidentalDeletion $true
}
#Création des OU contenues dans ENG
foreach ($SousOu in $OUsENG){
New-ADOrganizationalUnit -name $SousOu -Path "OU=ENG, DC=lpasr, DC=loc" -ProtectedFromAccidentalDeletion $true
}
###2 - Création des utilisateurs
#Mon tableau d'utilisateurs
$NouveauxUsers = @("sbozor", "mcolak", "ndesserrey", "idiallo", "lelkamel", "rgermain", "rgueye", "flarcher", "plawson", "pmandrou", "imohamed", "jnanthaphak", "aquach", "ktandavane", "atiroual", "eyamani")
#Création du mot de passe :
#Tous les utilisateurs commencent avec un mot de passe temporaire identique, qu'ils devront changer à leur première connexion
$pass = "MotDePasseTemporaire!"
$passSec = ConvertTo-SecureString $pass -AsPlainText -Force
#Création des utilisateurs
foreach ($nom in $NouveauxUsers){
New-ADUser -name $nom -UserPrincipalName "$nom@lpasr.loc" -Path "OU=ENG, DC=lpasr, DC=loc" -AccountPassword $passSec -Enabled $true #Chaque utilisateur est créé dans "ENG", avec un mdp temporaire, et un login nom@lpasr.loc
Get-ADUser -Filter {Name -eq $nom} -SearchBase "OU=ENG, DC=lpasr, DC=loc" | Set-ADUser -ChangePasswordAtLogon $true | Set-ADObject -ProtectedFromAccidentalDeletion $true #L'utilisateur doit changer son mot de passe, et on protège son compte de la suppression accidentelle
Write-Host "L'utilisateur $nom est créé dans l'OU ENG" #Message d'avertissement
}