dsclibrary/MEMBER_FILESERVER_ISCSI.DSC.ps1

<###################################################################################################
DSC Template Configuration File For use by LabBuilder
.Title
    MEMBER_FILESERVER_ISCSI
.Desription
    Builds a Server that is joined to a domain and then made into a File Server.
    Configures a iSCSI targets and virtual disks.
.Parameters:
    DomainName = "LABBUILDER.COM"
    DomainAdminPassword = "P@ssword!1"
    DCName = 'SA-DC1'
    PSDscAllowDomainUser = $True
    TargetName = 'sa-foc-target'
    VirtualDisks = @(
        @{ Path = 'D:\iSCSIVirtualDisks\sa-foc-witness.vhdx';
            DiskType = 'Dynamic';
            SizeBytes = 500MB;
        },
        @{ Path = 'D:\iSCSIVirtualDisks\sa-foc-disk1.vhdx';
            DiskType = 'Dynamic';
            SizeBytes = 10GB;
        },
        @{ Path = 'D:\iSCSIVirtualDisks\sa-foc-disk2.vhdx';
            DiskType = 'Dynamic';
            SizeBytes = 10GB;
        },
        @{ Path = 'D:\iSCSIVirtualDisks\sa-foc-disk3.vhdx';
            DiskType = 'Dynamic';
            SizeBytes = 10GB;
        }
    )
    ClusterInitiatorIds = @(
        'Iqn:iqn.1991-05.com.microsoft:sa-foc1.labbuilder.com'
        'Iqn:iqn.1991-05.com.microsoft:sa-foc2.labbuilder.com'
        'Iqn:iqn.1991-05.com.microsoft:sa-foc3.labbuilder.com'
    )
###################################################################################################>


Configuration MEMBER_FILESERVER_ISCSI
{
    Import-DscResource -ModuleName 'PSDesiredStateConfiguration'
    Import-DscResource -ModuleName ComputerManagementDsc
    Import-DscResource -ModuleName StorageDsc
    Import-DscResource -ModuleName xNetworking
    Import-DscResource -ModuleName ISCSI

    Node $AllNodes.NodeName {
        # Assemble the Local Admin Credentials
        if ($Node.LocalAdminPassword)
        {
            [PSCredential]$LocalAdminCredential = New-Object System.Management.Automation.PSCredential ("Administrator", (ConvertTo-SecureString $Node.LocalAdminPassword -AsPlainText -Force))
        }
        if ($Node.DomainAdminPassword)
        {
            [PSCredential]$DomainAdminCredential = New-Object System.Management.Automation.PSCredential ("$($Node.DomainName)\Administrator", (ConvertTo-SecureString $Node.DomainAdminPassword -AsPlainText -Force))
        }

        WindowsFeature FileServerInstall
        {
            Ensure = "Present"
            Name   = "FS-FileServer"
        }

        WindowsFeature DataDedupInstall
        {
            Ensure    = "Present"
            Name      = "FS-Data-Deduplication"
            DependsOn = "[WindowsFeature]FileServerInstall"
        }

        WindowsFeature BranchCacheInstall
        {
            Ensure    = "Present"
            Name      = "FS-BranchCache"
            DependsOn = "[WindowsFeature]DataDedupInstall"
        }

        WindowsFeature DFSNameSpaceInstall
        {
            Ensure    = "Present"
            Name      = "FS-DFS-Namespace"
            DependsOn = "[WindowsFeature]BranchCacheInstall"
        }

        WindowsFeature DFSReplicationInstall
        {
            Ensure    = "Present"
            Name      = "FS-DFS-Replication"
            DependsOn = "[WindowsFeature]DFSNameSpaceInstall"
        }

        WindowsFeature FSResourceManagerInstall
        {
            Ensure    = "Present"
            Name      = "FS-Resource-Manager"
            DependsOn = "[WindowsFeature]DFSReplicationInstall"
        }

        WindowsFeature FSSyncShareInstall
        {
            Ensure    = "Present"
            Name      = "FS-SyncShareService"
            DependsOn = "[WindowsFeature]FSResourceManagerInstall"
        }

        WindowsFeature StorageServicesInstall
        {
            Ensure    = "Present"
            Name      = "Storage-Services"
            DependsOn = "[WindowsFeature]FSSyncShareInstall"
        }

        WindowsFeature ISCSITargetServerInstall
        {
            Ensure    = "Present"
            Name      = "FS-iSCSITarget-Server"
            DependsOn = "[WindowsFeature]StorageServicesInstall"
        }

        # Wait for the Domain to be available so we can join it.
        WaitForAll DC
        {
            ResourceName     = '[xADDomain]PrimaryDC'
            NodeName         = $Node.DCname
            RetryIntervalSec = 15
            RetryCount       = 60
        }

        # Join this Server to the Domain
        Computer JoinDomain
        {
            Name       = $Node.NodeName
            DomainName = $Node.DomainName
            Credential = $DomainAdminCredential
            DependsOn  = "[WaitForAll]DC"
        }

        # Enable FSRM FireWall rules so we can remote manage FSRM
        xFirewall FSRMFirewall1
        {
            Name    = "FSRM-WMI-ASYNC-In-TCP"
            Ensure  = 'Present'
            Enabled = 'True'
        }

        xFirewall FSRMFirewall2
        {
            Name    = "FSRM-WMI-WINMGMT-In-TCP"
            Ensure  = 'Present'
            Enabled = 'True'
        }

        xFirewall FSRMFirewall3
        {
            Name    = "FSRM-RemoteRegistry-In (RPC)"
            Ensure  = 'Present'
            Enabled = 'True'
        }

        xFirewall FSRMFirewall4
        {
            Name    = "FSRM-Task-Scheduler-In (RPC)"
            Ensure  = 'Present'
            Enabled = 'True'
        }

        xFirewall FSRMFirewall5
        {
            Name    = "FSRM-SrmReports-In (RPC)"
            Ensure  = 'Present'
            Enabled = 'True'
        }

        xFirewall FSRMFirewall6
        {
            Name    = "FSRM-RpcSs-In (RPC-EPMAP)"
            Ensure  = 'Present'
            Enabled = 'True'
        }

        xFirewall FSRMFirewall7
        {
            Name    = "FSRM-System-In (TCP-445)"
            Ensure  = 'Present'
            Enabled = 'True'
        }

        xFirewall FSRMFirewall8
        {
            Name    = "FSRM-SrmSvc-In (RPC)"
            Ensure  = 'Present'
            Enabled = 'True'
        }

        WaitforDisk Disk2
        {
            DiskId           = 1
            RetryIntervalSec = 60
            RetryCount       = 60
            DependsOn        = "[Computer]JoinDomain"
        }

        Disk DVolume
        {
            DiskId      = 1
            DriveLetter = 'D'
            DependsOn   = "[WaitforDisk]Disk2"
        }

        File VirtualDisksFolder
        {
            Ensure          = 'Present'
            DestinationPath = 'D:\iSCSIVirtualDisks'
            Type            = 'Directory'
            DependsOn       = '[Disk]DVolume'
        }

        $DependsOn = '[File]VirtualDisksFolder'
        [Int] $Count = 0
        foreach ($VirtualDisk in $Node.VirtualDisks)
        {
            $Count++
            $Name = "$($Node.TargetName)_Disk_$Count"
            ISCSIVirtualDisk $Name
            {
                Ensure      = 'Present'
                Path        = $VirtualDisk.Path
                DiskType    = $VirtualDisk.DiskType
                SizeBytes   = $VirtualDisk.SizeBytes
                Description = $VirtualDisk.Description
                DependsOn   = $DependsOn
            }
            $DependsOn = "[ISCSIVirtualDisk]$Name"
        }

        ISCSIServerTarget ClusterServerTarget
        {
            Ensure       = 'Present'
            TargetName   = $Node.TargetName
            InitiatorIds = $Node.ClusterInitiatorIds
            Paths        = $Node.VirtualDisks.Path
            DependsOn    = $DependsOn
        }
    }
}