From 44679990d274f7d3b9d36d275887379565be4255 Mon Sep 17 00:00:00 2001 From: Tim Eertmoed Date: Thu, 7 Nov 2024 14:13:42 +0100 Subject: [PATCH] scripts/AD_USER_CREATE.ps1 aktualisiert --- scripts/AD_USER_CREATE.ps1 | 220 ++++++++++++++++++++++--------------- 1 file changed, 130 insertions(+), 90 deletions(-) diff --git a/scripts/AD_USER_CREATE.ps1 b/scripts/AD_USER_CREATE.ps1 index c59fc24..dd75b95 100644 --- a/scripts/AD_USER_CREATE.ps1 +++ b/scripts/AD_USER_CREATE.ps1 @@ -1,11 +1,10 @@ -$runAsAdmin = [Security.Principal.WindowsPrincipal][Security.Principal.WindowsIdentity]::GetCurrent() -$adminRole = [Security.Principal.WindowsBuiltInRole]::Administrator +$myWindowsIdentity = [System.Security.Principal.WindowsIdentity]::GetCurrent() +$myPrincipal = New-Object System.Security.Principal.WindowsPrincipal($myWindowsIdentity) -if (-not $runAsAdmin.IsInRole($adminRole)) { - # Relaunch the script as Administrator - $arguments = "$($myinvocation.MyCommand.Definition)" - Start-Process powershell -ArgumentList "-NoProfile -ExecutionPolicy Bypass -File $arguments" -Verb RunAs - exit +if (-not $myPrincipal.IsInRole([System.Security.Principal.WindowsBuiltInRole]::Administrator)) { + $arguments = "& '" + $myinvocation.mycommand.definition + "'" + Start-Process powershell -ArgumentList $arguments -Verb runAs + Exit } Add-Type -AssemblyName System.Windows.Forms @@ -21,19 +20,49 @@ $domain = (Get-ADDomain).DNSRoot # GUI erstellen $form = New-Object System.Windows.Forms.Form $form.Text = "Benutzererstellung" -$form.Size = New-Object System.Drawing.Size(800, 600) # Gesamtgröße der Form anpassen +$form.Size = New-Object System.Drawing.Size(990, 600) # Gesamtgröße der Form anpassen + +# Funktion zur Berechnung der maximalen Breite der ComboBox +function Set-DropDownWidth { + param ( + [System.Windows.Forms.ComboBox]$comboBox + ) + + $maxLength = 0 + foreach ($item in $comboBox.Items) { + $itemLength = $item.Length + if ($itemLength -gt $maxLength) { + $maxLength = $itemLength + } + } + + # Setze die DropDownWidth entsprechend der maximalen Länge + $comboBox.DropDownWidth = $maxLength * 6 # Schätzbreite (Zeichen * 8 Pixel) +} + +# Masterkennwort Eingabefeld +$masterPasswordLabel = New-Object System.Windows.Forms.Label +$masterPasswordLabel.Text = "Masterkennwort:" +$masterPasswordLabel.Location = New-Object System.Drawing.Point(10, 12) +$masterPasswordLabel.Size = New-Object System.Drawing.Size(100, 20) +$form.Controls.Add($masterPasswordLabel) + +$masterPasswordTextBox = New-Object System.Windows.Forms.TextBox +$masterPasswordTextBox.Location = New-Object System.Drawing.Point(110, 10) +$masterPasswordTextBox.Size = New-Object System.Drawing.Size(200, 20) +$masterPasswordTextBox.UseSystemPasswordChar = $true # Passwortfeld +$form.Controls.Add($masterPasswordTextBox) # Master-OU für Benutzer Auswahl $masterOULabel = New-Object System.Windows.Forms.Label $masterOULabel.Text = "Master-OU (Benutzer):" -$masterOULabel.Location = New-Object System.Drawing.Point(10, 10) +$masterOULabel.Location = New-Object System.Drawing.Point(320, 12) $masterOULabel.Size = New-Object System.Drawing.Size(120, 20) $form.Controls.Add($masterOULabel) -# Master-OU ComboBox für Benutzer $masterOUComboBox = New-Object System.Windows.Forms.ComboBox -$masterOUComboBox.Location = New-Object System.Drawing.Point(130, 10) -$masterOUComboBox.Size = New-Object System.Drawing.Size(250, 20) # ComboBox-Größe festgelegt +$masterOUComboBox.Location = New-Object System.Drawing.Point(440, 10) +$masterOUComboBox.Size = New-Object System.Drawing.Size(200, 20) # ComboBox-Größe festgelegt $masterOUComboBox.DropDownStyle = 'DropDownList' # OUs aus dem AD für Benutzer abrufen und in die ComboBox einfügen @@ -42,17 +71,19 @@ $masterOUComboBox.Items.AddRange($ouList) $masterOUComboBox.SelectedItem = $masterOU # Standardwerte setzen $form.Controls.Add($masterOUComboBox) -# Master-OU für Gruppen Auswahl (Rechts oben) +# Berechne und setze die DropDownWidth basierend auf der maximalen Länge +Set-DropDownWidth -comboBox $masterOUComboBox + +# Master-OU für Gruppen Auswahl $masterGroupOULabel = New-Object System.Windows.Forms.Label $masterGroupOULabel.Text = "Master-OU (Gruppen):" -$masterGroupOULabel.Location = New-Object System.Drawing.Point(400, 10) +$masterGroupOULabel.Location = New-Object System.Drawing.Point(645, 12) $masterGroupOULabel.Size = New-Object System.Drawing.Size(120, 20) $form.Controls.Add($masterGroupOULabel) -# Master-OU ComboBox für Gruppen $masterGroupOUComboBox = New-Object System.Windows.Forms.ComboBox -$masterGroupOUComboBox.Location = New-Object System.Drawing.Point(520, 10) -$masterGroupOUComboBox.Size = New-Object System.Drawing.Size(250, 20) # ComboBox-Größe für Gruppen +$masterGroupOUComboBox.Location = New-Object System.Drawing.Point(765, 10) +$masterGroupOUComboBox.Size = New-Object System.Drawing.Size(200, 20) # ComboBox-Größe für Gruppen $masterGroupOUComboBox.DropDownStyle = 'DropDownList' # OUs aus dem AD für Gruppen abrufen und in die ComboBox einfügen @@ -61,13 +92,25 @@ $masterGroupOUComboBox.Items.AddRange($groupOUList) $masterGroupOUComboBox.SelectedItem = $masterGroupOU # Standardwerte setzen $form.Controls.Add($masterGroupOUComboBox) +# Berechne und setze die DropDownWidth basierend auf der maximalen Länge +Set-DropDownWidth -comboBox $masterGroupOUComboBox + # DataGridView erstellen $dataGridView = New-Object System.Windows.Forms.DataGridView -$dataGridView.Size = New-Object System.Drawing.Size(764, 300) # Breite und Höhe des DataGridViews festgelegt +$dataGridView.Size = New-Object System.Drawing.Size(954, 300) # Breite und Höhe des DataGridViews festgelegt $dataGridView.Location = New-Object System.Drawing.Point(10, 40) # Position des DataGridViews $dataGridView.Anchor = [System.Windows.Forms.AnchorStyles]::Top $form.Controls.Add($dataGridView) +# Die Breite der DropDown-Liste manuell anpassen, da DropDownWidth für DataGridViewComboBoxColumn nicht unterstützt wird +$maxLength = 0 +foreach ($item in $masterGroupOUComboBox.Items) { + $itemLength = $item.ToString().Length + if ($itemLength -gt $maxLength) { + $maxLength = $itemLength + } +} + # Definieren der Spalten für die DataGridView $dataGridView.ColumnCount = 6 $dataGridView.Columns[0].Name = "Titel" # Titel in der ersten Spalte @@ -76,7 +119,7 @@ $dataGridView.Columns[2].Name = "Nachname" # Nachname $dataGridView.Columns[3].Name = "Globalgruppe" # Globalgruppe $dataGridView.Columns[4].Name = "Standardpasswort" # Standardpasswort $dataGridView.Columns[5].Name = "OU" # OU (wird als ComboBox hinzugefügt) -$dataGridView.Columns[5].Width = 220 +$dataGridView.Columns[5].Width = $ouComboBoxColumn # Dropdown für die OU in der DataGridView-ComboBox-Spalte $ouComboBoxColumn = New-Object System.Windows.Forms.DataGridViewComboBoxColumn @@ -84,29 +127,13 @@ $ouComboBoxColumn.HeaderText = "OU" $ouComboBoxColumn.Items.AddRange($ouList) # Hier fügen wir alle OUs hinzu $dataGridView.Columns.RemoveAt(5) # Entfernt die ursprüngliche OU-Spalte $dataGridView.Columns.Insert(5, $ouComboBoxColumn) # Fügt die ComboBox-Spalte an der richtigen Stelle ein -$ouComboBoxColumn.Width = 220 # Du kannst hier den Wert nach Bedarf anpassen - -# Funktion zum Setzen der OUs für alle Zeilen im DataGridView -function Update-OUsInGrid { - $selectedMasterOU = $masterOUComboBox.SelectedItem - foreach ($row in $dataGridView.Rows) { - if ($row.Index -lt $dataGridView.RowCount - 1) { # Nicht für die leere letzte Zeile - # Setze die Master-OU in der "OU"-Spalte für jede Zeile - $row.Cells[5].Value = $selectedMasterOU # Zeile aktualisieren, statt der 4. Spalte jetzt die 5. für OU - } - } -} - -# Master-OU ComboBox geändert: Aktualisiere alle OUs im DataGridView -$masterOUComboBox.Add_SelectedIndexChanged({ - Update-OUsInGrid -}) +$ouComboBoxColumn.Width = $maxLength * 6 # RichTextBox für Ausgaben (anstelle von TextBox) $outputTextBox = New-Object System.Windows.Forms.RichTextBox $outputTextBox.Multiline = $true $outputTextBox.Location = New-Object System.Drawing.Point(10, 350) # Position unterhalb des DataGridViews -$outputTextBox.Size = New-Object System.Drawing.Size(764, 150) # Größe der RichTextBox festgelegt +$outputTextBox.Size = New-Object System.Drawing.Size(954, 150) # Größe der RichTextBox festgelegt $outputTextBox.ScrollBars = 'Vertical' $form.Controls.Add($outputTextBox) @@ -115,7 +142,20 @@ $okButton = New-Object System.Windows.Forms.Button $okButton.Text = "Benutzer erstellen" $okButton.Size = New-Object System.Drawing.Size(380, 30) # Größe des Buttons festgelegt $okButton.Location = New-Object System.Drawing.Point(10, 510) # Position des Buttons unter der TextBox + +# Beenden-Button erstellen +$exitButton = New-Object System.Windows.Forms.Button +$exitButton.Text = "Beenden" +$exitButton.Size = New-Object System.Drawing.Size(380, 30) # Größe des Buttons festgelegt +$exitButton.Location = New-Object System.Drawing.Point(585, 510) # Position des Beenden-Buttons + +# Buttons zum Formular hinzufügen +$form.Controls.Add($okButton) +$form.Controls.Add($exitButton) + +# Event-Handler für den OK-Button hinzufügen $okButton.Add_Click({ + $masterPassword = $masterPasswordTextBox.Text # Masterkennwort holen foreach ($row in $dataGridView.Rows) { if ($row.Index -lt $dataGridView.RowCount - 1) { # Nicht für die leere letzte Zeile $title = $row.Cells[0].Value @@ -125,6 +165,16 @@ $okButton.Add_Click({ $password = $row.Cells[4].Value $ou = $row.Cells[5].Value # Hier wird die ausgewählte OU aus der ComboBox abgerufen + # Wenn keine OU in der Zeile gewählt wurde, nehme die Master-OU + if (-not $ou) { + $ou = $masterOUComboBox.SelectedItem + } + + # Wenn kein Passwort angegeben wurde, nutze das Masterkennwort + if (-not $password) { + $password = $masterPassword + } + # Überprüfen, ob notwendige Felder ausgefüllt sind if (-not $firstName -or -not $lastName) { $missingField = if (-not $firstName) { "Vorname" } elseif (-not $lastName) { "Nachname" } @@ -135,19 +185,8 @@ $okButton.Add_Click({ # Benutzername generieren: erster Buchstabe des Vornamens + Nachname $username = ($firstName.Substring(0, 1) + $lastName).ToLower() - # Passwort prüfen - if (-not $password) { - $outputTextBox.AppendText("Fehler bei der Erstellung des Benutzers '$firstName $lastName': Passwort fehlt.`r`n") - continue - } - # E-Mail-Adresse generieren - $email = Get-EmailAddress -firstName $firstName -lastName $lastName - - # Master-OU für den Benutzer setzen, falls keine OU explizit ausgewählt wurde - if (-not $ou) { - $ou = $masterOUComboBox.SelectedItem - } + $email = Get-EmailAddress -username $username # Benutzer erstellen try { @@ -155,22 +194,27 @@ $okButton.Add_Click({ $user = Get-ADUser -Filter { SamAccountName -eq $username } if (-not $user) { # Benutzer erstellen, falls er nicht existiert - New-ADUser -Name "$firstName $lastName" - -GivenName $firstName - -Surname $lastName - -SamAccountName $username - -UserPrincipalName $email - -EmailAddress $email - -AccountPassword (ConvertTo-SecureString $password -AsPlainText -Force) - -Enabled $true - -Path $ou + try { + New-ADUser -Name "$firstName $lastName" ` + -GivenName "$firstName" ` + -Surname "$lastName" ` + -SamAccountName "$username" ` + -UserPrincipalName "$email" ` + -AccountPassword (ConvertTo-SecureString $password -AsPlainText -Force) ` + -Enabled $true ` + -Path "$ou" + + $outputTextBox.SelectionColor = 'Green' + $outputTextBox.AppendText("Benutzer $username wurde erfolgreich erstellt.`r`n") + } + catch { + $outputTextBox.SelectionColor = 'Red' + $outputTextBox.AppendText("Fehler bei der Erstellung des Benutzers '$firstName $lastName': $_.Exception.Message`r`n") + } - # Erfolgsnachricht für Benutzererstellung in grün - $outputTextBox.SelectionColor = 'Green' - $outputTextBox.AppendText("Benutzer $username wurde erfolgreich erstellt.`r`n") } else { - # Erfolgsnachricht für vorhandenen Benutzer in grün + # Erfolgsnachricht für vorhandenen Benutzer $outputTextBox.SelectionColor = 'Green' $outputTextBox.AppendText("Benutzer $username existiert bereits.`r`n") } @@ -180,30 +224,34 @@ $okButton.Add_Click({ # Gruppen-OU immer auf die Master-OU setzen $groupOU = $masterGroupOU try { - # Überprüfen, ob die Gruppe existiert, und gegebenenfalls erstellen + # Überprüfen, ob die Gruppe existiert $group = Get-ADGroup -Filter { Name -eq $globalGroup } - if (-not $group) { + try { # Gruppe erstellen, falls sie nicht existiert - New-ADGroup -Name $globalGroup - -GroupScope Global - -Path $groupOU - -Description "Globale Gruppe für $globalGroup" - - # Erfolgsnachricht für Gruppenerstellung + $groupName = "GG_" + $globalGroup + New-ADGroup -Name $groupName ` + -GroupScope Global ` + -Path $groupOU ` + -Description "Globale Gruppe für $groupName" ` + -Enabled $true + # Erfolgsnachricht $outputTextBox.SelectionColor = 'Green' - $outputTextBox.AppendText("Globale Gruppe '$globalGroup' wurde erfolgreich erstellt.`r`n") + $outputTextBox.AppendText("Globale Gruppe '$groupName' wurde erfolgreich erstellt.`r`n") } - # Benutzer der Gruppe zuordnen - Add-ADGroupMember -Identity $globalGroup -Members $username - $outputTextBox.SelectionColor = 'Green' - $outputTextBox.AppendText("Benutzer '$username' wurde erfolgreich der Gruppe '$globalGroup' zugeordnet.`r`n") - } catch { - # Fehler bei der Gruppenzuordnung in rot + catch { + $outputTextBox.SelectionColor = 'Red' + $outputTextBox.AppendText("Fehler bei der Erstellung der Gruppe '$groupName': $_.Exception.Message`r`n") + $outputTextBox.AppendText("Fehlerdetails: $_`r`n") + } + } + catch { + # Fehler bei der Gruppenzuordnung $outputTextBox.SelectionColor = 'Red' $outputTextBox.AppendText("Fehler bei der Gruppenzuordnung für Benutzer '$username': $_.Exception.Message`r`n") } } - } catch { + } + catch { # Fehler bei der Benutzererstellung $outputTextBox.SelectionColor = 'Red' $outputTextBox.AppendText("Fehler bei der Erstellung des Benutzers '$firstName $lastName': $_.Exception.Message`r`n") @@ -212,26 +260,18 @@ $okButton.Add_Click({ } }) -# Beenden-Button erstellen -$exitButton = New-Object System.Windows.Forms.Button -$exitButton.Text = "Beenden" -$exitButton.Size = New-Object System.Drawing.Size(380, 30) # Größe des Buttons festgelegt -$exitButton.Location = New-Object System.Drawing.Point(395, 510) # Position des Beenden-Buttons +# Event-Handler für den Beenden-Button hinzufügen $exitButton.Add_Click({ $form.Close() # Formular schließen }) -# Buttons zum Formular hinzufügen -$form.Controls.Add($okButton) -$form.Controls.Add($exitButton) - # Funktion zum Erstellen der E-Mail-Adresse function Get-EmailAddress { param ( - [string]$firstName, - [string]$lastName + [string]$username ) - return "$firstName.$lastName@$domain" + + return "$username@$domain" } # Formular anzeigen