scripts/AD_USER_CREATE.ps1 aktualisiert

This commit is contained in:
2024-11-07 14:13:42 +01:00
parent 854431880a
commit 44679990d2

View File

@@ -1,11 +1,10 @@
$runAsAdmin = [Security.Principal.WindowsPrincipal][Security.Principal.WindowsIdentity]::GetCurrent() $myWindowsIdentity = [System.Security.Principal.WindowsIdentity]::GetCurrent()
$adminRole = [Security.Principal.WindowsBuiltInRole]::Administrator $myPrincipal = New-Object System.Security.Principal.WindowsPrincipal($myWindowsIdentity)
if (-not $runAsAdmin.IsInRole($adminRole)) { if (-not $myPrincipal.IsInRole([System.Security.Principal.WindowsBuiltInRole]::Administrator)) {
# Relaunch the script as Administrator $arguments = "& '" + $myinvocation.mycommand.definition + "'"
$arguments = "$($myinvocation.MyCommand.Definition)" Start-Process powershell -ArgumentList $arguments -Verb runAs
Start-Process powershell -ArgumentList "-NoProfile -ExecutionPolicy Bypass -File $arguments" -Verb RunAs Exit
exit
} }
Add-Type -AssemblyName System.Windows.Forms Add-Type -AssemblyName System.Windows.Forms
@@ -21,19 +20,49 @@ $domain = (Get-ADDomain).DNSRoot
# GUI erstellen # GUI erstellen
$form = New-Object System.Windows.Forms.Form $form = New-Object System.Windows.Forms.Form
$form.Text = "Benutzererstellung" $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 # Master-OU für Benutzer Auswahl
$masterOULabel = New-Object System.Windows.Forms.Label $masterOULabel = New-Object System.Windows.Forms.Label
$masterOULabel.Text = "Master-OU (Benutzer):" $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) $masterOULabel.Size = New-Object System.Drawing.Size(120, 20)
$form.Controls.Add($masterOULabel) $form.Controls.Add($masterOULabel)
# Master-OU ComboBox für Benutzer
$masterOUComboBox = New-Object System.Windows.Forms.ComboBox $masterOUComboBox = New-Object System.Windows.Forms.ComboBox
$masterOUComboBox.Location = New-Object System.Drawing.Point(130, 10) $masterOUComboBox.Location = New-Object System.Drawing.Point(440, 10)
$masterOUComboBox.Size = New-Object System.Drawing.Size(250, 20) # ComboBox-Größe festgelegt $masterOUComboBox.Size = New-Object System.Drawing.Size(200, 20) # ComboBox-Größe festgelegt
$masterOUComboBox.DropDownStyle = 'DropDownList' $masterOUComboBox.DropDownStyle = 'DropDownList'
# OUs aus dem AD für Benutzer abrufen und in die ComboBox einfügen # 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 $masterOUComboBox.SelectedItem = $masterOU # Standardwerte setzen
$form.Controls.Add($masterOUComboBox) $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 = New-Object System.Windows.Forms.Label
$masterGroupOULabel.Text = "Master-OU (Gruppen):" $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) $masterGroupOULabel.Size = New-Object System.Drawing.Size(120, 20)
$form.Controls.Add($masterGroupOULabel) $form.Controls.Add($masterGroupOULabel)
# Master-OU ComboBox für Gruppen
$masterGroupOUComboBox = New-Object System.Windows.Forms.ComboBox $masterGroupOUComboBox = New-Object System.Windows.Forms.ComboBox
$masterGroupOUComboBox.Location = New-Object System.Drawing.Point(520, 10) $masterGroupOUComboBox.Location = New-Object System.Drawing.Point(765, 10)
$masterGroupOUComboBox.Size = New-Object System.Drawing.Size(250, 20) # ComboBox-Größe für Gruppen $masterGroupOUComboBox.Size = New-Object System.Drawing.Size(200, 20) # ComboBox-Größe für Gruppen
$masterGroupOUComboBox.DropDownStyle = 'DropDownList' $masterGroupOUComboBox.DropDownStyle = 'DropDownList'
# OUs aus dem AD für Gruppen abrufen und in die ComboBox einfügen # 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 $masterGroupOUComboBox.SelectedItem = $masterGroupOU # Standardwerte setzen
$form.Controls.Add($masterGroupOUComboBox) $form.Controls.Add($masterGroupOUComboBox)
# Berechne und setze die DropDownWidth basierend auf der maximalen Länge
Set-DropDownWidth -comboBox $masterGroupOUComboBox
# DataGridView erstellen # DataGridView erstellen
$dataGridView = New-Object System.Windows.Forms.DataGridView $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.Location = New-Object System.Drawing.Point(10, 40) # Position des DataGridViews
$dataGridView.Anchor = [System.Windows.Forms.AnchorStyles]::Top $dataGridView.Anchor = [System.Windows.Forms.AnchorStyles]::Top
$form.Controls.Add($dataGridView) $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 # Definieren der Spalten für die DataGridView
$dataGridView.ColumnCount = 6 $dataGridView.ColumnCount = 6
$dataGridView.Columns[0].Name = "Titel" # Titel in der ersten Spalte $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[3].Name = "Globalgruppe" # Globalgruppe
$dataGridView.Columns[4].Name = "Standardpasswort" # Standardpasswort $dataGridView.Columns[4].Name = "Standardpasswort" # Standardpasswort
$dataGridView.Columns[5].Name = "OU" # OU (wird als ComboBox hinzugefügt) $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 # Dropdown für die OU in der DataGridView-ComboBox-Spalte
$ouComboBoxColumn = New-Object System.Windows.Forms.DataGridViewComboBoxColumn $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 $ouComboBoxColumn.Items.AddRange($ouList) # Hier fügen wir alle OUs hinzu
$dataGridView.Columns.RemoveAt(5) # Entfernt die ursprüngliche OU-Spalte $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 $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 $ouComboBoxColumn.Width = $maxLength * 6
# 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
})
# RichTextBox für Ausgaben (anstelle von TextBox) # RichTextBox für Ausgaben (anstelle von TextBox)
$outputTextBox = New-Object System.Windows.Forms.RichTextBox $outputTextBox = New-Object System.Windows.Forms.RichTextBox
$outputTextBox.Multiline = $true $outputTextBox.Multiline = $true
$outputTextBox.Location = New-Object System.Drawing.Point(10, 350) # Position unterhalb des DataGridViews $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' $outputTextBox.ScrollBars = 'Vertical'
$form.Controls.Add($outputTextBox) $form.Controls.Add($outputTextBox)
@@ -115,7 +142,20 @@ $okButton = New-Object System.Windows.Forms.Button
$okButton.Text = "Benutzer erstellen" $okButton.Text = "Benutzer erstellen"
$okButton.Size = New-Object System.Drawing.Size(380, 30) # Größe des Buttons festgelegt $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 $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({ $okButton.Add_Click({
$masterPassword = $masterPasswordTextBox.Text # Masterkennwort holen
foreach ($row in $dataGridView.Rows) { foreach ($row in $dataGridView.Rows) {
if ($row.Index -lt $dataGridView.RowCount - 1) { # Nicht für die leere letzte Zeile if ($row.Index -lt $dataGridView.RowCount - 1) { # Nicht für die leere letzte Zeile
$title = $row.Cells[0].Value $title = $row.Cells[0].Value
@@ -125,6 +165,16 @@ $okButton.Add_Click({
$password = $row.Cells[4].Value $password = $row.Cells[4].Value
$ou = $row.Cells[5].Value # Hier wird die ausgewählte OU aus der ComboBox abgerufen $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 # Überprüfen, ob notwendige Felder ausgefüllt sind
if (-not $firstName -or -not $lastName) { if (-not $firstName -or -not $lastName) {
$missingField = if (-not $firstName) { "Vorname" } elseif (-not $lastName) { "Nachname" } $missingField = if (-not $firstName) { "Vorname" } elseif (-not $lastName) { "Nachname" }
@@ -135,19 +185,8 @@ $okButton.Add_Click({
# Benutzername generieren: erster Buchstabe des Vornamens + Nachname # Benutzername generieren: erster Buchstabe des Vornamens + Nachname
$username = ($firstName.Substring(0, 1) + $lastName).ToLower() $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 # E-Mail-Adresse generieren
$email = Get-EmailAddress -firstName $firstName -lastName $lastName $email = Get-EmailAddress -username $username
# Master-OU für den Benutzer setzen, falls keine OU explizit ausgewählt wurde
if (-not $ou) {
$ou = $masterOUComboBox.SelectedItem
}
# Benutzer erstellen # Benutzer erstellen
try { try {
@@ -155,22 +194,27 @@ $okButton.Add_Click({
$user = Get-ADUser -Filter { SamAccountName -eq $username } $user = Get-ADUser -Filter { SamAccountName -eq $username }
if (-not $user) { if (-not $user) {
# Benutzer erstellen, falls er nicht existiert # Benutzer erstellen, falls er nicht existiert
New-ADUser -Name "$firstName $lastName" try {
-GivenName $firstName New-ADUser -Name "$firstName $lastName" `
-Surname $lastName -GivenName "$firstName" `
-SamAccountName $username -Surname "$lastName" `
-UserPrincipalName $email -SamAccountName "$username" `
-EmailAddress $email -UserPrincipalName "$email" `
-AccountPassword (ConvertTo-SecureString $password -AsPlainText -Force) -AccountPassword (ConvertTo-SecureString $password -AsPlainText -Force) `
-Enabled $true -Enabled $true `
-Path $ou -Path "$ou"
# Erfolgsnachricht für Benutzererstellung in grün
$outputTextBox.SelectionColor = 'Green' $outputTextBox.SelectionColor = 'Green'
$outputTextBox.AppendText("Benutzer $username wurde erfolgreich erstellt.`r`n") $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")
}
}
else { else {
# Erfolgsnachricht für vorhandenen Benutzer in grün # Erfolgsnachricht für vorhandenen Benutzer
$outputTextBox.SelectionColor = 'Green' $outputTextBox.SelectionColor = 'Green'
$outputTextBox.AppendText("Benutzer $username existiert bereits.`r`n") $outputTextBox.AppendText("Benutzer $username existiert bereits.`r`n")
} }
@@ -180,30 +224,34 @@ $okButton.Add_Click({
# Gruppen-OU immer auf die Master-OU setzen # Gruppen-OU immer auf die Master-OU setzen
$groupOU = $masterGroupOU $groupOU = $masterGroupOU
try { try {
# Überprüfen, ob die Gruppe existiert, und gegebenenfalls erstellen # Überprüfen, ob die Gruppe existiert
$group = Get-ADGroup -Filter { Name -eq $globalGroup } $group = Get-ADGroup -Filter { Name -eq $globalGroup }
if (-not $group) { try {
# Gruppe erstellen, falls sie nicht existiert # Gruppe erstellen, falls sie nicht existiert
New-ADGroup -Name $globalGroup $groupName = "GG_" + $globalGroup
-GroupScope Global New-ADGroup -Name $groupName `
-Path $groupOU -GroupScope Global `
-Description "Globale Gruppe für $globalGroup" -Path $groupOU `
-Description "Globale Gruppe für $groupName" `
# Erfolgsnachricht für Gruppenerstellung -Enabled $true
# Erfolgsnachricht
$outputTextBox.SelectionColor = 'Green' $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 catch {
Add-ADGroupMember -Identity $globalGroup -Members $username $outputTextBox.SelectionColor = 'Red'
$outputTextBox.SelectionColor = 'Green' $outputTextBox.AppendText("Fehler bei der Erstellung der Gruppe '$groupName': $_.Exception.Message`r`n")
$outputTextBox.AppendText("Benutzer '$username' wurde erfolgreich der Gruppe '$globalGroup' zugeordnet.`r`n") $outputTextBox.AppendText("Fehlerdetails: $_`r`n")
} catch { }
# Fehler bei der Gruppenzuordnung in rot }
catch {
# Fehler bei der Gruppenzuordnung
$outputTextBox.SelectionColor = 'Red' $outputTextBox.SelectionColor = 'Red'
$outputTextBox.AppendText("Fehler bei der Gruppenzuordnung für Benutzer '$username': $_.Exception.Message`r`n") $outputTextBox.AppendText("Fehler bei der Gruppenzuordnung für Benutzer '$username': $_.Exception.Message`r`n")
} }
} }
} catch { }
catch {
# Fehler bei der Benutzererstellung # Fehler bei der Benutzererstellung
$outputTextBox.SelectionColor = 'Red' $outputTextBox.SelectionColor = 'Red'
$outputTextBox.AppendText("Fehler bei der Erstellung des Benutzers '$firstName $lastName': $_.Exception.Message`r`n") $outputTextBox.AppendText("Fehler bei der Erstellung des Benutzers '$firstName $lastName': $_.Exception.Message`r`n")
@@ -212,26 +260,18 @@ $okButton.Add_Click({
} }
}) })
# Beenden-Button erstellen # Event-Handler für den Beenden-Button hinzufügen
$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
$exitButton.Add_Click({ $exitButton.Add_Click({
$form.Close() # Formular schließen $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 # Funktion zum Erstellen der E-Mail-Adresse
function Get-EmailAddress { function Get-EmailAddress {
param ( param (
[string]$firstName, [string]$username
[string]$lastName
) )
return "$firstName.$lastName@$domain"
return "$username@$domain"
} }
# Formular anzeigen # Formular anzeigen