AutoOUADCreator/AutoOUADCreator.ps1

42 lines
1.7 KiB
PowerShell
Raw Normal View History

2024-04-12 09:43:27 +00:00
# Copyright 2024 Rayyan Hodges, TAFE NSW, AlphaDelta
# Contact: rayyan.hodges@studytafensw.edu.au
# Program Name: AutoOUADCreator
# Purpose of script: Create a batch set of OU' using a CSV file within an existing Active Directory Forest.
# Extra Notes: Modify line 37 with appropriate domain info. (AlphaDelta.com is used in this scenario)
#Import the Active Directory module to allow modifcations to the forest.
import-module ActiveDirectory
#Get user to specify path of the CSV file containing OU names to be added into the Active Directory.
2024-04-12 10:42:13 +00:00
$fpath = Read-Host -Prompt "Please enter the path to your CSV file containing OU info to be added within the Active Directory Domain Forest"
2024-04-12 09:43:27 +00:00
2024-04-12 11:00:54 +00:00
# Check if the CSV file exists
if (Test-Path $fpath) {
# Display path to file given by end-user
echo $fpath
2024-04-12 09:43:27 +00:00
# Display path to file given by end-user
echo $fpath
#Import OU info from CSV file.
$fous = Import-Csv $fpath
#Create OU's within the Active Directory forest by looping throughout each row within the CSV file.
2024-04-12 11:12:06 +00:00
foreach ($row in $fous) {
2024-04-12 09:43:27 +00:00
# Get the name of the OU from the CSV
$ouName = $row.Name
# Check if the OU already exists
2024-04-12 11:18:05 +00:00
if (-not (Get-ADOrganizationalUnit -LDAPFilter "(Name=$ouName)")) {
2024-04-12 09:43:27 +00:00
# Create the OU
New-ADOrganizationalUnit -Name $ouName -Path "DC=alphadelta,DC=com" -ErrorAction SilentlyContinue
Write-Host "OU '$ouName' created successfully."
# If OU name already exists, simply display a message stating it exists and skip to next entry.
} else {
Write-Host "OU '$ouName' already exists, proceeding to next entry."
}
}
2024-04-12 11:12:06 +00:00
} else {
Write-Host "The specified CSV file does not exist."
2024-04-12 11:03:48 +00:00
}