Files
LAPS/laps.ps1
2025-07-08 11:13:32 +02:00

258 lines
15 KiB
PowerShell

Add-Type -AssemblyName System.Windows.Forms
Add-Type -AssemblyName System.Drawing
Add-Type -AssemblyName PresentationCore
$form = New-Object System.Windows.Forms.Form
$form.Text = 'LAPS'
$form.Size = New-Object System.Drawing.Size(380,180)
$form.StartPosition = 'CenterScreen'
$form.MaximizeBox = $false
$form.MinimizeBox = $false
$form.FormBorderStyle = 'Fixed3D'
$iconBase64 = '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'
$bitmap = New-Object System.Windows.Media.Imaging.BitmapImage
$bitmap.BeginInit()
$bitmap.StreamSource = [System.IO.MemoryStream][System.Convert]::FromBase64String($iconBase64)
$bitmap.EndInit()
$bitmap.Freeze()
$image = [System.Drawing.Bitmap][System.Drawing.Image]::FromStream($bitmap.StreamSource)
$icon = [System.Drawing.Icon]::FromHandle($image.GetHicon())
$form.Icon = $icon
$usernameLabel = New-Object System.Windows.Forms.Label
$usernameLabel.Location = New-Object System.Drawing.Point(30,20)
$usernameLabel.Text = 'Identifiant :'
$usernameTextbox = New-Object System.Windows.Forms.TextBox
$usernameTextbox.Location = New-Object System.Drawing.Point(120,20)
$usernameTextbox.Size = New-Object System.Drawing.Size(200,20)
#$usernameTextbox.PlaceholderText = 'admin-uid'
$passwordLabel = New-Object System.Windows.Forms.Label
$passwordLabel.Location = New-Object System.Drawing.Point(30,50)
$passwordLabel.Text = 'Mot de passe :'
$passwordTextbox = New-Object System.Windows.Forms.TextBox
$passwordTextbox.Location = New-Object System.Drawing.Point(120,50)
$passwordTextbox.Size = New-Object System.Drawing.Size(200,20)
$passwordTextbox.PasswordChar = '*'
$errorLabel = New-Object System.Windows.Forms.Label
$errorLabel.Location = New-Object System.Drawing.Point(30,100)
$errorLabel.Size = New-Object System.Drawing.Size(200,20)
$errorLabel.Visible = $false
$ValidateCreds = {
try{
if($usernameTextbox.Text -eq ''){
$errorLabel.Text = 'Identifiant manquant'
$errorLabel.ForeColor = 'DarkRed'
$errorLabel.Visible = $true
return
}
if($passwordTextbox.text -eq ''){
$errorLabel.Text = 'Mot de passe manquant'
$errorLabel.ForeColor = 'DarkRed'
$errorLabel.Visible = $true
return
}
$password = ConvertTo-SecureString $passwordTextbox.text -AsPlainText -Force
$creds = New-Object System.Management.Automation.PsCredential "ac-bureautique\$($usernameTextbox.Text)", $password
Get-LapsADPassword -Identity $env:COMPUTERNAME -Credential $creds
$form.DialogResult = 'OK'
$form.Close()
}catch{
$exitCode = $_.exception.errorcode
$errorLabel.Visible = $true
$errorLabel.ForeColor = 'DarkRed'
if($exitCode -eq 49){
$errorLabel.Text = 'Mauvais identifiant/mot de passe'
}else{
$errorLabel.Text = $_
}
}
}
$generateLapsButton = New-Object System.Windows.Forms.Button
$generateLapsButton.Text = 'OK'
$generateLapsButton.Location = New-Object System.Drawing.Point(240,100)
$generateLapsButton.Add_Click($ValidateCreds)
$form.AcceptButton = $generateLapsButton
$form.Controls.add($usernameTextbox)
$form.Controls.add($passwordTextbox)
$form.Controls.add($passwordLabel)
$form.Controls.add($errorLabel)
$form.Controls.add($usernameLabel)
$form.Controls.add($generateLapsButton)
$result = $form.ShowDialog()
#$result = 'OK'
if($result -ne 'OK'){
exit 0
}
$password = ConvertTo-SecureString $passwordTextbox.text -AsPlainText -Force
$creds = New-Object System.Management.Automation.PsCredential "ac-bureautique\$($usernameTextbox.Text)", $password
$form.dispose()
$machineForm = New-Object System.Windows.Forms.Form
$machineForm.Text = 'LAPS'
$machineForm.Size = New-Object System.Drawing.Size(470,270)
$machineForm.StartPosition = 'CenterScreen'
$machineForm.MaximizeBox = $false
$machineForm.MinimizeBox = $false
$machineForm.FormBorderStyle = 'Fixed3D'
$machineForm.Icon = $icon
# computer fields
# label
$computerNameLabel = New-Object System.Windows.Forms.Label
$computerNameLabel.Location = New-Object System.Drawing.Point(30,20)
$computerNameLabel.Size = New-Object System.Drawing.Size(120,20)
$computerNameLabel.Text = "Nom de l'ordinateur"
# textbox
$computerNameTextbox = New-Object System.Windows.Forms.TextBox
$computerNameTextbox.Location = New-Object System.Drawing.Point(150,20)
$computerNameTextbox.Size = New-Object System.Drawing.Size(200,20)
# calendar
# label
$calendarLabel = New-Object System.Windows.Forms.Label
$calendarLabel.Location = New-Object System.Drawing.Point(30,70)
$calendarLabel.Text = "Date d'expiration"
$calendarLabel.Visible = $false
# calendar
$calendar = New-Object System.Windows.Forms.DateTimePicker
$calendar.Format = [windows.forms.datetimepickerFormat]::custom
$calendar.CustomFormat = "dd/MM/yyyy HH:mm:ss"
#$calendar.MinDate = [DateTime]::Now
$calendar.Location = New-Object System.Drawing.Point(150,70)
$calendar.Visible = $false
# laps fields
# label
$lapsPasswordLabel = New-Object System.Windows.Forms.Label
$lapsPasswordlabel.Location = New-Object System.Drawing.Point(30,120)
$lapsPasswordlabel.Size = New-Object System.Drawing.Size(120,20)
$lapsPasswordlabel.Text = "Mot de passe LAPS"
$lapsPasswordlabel.Visible = $false
# textbox
$lapsPasswordTextbox = New-Object System.Windows.Forms.TextBox
$lapsPasswordTextbox.Location = New-Object System.Drawing.Point(150,120)
$lapsPasswordTextbox.Size = New-Object System.Drawing.Size(200,20)
$lapsPasswordTextbox.Font = New-Object System.Drawing.Font('Consolas',10)
$lapsPasswordTextbox.ReadOnly = $true
$lapsPasswordTextbox.Visible = $false
$copyPassword = {
if($lapsPasswordTextbox.text -ne ''){
$lapsPasswordTextbox.text | Set-Clipboard
}
}
$copyButton = New-Object System.Windows.Forms.Button
$copyButton.Location = New-Object System.Drawing.Point(360,120)
$copyButton.Text = 'Copier'
$copyButton.Add_Click($copyPassword)
$copyButton.visible = $false
$copyButton.Enabled = $false
$errorLabel = New-Object System.Windows.Forms.Label
$errorLabel.Location = New-Object System.Drawing.Point(30,170)
$errorLabel.Size = New-Object System.Drawing.Size(240,60)
$errorLabel.Visible = $false
$generateLaps = {
$identity = $computerNameTextbox.Text
$effective = $calendar.Value
try{
$var = Set-LapsADPasswordExpirationTime -Identity $identity -Credential $creds -WhenEffective $effective -ErrorAction Stop
$laps = Get-LapsADPassword -Identity $identity -DecryptionCredential $creds -Credential $creds -AsPlainText -ErrorAction Stop
$lapsPasswordTextbox.text = $laps.Password
$errorLabel.Visible = $false
}catch{
switch($_){
"Cannot bind argument to parameter 'Identity' because it is an empty string." { $errorLabel.text = "Nom d'ordinateur manquant" }
"Failed to find the '$($identity)' computer in AD" { $errorLabel.text = "Impossible de trouver l'ordinateur $($identity) dans l'AD" }
default { $errorLabel.text = "$_" }
}
$lapsPasswordTextbox.text = ''
$errorLabel.ForeColor = 'DarkRed'
$errorLabel.Visible = $true
}
}
# label
# generate button
$generateLapsButton = New-Object System.Windows.Forms.Button
$generateLapsButton.Add_Click($generateLaps)
$generateLapsButton.Location = New-Object System.Drawing.Point(280,170)
$generateLapsButton.Size = New-Object System.Drawing.Size(80,20)
$generateLapsButton.text = 'Mettre à jour'
$generateLapsButton.Visible = $false
$showLaps = {
$identity = $computerNameTextbox.Text
$copyButton.Visible = $false
$lapsPasswordTextbox.Visible = $false
$lapsPasswordLabel.Visible = $false
$calendarLabel.Visible = $false
$calendar.Visible = $false
$generateLapsButton.Visible = $false
$calendar.MinDate = [DateTime]'01/01/1970'
try{
$laps = Get-LapsADPassword -Identity $identity -DecryptionCredential $creds -Credential $creds -AsPlainText -ErrorAction Stop
$lapsPasswordTextbox.text = $laps.Password
if($laps.Password -eq ''){
$copyButton.Enabled = $false
}else{
$copyButton.Enabled = $true
}
$errorLabel.Visible = $false
$copyButton.Visible = $true
$calendar.Value = [DateTime]$laps.ExpirationTimestamp
$calendar.MinDate = [DateTime]::Now
$lapsPasswordTextbox.Visible = $true
$lapsPasswordLabel.Visible = $true
$calendarLabel.Visible = $true
$calendar.Visible = $true
$generateLapsButton.Visible = $true
}catch{
switch($_){
"Cannot bind argument to parameter 'Identity' because it is an empty string." { $errorLabel.text = "Nom d'ordinateur manquant" }
"Failed to find the '$($identity)' computer in AD" { $errorLabel.text = "Impossible de trouver l'ordinateur $($identity) dans l'AD" }
default { $errorLabel.text = "$_" }
}
$lapsPasswordTextbox.text = ''
$errorLabel.ForeColor = 'DarkRed'
$errorLabel.Visible = $true
}
}
$showLapsButton = New-Object System.Windows.Forms.Button
$showLapsButton.Location = New-Object System.Drawing.Point(360,18)
$showLapsButton.Text = 'Chercher'
$showLapsButton.Add_Click($showLaps)
$machineForm.Controls.add($computerNameLabel)
$machineForm.Controls.add($computerNameTextbox)
$machineForm.Controls.add($showLapsButton)
$machineForm.Controls.add($calendarLabel)
$machineForm.Controls.add($calendar)
$machineForm.Controls.add($lapsPasswordLabel)
$machineForm.Controls.add($lapsPasswordTextbox)
$machineForm.Controls.add($copyButton)
$machineForm.Controls.add($errorLabel)
$machineForm.Controls.add($generateLapsButton)
$result = $machineForm.ShowDialog()
$machineForm.dispose()
exit 0