-
Notifications
You must be signed in to change notification settings - Fork 3
/
Copy pathwin_adserver.ps1
71 lines (64 loc) · 2.28 KB
/
win_adserver.ps1
1
2
3
4
5
6
7
8
9
10
11
12
13
14
15
16
17
18
19
20
21
22
23
24
25
26
27
28
29
30
31
32
33
34
35
36
37
38
39
40
41
42
43
44
45
46
47
48
49
50
51
52
53
54
55
56
57
58
59
60
61
62
63
64
65
66
67
68
69
70
71
#!powershell
#
# Copyright 2016, Stanley Karunditu <[email protected]>
#
# Ansible is free software: you can redistribute it and/or modify
# it under the terms of the GNU General Public License as published by
# the Free Software Foundation, either version 3 of the License, or
# (at your option) any later version.
#
# Ansible is distributed in the hope that it will be useful,
# but WITHOUT ANY WARRANTY; without even the implied warranty of
# MERCHANTABILITY or FITNESS FOR A PARTICULAR PURPOSE. See the
# GNU General Public License for more details.
#
# You should have received a copy of the GNU General Public License
# along with Ansible. If not, see <http://www.gnu.org/licenses/>.
# WANT_JSON
# POWERSHELL_COMMON
$params = Parse-Args $args;
$result = New-Object psobject;
Set-Attr $result "changed" $false;
$domainname = Get-Attr $params "domain_name" -failifempty $true
$domainmode = Get-Attr $params "domain_mode" "Win2012R2"
$netbiosname = Get-Attr $params "netbios_name" -failifempty $true
$safemodepasswd = Get-Attr $params "safemode_passwd" -failifempty $true
$forestmode = Get-Attr $params "forest_mode" "WIN2012R2"
# check if AD feature is enabled
$adfeature = get-windowsfeature -name AD*
if ([string]::IsNullorEmpty($adfeature)) {
Fail-Json $result "AD Feature is not installed. Use win_feature using the name 'ad-domain-services' to get it installed"
}
# First check if domain is created
try {
$domain = Get-ADDomain
$domainroot = $domain.dnsroot
Set-Attr $result "msg" "Domain Exists. Domain Root is $domainroot"
Exit-Json $result
}
Catch
{
try {
Import-Module ADDSDeployment
Install-ADDSForest `
-CreateDnsDelegation:$false `
-DatabasePath "C:\Windows\NTDS" `
-DomainMode "$domainmode" `
-DomainName "$domainname" `
-DomainNetbiosName "$netbiosname" `
-ForestMode "$forestmode" `
-InstallDns:$true `
-safemodeadministratorpassword (convertto-securestring $safemodepasswd -asplaintext -force) `
-LogPath "C:\Windows\NTDS" `
-NoRebootOnCompletion:$false `
-SysvolPath "C:\Windows\SYSVOL" `
-Force:$true
$result.changed = $true
Set-Attr $result "msg" "New Domain Created. Domain Root is $domainname"
}
Catch
{
Fail-Json $result $_.Exception.Message
}
}
Exit-Json $result