Principaux points à retenir
- Les stratégies d’expiration des mots de passe sont essentielles pour renforcer la sécurité informatique et promouvoir une bonne cyberhygiène.
- Le script PowerShell fourni ajuste efficacement l’âge maximum du mot de passe pour les ordinateurs de domaine ou de non-domaine.
- Le script nécessite la version 5.1 de PowerShell et la fonction RSAT pour Active Directory.
- En fonction des paramètres fournis, le script modifie la stratégie de mot de passe du domaine par défaut d’Active Directory ou la stratégie de la machine locale.
- Pour les tâches informatiques, les scripts PowerShell offrent une évolutivité et une efficacité supérieures à celles des outils traditionnels basés sur l’interface graphique.
- N’oubliez jamais de sauvegarder les configurations, d’informer les utilisateurs des changements et de vérifier les effets des modifications de la stratégie.
- Il est essentiel de trouver un équilibre dans la fréquence des changements de mot de passe pour éviter les pièges potentiels en matière de sécurité.
- NinjaOne, avec des scripts comme ceux-ci, aide les professionnels de l’informatique à gérer des environnements numériques complexes de manière intuitive.
Avec l’augmentation constante des cybermenaces, la gestion efficace des stratégies de mots de passe n’a jamais été aussi importante dans le monde de l’informatique. Une bonne gestion des mots de passe permet non seulement d’assurer une défense performante contre les violations potentielles, mais aussi de promouvoir une bonne cyberhygiène auprès des utilisateurs. L’une de ces règles essentielles est la configuration de l’expiration des mots de passe. Aujourd’hui, nous allons présenter un script PowerShell qui vous permet de modifier l’âge maximum du mot de passe, ce qui dicte le délai d’expiration pour les ordinateurs de domaine ou de non-domaine.
Contexte
Le script fourni vise à rationaliser le processus de modification des stratégies d’expiration des mots de passe. Au fur et à mesure que les environnements informatiques se développent et évoluent, le besoin de méthodes centralisées, efficaces et évolutives pour gérer les identifiants utilisateurs devient primordial. Les professionnels de l’informatique et les fournisseurs de services gérés (MSP) se retrouvent souvent à jongler avec des systèmes, des stratégies et des exigences utilisateurs divers. Grâce à PowerShell, un puissant cadre d’automatisation des tâches, il devient possible d’ajuster quelque chose d’aussi vital que l’expiration d’un mot de passe sur plusieurs systèmes.
Le script PowerShell
#Requires -Version 5.1 <# .SYNOPSIS Changes the Maximum Password Age(Expiry) for the domain or a non-domain computer. .DESCRIPTION Changes the Maximum Password Age(Expiry) for the domain or a non-domain computer. .EXAMPLE -MaxPasswordAge 90 Set MaximumPasswordAge on the computer this script runs on to 90 days. .EXAMPLE No param needed Disables MaximumPasswordAge on the computer this script runs on. .EXAMPLE -MaxPasswordAge 90 -Domain "test.consto.com" Enables MaximumPasswordAge in Active Directory for the Default Domain Password Policy to 90 days. .EXAMPLE PS C:> .Set-Password-Complexity.ps1 -MaxPasswordAge 90 -Domain "test.consto.com" Enables MaximumPasswordAge in Active Directory for the Default Domain Password Policy to 90 days. .OUTPUTS None .NOTES Minimum OS Architecture Supported: Windows 10, Windows Server 2016 The RSAT feature for Active Directory needs to be installed on the computer this runs on. Release Notes: Initial Release By using this script, you indicate your acceptance of the following legal terms as well as our Terms of Use at https://www.ninjaone.com/terms-of-use. Ownership Rights: NinjaOne owns and will continue to own all right, title, and interest in and to the script (including the copyright). NinjaOne is giving you a limited license to use the script in accordance with these legal terms. Use Limitation: You may only use the script for your legitimate personal or internal business purposes, and you may not share the script with another party. Republication Prohibition: Under no circumstances are you permitted to re-publish the script in any script library or website belonging to or under the control of any other software provider. Warranty Disclaimer: The script is provided “as is” and “as available”, without warranty of any kind. NinjaOne makes no promise or guarantee that the script will be free from defects or that it will meet your specific needs or expectations. Assumption of Risk: Your use of the script is at your own risk. You acknowledge that there are certain inherent risks in using the script, and you understand and assume each of those risks. Waiver and Release: You will not hold NinjaOne responsible for any adverse or unintended consequences resulting from your use of the script, and you waive any legal or equitable rights or remedies you may have against NinjaOne relating to your use of the script. EULA: If you are a NinjaOne customer, your use of the script is subject to the End User License Agreement applicable to you (EULA). .COMPONENT ManageUsers #> [CmdletBinding()] param ( [Parameter(Mandatory = $false)] [int] $MaxPasswordAge, [Parameter(Mandatory = $false)] [String] $Domain ) function Test-IsElevated { $id = [System.Security.Principal.WindowsIdentity]::GetCurrent() $p = New-Object System.Security.Principal.WindowsPrincipal($id) if ($p.IsInRole([System.Security.Principal.WindowsBuiltInRole]::Administrator)) { Write-Output $true } else { Write-Output $false } } function Get-LocalPasswordPolicy { param () $Result = [PSCustomObject]@{ MinimumLength = 0 MaximumAge = 0 MinimumAge = 0 } $(net.exe accounts) -split "n" | ForEach-Object { $Line = $_ -split ":" if ($_ -like "Minimum password length*") { $Result.MinimumLength = "$($Line[1])".Trim(' ') } if ($_ -like "Maximum password age (days)*") { $Result.MaximumAge = "$($Line[1])".Trim(' ') } if ($_ -like "Minimum password age (days)*") { $Result.MinimumAge = "$($Line[1])".Trim(' ') } } $Result } if (-not (Test-IsElevated)) { Write-Error -Message "Access Denied. Please run with Administrator privileges." exit 1 } $NetExeError = $false $MaxAge = "" if ($PSBoundParameters.ContainsKey("MaxPasswordAge")) { $MaxAge = $MaxPasswordAge } else { # If $MaxPasswordAge isn't used or is set to 0. $MaxAge = 0 } if ($Domain -and [string]::IsNullOrEmpty($Domain) -and [string]::IsNullOrWhiteSpace($Domain)) { # Active Directory # Check if the ActiveDirectory module is installed if ((Get-Module -Name ActiveDirectory -ListAvailable -ErrorAction SilentlyContinue)) { try { # Try to import the ActiveDirectory module Import-Module -Name ActiveDirectory } catch { Write-Error -Message "Ninja Agent could not access AD, either RSAT was not installed or that the agent does not have permissions to add and remove users from groups." exit 5 # Access Denied exit code } # Set MaxPasswordAge to what was passed into $MaxPasswordAge Set-ADDefaultDomainPasswordPolicy -Identity $Domain -MaxPasswordAge $([TimeSpan]"$MaxPasswordAge.00:00:00") -Confirm:$false # Sleep a little while, just in case Get-ADDefaultDomainPasswordPolicy connect to a different AD server and replication is slow Start-Sleep -Seconds 60 # Check if the MaxPasswordAge policy was applied correctly $Results = Get-ADDefaultDomainPasswordPolicy -Identity $Domain # Check that the policy matches what was requested if ($Results -and $Results.MaxPasswordAge.Days -eq $MaxPasswordAge) { exit 0 } else { # The policy was not set for some reason exit 1 } } else { Write-Error -Message "Ninja Agent could not access AD, RSAT was not installed." Write-Output "RSAT install documentation: https://docs.microsoft.com/en-us/troubleshoot/windows-server/system-management-components/remote-server-administration-tools" Write-Output "Windows Server install command: Install-WindowsFeature RSAT" Write-Output "Windows 10/11 install command: Add-WindowsCapability -Name RSAT* -Online" exit 5 # Access Denied exit code } } else { # Get Current localhost password policy settings $CurrentSettings = Get-LocalPasswordPolicy Write-Host "Changing Maximum Password Age from $($CurrentSettings.MaximumAge) to $MaxAge" if ($MaxAge -ge 1 -and $MaxAge -is [int]) { net.exe accounts /maxpwage:$MaxAge } else { net.exe accounts /maxpwage:unlimited } # Get New localhost password policy settings and check if anything changed $NewSettings = Get-LocalPasswordPolicy if ($MaxAge -notlike $(if ($NewSettings.MaximumAge -like "unlimited") { 0 }else { $NewSettings.MaximumAge })) { $NetExeError = $true Write-Host "Maximum Age was not set correctly." } if ($NetExeError) { exit 1 } }
Accédez à plus de 700 scripts dans le Dojo NinjaOne
Description détaillée
Examinons dans le détail le fonctionnement du script :
- Prérequis : Le script nécessite la version 5.1 de PowerShell et la fonctionnalité RSAT (Remote Server Administration Tools) pour Active Directory.
- Paramètres : Deux paramètres principaux peuvent être transmis : MaxPasswordAge, qui définit le délai maximum (en jours) avant l’expiration du mot de passe, et Domain, qui spécifie le domaine pour lequel la stratégie de mot de passe doit être ajustée.
- Fonctions : Le script comprend des fonctions d’aide comme Test-IsElevated pour vérifier si le script est exécuté avec des droits d’administrateur et Get-LocalPasswordPolicy pour récupérer la stratégie de mot de passe actuelle de l’ordinateur local.
- Flux d’exécution : Selon si le domaine est fourni ou non, soit le script ajuste la stratégie de mot de passe du domaine par défaut d’Active Directory, soit il ajuste la stratégie de mot de passe de l’ordinateur local.
Cas d’utilisation potentiels
Étude de cas : Imaginez une entreprise MSP qui supervise les opérations informatiques d’une entreprise dont les effectifs augmentent. Les nouvelles réglementations en matière de cybersécurité exigent que tous les mots de passe des employés expirent et soient renouvelés tous les 60 jours. En utilisant le script fourni, le fournisseur de services gérés peut efficacement ajuster l’âge maximum du mot de passe pour tous les ordinateurs du domaine, garantissant ainsi la conformité sans avoir à gérer chaque système manuellement.
Comparaisons
Traditionnellement, l’ajustement des stratégies de mot de passe, en particulier dans les grands réseaux, nécessitait de passer par des outils à interface graphique tels que la console de gestion des stratégies de groupe. Bien qu’efficaces, ces méthodes peuvent ne pas l’être autant à grande échelle. Grâce à l’approche PowerShell, les professionnels de l’informatique peuvent appliquer rapidement des modifications à plusieurs systèmes, ce qui garantit la cohérence et permet de gagner du temps.
FAQ
- Puis-je utiliser ce script sur n’importe quel ordinateur Windows ?
Le script est conçu pour Windows 10, Windows Server 2016 et les versions ultérieures.
- Que se passe-t-il si je n’indique pas la valeur MaxPasswordAge ?
Le délai d’expiration du mot de passe sera défini sur « illimité », ce qui revient à désactiver l’expiration.
Implications
La définition d’une stratégie d’expiration des mots de passe est une arme à double tranchant. Si des changements fréquents peuvent renforcer la sécurité en limitant la durée de validité d’un mot de passe compromis, ils peuvent aussi encourager les utilisateurs à opter pour des mots de passe plus simples ou à les noter, ce qui réduit la sécurité globale. Ce script aide les équipes informatiques à trouver le bon équilibre et à appliquer la stratégie de manière cohérente à l’ensemble de leur infrastructure.
Recommandations
- Veillez à toujours sauvegarder les configurations actuelles avant d’apporter des modifications.
- Il est conseillé d’informer les utilisateurs des changements imminents dans les stratégies de mots de passe.
- Contrôlez et auditez les effets des changements de stratégies en matière de mots de passe pour vous assurer qu’il n’y a pas de conséquences imprévues.
Conclusion
Face à l’évolution des cybermenaces, des outils comme NinjaOne offrent des solutions inestimables aux professionnels de l’informatique, leur permettant de garder une longueur d’avance sur les défis potentiels. En intégrant des scripts comme celui-ci, NinjaOne offre une plateforme complète qui peut répondre à divers besoins de gestion informatique, des ajustements de la stratégie de mot de passe aux configurations de systèmes plus complexes. Alors que le paysage numérique continue de se transformer, il est essentiel de disposer d’outils permettant aux équipes informatiques d’assurer l’efficacité et la sécurité des opérations.