scripts/AD_USER_CREATE.ps1 hinzugefügt
This commit is contained in:
188
scripts/AD_USER_CREATE.ps1
Normal file
188
scripts/AD_USER_CREATE.ps1
Normal file
@@ -0,0 +1,188 @@
|
|||||||
|
Add-Type -AssemblyName System.Windows.Forms
|
||||||
|
Import-Module ActiveDirectory
|
||||||
|
|
||||||
|
# Master-OU und Domäne ermitteln
|
||||||
|
$masterOU = "OU=Benutzer,DC=domain,DC=com" # Beispielwert, passe ihn an eure Umgebung an
|
||||||
|
|
||||||
|
# Holen Sie sich die Domäne aus dem Active Directory
|
||||||
|
$domain = (Get-ADDomain).DNSRoot
|
||||||
|
|
||||||
|
# GUI erstellen
|
||||||
|
$form = New-Object System.Windows.Forms.Form
|
||||||
|
$form.Text = "Benutzererstellung"
|
||||||
|
$form.Size = New-Object System.Drawing.Size(680, 600) # Gesamtgröße der Form anpassen
|
||||||
|
|
||||||
|
# Master-OU Auswahl oberhalb des DataGrid
|
||||||
|
$masterOULabel = New-Object System.Windows.Forms.Label
|
||||||
|
$masterOULabel.Text = "Master-OU:"
|
||||||
|
$masterOULabel.Location = New-Object System.Drawing.Point(10, 10)
|
||||||
|
$masterOULabel.Size = New-Object System.Drawing.Size(80, 20)
|
||||||
|
$form.Controls.Add($masterOULabel)
|
||||||
|
|
||||||
|
# Master-OU ComboBox
|
||||||
|
$masterOUComboBox = New-Object System.Windows.Forms.ComboBox
|
||||||
|
$masterOUComboBox.Location = New-Object System.Drawing.Point(100, 10)
|
||||||
|
$masterOUComboBox.Size = New-Object System.Drawing.Size(250, 20) # ComboBox-Größe festgelegt
|
||||||
|
$masterOUComboBox.DropDownStyle = 'DropDownList'
|
||||||
|
|
||||||
|
# OUs aus dem AD abrufen und in die ComboBox einfügen
|
||||||
|
$ouList = Get-ADOrganizationalUnit -Filter * | Select-Object -ExpandProperty DistinguishedName
|
||||||
|
$masterOUComboBox.Items.AddRange($ouList)
|
||||||
|
$masterOUComboBox.SelectedItem = $masterOU # Standardwerte setzen
|
||||||
|
$form.Controls.Add($masterOUComboBox)
|
||||||
|
|
||||||
|
# DataGridView erstellen
|
||||||
|
$dataGridView = New-Object System.Windows.Forms.DataGridView
|
||||||
|
$dataGridView.Size = New-Object System.Drawing.Size(644, 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)
|
||||||
|
|
||||||
|
# Definieren der Spalten für die DataGridView
|
||||||
|
$dataGridView.ColumnCount = 6
|
||||||
|
$dataGridView.Columns[0].Name = "Titel" # Titel in der ersten Spalte
|
||||||
|
$dataGridView.Columns[1].Name = "Vorname" # Vorname
|
||||||
|
$dataGridView.Columns[2].Name = "Nachname" # Nachname
|
||||||
|
$dataGridView.Columns[3].Name = "Globalgruppe" # Globalgruppe
|
||||||
|
$dataGridView.Columns[4].Name = "OU" # OU
|
||||||
|
$dataGridView.Columns[5].Name = "Standardpasswort" # Standardpasswort
|
||||||
|
|
||||||
|
# Funktion zum Abrufen der verfügbaren OUs
|
||||||
|
function Get-OUs {
|
||||||
|
return Get-ADOrganizationalUnit -Filter * | Select-Object -ExpandProperty DistinguishedName
|
||||||
|
}
|
||||||
|
|
||||||
|
# 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[4].Value = $selectedMasterOU
|
||||||
|
}
|
||||||
|
}
|
||||||
|
}
|
||||||
|
|
||||||
|
# Master-OU ComboBox geändert: Aktualisiere alle OUs im DataGridView
|
||||||
|
$masterOUComboBox.Add_SelectedIndexChanged({
|
||||||
|
Update-OUsInGrid
|
||||||
|
})
|
||||||
|
|
||||||
|
# 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(644, 150) # Größe der RichTextBox festgelegt
|
||||||
|
$outputTextBox.ScrollBars = 'Vertical'
|
||||||
|
$form.Controls.Add($outputTextBox)
|
||||||
|
|
||||||
|
# OK-Button erstellen
|
||||||
|
$okButton = New-Object System.Windows.Forms.Button
|
||||||
|
$okButton.Text = "Benutzer erstellen"
|
||||||
|
$okButton.Size = New-Object System.Drawing.Size(150, 30) # Größe des Buttons festgelegt
|
||||||
|
$okButton.Location = New-Object System.Drawing.Point(10, 510) # Position des Buttons unter der TextBox
|
||||||
|
$okButton.Add_Click({
|
||||||
|
foreach ($row in $dataGridView.Rows) {
|
||||||
|
if ($row.Index -lt $dataGridView.RowCount - 1) { # Nicht für die leere letzte Zeile
|
||||||
|
$title = $row.Cells[0].Value
|
||||||
|
$firstName = $row.Cells[1].Value
|
||||||
|
$lastName = $row.Cells[2].Value
|
||||||
|
$globalGroup = $row.Cells[3].Value
|
||||||
|
$ou = $row.Cells[4].Value # Nun enthält $ou den DistinguishedName der OU
|
||||||
|
$password = $row.Cells[5].Value
|
||||||
|
|
||||||
|
# Überprüfen, ob notwendige Felder ausgefüllt sind
|
||||||
|
if (-not $firstName -or -not $lastName) {
|
||||||
|
$missingField = if (-not $firstName) { "Vorname" } elseif (-not $lastName) { "Nachname" }
|
||||||
|
$outputTextBox.AppendText("Fehler bei der Erstellung des Benutzers '$firstName $lastName': $missingField fehlt.`r`n")
|
||||||
|
continue
|
||||||
|
}
|
||||||
|
|
||||||
|
# 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
|
||||||
|
}
|
||||||
|
|
||||||
|
# Benutzer erstellen
|
||||||
|
try {
|
||||||
|
# Versuchen, den Benutzer abzurufen (auch wenn er bereits existiert)
|
||||||
|
$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
|
||||||
|
|
||||||
|
# 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
|
||||||
|
$outputTextBox.SelectionColor = 'Green'
|
||||||
|
$outputTextBox.AppendText("Benutzer $username existiert bereits.`r`n")
|
||||||
|
}
|
||||||
|
|
||||||
|
# Gruppenzuordnung durchführen, auch wenn der Benutzer schon existiert
|
||||||
|
if ($globalGroup) {
|
||||||
|
try {
|
||||||
|
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
|
||||||
|
$outputTextBox.SelectionColor = 'Red'
|
||||||
|
$outputTextBox.AppendText("Fehler bei der Gruppenzuordnung für Benutzer '$username': $_.Exception.Message`r`n")
|
||||||
|
}
|
||||||
|
}
|
||||||
|
} catch {
|
||||||
|
# Fehler bei der Benutzererstellung
|
||||||
|
$outputTextBox.SelectionColor = 'Red'
|
||||||
|
$outputTextBox.AppendText("Fehler bei der Erstellung des Benutzers $firstName '$lastName': $_.Exception.Message`r`n")
|
||||||
|
}
|
||||||
|
}
|
||||||
|
}
|
||||||
|
})
|
||||||
|
|
||||||
|
# Beenden-Button erstellen
|
||||||
|
$exitButton = New-Object System.Windows.Forms.Button
|
||||||
|
$exitButton.Text = "Beenden"
|
||||||
|
$exitButton.Size = New-Object System.Drawing.Size(150, 30) # Größe des Buttons festgelegt
|
||||||
|
$exitButton.Location = New-Object System.Drawing.Point(504, 510) # Position des Beenden-Buttons
|
||||||
|
$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
|
||||||
|
)
|
||||||
|
return "$firstName.$lastName@$domain"
|
||||||
|
}
|
||||||
|
|
||||||
|
# Formular anzeigen
|
||||||
|
$form.ShowDialog()
|
||||||
Reference in New Issue
Block a user