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"
 | 
						|
 | 
						|
 |