Private/New-Template.ps1

Function New-Template {
    <#
        .Synopsis
            Creates a new PKI template.
 
        .DESCRIPTION
            This function creates a new PKI template in Active Directory Certificate Services.
 
        .EXAMPLE
            New-Template -DisplayName "CustomTemplate" -TemplateOtherAttributes @{
                'KeyType' = 'ExchangeSignature'
                'KeyUsage' = 'DigitalSignature'
            }
 
        .PARAMETER DisplayName
            Display Name of the new template.
 
        .PARAMETER TemplateOtherAttributes
             attributes in the form of a Hashtable for the new template.
 
        .NOTES
            Used Functions:
                Name | Module
                -------------------------------|--------------------------
                Get-ADDomainController | ActiveDirectory
                Get-ADRootDSE | ActiveDirectory
                New-ADObject | ActiveDirectory
                New-TemplateOID | EguibarIT
 
        .NOTES
            Version: 1.4
            DateModified: 08/Oct/2021
            LasModifiedBy: Vicente Rodriguez Eguibar
                vicente@eguibar.com
                Eguibar Information Technology S.L.
                http://www.eguibarit.com
    #>

    [CmdletBinding(SupportsShouldProcess = $true, ConfirmImpact = 'Low')]
    [OutputType([void])]

    Param(
        [Parameter(Mandatory = $true,
            ValueFromPipeline = $true,
            ValueFromPipelineByPropertyName = $true,
            ValueFromRemainingArguments = $False,
            HelpMessage = 'Display Name of the new template.',
            Position = 0)]
        [ValidateNotNullOrEmpty()]
        [System.String]
        $DisplayName,

        [Parameter(Mandatory = $True,
            ValueFromPipeline = $true,
            ValueFromPipelineByPropertyName = $true,
            ValueFromRemainingArguments = $False,
            HelpMessage = 'Other attributes in form of HashTable of the new template.',
            Position = 1)]
        [System.Collections.Hashtable]
        $TemplateOtherAttributes
    )

    Begin {
        $txt = ($constants.Header -f
            (Get-Date).ToShortDateString(),
            $MyInvocation.Mycommand,
            (Get-FunctionDisplay $PsBoundParameters -Verbose:$False)
        )
        Write-Verbose -Message $txt

        ##############################
        # Module imports



        ##############################
        # Variables Definition

        $WhatIfMessage = "Creating a new PKI template with DisplayName: '$DisplayName'"

        #grab DC
        $Server = (Get-ADDomainController -Discover -ForceDiscover -Writable).HostName[0]

        #grab Naming Context
        $ConfigNC = (Get-ADRootDSE -Server $Server).configurationNamingContext

        # parameters variable for splatting CMDlets
        $Splat = [hashtable]::New([StringComparer]::OrdinalIgnoreCase)

    } # End BEGIN section

    Process {
        Try {
            #Create OID
            $OID = New-TemplateOID -Server $Server -ConfigNC $ConfigNC

            $TemplateOIDPath = 'CN=OID,CN=Public Key Services,CN=Services,{0}' -f $ConfigNC
            $OIDOtherAttributes = @{
                'DisplayName'             = $DisplayName
                'flags'                   = [System.Int32]'1'
                'msPKI-Cert-Template-OID' = $OID.TemplateOID
            }
            New-ADObject -Path $TemplateOIDPath -OtherAttributes $OIDOtherAttributes -Name $OID.TemplateName -Type 'msPKI-Enterprise-Oid' -Server $Server

            # Ensure if msPKI-Cert-Template-OID already add it to hashtable
            If (-not $TemplateOtherAttributes.ContainsKey('msPKI-Cert-Template-OID')) {
                #Create Template itself
                $TemplateOtherAttributes += @{
                    'msPKI-Cert-Template-OID' = $OID.TemplateOID
                }
            }
            $TemplatePath = 'CN=Certificate Templates,CN=Public Key Services,CN=Services,{0}' -f $ConfigNC


            if ($PSCmdlet.ShouldProcess($TemplatePath, $WhatIfMessage)) {
                $Splat = @{
                    Path            = $TemplatePath
                    OtherAttributes = $TemplateOtherAttributes
                    Name            = $DisplayName
                    DisplayName     = $DisplayName
                    Type            = 'pKICertificateTemplate'
                    Server          = $Server
                }
                New-ADObject @Splat
            }

        } catch {
            # Handle errors here
            ###Get-CurrentErrorToDisplay -CurrentError $error[0]
            throw
        } #end Try-Catch
    } # End PROCESS section

    End {
        $txt = ($Constants.Footer -f $MyInvocation.InvocationName,
            'adding new PKI template.'
        )
        Write-Verbose -Message $txt
    } #end End section

} # End Function New-Template