138 lines
		
	
	
		
			3.5 KiB
		
	
	
	
		
			YAML
		
	
	
	
	
	
			
		
		
	
	
			138 lines
		
	
	
		
			3.5 KiB
		
	
	
	
		
			YAML
		
	
	
	
	
	
| ---
 | |
| 
 | |
| - name: Hostname -> EXCHANGE
 | |
|   win_hostname:
 | |
|     name: EXCHANGE
 | |
|   register: res
 | |
| 
 | |
| - name: Reboot
 | |
|   win_reboot:
 | |
|   when: res.reboot_required
 | |
| 
 | |
| - name: Set HostOnly DNS Address
 | |
|   win_dns_client:
 | |
|     adapter_names: '*'
 | |
|     ipv4_addresses:
 | |
|       - 192.168.38.102
 | |
|       - 8.8.8.8
 | |
|     log_path: C:\dns_log.txt
 | |
| 
 | |
| - name: Install git
 | |
|   win_chocolatey:
 | |
|     name: git
 | |
|     state: present
 | |
| 
 | |
| - name: Check if existing DetectionLab directory
 | |
|   win_stat:
 | |
|     path: 'c:\DetectionLab'
 | |
|   register: dir
 | |
| 
 | |
| - name: Git clone Detectionlab
 | |
|   win_shell: git clone https://github.com/clong/DetectionLab.git
 | |
|   args:
 | |
|     chdir: 'c:\'
 | |
|   when: not dir.stat.exists
 | |
| 
 | |
| - name: Copy scripts to c:\vagrant
 | |
|   win_shell: Copy-Item -Recurse c:\DetectionLab\Vagrant c:\vagrant
 | |
| 
 | |
| - name: Join the Domain
 | |
|   win_shell: .\\provision.ps1
 | |
|   args:
 | |
|     chdir: 'c:\vagrant\scripts'
 | |
|   register: exchange_join_domain
 | |
|   changed_when: "'HasSucceeded : True' in exchange_join_domain.stdout"
 | |
| 
 | |
| - debug: msg="{{ exchange_join_domain.stdout_lines }}"
 | |
| 
 | |
| - name: Reboot After Joining the Domain
 | |
|   win_reboot:
 | |
|     msg: "Joining the domain. Rebooting..."
 | |
|     pre_reboot_delay: 5
 | |
|     reboot_timeout: 600
 | |
|     post_reboot_delay: 60
 | |
| 
 | |
| - name: Install Exchange Prereqs
 | |
|   win_command: powershell.exe .\\install-exchange.ps1
 | |
|   args:
 | |
|     chdir: 'c:\vagrant\scripts'
 | |
|   register: exchange_prereqs
 | |
|   changed_when: "'A reboot is required to continue installation of exchange.' in exchange_prereqs.stdout"
 | |
| 
 | |
| - debug: msg="{{ exchange_prereqs.stdout_lines }}"
 | |
| 
 | |
| - name: Reboot After Installing Exchange PreReqs
 | |
|   win_reboot:
 | |
|     msg: "Exchange Prereqs installed. Rebooting..."
 | |
|     pre_reboot_delay: 5
 | |
|     reboot_timeout: 600
 | |
|     post_reboot_delay: 60
 | |
| 
 | |
| - name: Download Exchange ISO and Mount It
 | |
|   win_shell: .\\install-exchange.ps1
 | |
|   args:
 | |
|     chdir: 'c:\vagrant\scripts'
 | |
|   register: download_exchange_iso
 | |
| 
 | |
| - name: Prepare Schema
 | |
|   win_package:
 | |
|     path: F:\Setup.exe
 | |
|     arguments: >-
 | |
|       /IAcceptExchangeServerLicenseTerms
 | |
|       /PrepareSchema
 | |
|     product_id: '{CD981244-E9B8-405A-9026-6AEB9DCEF1F1}'
 | |
|   vars:
 | |
|     ansible_become: yes
 | |
|     ansible_become_method: runas
 | |
|     ansible_become_user: WINDOMAIN\vagrant
 | |
|     ansible_become_password: vagrant
 | |
|   register: prepare_schema
 | |
| 
 | |
| - name: Prepare AD
 | |
|   win_package:
 | |
|     path: F:\Setup.exe
 | |
|     arguments: >-
 | |
|       /IAcceptExchangeServerLicenseTerms
 | |
|       /PrepareAD
 | |
|       /OrganizationName: DetectionLab
 | |
|     product_id: '{CD981244-E9B8-405A-9026-6AEB9DCEF1F1}'
 | |
|   vars:
 | |
|     ansible_become: yes
 | |
|     ansible_become_method: runas
 | |
|     ansible_become_user: WINDOMAIN\vagrant
 | |
|     ansible_become_password: vagrant
 | |
|   register: prepare_ad
 | |
| 
 | |
| - name: Install Exchange
 | |
|   win_package:
 | |
|     path: F:\Setup.exe
 | |
|     arguments: >-
 | |
|       /IAcceptExchangeServerLicenseTerms
 | |
|       /Mode:Install
 | |
|       /Role:Mailbox
 | |
|     product_id: '{CD981244-E9B8-405A-9026-6AEB9DCEF1F1}'
 | |
|   vars:
 | |
|     ansible_become: yes
 | |
|     ansible_become_method: runas
 | |
|     ansible_become_user: WINDOMAIN\vagrant
 | |
|     ansible_become_password: vagrant
 | |
|   register: install_exchange
 | |
| 
 | |
| - name: Reboot after Exchange Installation
 | |
|   win_reboot:
 | |
|     msg: "Exchange installed. Rebooting..."
 | |
|     pre_reboot_delay: 5
 | |
|     reboot_timeout: 600
 | |
|     post_reboot_delay: 60
 | |
| 
 | |
| - name: Clear Event Logs
 | |
|   win_shell: "wevtutil el | Select-String -notmatch \"Microsoft-Windows-LiveId\" | Foreach-Object {wevtutil cl \"$_\"}"
 | |
| 
 | |
| - name: Configure EXCHANGE with raw Commands
 | |
|   win_shell: "{{ item }}"
 | |
|   with_items:
 | |
|     - "wevtutil el | Select-String -notmatch \"Microsoft-Windows-LiveId\" | Foreach-Object {wevtutil cl \"$_\"}"
 | |
|     - "Set-SmbServerConfiguration -AuditSmb1Access $true -Force"
 | |
| 
 | |
| 
 | 
