From 7cc4144a8f45a5ce561645fee672802e9afad762 Mon Sep 17 00:00:00 2001 From: Tim Eertmoed Date: Mon, 11 Nov 2024 08:28:42 +0100 Subject: [PATCH] =?UTF-8?q?scripts/AD=5FCREATE=5FGROUPS.ps1=20hinzugef?= =?UTF-8?q?=C3=BCgt?= MIME-Version: 1.0 Content-Type: text/plain; charset=UTF-8 Content-Transfer-Encoding: 8bit --- scripts/AD_CREATE_GROUPS.ps1 | 173 +++++++++++++++++++++++++++++++++++ 1 file changed, 173 insertions(+) create mode 100644 scripts/AD_CREATE_GROUPS.ps1 diff --git a/scripts/AD_CREATE_GROUPS.ps1 b/scripts/AD_CREATE_GROUPS.ps1 new file mode 100644 index 0000000..19ce344 --- /dev/null +++ b/scripts/AD_CREATE_GROUPS.ps1 @@ -0,0 +1,173 @@ +# PowerShell GUI Script für Gruppenerstellung + +# Sicherstellen, dass das Skript als Administrator ausgeführt wird +$myWindowsIdentity = [System.Security.Principal.WindowsIdentity]::GetCurrent() +$myPrincipal = New-Object System.Security.Principal.WindowsPrincipal($myWindowsIdentity) + +if (-not $myPrincipal.IsInRole([System.Security.Principal.WindowsBuiltInRole]::Administrator)) { +$arguments = "& '" + $myinvocation.mycommand.definition + "'" +Start-Process powershell -ArgumentList $arguments -Verb runAs +Exit +} + +# Windows.Forms Assembly laden +Add-Type -AssemblyName System.Windows.Forms +Import-Module ActiveDirectory + +# 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 = "Gruppen Erstellung" +$form.Size = New-Object System.Drawing.Size(600, 555) # Gesamtgröße der Form anpassen + +# DataGridView für Gruppen erstellen +$dataGridView = New-Object System.Windows.Forms.DataGridView +$dataGridView.Size = New-Object System.Drawing.Size(564, 300) # Breite und Höhe des DataGridViews +$dataGridView.Location = New-Object System.Drawing.Point(10, 10) # Position des DataGridViews +$form.Controls.Add($dataGridView) + +# Definieren der Spalten für die DataGridView +$dataGridView.ColumnCount = 3 +$dataGridView.Columns[0].Name = "Typ" # Typ in der ersten Spalte +$dataGridView.Columns[1].Name = "Gruppenname" # Gruppenname in der zweiten Spalte +$dataGridView.Columns[2].Name = "OU" # OU in der dritten Spalte + +# Breite der Spalten festlegen +$dataGridView.Columns[0].Width = 75 # Typ-Spalte auf 50 Pixel setzen +$dataGridView.Columns[1].Width = 100 # Gruppenname-Spalte auf 100 Pixel setzen +$dataGridView.Columns[2].Width = 345 # OU-Spalte auf 400 Pixel setzen + +# Dropdown für den Typ (GG oder DL) +$typColumn = New-Object System.Windows.Forms.DataGridViewComboBoxColumn +$typColumn.HeaderText = "Typ" +$typColumn.Items.Add("GG") +$typColumn.Items.Add("DL") +$typColumn.Items.Add("DL_OS") +$dataGridView.Columns.RemoveAt(0) +$dataGridView.Columns.Insert(0, $typColumn) +# Breite der Typ-Spalte setzen +$typColumn.Width = 75 # Du kannst hier den Wert nach Bedarf anpassen + +# Dropdown für die OU-Auswahl in der dritten Spalte +$ouColumn = New-Object System.Windows.Forms.DataGridViewComboBoxColumn +$ouColumn.HeaderText = "OU" +$groupOUList = Get-ADOrganizationalUnit -Filter * | Select-Object -ExpandProperty DistinguishedName +foreach ($ou in $groupOUList) { + $ouColumn.Items.Add($ou) +} +$dataGridView.Columns.RemoveAt(2) +$dataGridView.Columns.Insert(2, $ouColumn) + +# Breite der OU-Spalte setzen +$ouColumn.Width = 345 # Du kannst hier den Wert nach Bedarf anpassen + +# RichTextBox für Ausgaben +$outputTextBox = New-Object System.Windows.Forms.RichTextBox +$outputTextBox.Multiline = $true +$outputTextBox.Location = New-Object System.Drawing.Point(10, 320) # Position unterhalb des DataGridViews +$outputTextBox.Size = New-Object System.Drawing.Size(564, 150) # Größe der RichTextBox +$outputTextBox.ScrollBars = 'Vertical' +$outputTextBox.ReadOnly = $true +$form.Controls.Add($outputTextBox) + +# OK-Button für Gruppen erstellen +$okButton = New-Object System.Windows.Forms.Button +$okButton.Text = "Gruppen erstellen" +$okButton.Size = New-Object System.Drawing.Size(280, 30) # Größe des Buttons +$okButton.Location = New-Object System.Drawing.Point(10, 475) # Position des Buttons +$okButton.Add_Click({ + foreach ($row in $dataGridView.Rows) { + if ($row.Index -lt $dataGridView.RowCount - 1) { # Nicht für die leere letzte Zeile + $groupType = $row.Cells[0].Value + $groupName = $row.Cells[1].Value + $groupOU = $row.Cells[2].Value + + if (-not $groupType -or -not $groupName -or -not $groupOU) { + $outputTextBox.SelectionColor = 'Red' + $outputTextBox.AppendText("Fehler: Alle Felder (Typ, Gruppenname, OU) müssen ausgefüllt sein.`r`n") + continue + } + + # Präfix vor den Gruppennamen setzen, basierend auf dem Typ + if ($groupType -eq "GG") { + $groupName = "GG_" + $groupName # Für globale Gruppen "GG_" voranstellen + } elseif ($groupType -eq "DL_OS") { + $groupName = "DL_" + $groupName # Für globale Gruppen "DL_OS" voranstellen + } elseif ($groupType -eq "DL") { + $groupName = "DL_" + $groupName # Für DomainLocal Gruppen "DL_" voranstellen + } + + try { + if ($groupType -eq "GG") { + # Globale Gruppe erstellen (keine Suffixe, aber Präfix wird hinzugefügt) + $group = Get-ADGroup -Filter { Name -eq $groupName } + if (-not $group) { + New-ADGroup -Name $groupName ` + -GroupScope Global ` + -Path $groupOU ` + -Description "Globale Gruppe für $groupName" + $outputTextBox.SelectionColor = 'Green' + $outputTextBox.AppendText("Globale Gruppe '$groupName' wurde erfolgreich erstellt.`r`n") + } else { + $outputTextBox.SelectionColor = 'Green' + $outputTextBox.AppendText("Globale Gruppe '$groupName' existiert bereits.`r`n") + } + } elseif ($groupType -eq "DL_OS") { + # DomainLocal Gruppen ohne Suffix erstellen + $domainLocalGroupName = "$groupName" + if (-not $group) { + New-ADGroup -Name $domainLocalGroupName ` + -GroupScope DomainLocal ` + -Path $groupOU ` + -Description "DomainLocal Gruppe für $domainLocalGroupName" + $outputTextBox.SelectionColor = 'Green' + $outputTextBox.AppendText("DomainLocal Gruppe '$domainLocalGroupName' wurde erfolgreich erstellt.`r`n") + } else { + $outputTextBox.SelectionColor = 'Green' + $outputTextBox.AppendText("DomainLocal Gruppe '$domainLocalGroupName' existiert bereits.`r`n") + } + } elseif ($groupType -eq "DL") { + # DomainLocal Gruppen mit Suffixen erstellen + $suffixes = "_FA", "_RW", "_RX", "_RO" + foreach ($suffix in $suffixes) { + $domainLocalGroupName = "$groupName$suffix" + $group = Get-ADGroup -Filter { Name -eq $domainLocalGroupName } + if (-not $group) { + New-ADGroup -Name $domainLocalGroupName ` + -GroupScope DomainLocal ` + -Path $groupOU ` + -Description "DomainLocal Gruppe für $domainLocalGroupName" + $outputTextBox.SelectionColor = 'Green' + $outputTextBox.AppendText("DomainLocal Gruppe '$domainLocalGroupName' wurde erfolgreich erstellt.`r`n") + } else { + $outputTextBox.SelectionColor = 'Green' + $outputTextBox.AppendText("DomainLocal Gruppe '$domainLocalGroupName' existiert bereits.`r`n") + } + } + } + } catch { + # Fehler bei der Gruppen-Erstellung + $outputTextBox.SelectionColor = 'Red' + $outputTextBox.AppendText("Fehler bei der Erstellung der Gruppe '$groupName': $_.Exception.Message`r`n") + } + } + } +}) + +# Beenden-Button erstellen +$exitButton = New-Object System.Windows.Forms.Button +$exitButton.Text = "Beenden" +$exitButton.Size = New-Object System.Drawing.Size(280, 30) +$exitButton.Location = New-Object System.Drawing.Point(295, 475) # 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) + +# Formular anzeigen +$form.Show() \ No newline at end of file