From 87e08756ed9cf67d547cff74a105b0e0c48ceea8 Mon Sep 17 00:00:00 2001 From: Ariel Moisis Date: Thu, 10 Jan 2019 11:18:35 +1100 Subject: [PATCH 01/28] add missing params --- .../MSFT_xExchImapSettings.psm1 | 440 +++++++++++++++++- .../MSFT_xExchImapSettings.schema.mof | 25 + Tests/Unit/MSFT_xExchImapSettings.tests.ps1 | 54 ++- 3 files changed, 497 insertions(+), 22 deletions(-) diff --git a/DSCResources/MSFT_xExchImapSettings/MSFT_xExchImapSettings.psm1 b/DSCResources/MSFT_xExchImapSettings/MSFT_xExchImapSettings.psm1 index 1d908aa1..e656aa04 100644 --- a/DSCResources/MSFT_xExchImapSettings/MSFT_xExchImapSettings.psm1 +++ b/DSCResources/MSFT_xExchImapSettings/MSFT_xExchImapSettings.psm1 @@ -66,7 +66,107 @@ function Get-TargetResource [Parameter()] [System.String] - $X509CertificateName + $X509CertificateName, + + [Parameter()] + [System.String] + $AuthenticatedConnectionTimeout, # + + [Parameter()] + [System.String] + $Banner, + + [Parameter()] + [ValidateSet('iCalendar', 'intranetUrl', 'InternetUrl', 'Custom')] + [System.String] + $CalendarItemRetrievalOption, + + [Parameter()] + [System.Boolean] + $EnableExactRFC822Size, + + [Parameter()] + [System.Boolean] + $EnableGSSAPIAndNTLMAuth, + + [Parameter()] + [System.Boolean] + $EnforceCertificateErrors, + + [Parameter()] + [ValidateSet('None', 'Allow', 'Require')] + [System.String] + $ExtendedProtectionPolicy, + + [Parameter()] + [System.String[]] + $InternalConnectionSettings, + + [Parameter()] + [System.String] + $LogFileLocation, + + [Parameter()] + [ValidateSet('Hourly', 'Daily', 'Weekly', 'Monthly')] + [System.String] + $LogFileRollOverSettings, + + [Parameter()] + [System.String[]] + $LogPerFileSizeQuota, + + [Parameter()] + [System.Int32] + $MaxCommandSize, + + [Parameter()] + [System.Int32] + $MaxConnectionFromSingleIP, + + [Parameter()] + [System.Int32] + $MaxConnections, + + [Parameter()] + [System.Int32] + $MaxConnectionsPerUser, + + [Parameter()] + [ValidateSet('TextOnly', 'HtmlOnly', 'HtmlAndTextAlternative', 'TextEnrichedOnly', 'TextEnrichedAndTextAlternative', 'BestBodyFormat', 'Tnef')] + [System.String] + $MessageRetrievalMimeFormat, + + [Parameter()] + [System.String] + $OwaServerUrl, + + [Parameter()] + [System.String] + $PreAuthenticatedConnectionTimeout, + + [Parameter()] + [System.Boolean] + $ProtocolLogEnabled, + + [Parameter()] + [System.Int32] + $ProxyTargetPort, + + [Parameter()] + [System.Boolean] + $ShowHiddenFoldersEnabled, + + [Parameter()] + [System.String[]] + $SSLBindings, + + [Parameter()] + [System.Boolean] + $SuppressReadReceipt, + + [Parameter()] + [System.String[]] + $UnencryptedOrTLSBindings ) Write-FunctionEntry -Parameters @{ @@ -81,10 +181,34 @@ function Get-TargetResource if ($null -ne $imap) { $returnValue = @{ - Server = [System.String] $Server - ExternalConnectionSettings = [System.String[]] $imap.ExternalConnectionSettings - LoginType = [System.String] $imap.LoginType - X509CertificateName = [System.String] $imap.X509CertificateName + Server = [System.String] $Server + ExternalConnectionSettings = [System.String[]] $imap.ExternalConnectionSettings + LoginType = [System.String] $imap.LoginType + X509CertificateName = [System.String] $imap.X509CertificateName + AuthenticatedConnectionTimeout = [System.String] $imap.AuthenticatedConnectionTimeout + Banner = [System.String] $imap.Banner + CalendarItemRetrievalOption = [System.String] $imap.CalendarItemRetrievalOption + EnableExactRFC822Size = [System.Boolean] $imap.EnableExactRFC822Size + EnableGSSAPIAndNTLMAuth = [System.Boolean] $imap.EnableGSSAPIAndNTLMAuth + EnforceCertificateErrors = [System.Boolean] $imap.EnforceCertificateErrors + ExtendedProtectionPolicy = [System.String] $imap.ExtendedProtectionPolicy + InternalConnectionSettings = [System.String[]] $imap.InternalConnectionSettings + LogFileLocation = [System.String] $imap.LogFileLocation + LogFileRollOverSettings = [System.String] $imap.LogFileRollOverSettings + LogPerFileSizeQuota = [System.String[]] $imap.LogPerFileSizeQuota + MaxCommandSize = [System.Int32] $imap.MaxCommandSize + MaxConnectionFromSingleIP = [System.Int32] $imap.MaxConnectionFromSingleIP + MaxConnections = [System.Int32] $imap.MaxConnections + MaxConnectionsPerUser = [System.Int32] $imap.MaxConnectionsPerUser + MessageRetrievalMimeFormat = [System.String] $imap.MessageRetrievalMimeFormat + OwaServerUrl = [System.String] $imap.OwaServerUrl + PreAuthenticatedConnectionTimeout = [System.String] $imap.PreAuthenticatedConnectionTimeout + ProtocolLogEnabled = [System.Boolean] $imap.ProtocolLogEnabled + ProxyTargetPort = [System.Int32] $imap.ProxyTargetPort + ShowHiddenFoldersEnabled = [System.Boolean] $imap.ShowHiddenFoldersEnabled + SSLBindings = [System.String[]] $imap.SSLBindings + SuppressReadReceipt = [System.Boolean] $imap.SuppressReadReceipt + UnencryptedOrTLSBindings = [System.String[]] $imap.UnencryptedOrTLSBindings } } @@ -157,7 +281,107 @@ function Set-TargetResource [Parameter()] [System.String] - $X509CertificateName + $X509CertificateName, + + [Parameter()] + [System.String] + $AuthenticatedConnectionTimeout, # + + [Parameter()] + [System.String] + $Banner, + + [Parameter()] + [ValidateSet('iCalendar', 'intranetUrl', 'InternetUrl', 'Custom')] + [System.String] + $CalendarItemRetrievalOption, + + [Parameter()] + [System.Boolean] + $EnableExactRFC822Size, + + [Parameter()] + [System.Boolean] + $EnableGSSAPIAndNTLMAuth, + + [Parameter()] + [System.Boolean] + $EnforceCertificateErrors, + + [Parameter()] + [ValidateSet('None', 'Allow', 'Require')] + [System.String] + $ExtendedProtectionPolicy, + + [Parameter()] + [System.String[]] + $InternalConnectionSettings, + + [Parameter()] + [System.String] + $LogFileLocation, + + [Parameter()] + [ValidateSet('Hourly', 'Daily', 'Weekly', 'Monthly')] + [System.String] + $LogFileRollOverSettings, + + [Parameter()] + [System.String[]] + $LogPerFileSizeQuota, + + [Parameter()] + [System.Int32] + $MaxCommandSize, + + [Parameter()] + [System.Int32] + $MaxConnectionFromSingleIP, + + [Parameter()] + [System.Int32] + $MaxConnections, + + [Parameter()] + [System.Int32] + $MaxConnectionsPerUser, + + [Parameter()] + [ValidateSet('TextOnly', 'HtmlOnly', 'HtmlAndTextAlternative', 'TextEnrichedOnly', 'TextEnrichedAndTextAlternative', 'BestBodyFormat', 'Tnef')] + [System.String] + $MessageRetrievalMimeFormat, + + [Parameter()] + [System.String] + $OwaServerUrl, + + [Parameter()] + [System.String] + $PreAuthenticatedConnectionTimeout, + + [Parameter()] + [System.Boolean] + $ProtocolLogEnabled, + + [Parameter()] + [System.Int32] + $ProxyTargetPort, + + [Parameter()] + [System.Boolean] + $ShowHiddenFoldersEnabled, + + [Parameter()] + [System.String[]] + $SSLBindings, + + [Parameter()] + [System.Boolean] + $SuppressReadReceipt, + + [Parameter()] + [System.String[]] + $UnencryptedOrTLSBindings ) Write-FunctionEntry -Parameters @{ @@ -252,7 +476,107 @@ function Test-TargetResource [Parameter()] [System.String] - $X509CertificateName + $X509CertificateName, + + [Parameter()] + [System.String] + $AuthenticatedConnectionTimeout, # + + [Parameter()] + [System.String] + $Banner, + + [Parameter()] + [ValidateSet('iCalendar', 'intranetUrl', 'InternetUrl', 'Custom')] + [System.String] + $CalendarItemRetrievalOption, + + [Parameter()] + [System.Boolean] + $EnableExactRFC822Size, + + [Parameter()] + [System.Boolean] + $EnableGSSAPIAndNTLMAuth, + + [Parameter()] + [System.Boolean] + $EnforceCertificateErrors, + + [Parameter()] + [ValidateSet('None', 'Allow', 'Require')] + [System.String] + $ExtendedProtectionPolicy, + + [Parameter()] + [System.String[]] + $InternalConnectionSettings, + + [Parameter()] + [System.String] + $LogFileLocation, + + [Parameter()] + [ValidateSet('Hourly', 'Daily', 'Weekly', 'Monthly')] + [System.String] + $LogFileRollOverSettings, + + [Parameter()] + [System.String[]] + $LogPerFileSizeQuota, + + [Parameter()] + [System.Int32] + $MaxCommandSize, + + [Parameter()] + [System.Int32] + $MaxConnectionFromSingleIP, + + [Parameter()] + [System.Int32] + $MaxConnections, + + [Parameter()] + [System.Int32] + $MaxConnectionsPerUser, + + [Parameter()] + [ValidateSet('TextOnly', 'HtmlOnly', 'HtmlAndTextAlternative', 'TextEnrichedOnly', 'TextEnrichedAndTextAlternative', 'BestBodyFormat', 'Tnef')] + [System.String] + $MessageRetrievalMimeFormat, + + [Parameter()] + [System.String] + $OwaServerUrl, + + [Parameter()] + [System.String] + $PreAuthenticatedConnectionTimeout, + + [Parameter()] + [System.Boolean] + $ProtocolLogEnabled, + + [Parameter()] + [System.Int32] + $ProxyTargetPort, + + [Parameter()] + [System.Boolean] + $ShowHiddenFoldersEnabled, + + [Parameter()] + [System.String[]] + $SSLBindings, + + [Parameter()] + [System.Boolean] + $SuppressReadReceipt, + + [Parameter()] + [System.String[]] + $UnencryptedOrTLSBindings ) Write-FunctionEntry -Parameters @{ @@ -363,7 +687,107 @@ function Get-ImapSettingsInternal [Parameter()] [System.String] - $X509CertificateName + $X509CertificateName, + + [Parameter()] + [System.String] + $AuthenticatedConnectionTimeout, # + + [Parameter()] + [System.String] + $Banner, + + [Parameter()] + [ValidateSet('iCalendar', 'intranetUrl', 'InternetUrl', 'Custom')] + [System.String] + $CalendarItemRetrievalOption, + + [Parameter()] + [System.Boolean] + $EnableExactRFC822Size, + + [Parameter()] + [System.Boolean] + $EnableGSSAPIAndNTLMAuth, + + [Parameter()] + [System.Boolean] + $EnforceCertificateErrors, + + [Parameter()] + [ValidateSet('None', 'Allow', 'Require')] + [System.String] + $ExtendedProtectionPolicy, + + [Parameter()] + [System.String[]] + $InternalConnectionSettings, + + [Parameter()] + [System.String] + $LogFileLocation, + + [Parameter()] + [ValidateSet('Hourly', 'Daily', 'Weekly', 'Monthly')] + [System.String] + $LogFileRollOverSettings, + + [Parameter()] + [System.String[]] + $LogPerFileSizeQuota, + + [Parameter()] + [System.Int32] + $MaxCommandSize, + + [Parameter()] + [System.Int32] + $MaxConnectionFromSingleIP, + + [Parameter()] + [System.Int32] + $MaxConnections, + + [Parameter()] + [System.Int32] + $MaxConnectionsPerUser, + + [Parameter()] + [ValidateSet('TextOnly', 'HtmlOnly', 'HtmlAndTextAlternative', 'TextEnrichedOnly', 'TextEnrichedAndTextAlternative', 'BestBodyFormat', 'Tnef')] + [System.String] + $MessageRetrievalMimeFormat, + + [Parameter()] + [System.String] + $OwaServerUrl, + + [Parameter()] + [System.String] + $PreAuthenticatedConnectionTimeout, + + [Parameter()] + [System.Boolean] + $ProtocolLogEnabled, + + [Parameter()] + [System.Int32] + $ProxyTargetPort, + + [Parameter()] + [System.Boolean] + $ShowHiddenFoldersEnabled, + + [Parameter()] + [System.String[]] + $SSLBindings, + + [Parameter()] + [System.Boolean] + $SuppressReadReceipt, + + [Parameter()] + [System.String[]] + $UnencryptedOrTLSBindings ) Remove-FromPSBoundParametersUsingHashtable -PSBoundParametersIn $PSBoundParameters -ParamsToKeep 'Server', 'DomainController' diff --git a/DSCResources/MSFT_xExchImapSettings/MSFT_xExchImapSettings.schema.mof b/DSCResources/MSFT_xExchImapSettings/MSFT_xExchImapSettings.schema.mof index 83f7daad..a4bbfd15 100644 --- a/DSCResources/MSFT_xExchImapSettings/MSFT_xExchImapSettings.schema.mof +++ b/DSCResources/MSFT_xExchImapSettings/MSFT_xExchImapSettings.schema.mof @@ -9,4 +9,29 @@ class MSFT_xExchImapSettings : OMI_BaseResource [Write, Description("The ExternalConnectionSettings parameter specifies the host name, port, and encryption method that's used by external IMAP4 clients (IMAP4 connections from outside your corporate network).")] String ExternalConnectionSettings[]; [Write, Description("The LoginType parameter specifies the authentication method for IMAP4 connections."), ValueMap{"PlainTextLogin","PlainTextAuthentication","SecureLogin"}, Values{"PlainTextLogin","PlainTextAuthentication","SecureLogin"}] String LoginType; [Write, Description("The X509CertificateName parameter specifies the certificate that's used for encrypting IMAP4 client connections.")] String X509CertificateName; + [Write, Description("The AuthenticatedConnectionTimeout parameter specifies the period of time to wait before closing an idle authenticated connection.")] String AuthenticatedConnectionTimeout; + [Write, Description("The Banner parameter specifies the text string that's displayed to connecting IMAP4 clients.")] String Banner; + [Write, Description("The CalendarItemRetrievalOption parameter specifies how calendar items are presented to IMAP4 clients."), ValueMap{"iCalendar","intranetUrl","InternetUrl", "Custom"}, Values{"iCalendar","intranetUrl","InternetUrl", "Custom"}] String CalendarItemRetrievalOption; + [Write, Description("The EnableExactRFC822Size parameter specifies how message sizes are presented to IMAP4 clients.")] Boolean EnableExactRFC822Size; + [Write, Description("The EnableGSSAPIAndNTLMAuth parameter specifies whether connections can use Integrated Windows authentication (NTLM) using the Generic Security Services application programming interface (GSSAPI). This setting applies to connections where Transport Layer Security (TLS) is disabled.")] Boolean EnableGSSAPIAndNTLMAuth; + [Write, Description("The EnforceCertificateErrors parameter specifies whether to enforce valid Secure Sockets Layer (SSL) certificate validation failures.")] Boolean EnforceCertificateErrors; + [Write, Description("The ExtendedProtectionPolicy parameter specifies how Extended Protection for Authentication is used."), ValueMap{"None","Allow","Require", "Custom"}, Values{"None","Allow","Require", "Custom"}] String ExtendedProtectionPolicy; + [Write, Description("The InternalConnectionSettings parameter specifies the host name, port, and encryption method that's used by internal IMAP4 clients (IMAP4 connections from inside your corporate network).")] String InternalConnectionSettings[]; + [Write, Description("The LogFileLocation parameter specifies the location for the IMAP4 protocol log files.")] String LogFileLocation; + [Write, Description("The LogFileRollOverSettings parameter specifies how frequently IMAP4 protocol logging creates a new log file."), ValueMap{"Hourly","Daily","Weekly", "Monthly"}, Values{"Hourly","Daily","Weekly", "Monthly"}] String LogFileRollOverSettings; + [Write, Description("The LogPerFileSizeQuota parameter specifies the maximum size of a IMAP4 protocol log file.")] String LogPerFileSizeQuota; + [Write, Description("The MaxCommandSize parameter specifies the maximum size in bytes of a single IMAP4 command.")] SInt32 MaxCommandSize; + [Write, Description("The MaxConnectionFromSingleIP parameter specifies the maximum number of IMAP4 connections that are accepted by the Exchange server from a single IP address.")] SInt32 MaxConnectionFromSingleIP; + [Write, Description("The MaxConnections parameter specifies the maximum number of IMAP4 connections that are accepted by the Exchange server.")] SInt32 MaxConnections; + [Write, Description("The MaxConnectionsPerUser parameter specifies the maximum number of IMAP4 connections that are allowed for each user.")] SInt32 MaxConnectionsPerUser; + [Write, Description("The MessageRetrievalMimeFormat parameter specifies the MIME encoding of messages."), ValueMap{"TextOnly","HtmlOnly","HtmlAndTextAlternative","TextEnrichedOnly","TextEnrichedAndTextAlternative","BestBodyFormat","Tnef"}, Values{"TextOnly","HtmlOnly","HtmlAndTextAlternative","TextEnrichedOnly","TextEnrichedAndTextAlternative","BestBodyFormat","Tnef"}] String MessageRetrievalMimeFormat; + [Write, Description("The OwaServerUrl parameter specifies the URL that's used to retrieve calendar information for instances of custom Outlook on the web calendar items.")] String OwaServerUrl; + [Write, Description("The PreAuthenticatedConnectionTimeout parameter specifies the period of time to wait before closing an idle IMAP4 connection that isn't authenticated.")] String PreAuthenticatedConnectionTimeout; + [Write, Description("The ProtocolLogEnabled parameter specifies whether to enable protocol logging for IMAP4.")] Boolean ProtocolLogEnabled; + [Write, Description("The ProxyTargetPort parameter specifies the port on the Microsoft Exchange IMAP4 Backend service that listens for client connections that are proxied from the Microsoft Exchange IMAP4 service.")] SInt32 ProxyTargetPort; + [Write, Description("")]Server ] + [Write, Description("The ShowHiddenFoldersEnabled parameter specifies whether hidden mailbox folders are visible.")] Boolean ShowHiddenFoldersEnabled; + [Write, Description("The SSLBindings parameter specifies the IP address and TCP port that's used for IMAP4 connection that's always encrypted by SSL/TLS. This parameter uses the syntax :.")] String SSLBindings[]; + [Write, Description("The SuppressReadReceipt parameter specifies whether to stop duplicate read receipts from being sent to IMAP4 clients that have the Send read receipts for messages I send setting configured in their IMAP4 email program.")] Boolean SuppressReadReceipt; + [Write, Description("The X509CertificateName parameter specifies the certificate that's used for encrypting IMAP4 client connections.")]String UnencryptedOrTLSBindings[]; }; diff --git a/Tests/Unit/MSFT_xExchImapSettings.tests.ps1 b/Tests/Unit/MSFT_xExchImapSettings.tests.ps1 index 7e6e8cff..98763fa7 100644 --- a/Tests/Unit/MSFT_xExchImapSettings.tests.ps1 +++ b/Tests/Unit/MSFT_xExchImapSettings.tests.ps1 @@ -37,28 +37,54 @@ try Invoke-TestSetup InModuleScope $script:DSCResourceName { + + Mock -CommandName Write-FunctionEntry -Verifiable + + $commonTargetResourceParams = @{ + Server = 'Server' + Credential = New-Object -TypeName System.Management.Automation.PSCredential -ArgumentList 'fakeuser', (New-Object -TypeName System.Security.SecureString) + } + + $commonImapSettingsStandardOutput = @{ + ExternalConnectionSettings = [System.String[]] @() + LoginType = [System.String] '' + X509CertificateName = [System.String] '' + AuthenticatedConnectionTimeout = [System.String] '' + Banner = [System.String] '' + CalendarItemRetrievalOption = [System.String] '' + EnableExactRFC822Size = [System.Boolean] $false + EnableGSSAPIAndNTLMAuth = [System.Boolean] $false + EnforceCertificateErrors = [System.Boolean] $false + ExtendedProtectionPolicy = [System.String] '' + InternalConnectionSettings = [System.String[]] @() + LogFileLocation = [System.String] '' + LogFileRollOverSettings = [System.String] '' + LogPerFileSizeQuota = [System.String[]] @() + MaxCommandSize = [System.Int32] 1 + MaxConnectionFromSingleIP = [System.Int32] 1 + MaxConnections = [System.Int32] 1 + MaxConnectionsPerUser = [System.Int32] 1 + MessageRetrievalMimeFormat = [System.String] '' + OwaServerUrl = [System.String] '' + PreAuthenticatedConnectionTimeout = [System.String] '' + ProtocolLogEnabled = [System.Boolean] $false + ProxyTargetPort = [System.Int32] 1 + ShowHiddenFoldersEnabled = [System.Boolean] $false + SSLBindings = [System.String[]] @() + SuppressReadReceipt = [System.Boolean] $false + UnencryptedOrTLSBindings = [System.String[]] @() + } Describe 'MSFT_xExchImapSettings\Get-TargetResource' -Tag 'Get' { AfterEach { Assert-VerifiableMock } - $getTargetResourceParams = @{ - Server = 'Server' - Credential = New-Object -TypeName System.Management.Automation.PSCredential -ArgumentList 'fakeuser', (New-Object -TypeName System.Security.SecureString) - } - - $getImapSettingsStandardOutput = @{ - ExternalConnectionSettings = [System.String[]] @() - LoginType = [System.String] '' - X509CertificateName = [System.String] '' - } - Context 'When Get-TargetResource is called' { - Mock -CommandName Write-FunctionEntry -Verifiable + Mock -CommandName Get-RemoteExchangeSession -Verifiable - Mock -CommandName Get-ImapSettingsInternal -Verifiable -MockWith { return $getImapSettingsStandardOutput } + Mock -CommandName Get-ImapSettingsInternal -Verifiable -MockWith { return $commonImapSettingsStandardOutput } - Test-CommonGetTargetResourceFunctionality -GetTargetResourceParams $getTargetResourceParams + Test-CommonGetTargetResourceFunctionality -GetTargetResourceParams $commonTargetResourceParams } } } From 24556a3f26b8eb73fc54f3504ec50d79489634ca Mon Sep 17 00:00:00 2001 From: Ariel Moisis Date: Fri, 11 Jan 2019 09:03:08 +1100 Subject: [PATCH 02/28] Add missing params and unit tests --- CHANGELOG.md | 1 + .../MSFT_xExchImapSettings.psm1 | 123 +++++++++++++++++- Tests/Unit/MSFT_xExchImapSettings.tests.ps1 | 67 +++++++++- 3 files changed, 187 insertions(+), 4 deletions(-) diff --git a/CHANGELOG.md b/CHANGELOG.md index 1aadab3d..b71da4d2 100644 --- a/CHANGELOG.md +++ b/CHANGELOG.md @@ -4,6 +4,7 @@ - Added xExchAddressList ressource - Added xExchSendConnector resource +- Added additional parameters to the MSFT_xExchImapSettings resource ## 1.30.0.0 diff --git a/DSCResources/MSFT_xExchImapSettings/MSFT_xExchImapSettings.psm1 b/DSCResources/MSFT_xExchImapSettings/MSFT_xExchImapSettings.psm1 index e656aa04..b8f09f95 100644 --- a/DSCResources/MSFT_xExchImapSettings/MSFT_xExchImapSettings.psm1 +++ b/DSCResources/MSFT_xExchImapSettings/MSFT_xExchImapSettings.psm1 @@ -398,8 +398,7 @@ function Set-TargetResource if ($AllowServiceRestart -eq $true) { Write-Verbose -Message 'Restarting IMAP Services' - - Get-Service MSExchangeIMAP4* | Restart-Service + Restart-Service -Name MSExchangeIMAP4* -WarningAction SilentlyContinue } else { @@ -614,6 +613,126 @@ function Test-TargetResource { $testResults = $false } + + if (!(Test-ExchangeSetting -Name 'AuthenticatedConnectionTimeout' -Type 'Timespan' -ExpectedValue $AuthenticatedConnectionTimeout -ActualValue $imap.AuthenticatedConnectionTimeout -PSBoundParametersIn $PSBoundParameters -Verbose:$VerbosePreference)) + { + $testResults = $false + } + + if (!(Test-ExchangeSetting -Name 'Banner' -Type 'String' -ExpectedValue $Banner -ActualValue $imap.Banner -PSBoundParametersIn $PSBoundParameters -Verbose:$VerbosePreference)) + { + $testResults = $false + } + + if (!(Test-ExchangeSetting -Name 'CalendarItemRetrievalOption' -Type 'String' -ExpectedValue $CalendarItemRetrievalOption -ActualValue $imap.CalendarItemRetrievalOption -PSBoundParametersIn $PSBoundParameters -Verbose:$VerbosePreference)) + { + $testResults = $false + } + + if (!(Test-ExchangeSetting -Name 'EnableExactRFC822Size' -Type 'Boolean' -ExpectedValue $EnableExactRFC822Size -ActualValue $imap.EnableExactRFC822Size -PSBoundParametersIn $PSBoundParameters -Verbose:$VerbosePreference)) + { + $testResults = $false + } + + if (!(Test-ExchangeSetting -Name 'EnableGSSAPIAndNTLMAuth' -Type 'Boolean' -ExpectedValue $EnableGSSAPIAndNTLMAuth -ActualValue $imap.EnableGSSAPIAndNTLMAuth -PSBoundParametersIn $PSBoundParameters -Verbose:$VerbosePreference)) + { + $testResults = $false + } + + if (!(Test-ExchangeSetting -Name 'EnforceCertificateErrors' -Type 'Boolean' -ExpectedValue $EnforceCertificateErrors -ActualValue $imap.EnforceCertificateErrors -PSBoundParametersIn $PSBoundParameters -Verbose:$VerbosePreference)) + { + $testResults = $false + } + + if (!(Test-ExchangeSetting -Name 'ExtendedProtectionPolicy' -Type 'String' -ExpectedValue $ExtendedProtectionPolicy -ActualValue $imap.ExtendedProtectionPolicy -PSBoundParametersIn $PSBoundParameters -Verbose:$VerbosePreference)) + { + $testResults = $false + } + + if (!(Test-ExchangeSetting -Name 'InternalConnectionSettings' -Type 'Array' -ExpectedValue $InternalConnectionSettings -ActualValue $imap.InternalConnectionSettings -PSBoundParametersIn $PSBoundParameters -Verbose:$VerbosePreference)) + { + $testResults = $false + } + + if (!(Test-ExchangeSetting -Name 'LogFileLocation' -Type 'String' -ExpectedValue $LogFileLocation -ActualValue $imap.LogFileLocation -PSBoundParametersIn $PSBoundParameters -Verbose:$VerbosePreference)) + { + $testResults = $false + } + + if (!(Test-ExchangeSetting -Name 'LogFileRollOverSettings' -Type 'String' -ExpectedValue $LogFileRollOverSettings -ActualValue $imap.LogFileRollOverSettings -PSBoundParametersIn $PSBoundParameters -Verbose:$VerbosePreference)) + { + $testResults = $false + } + + if (!(Test-ExchangeSetting -Name 'LogPerFileSizeQuota' -Type 'Array' -ExpectedValue $LogPerFileSizeQuota -ActualValue $imap.LogPerFileSizeQuota -PSBoundParametersIn $PSBoundParameters -Verbose:$VerbosePreference)) + { + $testResults = $false + } + + if (!(Test-ExchangeSetting -Name 'MaxCommandSize' -Type 'Int' -ExpectedValue $MaxCommandSize -ActualValue $imap.MaxCommandSize -PSBoundParametersIn $PSBoundParameters -Verbose:$VerbosePreference)) + { + $testResults = $false + } + + if (!(Test-ExchangeSetting -Name 'MaxConnectionFromSingleIP' -Type 'Int' -ExpectedValue $MaxConnectionFromSingleIP -ActualValue $imap.MaxConnectionFromSingleIP -PSBoundParametersIn $PSBoundParameters -Verbose:$VerbosePreference)) + { + $testResults = $false + } + + if (!(Test-ExchangeSetting -Name 'MaxConnections' -Type 'Int' -ExpectedValue $MaxConnections -ActualValue $imap.MaxConnections -PSBoundParametersIn $PSBoundParameters -Verbose:$VerbosePreference)) + { + $testResults = $false + } + + if (!(Test-ExchangeSetting -Name 'MaxConnectionsPerUser' -Type 'Int' -ExpectedValue $MaxConnectionsPerUser -ActualValue $imap.MaxConnectionsPerUser -PSBoundParametersIn $PSBoundParameters -Verbose:$VerbosePreference)) + { + $testResults = $false + } + + if (!(Test-ExchangeSetting -Name 'MessageRetrievalMimeFormat' -Type 'String' -ExpectedValue $MessageRetrievalMimeFormat -ActualValue $imap.MessageRetrievalMimeFormat -PSBoundParametersIn $PSBoundParameters -Verbose:$VerbosePreference)) + { + $testResults = $false + } + + if (!(Test-ExchangeSetting -Name 'OwaServerUrl' -Type 'String' -ExpectedValue $OwaServerUrl -ActualValue $imap.OwaServerUrl -PSBoundParametersIn $PSBoundParameters -Verbose:$VerbosePreference)) + { + $testResults = $false + } + + if (!(Test-ExchangeSetting -Name 'PreAuthenticatedConnectionTimeout' -Type 'Timespan' -ExpectedValue $PreAuthenticatedConnectionTimeout -ActualValue $imap.PreAuthenticatedConnectionTimeout -PSBoundParametersIn $PSBoundParameters -Verbose:$VerbosePreference)) + { + $testResults = $false + } + + if (!(Test-ExchangeSetting -Name 'ProtocolLogEnabled' -Type 'Boolean' -ExpectedValue $ProtocolLogEnabled -ActualValue $imap.ProtocolLogEnabled -PSBoundParametersIn $PSBoundParameters -Verbose:$VerbosePreference)) + { + $testResults = $false + } + + if (!(Test-ExchangeSetting -Name 'ProxyTargetPort' -Type 'Int' -ExpectedValue $ProxyTargetPort -ActualValue $imap.ProxyTargetPort -PSBoundParametersIn $PSBoundParameters -Verbose:$VerbosePreference)) + { + $testResults = $false + } + + if (!(Test-ExchangeSetting -Name 'ShowHiddenFoldersEnabled' -Type 'Boolean' -ExpectedValue $ShowHiddenFoldersEnabled -ActualValue $imap.ShowHiddenFoldersEnabled -PSBoundParametersIn $PSBoundParameters -Verbose:$VerbosePreference)) + { + $testResults = $false + } + + if (!(Test-ExchangeSetting -Name 'SSLBindings' -Type 'Array' -ExpectedValue $SSLBindings -ActualValue $imap.SSLBindings -PSBoundParametersIn $PSBoundParameters -Verbose:$VerbosePreference)) + { + $testResults = $false + } + + if (!(Test-ExchangeSetting -Name 'SuppressReadReceipt' -Type 'Boolean' -ExpectedValue $SuppressReadReceipt -ActualValue $imap.SuppressReadReceipt -PSBoundParametersIn $PSBoundParameters -Verbose:$VerbosePreference)) + { + $testResults = $false + } + + if (!(Test-ExchangeSetting -Name 'UnencryptedOrTLSBindings' -Type 'Array' -ExpectedValue $UnencryptedOrTLSBindings -ActualValue $imap.UnencryptedOrTLSBindings -PSBoundParametersIn $PSBoundParameters -Verbose:$VerbosePreference)) + { + $testResults = $false + } } return $testResults diff --git a/Tests/Unit/MSFT_xExchImapSettings.tests.ps1 b/Tests/Unit/MSFT_xExchImapSettings.tests.ps1 index 98763fa7..38a8586d 100644 --- a/Tests/Unit/MSFT_xExchImapSettings.tests.ps1 +++ b/Tests/Unit/MSFT_xExchImapSettings.tests.ps1 @@ -41,8 +41,9 @@ try Mock -CommandName Write-FunctionEntry -Verifiable $commonTargetResourceParams = @{ - Server = 'Server' - Credential = New-Object -TypeName System.Management.Automation.PSCredential -ArgumentList 'fakeuser', (New-Object -TypeName System.Security.SecureString) + Server = 'Server' + Credential = New-Object -TypeName System.Management.Automation.PSCredential -ArgumentList 'fakeuser', (New-Object -TypeName System.Security.SecureString) + AllowServiceRestart = $true } $commonImapSettingsStandardOutput = @{ @@ -74,6 +75,7 @@ try SuppressReadReceipt = [System.Boolean] $false UnencryptedOrTLSBindings = [System.String[]] @() } + Describe 'MSFT_xExchImapSettings\Get-TargetResource' -Tag 'Get' { AfterEach { Assert-VerifiableMock @@ -87,6 +89,67 @@ try Test-CommonGetTargetResourceFunctionality -GetTargetResourceParams $commonTargetResourceParams } } + + Describe 'MSFT_xExchImapSettings\Set-TargetResource' -Tag 'Set' { + # Override Exchange cmdlets + Mock -CommandName Get-RemoteExchangeSession -Verifiable + function Set-ImapSettings {} + + AfterEach { + Assert-VerifiableMock + } + + Context 'When Set-TargetResource is called' { + It 'Should call expected functions when AllowServiceRestart is true' { + Mock -CommandName Set-ImapSettings -Verifiable + Mock -CommandName Restart-Service -Verifiable + + Set-TargetResource @commonTargetResourceParams + } + + + It 'Should warn that a MSExchangeIMAP4 service restart is required' { + $AllowServiceRestart = $commonTargetResourceParams.AllowServiceRestart + $commonTargetResourceParams.AllowServiceRestart = $false + Mock -CommandName Set-ImapSettings -Verifiable + Mock -CommandName Write-Warning -Verifiable -ParameterFilter {$Message -eq 'The configuration will not take effect until MSExchangeIMAP4 services are manually restarted.'} + + Set-TargetResource @commonTargetResourceParams + $commonTargetResourceParams.AllowServiceRestart = $AllowServiceRestart + } + } + } + + Describe 'MSFT_xExchImapSettings\Test-TargetResource' -Tag 'Test' { + # Override Exchange cmdlets + Mock -CommandName Get-RemoteExchangeSession -Verifiable + + AfterEach { + Assert-VerifiableMock + } + + Context 'When Test-TargetResource is called' { + It 'Should return False when Get-UMCallRouterSettings returns null' { + Mock -CommandName Get-ImapSettingsInternal -Verifiable + + Test-TargetResource @commonTargetResourceParams -ErrorAction SilentlyContinue | Should -Be $false + } + + It 'Should return False when Test-ExchangeSetting returns False' { + Mock -CommandName Get-ImapSettingsInternal -Verifiable -MockWith { return $commonImapSettingsStandardOutput } + Mock -CommandName Test-ExchangeSetting -Verifiable -MockWith { return $false } + + Test-TargetResource @commonTargetResourceParams | Should -Be $false + } + + It 'Should return True when Test-ExchangeSetting returns True' { + Mock -CommandName Get-ImapSettingsInternal -Verifiable -MockWith { return $commonImapSettingsStandardOutput } + Mock -CommandName Test-ExchangeSetting -Verifiable -MockWith { return $true } + + Test-TargetResource @commonTargetResourceParams | Should -Be $true + } + } + } } } finally From bb470313edf0a1bb5bf975e14bbd7d1c042c9328 Mon Sep 17 00:00:00 2001 From: Ariel Moisis Date: Thu, 10 Jan 2019 11:18:35 +1100 Subject: [PATCH 03/28] add missing params --- Tests/Unit/MSFT_xExchImapSettings.tests.ps1 | 1 - 1 file changed, 1 deletion(-) diff --git a/Tests/Unit/MSFT_xExchImapSettings.tests.ps1 b/Tests/Unit/MSFT_xExchImapSettings.tests.ps1 index 38a8586d..a5faecff 100644 --- a/Tests/Unit/MSFT_xExchImapSettings.tests.ps1 +++ b/Tests/Unit/MSFT_xExchImapSettings.tests.ps1 @@ -75,7 +75,6 @@ try SuppressReadReceipt = [System.Boolean] $false UnencryptedOrTLSBindings = [System.String[]] @() } - Describe 'MSFT_xExchImapSettings\Get-TargetResource' -Tag 'Get' { AfterEach { Assert-VerifiableMock From 5541f48004d903c8aa91996d29252e086fc5e15d Mon Sep 17 00:00:00 2001 From: Ariel Moisis Date: Fri, 11 Jan 2019 09:03:08 +1100 Subject: [PATCH 04/28] Add missing params and unit tests --- Tests/Unit/MSFT_xExchImapSettings.tests.ps1 | 1 + 1 file changed, 1 insertion(+) diff --git a/Tests/Unit/MSFT_xExchImapSettings.tests.ps1 b/Tests/Unit/MSFT_xExchImapSettings.tests.ps1 index a5faecff..38a8586d 100644 --- a/Tests/Unit/MSFT_xExchImapSettings.tests.ps1 +++ b/Tests/Unit/MSFT_xExchImapSettings.tests.ps1 @@ -75,6 +75,7 @@ try SuppressReadReceipt = [System.Boolean] $false UnencryptedOrTLSBindings = [System.String[]] @() } + Describe 'MSFT_xExchImapSettings\Get-TargetResource' -Tag 'Get' { AfterEach { Assert-VerifiableMock From 9acfa694a04c6edbc190901898310389d999e5dd Mon Sep 17 00:00:00 2001 From: Ariel Moisis Date: Fri, 25 Jan 2019 11:02:24 +1100 Subject: [PATCH 05/28] remove duplicate server parameter in mof --- .../MSFT_xExchImapSettings/MSFT_xExchImapSettings.schema.mof | 3 +-- 1 file changed, 1 insertion(+), 2 deletions(-) diff --git a/DSCResources/MSFT_xExchImapSettings/MSFT_xExchImapSettings.schema.mof b/DSCResources/MSFT_xExchImapSettings/MSFT_xExchImapSettings.schema.mof index a4bbfd15..7090d168 100644 --- a/DSCResources/MSFT_xExchImapSettings/MSFT_xExchImapSettings.schema.mof +++ b/DSCResources/MSFT_xExchImapSettings/MSFT_xExchImapSettings.schema.mof @@ -5,7 +5,7 @@ class MSFT_xExchImapSettings : OMI_BaseResource [Key, Description("The IMAP server to configure.")] String Server; [Required, Description("Credentials used to establish a remote PowerShell session to Exchange."), EmbeddedInstance("MSFT_Credential")] String Credential; [Write, Description("Whether it is OK to restart the IMAP services after making changes. Defaults to $false.")] Boolean AllowServiceRestart; - [Write, Description("The DomainController parameter specifies the domain controller that's used by this cmdlet to read data from or write data to Active Directory. You identify the domain controller by its fully qualified domain name (FQDN). For example, dc01.contoso.com.")] String DomainController; //Optional Domain Controller to connect to + [Write, Description("The DomainController parameter specifies the domain controller that's used by this cmdlet to read data from or write data to Active Directory. You identify the domain controller by its fully qualified domain name (FQDN). For example, dc01.contoso.com.")] String DomainController; [Write, Description("The ExternalConnectionSettings parameter specifies the host name, port, and encryption method that's used by external IMAP4 clients (IMAP4 connections from outside your corporate network).")] String ExternalConnectionSettings[]; [Write, Description("The LoginType parameter specifies the authentication method for IMAP4 connections."), ValueMap{"PlainTextLogin","PlainTextAuthentication","SecureLogin"}, Values{"PlainTextLogin","PlainTextAuthentication","SecureLogin"}] String LoginType; [Write, Description("The X509CertificateName parameter specifies the certificate that's used for encrypting IMAP4 client connections.")] String X509CertificateName; @@ -29,7 +29,6 @@ class MSFT_xExchImapSettings : OMI_BaseResource [Write, Description("The PreAuthenticatedConnectionTimeout parameter specifies the period of time to wait before closing an idle IMAP4 connection that isn't authenticated.")] String PreAuthenticatedConnectionTimeout; [Write, Description("The ProtocolLogEnabled parameter specifies whether to enable protocol logging for IMAP4.")] Boolean ProtocolLogEnabled; [Write, Description("The ProxyTargetPort parameter specifies the port on the Microsoft Exchange IMAP4 Backend service that listens for client connections that are proxied from the Microsoft Exchange IMAP4 service.")] SInt32 ProxyTargetPort; - [Write, Description("")]Server ] [Write, Description("The ShowHiddenFoldersEnabled parameter specifies whether hidden mailbox folders are visible.")] Boolean ShowHiddenFoldersEnabled; [Write, Description("The SSLBindings parameter specifies the IP address and TCP port that's used for IMAP4 connection that's always encrypted by SSL/TLS. This parameter uses the syntax :.")] String SSLBindings[]; [Write, Description("The SuppressReadReceipt parameter specifies whether to stop duplicate read receipts from being sent to IMAP4 clients that have the Send read receipts for messages I send setting configured in their IMAP4 email program.")] Boolean SuppressReadReceipt; From a84964963095607c7ef1bceb43250d45edc5d4d7 Mon Sep 17 00:00:00 2001 From: Ariel Moisis Date: Fri, 25 Jan 2019 11:48:06 +1100 Subject: [PATCH 06/28] remove custom from mof definition for ExtendedProtectionPolicy --- .../MSFT_xExchImapSettings/MSFT_xExchImapSettings.psm1 | 8 ++++---- .../MSFT_xExchImapSettings.schema.mof | 2 +- 2 files changed, 5 insertions(+), 5 deletions(-) diff --git a/DSCResources/MSFT_xExchImapSettings/MSFT_xExchImapSettings.psm1 b/DSCResources/MSFT_xExchImapSettings/MSFT_xExchImapSettings.psm1 index b8f09f95..bdd88158 100644 --- a/DSCResources/MSFT_xExchImapSettings/MSFT_xExchImapSettings.psm1 +++ b/DSCResources/MSFT_xExchImapSettings/MSFT_xExchImapSettings.psm1 @@ -70,7 +70,7 @@ function Get-TargetResource [Parameter()] [System.String] - $AuthenticatedConnectionTimeout, # + $AuthenticatedConnectionTimeout, [Parameter()] [System.String] @@ -285,7 +285,7 @@ function Set-TargetResource [Parameter()] [System.String] - $AuthenticatedConnectionTimeout, # + $AuthenticatedConnectionTimeout, [Parameter()] [System.String] @@ -479,7 +479,7 @@ function Test-TargetResource [Parameter()] [System.String] - $AuthenticatedConnectionTimeout, # + $AuthenticatedConnectionTimeout, [Parameter()] [System.String] @@ -810,7 +810,7 @@ function Get-ImapSettingsInternal [Parameter()] [System.String] - $AuthenticatedConnectionTimeout, # + $AuthenticatedConnectionTimeout, [Parameter()] [System.String] diff --git a/DSCResources/MSFT_xExchImapSettings/MSFT_xExchImapSettings.schema.mof b/DSCResources/MSFT_xExchImapSettings/MSFT_xExchImapSettings.schema.mof index 7090d168..6bd042f2 100644 --- a/DSCResources/MSFT_xExchImapSettings/MSFT_xExchImapSettings.schema.mof +++ b/DSCResources/MSFT_xExchImapSettings/MSFT_xExchImapSettings.schema.mof @@ -15,7 +15,7 @@ class MSFT_xExchImapSettings : OMI_BaseResource [Write, Description("The EnableExactRFC822Size parameter specifies how message sizes are presented to IMAP4 clients.")] Boolean EnableExactRFC822Size; [Write, Description("The EnableGSSAPIAndNTLMAuth parameter specifies whether connections can use Integrated Windows authentication (NTLM) using the Generic Security Services application programming interface (GSSAPI). This setting applies to connections where Transport Layer Security (TLS) is disabled.")] Boolean EnableGSSAPIAndNTLMAuth; [Write, Description("The EnforceCertificateErrors parameter specifies whether to enforce valid Secure Sockets Layer (SSL) certificate validation failures.")] Boolean EnforceCertificateErrors; - [Write, Description("The ExtendedProtectionPolicy parameter specifies how Extended Protection for Authentication is used."), ValueMap{"None","Allow","Require", "Custom"}, Values{"None","Allow","Require", "Custom"}] String ExtendedProtectionPolicy; + [Write, Description("The ExtendedProtectionPolicy parameter specifies how Extended Protection for Authentication is used."), ValueMap{"None","Allow","Require"}, Values{"None","Allow","Require"}] String ExtendedProtectionPolicy; [Write, Description("The InternalConnectionSettings parameter specifies the host name, port, and encryption method that's used by internal IMAP4 clients (IMAP4 connections from inside your corporate network).")] String InternalConnectionSettings[]; [Write, Description("The LogFileLocation parameter specifies the location for the IMAP4 protocol log files.")] String LogFileLocation; [Write, Description("The LogFileRollOverSettings parameter specifies how frequently IMAP4 protocol logging creates a new log file."), ValueMap{"Hourly","Daily","Weekly", "Monthly"}, Values{"Hourly","Daily","Weekly", "Monthly"}] String LogFileRollOverSettings; From e96fe824d2e3089419f363b86e81b79062bfdb9a Mon Sep 17 00:00:00 2001 From: Ariel Moisis Date: Fri, 25 Jan 2019 13:32:43 +1100 Subject: [PATCH 07/28] LogPerFileSizeQuota to LogPerFileSizeQuota[] --- .../MSFT_xExchImapSettings/MSFT_xExchImapSettings.psm1 | 8 ++++---- .../MSFT_xExchImapSettings.schema.mof | 4 ++-- 2 files changed, 6 insertions(+), 6 deletions(-) diff --git a/DSCResources/MSFT_xExchImapSettings/MSFT_xExchImapSettings.psm1 b/DSCResources/MSFT_xExchImapSettings/MSFT_xExchImapSettings.psm1 index bdd88158..b46a4ffc 100644 --- a/DSCResources/MSFT_xExchImapSettings/MSFT_xExchImapSettings.psm1 +++ b/DSCResources/MSFT_xExchImapSettings/MSFT_xExchImapSettings.psm1 @@ -77,7 +77,7 @@ function Get-TargetResource $Banner, [Parameter()] - [ValidateSet('iCalendar', 'intranetUrl', 'InternetUrl', 'Custom')] + [ValidateSet('iCalendar', 'IntranetUrl', 'InternetUrl', 'Custom')] [System.String] $CalendarItemRetrievalOption, @@ -292,7 +292,7 @@ function Set-TargetResource $Banner, [Parameter()] - [ValidateSet('iCalendar', 'intranetUrl', 'InternetUrl', 'Custom')] + [ValidateSet('iCalendar', 'IntranetUrl', 'InternetUrl', 'Custom')] [System.String] $CalendarItemRetrievalOption, @@ -486,7 +486,7 @@ function Test-TargetResource $Banner, [Parameter()] - [ValidateSet('iCalendar', 'intranetUrl', 'InternetUrl', 'Custom')] + [ValidateSet('iCalendar', 'IntranetUrl', 'InternetUrl', 'Custom')] [System.String] $CalendarItemRetrievalOption, @@ -817,7 +817,7 @@ function Get-ImapSettingsInternal $Banner, [Parameter()] - [ValidateSet('iCalendar', 'intranetUrl', 'InternetUrl', 'Custom')] + [ValidateSet('iCalendar', 'IntranetUrl', 'InternetUrl', 'Custom')] [System.String] $CalendarItemRetrievalOption, diff --git a/DSCResources/MSFT_xExchImapSettings/MSFT_xExchImapSettings.schema.mof b/DSCResources/MSFT_xExchImapSettings/MSFT_xExchImapSettings.schema.mof index 6bd042f2..fd1fd895 100644 --- a/DSCResources/MSFT_xExchImapSettings/MSFT_xExchImapSettings.schema.mof +++ b/DSCResources/MSFT_xExchImapSettings/MSFT_xExchImapSettings.schema.mof @@ -19,7 +19,7 @@ class MSFT_xExchImapSettings : OMI_BaseResource [Write, Description("The InternalConnectionSettings parameter specifies the host name, port, and encryption method that's used by internal IMAP4 clients (IMAP4 connections from inside your corporate network).")] String InternalConnectionSettings[]; [Write, Description("The LogFileLocation parameter specifies the location for the IMAP4 protocol log files.")] String LogFileLocation; [Write, Description("The LogFileRollOverSettings parameter specifies how frequently IMAP4 protocol logging creates a new log file."), ValueMap{"Hourly","Daily","Weekly", "Monthly"}, Values{"Hourly","Daily","Weekly", "Monthly"}] String LogFileRollOverSettings; - [Write, Description("The LogPerFileSizeQuota parameter specifies the maximum size of a IMAP4 protocol log file.")] String LogPerFileSizeQuota; + [Write, Description("The LogPerFileSizeQuota parameter specifies the maximum size of a IMAP4 protocol log file.")] String LogPerFileSizeQuota[]; [Write, Description("The MaxCommandSize parameter specifies the maximum size in bytes of a single IMAP4 command.")] SInt32 MaxCommandSize; [Write, Description("The MaxConnectionFromSingleIP parameter specifies the maximum number of IMAP4 connections that are accepted by the Exchange server from a single IP address.")] SInt32 MaxConnectionFromSingleIP; [Write, Description("The MaxConnections parameter specifies the maximum number of IMAP4 connections that are accepted by the Exchange server.")] SInt32 MaxConnections; @@ -32,5 +32,5 @@ class MSFT_xExchImapSettings : OMI_BaseResource [Write, Description("The ShowHiddenFoldersEnabled parameter specifies whether hidden mailbox folders are visible.")] Boolean ShowHiddenFoldersEnabled; [Write, Description("The SSLBindings parameter specifies the IP address and TCP port that's used for IMAP4 connection that's always encrypted by SSL/TLS. This parameter uses the syntax :.")] String SSLBindings[]; [Write, Description("The SuppressReadReceipt parameter specifies whether to stop duplicate read receipts from being sent to IMAP4 clients that have the Send read receipts for messages I send setting configured in their IMAP4 email program.")] Boolean SuppressReadReceipt; - [Write, Description("The X509CertificateName parameter specifies the certificate that's used for encrypting IMAP4 client connections.")]String UnencryptedOrTLSBindings[]; + [Write, Description("The X509CertificateName parameter specifies the certificate that's used for encrypting IMAP4 client connections.")] String UnencryptedOrTLSBindings[]; }; From 8dfda6331ea04ca559ee0b665f1e81ec208a87df Mon Sep 17 00:00:00 2001 From: Ariel Moisis Date: Fri, 25 Jan 2019 13:35:15 +1100 Subject: [PATCH 08/28] change to system.string --- .../MSFT_xExchImapSettings/MSFT_xExchImapSettings.psm1 | 8 ++++---- .../MSFT_xExchImapSettings.schema.mof | 2 +- 2 files changed, 5 insertions(+), 5 deletions(-) diff --git a/DSCResources/MSFT_xExchImapSettings/MSFT_xExchImapSettings.psm1 b/DSCResources/MSFT_xExchImapSettings/MSFT_xExchImapSettings.psm1 index b46a4ffc..dcfc5ae1 100644 --- a/DSCResources/MSFT_xExchImapSettings/MSFT_xExchImapSettings.psm1 +++ b/DSCResources/MSFT_xExchImapSettings/MSFT_xExchImapSettings.psm1 @@ -112,7 +112,7 @@ function Get-TargetResource $LogFileRollOverSettings, [Parameter()] - [System.String[]] + [System.String] $LogPerFileSizeQuota, [Parameter()] @@ -327,7 +327,7 @@ function Set-TargetResource $LogFileRollOverSettings, [Parameter()] - [System.String[]] + [System.String] $LogPerFileSizeQuota, [Parameter()] @@ -521,7 +521,7 @@ function Test-TargetResource $LogFileRollOverSettings, [Parameter()] - [System.String[]] + [System.String] $LogPerFileSizeQuota, [Parameter()] @@ -852,7 +852,7 @@ function Get-ImapSettingsInternal $LogFileRollOverSettings, [Parameter()] - [System.String[]] + [System.String] $LogPerFileSizeQuota, [Parameter()] diff --git a/DSCResources/MSFT_xExchImapSettings/MSFT_xExchImapSettings.schema.mof b/DSCResources/MSFT_xExchImapSettings/MSFT_xExchImapSettings.schema.mof index fd1fd895..286f0b5f 100644 --- a/DSCResources/MSFT_xExchImapSettings/MSFT_xExchImapSettings.schema.mof +++ b/DSCResources/MSFT_xExchImapSettings/MSFT_xExchImapSettings.schema.mof @@ -19,7 +19,7 @@ class MSFT_xExchImapSettings : OMI_BaseResource [Write, Description("The InternalConnectionSettings parameter specifies the host name, port, and encryption method that's used by internal IMAP4 clients (IMAP4 connections from inside your corporate network).")] String InternalConnectionSettings[]; [Write, Description("The LogFileLocation parameter specifies the location for the IMAP4 protocol log files.")] String LogFileLocation; [Write, Description("The LogFileRollOverSettings parameter specifies how frequently IMAP4 protocol logging creates a new log file."), ValueMap{"Hourly","Daily","Weekly", "Monthly"}, Values{"Hourly","Daily","Weekly", "Monthly"}] String LogFileRollOverSettings; - [Write, Description("The LogPerFileSizeQuota parameter specifies the maximum size of a IMAP4 protocol log file.")] String LogPerFileSizeQuota[]; + [Write, Description("The LogPerFileSizeQuota parameter specifies the maximum size of a IMAP4 protocol log file.")] String LogPerFileSizeQuota; [Write, Description("The MaxCommandSize parameter specifies the maximum size in bytes of a single IMAP4 command.")] SInt32 MaxCommandSize; [Write, Description("The MaxConnectionFromSingleIP parameter specifies the maximum number of IMAP4 connections that are accepted by the Exchange server from a single IP address.")] SInt32 MaxConnectionFromSingleIP; [Write, Description("The MaxConnections parameter specifies the maximum number of IMAP4 connections that are accepted by the Exchange server.")] SInt32 MaxConnections; From 1178a201e45388e610c56c8013e95dee6f9b9813 Mon Sep 17 00:00:00 2001 From: Ariel Moisis Date: Fri, 25 Jan 2019 13:58:54 +1100 Subject: [PATCH 09/28] update for mof file issues --- DSCResources/MSFT_xExchImapSettings/MSFT_xExchImapSettings.psm1 | 2 +- .../MSFT_xExchImapSettings/MSFT_xExchImapSettings.schema.mof | 2 +- 2 files changed, 2 insertions(+), 2 deletions(-) diff --git a/DSCResources/MSFT_xExchImapSettings/MSFT_xExchImapSettings.psm1 b/DSCResources/MSFT_xExchImapSettings/MSFT_xExchImapSettings.psm1 index dcfc5ae1..1cdbb681 100644 --- a/DSCResources/MSFT_xExchImapSettings/MSFT_xExchImapSettings.psm1 +++ b/DSCResources/MSFT_xExchImapSettings/MSFT_xExchImapSettings.psm1 @@ -664,7 +664,7 @@ function Test-TargetResource $testResults = $false } - if (!(Test-ExchangeSetting -Name 'LogPerFileSizeQuota' -Type 'Array' -ExpectedValue $LogPerFileSizeQuota -ActualValue $imap.LogPerFileSizeQuota -PSBoundParametersIn $PSBoundParameters -Verbose:$VerbosePreference)) + if (!(Test-ExchangeSetting -Name 'LogPerFileSizeQuota' -Type 'String' -ExpectedValue $LogPerFileSizeQuota -ActualValue $imap.LogPerFileSizeQuota -PSBoundParametersIn $PSBoundParameters -Verbose:$VerbosePreference)) { $testResults = $false } diff --git a/DSCResources/MSFT_xExchImapSettings/MSFT_xExchImapSettings.schema.mof b/DSCResources/MSFT_xExchImapSettings/MSFT_xExchImapSettings.schema.mof index 286f0b5f..c5861a3c 100644 --- a/DSCResources/MSFT_xExchImapSettings/MSFT_xExchImapSettings.schema.mof +++ b/DSCResources/MSFT_xExchImapSettings/MSFT_xExchImapSettings.schema.mof @@ -11,7 +11,7 @@ class MSFT_xExchImapSettings : OMI_BaseResource [Write, Description("The X509CertificateName parameter specifies the certificate that's used for encrypting IMAP4 client connections.")] String X509CertificateName; [Write, Description("The AuthenticatedConnectionTimeout parameter specifies the period of time to wait before closing an idle authenticated connection.")] String AuthenticatedConnectionTimeout; [Write, Description("The Banner parameter specifies the text string that's displayed to connecting IMAP4 clients.")] String Banner; - [Write, Description("The CalendarItemRetrievalOption parameter specifies how calendar items are presented to IMAP4 clients."), ValueMap{"iCalendar","intranetUrl","InternetUrl", "Custom"}, Values{"iCalendar","intranetUrl","InternetUrl", "Custom"}] String CalendarItemRetrievalOption; + [Write, Description("The CalendarItemRetrievalOption parameter specifies how calendar items are presented to IMAP4 clients."), ValueMap{"iCalendar","IntranetUrl","InternetUrl", "Custom"}, Values{"iCalendar","IntranetUrl","InternetUrl", "Custom"}] String CalendarItemRetrievalOption; [Write, Description("The EnableExactRFC822Size parameter specifies how message sizes are presented to IMAP4 clients.")] Boolean EnableExactRFC822Size; [Write, Description("The EnableGSSAPIAndNTLMAuth parameter specifies whether connections can use Integrated Windows authentication (NTLM) using the Generic Security Services application programming interface (GSSAPI). This setting applies to connections where Transport Layer Security (TLS) is disabled.")] Boolean EnableGSSAPIAndNTLMAuth; [Write, Description("The EnforceCertificateErrors parameter specifies whether to enforce valid Secure Sockets Layer (SSL) certificate validation failures.")] Boolean EnforceCertificateErrors; From 5590c066c6c1999c9b4d8c708858dd397a64df90 Mon Sep 17 00:00:00 2001 From: Ariel Moisis Date: Fri, 25 Jan 2019 14:00:13 +1100 Subject: [PATCH 10/28] update imapsettings unit tests --- Tests/Unit/MSFT_xExchImapSettings.tests.ps1 | 2 +- 1 file changed, 1 insertion(+), 1 deletion(-) diff --git a/Tests/Unit/MSFT_xExchImapSettings.tests.ps1 b/Tests/Unit/MSFT_xExchImapSettings.tests.ps1 index 38a8586d..e3e6b380 100644 --- a/Tests/Unit/MSFT_xExchImapSettings.tests.ps1 +++ b/Tests/Unit/MSFT_xExchImapSettings.tests.ps1 @@ -60,7 +60,7 @@ try InternalConnectionSettings = [System.String[]] @() LogFileLocation = [System.String] '' LogFileRollOverSettings = [System.String] '' - LogPerFileSizeQuota = [System.String[]] @() + LogPerFileSizeQuota = [System.String '' MaxCommandSize = [System.Int32] 1 MaxConnectionFromSingleIP = [System.Int32] 1 MaxConnections = [System.Int32] 1 From ecce2f52feb8770d692af32ea7fc34e558855569 Mon Sep 17 00:00:00 2001 From: Ariel Moisis Date: Fri, 25 Jan 2019 14:04:36 +1100 Subject: [PATCH 11/28] update tests to imclude internal helper --- Tests/Unit/MSFT_xExchImapSettings.tests.ps1 | 18 ++++++++++++++++++ 1 file changed, 18 insertions(+) diff --git a/Tests/Unit/MSFT_xExchImapSettings.tests.ps1 b/Tests/Unit/MSFT_xExchImapSettings.tests.ps1 index e3e6b380..9cf320bd 100644 --- a/Tests/Unit/MSFT_xExchImapSettings.tests.ps1 +++ b/Tests/Unit/MSFT_xExchImapSettings.tests.ps1 @@ -150,6 +150,24 @@ try } } } + + Describe 'MSFT_xExchImapSettings\Get-ImapSettingsInternal' -Tag 'Helper' { + # Override Exchange cmdlets + function Get-ImapSettings { } + + AfterEach { + Assert-VerifiableMock + } + + Context 'When Get-ImapSettingsInternal is called' { + It 'Should call expected functions' { + Mock -CommandName Get-ImapSettings -Verifiable -MockWith { return $commonImapSettingsStandardOutput } + Mock -CommandName Restart-Service -Verifiable + + Get-ImapSettingsInternal @commonTargetResourceParams + } + } + } } } finally From 2c845f419413d8782e994f6e2697417c7251c40c Mon Sep 17 00:00:00 2001 From: Ariel Moisis Date: Fri, 25 Jan 2019 14:06:48 +1100 Subject: [PATCH 12/28] add missing ] --- Tests/Unit/MSFT_xExchImapSettings.tests.ps1 | 2 +- 1 file changed, 1 insertion(+), 1 deletion(-) diff --git a/Tests/Unit/MSFT_xExchImapSettings.tests.ps1 b/Tests/Unit/MSFT_xExchImapSettings.tests.ps1 index 9cf320bd..ea384f08 100644 --- a/Tests/Unit/MSFT_xExchImapSettings.tests.ps1 +++ b/Tests/Unit/MSFT_xExchImapSettings.tests.ps1 @@ -60,7 +60,7 @@ try InternalConnectionSettings = [System.String[]] @() LogFileLocation = [System.String] '' LogFileRollOverSettings = [System.String] '' - LogPerFileSizeQuota = [System.String '' + LogPerFileSizeQuota = [System.String] '' MaxCommandSize = [System.Int32] 1 MaxConnectionFromSingleIP = [System.Int32] 1 MaxConnections = [System.Int32] 1 From 7b7000e64928fe8dcc075aa06739f04025fdbf41 Mon Sep 17 00:00:00 2001 From: Ariel Moisis Date: Fri, 25 Jan 2019 15:04:26 +1100 Subject: [PATCH 13/28] remove restart-service mock line 165 --- Tests/Unit/MSFT_xExchImapSettings.tests.ps1 | 1 - 1 file changed, 1 deletion(-) diff --git a/Tests/Unit/MSFT_xExchImapSettings.tests.ps1 b/Tests/Unit/MSFT_xExchImapSettings.tests.ps1 index ea384f08..6384f1b6 100644 --- a/Tests/Unit/MSFT_xExchImapSettings.tests.ps1 +++ b/Tests/Unit/MSFT_xExchImapSettings.tests.ps1 @@ -162,7 +162,6 @@ try Context 'When Get-ImapSettingsInternal is called' { It 'Should call expected functions' { Mock -CommandName Get-ImapSettings -Verifiable -MockWith { return $commonImapSettingsStandardOutput } - Mock -CommandName Restart-Service -Verifiable Get-ImapSettingsInternal @commonTargetResourceParams } From f69952422860c17f3b329903cbdca32c88f17d6e Mon Sep 17 00:00:00 2001 From: Ariel Moisis Date: Fri, 25 Jan 2019 15:28:50 +1100 Subject: [PATCH 14/28] update get-targetresource output --- DSCResources/MSFT_xExchImapSettings/MSFT_xExchImapSettings.psm1 | 2 +- 1 file changed, 1 insertion(+), 1 deletion(-) diff --git a/DSCResources/MSFT_xExchImapSettings/MSFT_xExchImapSettings.psm1 b/DSCResources/MSFT_xExchImapSettings/MSFT_xExchImapSettings.psm1 index 1cdbb681..66c011d0 100644 --- a/DSCResources/MSFT_xExchImapSettings/MSFT_xExchImapSettings.psm1 +++ b/DSCResources/MSFT_xExchImapSettings/MSFT_xExchImapSettings.psm1 @@ -195,7 +195,7 @@ function Get-TargetResource InternalConnectionSettings = [System.String[]] $imap.InternalConnectionSettings LogFileLocation = [System.String] $imap.LogFileLocation LogFileRollOverSettings = [System.String] $imap.LogFileRollOverSettings - LogPerFileSizeQuota = [System.String[]] $imap.LogPerFileSizeQuota + LogPerFileSizeQuota = [System.String] $imap.LogPerFileSizeQuota MaxCommandSize = [System.Int32] $imap.MaxCommandSize MaxConnectionFromSingleIP = [System.Int32] $imap.MaxConnectionFromSingleIP MaxConnections = [System.Int32] $imap.MaxConnections From d45e3fc2db1e63296a89054f1f04aca106ad66e2 Mon Sep 17 00:00:00 2001 From: Ariel Moisis Date: Thu, 10 Jan 2019 11:18:35 +1100 Subject: [PATCH 15/28] add missing params --- .../MSFT_xExchImapSettings/MSFT_xExchImapSettings.psm1 | 4 ++-- Tests/Unit/MSFT_xExchImapSettings.tests.ps1 | 1 - 2 files changed, 2 insertions(+), 3 deletions(-) diff --git a/DSCResources/MSFT_xExchImapSettings/MSFT_xExchImapSettings.psm1 b/DSCResources/MSFT_xExchImapSettings/MSFT_xExchImapSettings.psm1 index 66c011d0..96bc1dd1 100644 --- a/DSCResources/MSFT_xExchImapSettings/MSFT_xExchImapSettings.psm1 +++ b/DSCResources/MSFT_xExchImapSettings/MSFT_xExchImapSettings.psm1 @@ -77,7 +77,7 @@ function Get-TargetResource $Banner, [Parameter()] - [ValidateSet('iCalendar', 'IntranetUrl', 'InternetUrl', 'Custom')] + [ValidateSet('iCalendar', 'intranetUrl', 'InternetUrl', 'Custom')] [System.String] $CalendarItemRetrievalOption, @@ -292,7 +292,7 @@ function Set-TargetResource $Banner, [Parameter()] - [ValidateSet('iCalendar', 'IntranetUrl', 'InternetUrl', 'Custom')] + [ValidateSet('iCalendar', 'intranetUrl', 'InternetUrl', 'Custom')] [System.String] $CalendarItemRetrievalOption, diff --git a/Tests/Unit/MSFT_xExchImapSettings.tests.ps1 b/Tests/Unit/MSFT_xExchImapSettings.tests.ps1 index 6384f1b6..de431205 100644 --- a/Tests/Unit/MSFT_xExchImapSettings.tests.ps1 +++ b/Tests/Unit/MSFT_xExchImapSettings.tests.ps1 @@ -75,7 +75,6 @@ try SuppressReadReceipt = [System.Boolean] $false UnencryptedOrTLSBindings = [System.String[]] @() } - Describe 'MSFT_xExchImapSettings\Get-TargetResource' -Tag 'Get' { AfterEach { Assert-VerifiableMock From 409b1e2269537fde566e9b03424425417fd16147 Mon Sep 17 00:00:00 2001 From: Ariel Moisis Date: Fri, 11 Jan 2019 09:03:08 +1100 Subject: [PATCH 16/28] Add missing params and unit tests --- Tests/Unit/MSFT_xExchImapSettings.tests.ps1 | 1 + 1 file changed, 1 insertion(+) diff --git a/Tests/Unit/MSFT_xExchImapSettings.tests.ps1 b/Tests/Unit/MSFT_xExchImapSettings.tests.ps1 index de431205..6384f1b6 100644 --- a/Tests/Unit/MSFT_xExchImapSettings.tests.ps1 +++ b/Tests/Unit/MSFT_xExchImapSettings.tests.ps1 @@ -75,6 +75,7 @@ try SuppressReadReceipt = [System.Boolean] $false UnencryptedOrTLSBindings = [System.String[]] @() } + Describe 'MSFT_xExchImapSettings\Get-TargetResource' -Tag 'Get' { AfterEach { Assert-VerifiableMock From 637b2233b0196cc599a59dfd2ad2aebdaa835383 Mon Sep 17 00:00:00 2001 From: Ariel Moisis Date: Thu, 10 Jan 2019 11:18:35 +1100 Subject: [PATCH 17/28] add missing params --- Tests/Unit/MSFT_xExchImapSettings.tests.ps1 | 1 - 1 file changed, 1 deletion(-) diff --git a/Tests/Unit/MSFT_xExchImapSettings.tests.ps1 b/Tests/Unit/MSFT_xExchImapSettings.tests.ps1 index 6384f1b6..de431205 100644 --- a/Tests/Unit/MSFT_xExchImapSettings.tests.ps1 +++ b/Tests/Unit/MSFT_xExchImapSettings.tests.ps1 @@ -75,7 +75,6 @@ try SuppressReadReceipt = [System.Boolean] $false UnencryptedOrTLSBindings = [System.String[]] @() } - Describe 'MSFT_xExchImapSettings\Get-TargetResource' -Tag 'Get' { AfterEach { Assert-VerifiableMock From 4786b9dd163dae82af1102a3a4790c0ebab086f9 Mon Sep 17 00:00:00 2001 From: Ariel Moisis Date: Fri, 11 Jan 2019 09:03:08 +1100 Subject: [PATCH 18/28] Add missing params and unit tests --- Tests/Unit/MSFT_xExchImapSettings.tests.ps1 | 1 + 1 file changed, 1 insertion(+) diff --git a/Tests/Unit/MSFT_xExchImapSettings.tests.ps1 b/Tests/Unit/MSFT_xExchImapSettings.tests.ps1 index de431205..6384f1b6 100644 --- a/Tests/Unit/MSFT_xExchImapSettings.tests.ps1 +++ b/Tests/Unit/MSFT_xExchImapSettings.tests.ps1 @@ -75,6 +75,7 @@ try SuppressReadReceipt = [System.Boolean] $false UnencryptedOrTLSBindings = [System.String[]] @() } + Describe 'MSFT_xExchImapSettings\Get-TargetResource' -Tag 'Get' { AfterEach { Assert-VerifiableMock From 29f8b932071279b088a29d1f5fccf400e632ef42 Mon Sep 17 00:00:00 2001 From: Ariel Moisis Date: Fri, 25 Jan 2019 13:32:43 +1100 Subject: [PATCH 19/28] LogPerFileSizeQuota to LogPerFileSizeQuota[] --- .../MSFT_xExchImapSettings/MSFT_xExchImapSettings.psm1 | 4 ++-- .../MSFT_xExchImapSettings/MSFT_xExchImapSettings.schema.mof | 2 +- 2 files changed, 3 insertions(+), 3 deletions(-) diff --git a/DSCResources/MSFT_xExchImapSettings/MSFT_xExchImapSettings.psm1 b/DSCResources/MSFT_xExchImapSettings/MSFT_xExchImapSettings.psm1 index 96bc1dd1..66c011d0 100644 --- a/DSCResources/MSFT_xExchImapSettings/MSFT_xExchImapSettings.psm1 +++ b/DSCResources/MSFT_xExchImapSettings/MSFT_xExchImapSettings.psm1 @@ -77,7 +77,7 @@ function Get-TargetResource $Banner, [Parameter()] - [ValidateSet('iCalendar', 'intranetUrl', 'InternetUrl', 'Custom')] + [ValidateSet('iCalendar', 'IntranetUrl', 'InternetUrl', 'Custom')] [System.String] $CalendarItemRetrievalOption, @@ -292,7 +292,7 @@ function Set-TargetResource $Banner, [Parameter()] - [ValidateSet('iCalendar', 'intranetUrl', 'InternetUrl', 'Custom')] + [ValidateSet('iCalendar', 'IntranetUrl', 'InternetUrl', 'Custom')] [System.String] $CalendarItemRetrievalOption, diff --git a/DSCResources/MSFT_xExchImapSettings/MSFT_xExchImapSettings.schema.mof b/DSCResources/MSFT_xExchImapSettings/MSFT_xExchImapSettings.schema.mof index c5861a3c..5edb3fb5 100644 --- a/DSCResources/MSFT_xExchImapSettings/MSFT_xExchImapSettings.schema.mof +++ b/DSCResources/MSFT_xExchImapSettings/MSFT_xExchImapSettings.schema.mof @@ -19,7 +19,7 @@ class MSFT_xExchImapSettings : OMI_BaseResource [Write, Description("The InternalConnectionSettings parameter specifies the host name, port, and encryption method that's used by internal IMAP4 clients (IMAP4 connections from inside your corporate network).")] String InternalConnectionSettings[]; [Write, Description("The LogFileLocation parameter specifies the location for the IMAP4 protocol log files.")] String LogFileLocation; [Write, Description("The LogFileRollOverSettings parameter specifies how frequently IMAP4 protocol logging creates a new log file."), ValueMap{"Hourly","Daily","Weekly", "Monthly"}, Values{"Hourly","Daily","Weekly", "Monthly"}] String LogFileRollOverSettings; - [Write, Description("The LogPerFileSizeQuota parameter specifies the maximum size of a IMAP4 protocol log file.")] String LogPerFileSizeQuota; + [Write, Description("The LogPerFileSizeQuota parameter specifies the maximum size of a IMAP4 protocol log file.")] String LogPerFileSizeQuota[]; [Write, Description("The MaxCommandSize parameter specifies the maximum size in bytes of a single IMAP4 command.")] SInt32 MaxCommandSize; [Write, Description("The MaxConnectionFromSingleIP parameter specifies the maximum number of IMAP4 connections that are accepted by the Exchange server from a single IP address.")] SInt32 MaxConnectionFromSingleIP; [Write, Description("The MaxConnections parameter specifies the maximum number of IMAP4 connections that are accepted by the Exchange server.")] SInt32 MaxConnections; From 29af78b46bb9beb53c5aae4ffafe04c4505e970c Mon Sep 17 00:00:00 2001 From: Ariel Moisis Date: Fri, 25 Jan 2019 13:35:15 +1100 Subject: [PATCH 20/28] change to system.string --- .../MSFT_xExchImapSettings/MSFT_xExchImapSettings.schema.mof | 2 +- 1 file changed, 1 insertion(+), 1 deletion(-) diff --git a/DSCResources/MSFT_xExchImapSettings/MSFT_xExchImapSettings.schema.mof b/DSCResources/MSFT_xExchImapSettings/MSFT_xExchImapSettings.schema.mof index 5edb3fb5..c5861a3c 100644 --- a/DSCResources/MSFT_xExchImapSettings/MSFT_xExchImapSettings.schema.mof +++ b/DSCResources/MSFT_xExchImapSettings/MSFT_xExchImapSettings.schema.mof @@ -19,7 +19,7 @@ class MSFT_xExchImapSettings : OMI_BaseResource [Write, Description("The InternalConnectionSettings parameter specifies the host name, port, and encryption method that's used by internal IMAP4 clients (IMAP4 connections from inside your corporate network).")] String InternalConnectionSettings[]; [Write, Description("The LogFileLocation parameter specifies the location for the IMAP4 protocol log files.")] String LogFileLocation; [Write, Description("The LogFileRollOverSettings parameter specifies how frequently IMAP4 protocol logging creates a new log file."), ValueMap{"Hourly","Daily","Weekly", "Monthly"}, Values{"Hourly","Daily","Weekly", "Monthly"}] String LogFileRollOverSettings; - [Write, Description("The LogPerFileSizeQuota parameter specifies the maximum size of a IMAP4 protocol log file.")] String LogPerFileSizeQuota[]; + [Write, Description("The LogPerFileSizeQuota parameter specifies the maximum size of a IMAP4 protocol log file.")] String LogPerFileSizeQuota; [Write, Description("The MaxCommandSize parameter specifies the maximum size in bytes of a single IMAP4 command.")] SInt32 MaxCommandSize; [Write, Description("The MaxConnectionFromSingleIP parameter specifies the maximum number of IMAP4 connections that are accepted by the Exchange server from a single IP address.")] SInt32 MaxConnectionFromSingleIP; [Write, Description("The MaxConnections parameter specifies the maximum number of IMAP4 connections that are accepted by the Exchange server.")] SInt32 MaxConnections; From 957e9c559656951f46916a60256d7790f4aa2724 Mon Sep 17 00:00:00 2001 From: Ariel Moisis Date: Fri, 25 Jan 2019 14:04:36 +1100 Subject: [PATCH 21/28] update tests to imclude internal helper --- Tests/Unit/MSFT_xExchImapSettings.tests.ps1 | 18 ++++++++++++++++++ 1 file changed, 18 insertions(+) diff --git a/Tests/Unit/MSFT_xExchImapSettings.tests.ps1 b/Tests/Unit/MSFT_xExchImapSettings.tests.ps1 index 6384f1b6..758c0092 100644 --- a/Tests/Unit/MSFT_xExchImapSettings.tests.ps1 +++ b/Tests/Unit/MSFT_xExchImapSettings.tests.ps1 @@ -167,6 +167,24 @@ try } } } + + Describe 'MSFT_xExchImapSettings\Get-ImapSettingsInternal' -Tag 'Helper' { + # Override Exchange cmdlets + function Get-ImapSettings { } + + AfterEach { + Assert-VerifiableMock + } + + Context 'When Get-ImapSettingsInternal is called' { + It 'Should call expected functions' { + Mock -CommandName Get-ImapSettings -Verifiable -MockWith { return $commonImapSettingsStandardOutput } + Mock -CommandName Restart-Service -Verifiable + + Get-ImapSettingsInternal @commonTargetResourceParams + } + } + } } } finally From 0bd62c67b433a480cd4c62e8116e70e4cf53f171 Mon Sep 17 00:00:00 2001 From: Ariel Moisis Date: Fri, 25 Jan 2019 15:04:26 +1100 Subject: [PATCH 22/28] remove restart-service mock line 165 --- Tests/Unit/MSFT_xExchImapSettings.tests.ps1 | 1 - 1 file changed, 1 deletion(-) diff --git a/Tests/Unit/MSFT_xExchImapSettings.tests.ps1 b/Tests/Unit/MSFT_xExchImapSettings.tests.ps1 index 758c0092..47f01d77 100644 --- a/Tests/Unit/MSFT_xExchImapSettings.tests.ps1 +++ b/Tests/Unit/MSFT_xExchImapSettings.tests.ps1 @@ -179,7 +179,6 @@ try Context 'When Get-ImapSettingsInternal is called' { It 'Should call expected functions' { Mock -CommandName Get-ImapSettings -Verifiable -MockWith { return $commonImapSettingsStandardOutput } - Mock -CommandName Restart-Service -Verifiable Get-ImapSettingsInternal @commonTargetResourceParams } From 462359ad2bbf91192da9d6223f755ba392549efc Mon Sep 17 00:00:00 2001 From: Ariel Moisis Date: Wed, 20 Feb 2019 10:56:04 +1100 Subject: [PATCH 23/28] update comment based help --- .../MSFT_xExchImapSettings.psm1 | 644 +++++++++++++++++- 1 file changed, 608 insertions(+), 36 deletions(-) diff --git a/DSCResources/MSFT_xExchImapSettings/MSFT_xExchImapSettings.psm1 b/DSCResources/MSFT_xExchImapSettings/MSFT_xExchImapSettings.psm1 index 66c011d0..eb1af154 100644 --- a/DSCResources/MSFT_xExchImapSettings/MSFT_xExchImapSettings.psm1 +++ b/DSCResources/MSFT_xExchImapSettings/MSFT_xExchImapSettings.psm1 @@ -3,7 +3,12 @@ Retrieves the current DSC configuration for this resource. .PARAMETER Server - The IMAP server to configure. + The Server parameter specifies the Exchange server where you want to run this command. You can use any value that uniquely identifies the server. For example: + * Name + * FQDN + * Distinguished name (DN) + * Exchange Legacy DN + If you don't use this parameter, the command is run on the local server. .PARAMETER Credential Credentials used to establish a remote PowerShell session to Exchange. @@ -18,18 +23,156 @@ Directory. You identify the domain controller by its fully qualified domain name (FQDN). For example, dc01.contoso.com. - .PARAMETER ExternalConnectionSettings - The ExternalConnectionSettings parameter specifies the host name, port, - and encryption method that's used by external IMAP4 clients (IMAP4 - connections from outside your corporate network). + .Parameter AuthenticatedConnectionTimeout + The AuthenticatedConnectionTimeout parameter specifies the period of time to wait before closing an idle authenticated connection. + To specify a value, enter it as a time span: dd.hh:mm:ss where dd = days, hh = hours, mm = minutes, and ss = seconds. + Valid values are 00:00:30 to 1:00:00. The default setting is 00:30:00 (30 minutes). + + .Parameter Banner + The Banner parameter specifies the text string that's displayed to connecting IMAP4 clients. The default value is: The Microsoft Exchange IMAP4 service is ready. + + .Parameter CalendarItemRetrievalOption + The CalendarItemRetrievalOption parameter specifies how calendar items are presented to IMAP4 clients. Valid values are: + * 0 or iCalendar. This is the default value. + * 1 or IntranetUrl + * 2 or InternetUrl + * 3 or Custom + If you specify 3 or Custom, you need to specify a value for the OwaServerUrl parameter setting. + + .Parameter EnableExactRFC822Size + The EnableExactRFC822Size parameter specifies how message sizes are presented to IMAP4 clients. Valid values are: + * $true: Calculate the exact message size. Because this setting can negatively affect performance, you should configure it only if it's required by your IMAP4 clients. + * $false: Use an estimated message size. This is the default value. + + .Parameter EnableGSSAPIAndNTLMAuth + The EnableGSSAPIAndNTLMAuth parameter specifies whether connections can use Integrated Windows authentication (NTLM) using the Generic Security Services application programming interface (GSSAPI). This setting applies to connections where Transport Layer Security (TLS) is disabled. Valid values are: + * $true: NTLM for IMAP4 connections is enabled. This is the default value. + * $false: NTLM for IMAP4 connections is disabled. + + .Parameter EnforceCertificateErrors + The EnforceCertificateErrors parameter specifies whether to enforce valid Secure Sockets Layer (SSL) certificate validation failures. Valid values are: + The default setting is $false. + * $true: If the certificate isn't valid or doesn't match the target IMAP4 server's FQDN, the connection attempt fails. + * $false: The server doesn't deny IMAP4 connections based on certificate errors. This is the default value. + + .Parameter ExtendedProtectionPolicy + The ExtendedProtectionPolicy parameter specifies how Extended Protection for Authentication is used. Valid values are: + * None: Extended Protection for Authentication isn't used. This is the default value. + * Allow: Extended Protection for Authentication is used only if it's supported by the incoming IMAP4 connection. If it's not, Extended Protection for Authentication isn't used. + * Require: Extended Protection for Authentication is required for all IMAP4 connections. If the incoming IMAP4 connection doesn't support it, the connection is rejected. + Extended Protection for Authentication enhances the protection and handling of credentials by Integrated Windows authentication (also known as NTLM), so we strongly recommend that you use it if it's supported by your clients (default installations of Windows 7 or later and Windows Server 2008 R2 or later support it). + + .Parameter InternalConnectionSettings + The InternalConnectionSettings parameter specifies the host name, port, and encryption method that's used by internal IMAP4 clients (IMAP4 connections from inside your corporate network). This setting is also used when a IMAP4 connection is forwarded to another Exchange server that's running the Microsoft Exchange IMAP4 service. + This parameter uses the syntax ::[]. The encryption method value is optional (blank indicates unencrypted connections). + The default value is :993:SSL,:143:TLS. + To enter multiple values and overwrite any existing entries, use the following syntax: ,,.... If the values contain spaces or otherwise require quotation marks, you need to use the following syntax: "","",..."". + To add or remove one or more values without affecting any existing entries, use the following syntax: @{Add="",""...; Remove="",""...}. + The combination of encryption methods and ports that are specified for this parameter need to match the corresponding encryption methods and ports that are specified by the SSLBindings and UnencryptedOrTLSBindings parameters. + + .Parameter LogFileLocation + The LogFileLocation parameter specifies the location for the IMAP4 protocol log files. The default location is %ExchangeInstallPath%Logging\Imap4. + This parameter is only meaningful when the ProtocolLogEnabled parameter value is $true. + + .Parameter LogFileRollOverSettings + The LogFileRollOverSettings parameter specifies how frequently IMAP4 protocol logging creates a new log file. Valid values are: + * 1 or Hourly. + * 2 or Daily. This is the default value + * 3 or Weekly. + * 4 or Monthly. + This parameter is only meaningful when the LogPerFileSizeQuota parameter value is 0, and the ProtocolLogEnabled parameter value is $true. + + .Parameter LogPerFileSizeQuota + The LogPerFileSizeQuota parameter specifies the maximum size of a IMAP4 protocol log file. + When you enter a value, qualify the value with one of the following units: + * B (bytes) + * KB (kilobytes) + * MB (megabytes) + * GB (gigabytes) + * TB (terabytes) + Unqualified values are typically treated as bytes, but small values may be rounded up to the nearest kilobyte. + The default value is 0, which means a new IMAP4 protocol log file is created at the frequency that's specified by the LogFileRollOverSettings parameter. + This parameter is only meaningful when the ProtocolLogEnabled parameter value is $true. .PARAMETER LoginType - The LoginType parameter specifies the authentication method for IMAP4 - connections. + The LoginType parameter specifies the authentication method for IMAP4 connections. Valid values are: + * 1 or PlainTextLogin. + * 2 or PlainTextAuthentication. + * 3 or SecureLogin. This is the default value. + + .Parameter MaxCommandSize + The MaxCommandSize parameter specifies the maximum size in bytes of a single IMAP4 command. Valid values are from 40 through 1024. The default value is 512. + + .Parameter MaxConnectionFromSingleIP + The MaxConnectionFromSingleIP parameter specifies the maximum number of IMAP4 connections that are accepted by the Exchange server from a single IP address. Valid values are from 1 through 2147483647. The default value is 2147483647. + + .Parameter MaxConnections + The MaxConnections parameter specifies the maximum number of IMAP4 connections that are accepted by the Exchange server. Valid values are from 1 through 2147483647. The default value is 2147483647. + + .Parameter MaxConnectionsPerUser + The MaxConnectionsPerUser parameter specifies the maximum number of IMAP4 connections that are allowed for each user. Valid values are from 1 through 2147483647. The default value is 16. + + .Parameter MessageRetrievalMimeFormat + The MessageRetrievalMimeFormat parameter specifies the MIME encoding of messages. Valid values are: + * 0 or TextOnly. + * 1 or HtmlOnly. + * 2 or HtmlAndTextAlternative. + * 3 or TextEnrichedOnly. + * 4 or TextEnrichedAndTextAlternative. + * 5 or BestBodyFormat. This is the default value. + * 6 or Tnef. + + .Parameter OwaServerUrl + The OwaServerUrl parameter specifies the URL that's used to retrieve calendar information for instances of custom Outlook on the web calendar items. + + .Parameter PreAuthenticatedConnectionTimeout + The PreAuthenticatedConnectionTimeout parameter specifies the period of time to wait before closing an idle IMAP4 connection that isn't authenticated. + To specify a value, enter it as a time span: dd.hh:mm:ss where dd = days, hh = hours, mm = minutes, and ss = seconds. + Valid values are00:00:30 to 1:00:00. The default value is 00:01:00 (one minute). + + .Parameter ProtocolLogEnabled + The ProtocolLogEnabled parameter specifies whether to enable protocol logging for IMAP4. Valid values are: + * $true: IMAP4 protocol logging is enabled. + * $false: IMAP4 protocol logging is disabled. This is the default value. + + .Parameter ProxyTargetPort + The ProxyTargetPort parameter specifies the port on the Microsoft Exchange IMAP4 Backend service that listens for client connections that are proxied from the Microsoft Exchange IMAP4 service. The default value is 1993. + + .Parameter ShowHiddenFoldersEnabled + The ShowHiddenFoldersEnabled parameter specifies whether hidden mailbox folders are visible. Valid values are: + * $true: Hidden folders are visible. + * $false: Hidden folders aren't visible. This is the default value. + + .Parameter SSLBindings + The SSLBindings parameter specifies the IP address and TCP port that's used for IMAP4 connection that's always encrypted by SSL/TLS. This parameter uses the syntax :. + The default value is [::]:993,0.0.0.0:993. + To enter multiple values and overwrite any existing entries, use the following syntax: ,,.... If the values contain spaces or otherwise require quotation marks, you need to use the following syntax: "","",..."". + To add or remove one or more values without affecting any existing entries, use the following syntax: @{Add="",""...; Remove="",""...}. + + .Parameter SuppressReadReceipt + The SuppressReadReceipt parameter specifies whether to stop duplicate read receipts from being sent to IMAP4 clients that have the Send read receipts for messages I send setting configured in their IMAP4 email program. Valid values are: + * $true: The sender receives a read receipt only when the recipient opens the message. + * $false: The sender receives a read receipt when the recipient downloads the message, and when the recipient opens the message. This is the default value. + + .Parameter UnencryptedOrTLSBindings + The UnencryptedOrTLSBindings parameter specifies the IP address and TCP port that's used for unencrypted IMAP4 connections, or IMAP4 connections that are encrypted by using opportunistic TLS (STARTTLS) after the initial unencrypted protocol handshake. This parameter uses the syntax :. + The default value is [::]:143,0.0.0.0:143. + To enter multiple values and overwrite any existing entries, use the following syntax: ,,.... If the values contain spaces or otherwise require quotation marks, you need to use the following syntax: "","",..."". + To add or remove one or more values without affecting any existing entries, use the following syntax: @{Add="",""...; Remove="",""...}. + + .PARAMETER ExternalConnectionSettings + The ExternalConnectionSettings parameter specifies the host name, port, and encryption method that's used by external IMAP4 clients (IMAP4 connections from outside your corporate network). + This parameter uses the syntax ::[]. The encryption method value is optional (blank indicates unencrypted connections). + The default value is blank ($null), which means no external IMAP4 connection settings are configured. + To enter multiple values and overwrite any existing entries, use the following syntax: ,,.... If the values contain spaces or otherwise require quotation marks, you need to use the following syntax: "","",..."". + To add or remove one or more values without affecting any existing entries, use the following syntax: @{Add="",""...; Remove="",""...}. + The combination of encryption methods and ports that are specified for this parameter need to match the corresponding encryption methods and ports that are specified by the SSLBindings and UnencryptedOrTLSBindings parameters. .PARAMETER X509CertificateName - The X509CertificateName parameter specifies the certificate that's used - for encrypting IMAP4 client connections. + The X509CertificateName parameter specifies the certificate that's used for encrypting IMAP4 client connections. + A valid value for this parameter is the FQDN from the ExternalConnectionSettings or InternalConnectionSettings parameters (for example, mail.contoso.com or mailbox01.contoso.com). + If you use a single subject certificate or a subject alternative name (SAN) certificate, you also need to assign the certificate to the Exchange IMAP service by using the Enable-ExchangeCertificate cmdlet. + If you use a wildcard certificate, you don't need to assign the certificate to the Exchange IMAP service. #> function Get-TargetResource { @@ -220,7 +363,12 @@ function Get-TargetResource Sets the DSC configuration for this resource. .PARAMETER Server - The IMAP server to configure. + The Server parameter specifies the Exchange server where you want to run this command. You can use any value that uniquely identifies the server. For example: + * Name + * FQDN + * Distinguished name (DN) + * Exchange Legacy DN + If you don't use this parameter, the command is run on the local server. .PARAMETER Credential Credentials used to establish a remote PowerShell session to Exchange. @@ -235,18 +383,156 @@ function Get-TargetResource Directory. You identify the domain controller by its fully qualified domain name (FQDN). For example, dc01.contoso.com. - .PARAMETER ExternalConnectionSettings - The ExternalConnectionSettings parameter specifies the host name, port, - and encryption method that's used by external IMAP4 clients (IMAP4 - connections from outside your corporate network). + .Parameter AuthenticatedConnectionTimeout + The AuthenticatedConnectionTimeout parameter specifies the period of time to wait before closing an idle authenticated connection. + To specify a value, enter it as a time span: dd.hh:mm:ss where dd = days, hh = hours, mm = minutes, and ss = seconds. + Valid values are 00:00:30 to 1:00:00. The default setting is 00:30:00 (30 minutes). + + .Parameter Banner + The Banner parameter specifies the text string that's displayed to connecting IMAP4 clients. The default value is: The Microsoft Exchange IMAP4 service is ready. + + .Parameter CalendarItemRetrievalOption + The CalendarItemRetrievalOption parameter specifies how calendar items are presented to IMAP4 clients. Valid values are: + * 0 or iCalendar. This is the default value. + * 1 or IntranetUrl + * 2 or InternetUrl + * 3 or Custom + If you specify 3 or Custom, you need to specify a value for the OwaServerUrl parameter setting. + + .Parameter EnableExactRFC822Size + The EnableExactRFC822Size parameter specifies how message sizes are presented to IMAP4 clients. Valid values are: + * $true: Calculate the exact message size. Because this setting can negatively affect performance, you should configure it only if it's required by your IMAP4 clients. + * $false: Use an estimated message size. This is the default value. + + .Parameter EnableGSSAPIAndNTLMAuth + The EnableGSSAPIAndNTLMAuth parameter specifies whether connections can use Integrated Windows authentication (NTLM) using the Generic Security Services application programming interface (GSSAPI). This setting applies to connections where Transport Layer Security (TLS) is disabled. Valid values are: + * $true: NTLM for IMAP4 connections is enabled. This is the default value. + * $false: NTLM for IMAP4 connections is disabled. + + .Parameter EnforceCertificateErrors + The EnforceCertificateErrors parameter specifies whether to enforce valid Secure Sockets Layer (SSL) certificate validation failures. Valid values are: + The default setting is $false. + * $true: If the certificate isn't valid or doesn't match the target IMAP4 server's FQDN, the connection attempt fails. + * $false: The server doesn't deny IMAP4 connections based on certificate errors. This is the default value. + + .Parameter ExtendedProtectionPolicy + The ExtendedProtectionPolicy parameter specifies how Extended Protection for Authentication is used. Valid values are: + * None: Extended Protection for Authentication isn't used. This is the default value. + * Allow: Extended Protection for Authentication is used only if it's supported by the incoming IMAP4 connection. If it's not, Extended Protection for Authentication isn't used. + * Require: Extended Protection for Authentication is required for all IMAP4 connections. If the incoming IMAP4 connection doesn't support it, the connection is rejected. + Extended Protection for Authentication enhances the protection and handling of credentials by Integrated Windows authentication (also known as NTLM), so we strongly recommend that you use it if it's supported by your clients (default installations of Windows 7 or later and Windows Server 2008 R2 or later support it). + + .Parameter InternalConnectionSettings + The InternalConnectionSettings parameter specifies the host name, port, and encryption method that's used by internal IMAP4 clients (IMAP4 connections from inside your corporate network). This setting is also used when a IMAP4 connection is forwarded to another Exchange server that's running the Microsoft Exchange IMAP4 service. + This parameter uses the syntax ::[]. The encryption method value is optional (blank indicates unencrypted connections). + The default value is :993:SSL,:143:TLS. + To enter multiple values and overwrite any existing entries, use the following syntax: ,,.... If the values contain spaces or otherwise require quotation marks, you need to use the following syntax: "","",..."". + To add or remove one or more values without affecting any existing entries, use the following syntax: @{Add="",""...; Remove="",""...}. + The combination of encryption methods and ports that are specified for this parameter need to match the corresponding encryption methods and ports that are specified by the SSLBindings and UnencryptedOrTLSBindings parameters. + + .Parameter LogFileLocation + The LogFileLocation parameter specifies the location for the IMAP4 protocol log files. The default location is %ExchangeInstallPath%Logging\Imap4. + This parameter is only meaningful when the ProtocolLogEnabled parameter value is $true. + + .Parameter LogFileRollOverSettings + The LogFileRollOverSettings parameter specifies how frequently IMAP4 protocol logging creates a new log file. Valid values are: + * 1 or Hourly. + * 2 or Daily. This is the default value + * 3 or Weekly. + * 4 or Monthly. + This parameter is only meaningful when the LogPerFileSizeQuota parameter value is 0, and the ProtocolLogEnabled parameter value is $true. + + .Parameter LogPerFileSizeQuota + The LogPerFileSizeQuota parameter specifies the maximum size of a IMAP4 protocol log file. + When you enter a value, qualify the value with one of the following units: + * B (bytes) + * KB (kilobytes) + * MB (megabytes) + * GB (gigabytes) + * TB (terabytes) + Unqualified values are typically treated as bytes, but small values may be rounded up to the nearest kilobyte. + The default value is 0, which means a new IMAP4 protocol log file is created at the frequency that's specified by the LogFileRollOverSettings parameter. + This parameter is only meaningful when the ProtocolLogEnabled parameter value is $true. .PARAMETER LoginType - The LoginType parameter specifies the authentication method for IMAP4 - connections. + The LoginType parameter specifies the authentication method for IMAP4 connections. Valid values are: + * 1 or PlainTextLogin. + * 2 or PlainTextAuthentication. + * 3 or SecureLogin. This is the default value. + + .Parameter MaxCommandSize + The MaxCommandSize parameter specifies the maximum size in bytes of a single IMAP4 command. Valid values are from 40 through 1024. The default value is 512. + + .Parameter MaxConnectionFromSingleIP + The MaxConnectionFromSingleIP parameter specifies the maximum number of IMAP4 connections that are accepted by the Exchange server from a single IP address. Valid values are from 1 through 2147483647. The default value is 2147483647. + + .Parameter MaxConnections + The MaxConnections parameter specifies the maximum number of IMAP4 connections that are accepted by the Exchange server. Valid values are from 1 through 2147483647. The default value is 2147483647. + + .Parameter MaxConnectionsPerUser + The MaxConnectionsPerUser parameter specifies the maximum number of IMAP4 connections that are allowed for each user. Valid values are from 1 through 2147483647. The default value is 16. + + .Parameter MessageRetrievalMimeFormat + The MessageRetrievalMimeFormat parameter specifies the MIME encoding of messages. Valid values are: + * 0 or TextOnly. + * 1 or HtmlOnly. + * 2 or HtmlAndTextAlternative. + * 3 or TextEnrichedOnly. + * 4 or TextEnrichedAndTextAlternative. + * 5 or BestBodyFormat. This is the default value. + * 6 or Tnef. + + .Parameter OwaServerUrl + The OwaServerUrl parameter specifies the URL that's used to retrieve calendar information for instances of custom Outlook on the web calendar items. + + .Parameter PreAuthenticatedConnectionTimeout + The PreAuthenticatedConnectionTimeout parameter specifies the period of time to wait before closing an idle IMAP4 connection that isn't authenticated. + To specify a value, enter it as a time span: dd.hh:mm:ss where dd = days, hh = hours, mm = minutes, and ss = seconds. + Valid values are00:00:30 to 1:00:00. The default value is 00:01:00 (one minute). + + .Parameter ProtocolLogEnabled + The ProtocolLogEnabled parameter specifies whether to enable protocol logging for IMAP4. Valid values are: + * $true: IMAP4 protocol logging is enabled. + * $false: IMAP4 protocol logging is disabled. This is the default value. + + .Parameter ProxyTargetPort + The ProxyTargetPort parameter specifies the port on the Microsoft Exchange IMAP4 Backend service that listens for client connections that are proxied from the Microsoft Exchange IMAP4 service. The default value is 1993. + + .Parameter ShowHiddenFoldersEnabled + The ShowHiddenFoldersEnabled parameter specifies whether hidden mailbox folders are visible. Valid values are: + * $true: Hidden folders are visible. + * $false: Hidden folders aren't visible. This is the default value. + + .Parameter SSLBindings + The SSLBindings parameter specifies the IP address and TCP port that's used for IMAP4 connection that's always encrypted by SSL/TLS. This parameter uses the syntax :. + The default value is [::]:993,0.0.0.0:993. + To enter multiple values and overwrite any existing entries, use the following syntax: ,,.... If the values contain spaces or otherwise require quotation marks, you need to use the following syntax: "","",..."". + To add or remove one or more values without affecting any existing entries, use the following syntax: @{Add="",""...; Remove="",""...}. + + .Parameter SuppressReadReceipt + The SuppressReadReceipt parameter specifies whether to stop duplicate read receipts from being sent to IMAP4 clients that have the Send read receipts for messages I send setting configured in their IMAP4 email program. Valid values are: + * $true: The sender receives a read receipt only when the recipient opens the message. + * $false: The sender receives a read receipt when the recipient downloads the message, and when the recipient opens the message. This is the default value. + + .Parameter UnencryptedOrTLSBindings + The UnencryptedOrTLSBindings parameter specifies the IP address and TCP port that's used for unencrypted IMAP4 connections, or IMAP4 connections that are encrypted by using opportunistic TLS (STARTTLS) after the initial unencrypted protocol handshake. This parameter uses the syntax :. + The default value is [::]:143,0.0.0.0:143. + To enter multiple values and overwrite any existing entries, use the following syntax: ,,.... If the values contain spaces or otherwise require quotation marks, you need to use the following syntax: "","",..."". + To add or remove one or more values without affecting any existing entries, use the following syntax: @{Add="",""...; Remove="",""...}. + + .PARAMETER ExternalConnectionSettings + The ExternalConnectionSettings parameter specifies the host name, port, and encryption method that's used by external IMAP4 clients (IMAP4 connections from outside your corporate network). + This parameter uses the syntax ::[]. The encryption method value is optional (blank indicates unencrypted connections). + The default value is blank ($null), which means no external IMAP4 connection settings are configured. + To enter multiple values and overwrite any existing entries, use the following syntax: ,,.... If the values contain spaces or otherwise require quotation marks, you need to use the following syntax: "","",..."". + To add or remove one or more values without affecting any existing entries, use the following syntax: @{Add="",""...; Remove="",""...}. + The combination of encryption methods and ports that are specified for this parameter need to match the corresponding encryption methods and ports that are specified by the SSLBindings and UnencryptedOrTLSBindings parameters. .PARAMETER X509CertificateName - The X509CertificateName parameter specifies the certificate that's used - for encrypting IMAP4 client connections. + The X509CertificateName parameter specifies the certificate that's used for encrypting IMAP4 client connections. + A valid value for this parameter is the FQDN from the ExternalConnectionSettings or InternalConnectionSettings parameters (for example, mail.contoso.com or mailbox01.contoso.com). + If you use a single subject certificate or a subject alternative name (SAN) certificate, you also need to assign the certificate to the Exchange IMAP service by using the Enable-ExchangeCertificate cmdlet. + If you use a wildcard certificate, you don't need to assign the certificate to the Exchange IMAP service. #> function Set-TargetResource { @@ -412,7 +698,12 @@ function Set-TargetResource applied. .PARAMETER Server - The IMAP server to configure. + The Server parameter specifies the Exchange server where you want to run this command. You can use any value that uniquely identifies the server. For example: + * Name + * FQDN + * Distinguished name (DN) + * Exchange Legacy DN + If you don't use this parameter, the command is run on the local server. .PARAMETER Credential Credentials used to establish a remote PowerShell session to Exchange. @@ -427,18 +718,156 @@ function Set-TargetResource Directory. You identify the domain controller by its fully qualified domain name (FQDN). For example, dc01.contoso.com. - .PARAMETER ExternalConnectionSettings - The ExternalConnectionSettings parameter specifies the host name, port, - and encryption method that's used by external IMAP4 clients (IMAP4 - connections from outside your corporate network). + .Parameter AuthenticatedConnectionTimeout + The AuthenticatedConnectionTimeout parameter specifies the period of time to wait before closing an idle authenticated connection. + To specify a value, enter it as a time span: dd.hh:mm:ss where dd = days, hh = hours, mm = minutes, and ss = seconds. + Valid values are 00:00:30 to 1:00:00. The default setting is 00:30:00 (30 minutes). + + .Parameter Banner + The Banner parameter specifies the text string that's displayed to connecting IMAP4 clients. The default value is: The Microsoft Exchange IMAP4 service is ready. + + .Parameter CalendarItemRetrievalOption + The CalendarItemRetrievalOption parameter specifies how calendar items are presented to IMAP4 clients. Valid values are: + * 0 or iCalendar. This is the default value. + * 1 or IntranetUrl + * 2 or InternetUrl + * 3 or Custom + If you specify 3 or Custom, you need to specify a value for the OwaServerUrl parameter setting. + + .Parameter EnableExactRFC822Size + The EnableExactRFC822Size parameter specifies how message sizes are presented to IMAP4 clients. Valid values are: + * $true: Calculate the exact message size. Because this setting can negatively affect performance, you should configure it only if it's required by your IMAP4 clients. + * $false: Use an estimated message size. This is the default value. + + .Parameter EnableGSSAPIAndNTLMAuth + The EnableGSSAPIAndNTLMAuth parameter specifies whether connections can use Integrated Windows authentication (NTLM) using the Generic Security Services application programming interface (GSSAPI). This setting applies to connections where Transport Layer Security (TLS) is disabled. Valid values are: + * $true: NTLM for IMAP4 connections is enabled. This is the default value. + * $false: NTLM for IMAP4 connections is disabled. + + .Parameter EnforceCertificateErrors + The EnforceCertificateErrors parameter specifies whether to enforce valid Secure Sockets Layer (SSL) certificate validation failures. Valid values are: + The default setting is $false. + * $true: If the certificate isn't valid or doesn't match the target IMAP4 server's FQDN, the connection attempt fails. + * $false: The server doesn't deny IMAP4 connections based on certificate errors. This is the default value. + + .Parameter ExtendedProtectionPolicy + The ExtendedProtectionPolicy parameter specifies how Extended Protection for Authentication is used. Valid values are: + * None: Extended Protection for Authentication isn't used. This is the default value. + * Allow: Extended Protection for Authentication is used only if it's supported by the incoming IMAP4 connection. If it's not, Extended Protection for Authentication isn't used. + * Require: Extended Protection for Authentication is required for all IMAP4 connections. If the incoming IMAP4 connection doesn't support it, the connection is rejected. + Extended Protection for Authentication enhances the protection and handling of credentials by Integrated Windows authentication (also known as NTLM), so we strongly recommend that you use it if it's supported by your clients (default installations of Windows 7 or later and Windows Server 2008 R2 or later support it). + + .Parameter InternalConnectionSettings + The InternalConnectionSettings parameter specifies the host name, port, and encryption method that's used by internal IMAP4 clients (IMAP4 connections from inside your corporate network). This setting is also used when a IMAP4 connection is forwarded to another Exchange server that's running the Microsoft Exchange IMAP4 service. + This parameter uses the syntax ::[]. The encryption method value is optional (blank indicates unencrypted connections). + The default value is :993:SSL,:143:TLS. + To enter multiple values and overwrite any existing entries, use the following syntax: ,,.... If the values contain spaces or otherwise require quotation marks, you need to use the following syntax: "","",..."". + To add or remove one or more values without affecting any existing entries, use the following syntax: @{Add="",""...; Remove="",""...}. + The combination of encryption methods and ports that are specified for this parameter need to match the corresponding encryption methods and ports that are specified by the SSLBindings and UnencryptedOrTLSBindings parameters. + + .Parameter LogFileLocation + The LogFileLocation parameter specifies the location for the IMAP4 protocol log files. The default location is %ExchangeInstallPath%Logging\Imap4. + This parameter is only meaningful when the ProtocolLogEnabled parameter value is $true. + + .Parameter LogFileRollOverSettings + The LogFileRollOverSettings parameter specifies how frequently IMAP4 protocol logging creates a new log file. Valid values are: + * 1 or Hourly. + * 2 or Daily. This is the default value + * 3 or Weekly. + * 4 or Monthly. + This parameter is only meaningful when the LogPerFileSizeQuota parameter value is 0, and the ProtocolLogEnabled parameter value is $true. + + .Parameter LogPerFileSizeQuota + The LogPerFileSizeQuota parameter specifies the maximum size of a IMAP4 protocol log file. + When you enter a value, qualify the value with one of the following units: + * B (bytes) + * KB (kilobytes) + * MB (megabytes) + * GB (gigabytes) + * TB (terabytes) + Unqualified values are typically treated as bytes, but small values may be rounded up to the nearest kilobyte. + The default value is 0, which means a new IMAP4 protocol log file is created at the frequency that's specified by the LogFileRollOverSettings parameter. + This parameter is only meaningful when the ProtocolLogEnabled parameter value is $true. .PARAMETER LoginType - The LoginType parameter specifies the authentication method for IMAP4 - connections. + The LoginType parameter specifies the authentication method for IMAP4 connections. Valid values are: + * 1 or PlainTextLogin. + * 2 or PlainTextAuthentication. + * 3 or SecureLogin. This is the default value. + + .Parameter MaxCommandSize + The MaxCommandSize parameter specifies the maximum size in bytes of a single IMAP4 command. Valid values are from 40 through 1024. The default value is 512. + + .Parameter MaxConnectionFromSingleIP + The MaxConnectionFromSingleIP parameter specifies the maximum number of IMAP4 connections that are accepted by the Exchange server from a single IP address. Valid values are from 1 through 2147483647. The default value is 2147483647. + + .Parameter MaxConnections + The MaxConnections parameter specifies the maximum number of IMAP4 connections that are accepted by the Exchange server. Valid values are from 1 through 2147483647. The default value is 2147483647. + + .Parameter MaxConnectionsPerUser + The MaxConnectionsPerUser parameter specifies the maximum number of IMAP4 connections that are allowed for each user. Valid values are from 1 through 2147483647. The default value is 16. + + .Parameter MessageRetrievalMimeFormat + The MessageRetrievalMimeFormat parameter specifies the MIME encoding of messages. Valid values are: + * 0 or TextOnly. + * 1 or HtmlOnly. + * 2 or HtmlAndTextAlternative. + * 3 or TextEnrichedOnly. + * 4 or TextEnrichedAndTextAlternative. + * 5 or BestBodyFormat. This is the default value. + * 6 or Tnef. + + .Parameter OwaServerUrl + The OwaServerUrl parameter specifies the URL that's used to retrieve calendar information for instances of custom Outlook on the web calendar items. + + .Parameter PreAuthenticatedConnectionTimeout + The PreAuthenticatedConnectionTimeout parameter specifies the period of time to wait before closing an idle IMAP4 connection that isn't authenticated. + To specify a value, enter it as a time span: dd.hh:mm:ss where dd = days, hh = hours, mm = minutes, and ss = seconds. + Valid values are00:00:30 to 1:00:00. The default value is 00:01:00 (one minute). + + .Parameter ProtocolLogEnabled + The ProtocolLogEnabled parameter specifies whether to enable protocol logging for IMAP4. Valid values are: + * $true: IMAP4 protocol logging is enabled. + * $false: IMAP4 protocol logging is disabled. This is the default value. + + .Parameter ProxyTargetPort + The ProxyTargetPort parameter specifies the port on the Microsoft Exchange IMAP4 Backend service that listens for client connections that are proxied from the Microsoft Exchange IMAP4 service. The default value is 1993. + + .Parameter ShowHiddenFoldersEnabled + The ShowHiddenFoldersEnabled parameter specifies whether hidden mailbox folders are visible. Valid values are: + * $true: Hidden folders are visible. + * $false: Hidden folders aren't visible. This is the default value. + + .Parameter SSLBindings + The SSLBindings parameter specifies the IP address and TCP port that's used for IMAP4 connection that's always encrypted by SSL/TLS. This parameter uses the syntax :. + The default value is [::]:993,0.0.0.0:993. + To enter multiple values and overwrite any existing entries, use the following syntax: ,,.... If the values contain spaces or otherwise require quotation marks, you need to use the following syntax: "","",..."". + To add or remove one or more values without affecting any existing entries, use the following syntax: @{Add="",""...; Remove="",""...}. + + .Parameter SuppressReadReceipt + The SuppressReadReceipt parameter specifies whether to stop duplicate read receipts from being sent to IMAP4 clients that have the Send read receipts for messages I send setting configured in their IMAP4 email program. Valid values are: + * $true: The sender receives a read receipt only when the recipient opens the message. + * $false: The sender receives a read receipt when the recipient downloads the message, and when the recipient opens the message. This is the default value. + + .Parameter UnencryptedOrTLSBindings + The UnencryptedOrTLSBindings parameter specifies the IP address and TCP port that's used for unencrypted IMAP4 connections, or IMAP4 connections that are encrypted by using opportunistic TLS (STARTTLS) after the initial unencrypted protocol handshake. This parameter uses the syntax :. + The default value is [::]:143,0.0.0.0:143. + To enter multiple values and overwrite any existing entries, use the following syntax: ,,.... If the values contain spaces or otherwise require quotation marks, you need to use the following syntax: "","",..."". + To add or remove one or more values without affecting any existing entries, use the following syntax: @{Add="",""...; Remove="",""...}. + + .PARAMETER ExternalConnectionSettings + The ExternalConnectionSettings parameter specifies the host name, port, and encryption method that's used by external IMAP4 clients (IMAP4 connections from outside your corporate network). + This parameter uses the syntax ::[]. The encryption method value is optional (blank indicates unencrypted connections). + The default value is blank ($null), which means no external IMAP4 connection settings are configured. + To enter multiple values and overwrite any existing entries, use the following syntax: ,,.... If the values contain spaces or otherwise require quotation marks, you need to use the following syntax: "","",..."". + To add or remove one or more values without affecting any existing entries, use the following syntax: @{Add="",""...; Remove="",""...}. + The combination of encryption methods and ports that are specified for this parameter need to match the corresponding encryption methods and ports that are specified by the SSLBindings and UnencryptedOrTLSBindings parameters. .PARAMETER X509CertificateName - The X509CertificateName parameter specifies the certificate that's used - for encrypting IMAP4 client connections. + The X509CertificateName parameter specifies the certificate that's used for encrypting IMAP4 client connections. + A valid value for this parameter is the FQDN from the ExternalConnectionSettings or InternalConnectionSettings parameters (for example, mail.contoso.com or mailbox01.contoso.com). + If you use a single subject certificate or a subject alternative name (SAN) certificate, you also need to assign the certificate to the Exchange IMAP service by using the Enable-ExchangeCertificate cmdlet. + If you use a wildcard certificate, you don't need to assign the certificate to the Exchange IMAP service. #> function Test-TargetResource { @@ -745,7 +1174,12 @@ function Test-TargetResource optionally DomainController, and returns the results. .PARAMETER Server - The IMAP server to configure. + The Server parameter specifies the Exchange server where you want to run this command. You can use any value that uniquely identifies the server. For example: + * Name + * FQDN + * Distinguished name (DN) + * Exchange Legacy DN + If you don't use this parameter, the command is run on the local server. .PARAMETER Credential Credentials used to establish a remote PowerShell session to Exchange. @@ -760,18 +1194,156 @@ function Test-TargetResource Directory. You identify the domain controller by its fully qualified domain name (FQDN). For example, dc01.contoso.com. - .PARAMETER ExternalConnectionSettings - The ExternalConnectionSettings parameter specifies the host name, port, - and encryption method that's used by external IMAP4 clients (IMAP4 - connections from outside your corporate network). + .Parameter AuthenticatedConnectionTimeout + The AuthenticatedConnectionTimeout parameter specifies the period of time to wait before closing an idle authenticated connection. + To specify a value, enter it as a time span: dd.hh:mm:ss where dd = days, hh = hours, mm = minutes, and ss = seconds. + Valid values are 00:00:30 to 1:00:00. The default setting is 00:30:00 (30 minutes). + + .Parameter Banner + The Banner parameter specifies the text string that's displayed to connecting IMAP4 clients. The default value is: The Microsoft Exchange IMAP4 service is ready. + + .Parameter CalendarItemRetrievalOption + The CalendarItemRetrievalOption parameter specifies how calendar items are presented to IMAP4 clients. Valid values are: + * 0 or iCalendar. This is the default value. + * 1 or IntranetUrl + * 2 or InternetUrl + * 3 or Custom + If you specify 3 or Custom, you need to specify a value for the OwaServerUrl parameter setting. + + .Parameter EnableExactRFC822Size + The EnableExactRFC822Size parameter specifies how message sizes are presented to IMAP4 clients. Valid values are: + * $true: Calculate the exact message size. Because this setting can negatively affect performance, you should configure it only if it's required by your IMAP4 clients. + * $false: Use an estimated message size. This is the default value. + + .Parameter EnableGSSAPIAndNTLMAuth + The EnableGSSAPIAndNTLMAuth parameter specifies whether connections can use Integrated Windows authentication (NTLM) using the Generic Security Services application programming interface (GSSAPI). This setting applies to connections where Transport Layer Security (TLS) is disabled. Valid values are: + * $true: NTLM for IMAP4 connections is enabled. This is the default value. + * $false: NTLM for IMAP4 connections is disabled. + + .Parameter EnforceCertificateErrors + The EnforceCertificateErrors parameter specifies whether to enforce valid Secure Sockets Layer (SSL) certificate validation failures. Valid values are: + The default setting is $false. + * $true: If the certificate isn't valid or doesn't match the target IMAP4 server's FQDN, the connection attempt fails. + * $false: The server doesn't deny IMAP4 connections based on certificate errors. This is the default value. + + .Parameter ExtendedProtectionPolicy + The ExtendedProtectionPolicy parameter specifies how Extended Protection for Authentication is used. Valid values are: + * None: Extended Protection for Authentication isn't used. This is the default value. + * Allow: Extended Protection for Authentication is used only if it's supported by the incoming IMAP4 connection. If it's not, Extended Protection for Authentication isn't used. + * Require: Extended Protection for Authentication is required for all IMAP4 connections. If the incoming IMAP4 connection doesn't support it, the connection is rejected. + Extended Protection for Authentication enhances the protection and handling of credentials by Integrated Windows authentication (also known as NTLM), so we strongly recommend that you use it if it's supported by your clients (default installations of Windows 7 or later and Windows Server 2008 R2 or later support it). + + .Parameter InternalConnectionSettings + The InternalConnectionSettings parameter specifies the host name, port, and encryption method that's used by internal IMAP4 clients (IMAP4 connections from inside your corporate network). This setting is also used when a IMAP4 connection is forwarded to another Exchange server that's running the Microsoft Exchange IMAP4 service. + This parameter uses the syntax ::[]. The encryption method value is optional (blank indicates unencrypted connections). + The default value is :993:SSL,:143:TLS. + To enter multiple values and overwrite any existing entries, use the following syntax: ,,.... If the values contain spaces or otherwise require quotation marks, you need to use the following syntax: "","",..."". + To add or remove one or more values without affecting any existing entries, use the following syntax: @{Add="",""...; Remove="",""...}. + The combination of encryption methods and ports that are specified for this parameter need to match the corresponding encryption methods and ports that are specified by the SSLBindings and UnencryptedOrTLSBindings parameters. + + .Parameter LogFileLocation + The LogFileLocation parameter specifies the location for the IMAP4 protocol log files. The default location is %ExchangeInstallPath%Logging\Imap4. + This parameter is only meaningful when the ProtocolLogEnabled parameter value is $true. + + .Parameter LogFileRollOverSettings + The LogFileRollOverSettings parameter specifies how frequently IMAP4 protocol logging creates a new log file. Valid values are: + * 1 or Hourly. + * 2 or Daily. This is the default value + * 3 or Weekly. + * 4 or Monthly. + This parameter is only meaningful when the LogPerFileSizeQuota parameter value is 0, and the ProtocolLogEnabled parameter value is $true. + + .Parameter LogPerFileSizeQuota + The LogPerFileSizeQuota parameter specifies the maximum size of a IMAP4 protocol log file. + When you enter a value, qualify the value with one of the following units: + * B (bytes) + * KB (kilobytes) + * MB (megabytes) + * GB (gigabytes) + * TB (terabytes) + Unqualified values are typically treated as bytes, but small values may be rounded up to the nearest kilobyte. + The default value is 0, which means a new IMAP4 protocol log file is created at the frequency that's specified by the LogFileRollOverSettings parameter. + This parameter is only meaningful when the ProtocolLogEnabled parameter value is $true. .PARAMETER LoginType - The LoginType parameter specifies the authentication method for IMAP4 - connections. + The LoginType parameter specifies the authentication method for IMAP4 connections. Valid values are: + * 1 or PlainTextLogin. + * 2 or PlainTextAuthentication. + * 3 or SecureLogin. This is the default value. + + .Parameter MaxCommandSize + The MaxCommandSize parameter specifies the maximum size in bytes of a single IMAP4 command. Valid values are from 40 through 1024. The default value is 512. + + .Parameter MaxConnectionFromSingleIP + The MaxConnectionFromSingleIP parameter specifies the maximum number of IMAP4 connections that are accepted by the Exchange server from a single IP address. Valid values are from 1 through 2147483647. The default value is 2147483647. + + .Parameter MaxConnections + The MaxConnections parameter specifies the maximum number of IMAP4 connections that are accepted by the Exchange server. Valid values are from 1 through 2147483647. The default value is 2147483647. + + .Parameter MaxConnectionsPerUser + The MaxConnectionsPerUser parameter specifies the maximum number of IMAP4 connections that are allowed for each user. Valid values are from 1 through 2147483647. The default value is 16. + + .Parameter MessageRetrievalMimeFormat + The MessageRetrievalMimeFormat parameter specifies the MIME encoding of messages. Valid values are: + * 0 or TextOnly. + * 1 or HtmlOnly. + * 2 or HtmlAndTextAlternative. + * 3 or TextEnrichedOnly. + * 4 or TextEnrichedAndTextAlternative. + * 5 or BestBodyFormat. This is the default value. + * 6 or Tnef. + + .Parameter OwaServerUrl + The OwaServerUrl parameter specifies the URL that's used to retrieve calendar information for instances of custom Outlook on the web calendar items. + + .Parameter PreAuthenticatedConnectionTimeout + The PreAuthenticatedConnectionTimeout parameter specifies the period of time to wait before closing an idle IMAP4 connection that isn't authenticated. + To specify a value, enter it as a time span: dd.hh:mm:ss where dd = days, hh = hours, mm = minutes, and ss = seconds. + Valid values are00:00:30 to 1:00:00. The default value is 00:01:00 (one minute). + + .Parameter ProtocolLogEnabled + The ProtocolLogEnabled parameter specifies whether to enable protocol logging for IMAP4. Valid values are: + * $true: IMAP4 protocol logging is enabled. + * $false: IMAP4 protocol logging is disabled. This is the default value. + + .Parameter ProxyTargetPort + The ProxyTargetPort parameter specifies the port on the Microsoft Exchange IMAP4 Backend service that listens for client connections that are proxied from the Microsoft Exchange IMAP4 service. The default value is 1993. + + .Parameter ShowHiddenFoldersEnabled + The ShowHiddenFoldersEnabled parameter specifies whether hidden mailbox folders are visible. Valid values are: + * $true: Hidden folders are visible. + * $false: Hidden folders aren't visible. This is the default value. + + .Parameter SSLBindings + The SSLBindings parameter specifies the IP address and TCP port that's used for IMAP4 connection that's always encrypted by SSL/TLS. This parameter uses the syntax :. + The default value is [::]:993,0.0.0.0:993. + To enter multiple values and overwrite any existing entries, use the following syntax: ,,.... If the values contain spaces or otherwise require quotation marks, you need to use the following syntax: "","",..."". + To add or remove one or more values without affecting any existing entries, use the following syntax: @{Add="",""...; Remove="",""...}. + + .Parameter SuppressReadReceipt + The SuppressReadReceipt parameter specifies whether to stop duplicate read receipts from being sent to IMAP4 clients that have the Send read receipts for messages I send setting configured in their IMAP4 email program. Valid values are: + * $true: The sender receives a read receipt only when the recipient opens the message. + * $false: The sender receives a read receipt when the recipient downloads the message, and when the recipient opens the message. This is the default value. + + .Parameter UnencryptedOrTLSBindings + The UnencryptedOrTLSBindings parameter specifies the IP address and TCP port that's used for unencrypted IMAP4 connections, or IMAP4 connections that are encrypted by using opportunistic TLS (STARTTLS) after the initial unencrypted protocol handshake. This parameter uses the syntax :. + The default value is [::]:143,0.0.0.0:143. + To enter multiple values and overwrite any existing entries, use the following syntax: ,,.... If the values contain spaces or otherwise require quotation marks, you need to use the following syntax: "","",..."". + To add or remove one or more values without affecting any existing entries, use the following syntax: @{Add="",""...; Remove="",""...}. + + .PARAMETER ExternalConnectionSettings + The ExternalConnectionSettings parameter specifies the host name, port, and encryption method that's used by external IMAP4 clients (IMAP4 connections from outside your corporate network). + This parameter uses the syntax ::[]. The encryption method value is optional (blank indicates unencrypted connections). + The default value is blank ($null), which means no external IMAP4 connection settings are configured. + To enter multiple values and overwrite any existing entries, use the following syntax: ,,.... If the values contain spaces or otherwise require quotation marks, you need to use the following syntax: "","",..."". + To add or remove one or more values without affecting any existing entries, use the following syntax: @{Add="",""...; Remove="",""...}. + The combination of encryption methods and ports that are specified for this parameter need to match the corresponding encryption methods and ports that are specified by the SSLBindings and UnencryptedOrTLSBindings parameters. .PARAMETER X509CertificateName - The X509CertificateName parameter specifies the certificate that's used - for encrypting IMAP4 client connections. + The X509CertificateName parameter specifies the certificate that's used for encrypting IMAP4 client connections. + A valid value for this parameter is the FQDN from the ExternalConnectionSettings or InternalConnectionSettings parameters (for example, mail.contoso.com or mailbox01.contoso.com). + If you use a single subject certificate or a subject alternative name (SAN) certificate, you also need to assign the certificate to the Exchange IMAP service by using the Enable-ExchangeCertificate cmdlet. + If you use a wildcard certificate, you don't need to assign the certificate to the Exchange IMAP service. #> function Get-ImapSettingsInternal { From a7c09bc1fa5851e234ae293dfbee7941346e15b7 Mon Sep 17 00:00:00 2001 From: Ariel Moisis Date: Wed, 20 Feb 2019 11:45:10 +1100 Subject: [PATCH 24/28] update unit tests --- Tests/Unit/MSFT_xExchImapSettings.tests.ps1 | 2 +- 1 file changed, 1 insertion(+), 1 deletion(-) diff --git a/Tests/Unit/MSFT_xExchImapSettings.tests.ps1 b/Tests/Unit/MSFT_xExchImapSettings.tests.ps1 index 47f01d77..f652a1d7 100644 --- a/Tests/Unit/MSFT_xExchImapSettings.tests.ps1 +++ b/Tests/Unit/MSFT_xExchImapSettings.tests.ps1 @@ -129,7 +129,7 @@ try } Context 'When Test-TargetResource is called' { - It 'Should return False when Get-UMCallRouterSettings returns null' { + It 'Should return False when Get-ImapSettingsInternal returns null' { Mock -CommandName Get-ImapSettingsInternal -Verifiable Test-TargetResource @commonTargetResourceParams -ErrorAction SilentlyContinue | Should -Be $false From 27f3bf0f6f86168f125505e2f280dd652133dda5 Mon Sep 17 00:00:00 2001 From: Ariel Moisis Date: Fri, 1 Mar 2019 15:30:28 +1100 Subject: [PATCH 25/28] update Readme.md --- README.md | 63 +++++++++++++++++++++++++++++++++++++++++++++++++++++++ 1 file changed, 63 insertions(+) diff --git a/README.md b/README.md index fee01122..d2b982ac 100644 --- a/README.md +++ b/README.md @@ -758,6 +758,69 @@ parameters. for IMAP4 connections. * **X509CertificateName**: The X509CertificateName parameter specifies the certificate that's used for encrypting IMAP4 client connections. +* **AuthenticatedConnectionTimeout**: The AuthenticatedConnectionTimeout + parameter specifies the period of time to wait before closing an idle + authenticated connection.")] String AuthenticatedConnectionTimeout. +* **Banner**: The Banner parameter specifies the text string that's displayed to + connecting IMAP4 clients. +* **CalendarItemRetrievalOption**: The CalendarItemRetrievalOption parameter + specifies how calendar items are presented to IMAP4 clients. + {iCalendar | IntranetUrl | InternetUrl | Custom} +* **EnableExactRFC822Size**: The EnableExactRFC822Size parameter specifies how + message sizes are presented to IMAP4 clients. +* **EnableGSSAPIAndNTLMAuth**: The EnableGSSAPIAndNTLMAuth parameter specifies + whether connections can use Integrated Windows authentication (NTLM) using the + Generic Security Services application programming interface (GSSAPI). This + setting applies to connections where Transport Layer Security (TLS) is disabled. +* **EnforceCertificateErrors**: The EnforceCertificateErrors parameter specifies + whether to enforce valid Secure Sockets Layer (SSL) certificate validation failures. +* **ExtendedProtectionPolicy**: The ExtendedProtectionPolicy parameter specifies + how Extended Protection for Authentication is used. {None | Allow | Required} +* **InternalConnectionSettings**: The InternalConnectionSettings parameter + specifies the host name, port, and encryption method that's used by internal + IMAP4 clients (IMAP4 connections from inside your corporate network). +* **LogFileLocation**: The LogFileLocation parameter specifies the location for + the IMAP4 protocol log files. +* **LogFileRollOverSettings**: The LogFileRollOverSettings parameter specifies + how frequently IMAP4 protocol logging creates a new log file. + {Hourly | Daily | Weekly | Monthly} +* **LogPerFileSizeQuota**: The LogPerFileSizeQuota parameter specifies the + maximum size of a IMAP4 protocol log file. +* **MaxCommandSize**: The MaxCommandSize parameter specifies the maximum size in + bytes of a single IMAP4 command. +* **MaxConnectionFromSingleIP**: The MaxConnectionFromSingleIP parameter + specifies the maximum number of IMAP4 connections that are accepted by the + Exchange server from a single IP address. +* **MaxConnections**: The MaxConnections parameter specifies the maximum number + of IMAP4 connections that are accepted by the Exchange server. +* **MaxConnectionsPerUser**: The MaxConnectionsPerUser parameter specifies the + maximum number of IMAP4 connections that are allowed for each user. +* **MessageRetrievalMimeFormat**: The MessageRetrievalMimeFormat parameter + specifies the MIME encoding of messages. +{TextOnly | HtmlOnly | HtmlAndTextAlternative | + TextEnrichedOnly | TextEnrichedAndTextAlternative | BestBodyFormat | Tnef} +* **OwaServerUrl**: The OwaServerUrl parameter specifies the URL that's used to + retrieve calendar information for instances of custom Outlook on the web + calendar items. +* **PreAuthenticatedConnectionTimeout**: The PreAuthenticatedConnectionTimeout + parameter specifies the period of time to wait before closing an idle IMAP4 + connection that isn't authenticated. +* **ProtocolLogEnabled**: The ProtocolLogEnabled parameter specifies whether to + enable protocol logging for IMAP4. +* **ProxyTargetPort**: The ProxyTargetPort parameter specifies the port on the + Microsoft Exchange IMAP4 Backend service that listens for client connections + that are proxied from the Microsoft Exchange IMAP4 service. +* **ShowHiddenFoldersEnabled**: The ShowHiddenFoldersEnabled parameter specifies + whether hidden mailbox folders are visible. +* **SSLBindings**: The SSLBindings parameter specifies the IP address and TCP + port that's used for IMAP4 connection that's always encrypted by SSL/TLS. This + parameter uses the syntax :. +* **SuppressReadReceipt**: The SuppressReadReceipt parameter specifies whether + to stop duplicate read receipts from being sent to IMAP4 clients that have the + Send read receipts for messages I send setting configured in their IMAP4 email + program. +* **UnencryptedOrTLSBindings**: The X509CertificateName parameter specifies the + certificate that's used for encrypting IMAP4 client connections. ### xExchInstall From 3e376ce14ce020ad865760bc597ade458eea553f Mon Sep 17 00:00:00 2001 From: Ariel Moisis Date: Thu, 7 Mar 2019 09:42:20 +1100 Subject: [PATCH 26/28] update brackets --- README.md | 2 +- 1 file changed, 1 insertion(+), 1 deletion(-) diff --git a/README.md b/README.md index d2b982ac..55008ff9 100644 --- a/README.md +++ b/README.md @@ -814,7 +814,7 @@ parameters. whether hidden mailbox folders are visible. * **SSLBindings**: The SSLBindings parameter specifies the IP address and TCP port that's used for IMAP4 connection that's always encrypted by SSL/TLS. This - parameter uses the syntax :. + parameter uses the syntax {IPv4OrIPv6Address}:{Port}. * **SuppressReadReceipt**: The SuppressReadReceipt parameter specifies whether to stop duplicate read receipts from being sent to IMAP4 clients that have the Send read receipts for messages I send setting configured in their IMAP4 email From 7c010b55cdabde331c4226879349d02ffdc67a21 Mon Sep 17 00:00:00 2001 From: Ariel Moisis Date: Fri, 8 Nov 2019 09:17:24 +1100 Subject: [PATCH 27/28] update help block --- .../MSFT_xExchImapSettings.psm1 | 50 +++++++++---------- 1 file changed, 25 insertions(+), 25 deletions(-) diff --git a/DSCResources/MSFT_xExchImapSettings/MSFT_xExchImapSettings.psm1 b/DSCResources/MSFT_xExchImapSettings/MSFT_xExchImapSettings.psm1 index eb1af154..c3e5733d 100644 --- a/DSCResources/MSFT_xExchImapSettings/MSFT_xExchImapSettings.psm1 +++ b/DSCResources/MSFT_xExchImapSettings/MSFT_xExchImapSettings.psm1 @@ -62,6 +62,14 @@ * Require: Extended Protection for Authentication is required for all IMAP4 connections. If the incoming IMAP4 connection doesn't support it, the connection is rejected. Extended Protection for Authentication enhances the protection and handling of credentials by Integrated Windows authentication (also known as NTLM), so we strongly recommend that you use it if it's supported by your clients (default installations of Windows 7 or later and Windows Server 2008 R2 or later support it). + .PARAMETER ExternalConnectionSettings + The ExternalConnectionSettings parameter specifies the host name, port, and encryption method that's used by external IMAP4 clients (IMAP4 connections from outside your corporate network). + This parameter uses the syntax ::[]. The encryption method value is optional (blank indicates unencrypted connections). + The default value is blank ($null), which means no external IMAP4 connection settings are configured. + To enter multiple values and overwrite any existing entries, use the following syntax: ,,.... If the values contain spaces or otherwise require quotation marks, you need to use the following syntax: "","",..."". + To add or remove one or more values without affecting any existing entries, use the following syntax: @{Add="",""...; Remove="",""...}. + The combination of encryption methods and ports that are specified for this parameter need to match the corresponding encryption methods and ports that are specified by the SSLBindings and UnencryptedOrTLSBindings parameters. + .Parameter InternalConnectionSettings The InternalConnectionSettings parameter specifies the host name, port, and encryption method that's used by internal IMAP4 clients (IMAP4 connections from inside your corporate network). This setting is also used when a IMAP4 connection is forwarded to another Exchange server that's running the Microsoft Exchange IMAP4 service. This parameter uses the syntax ::[]. The encryption method value is optional (blank indicates unencrypted connections). @@ -142,7 +150,7 @@ The ShowHiddenFoldersEnabled parameter specifies whether hidden mailbox folders are visible. Valid values are: * $true: Hidden folders are visible. * $false: Hidden folders aren't visible. This is the default value. - + .Parameter SSLBindings The SSLBindings parameter specifies the IP address and TCP port that's used for IMAP4 connection that's always encrypted by SSL/TLS. This parameter uses the syntax :. The default value is [::]:993,0.0.0.0:993. @@ -160,14 +168,6 @@ To enter multiple values and overwrite any existing entries, use the following syntax: ,,.... If the values contain spaces or otherwise require quotation marks, you need to use the following syntax: "","",..."". To add or remove one or more values without affecting any existing entries, use the following syntax: @{Add="",""...; Remove="",""...}. - .PARAMETER ExternalConnectionSettings - The ExternalConnectionSettings parameter specifies the host name, port, and encryption method that's used by external IMAP4 clients (IMAP4 connections from outside your corporate network). - This parameter uses the syntax ::[]. The encryption method value is optional (blank indicates unencrypted connections). - The default value is blank ($null), which means no external IMAP4 connection settings are configured. - To enter multiple values and overwrite any existing entries, use the following syntax: ,,.... If the values contain spaces or otherwise require quotation marks, you need to use the following syntax: "","",..."". - To add or remove one or more values without affecting any existing entries, use the following syntax: @{Add="",""...; Remove="",""...}. - The combination of encryption methods and ports that are specified for this parameter need to match the corresponding encryption methods and ports that are specified by the SSLBindings and UnencryptedOrTLSBindings parameters. - .PARAMETER X509CertificateName The X509CertificateName parameter specifies the certificate that's used for encrypting IMAP4 client connections. A valid value for this parameter is the FQDN from the ExternalConnectionSettings or InternalConnectionSettings parameters (for example, mail.contoso.com or mailbox01.contoso.com). @@ -422,6 +422,14 @@ function Get-TargetResource * Require: Extended Protection for Authentication is required for all IMAP4 connections. If the incoming IMAP4 connection doesn't support it, the connection is rejected. Extended Protection for Authentication enhances the protection and handling of credentials by Integrated Windows authentication (also known as NTLM), so we strongly recommend that you use it if it's supported by your clients (default installations of Windows 7 or later and Windows Server 2008 R2 or later support it). + .PARAMETER ExternalConnectionSettings + The ExternalConnectionSettings parameter specifies the host name, port, and encryption method that's used by external IMAP4 clients (IMAP4 connections from outside your corporate network). + This parameter uses the syntax ::[]. The encryption method value is optional (blank indicates unencrypted connections). + The default value is blank ($null), which means no external IMAP4 connection settings are configured. + To enter multiple values and overwrite any existing entries, use the following syntax: ,,.... If the values contain spaces or otherwise require quotation marks, you need to use the following syntax: "","",..."". + To add or remove one or more values without affecting any existing entries, use the following syntax: @{Add="",""...; Remove="",""...}. + The combination of encryption methods and ports that are specified for this parameter need to match the corresponding encryption methods and ports that are specified by the SSLBindings and UnencryptedOrTLSBindings parameters. + .Parameter InternalConnectionSettings The InternalConnectionSettings parameter specifies the host name, port, and encryption method that's used by internal IMAP4 clients (IMAP4 connections from inside your corporate network). This setting is also used when a IMAP4 connection is forwarded to another Exchange server that's running the Microsoft Exchange IMAP4 service. This parameter uses the syntax ::[]. The encryption method value is optional (blank indicates unencrypted connections). @@ -520,14 +528,6 @@ function Get-TargetResource To enter multiple values and overwrite any existing entries, use the following syntax: ,,.... If the values contain spaces or otherwise require quotation marks, you need to use the following syntax: "","",..."". To add or remove one or more values without affecting any existing entries, use the following syntax: @{Add="",""...; Remove="",""...}. - .PARAMETER ExternalConnectionSettings - The ExternalConnectionSettings parameter specifies the host name, port, and encryption method that's used by external IMAP4 clients (IMAP4 connections from outside your corporate network). - This parameter uses the syntax ::[]. The encryption method value is optional (blank indicates unencrypted connections). - The default value is blank ($null), which means no external IMAP4 connection settings are configured. - To enter multiple values and overwrite any existing entries, use the following syntax: ,,.... If the values contain spaces or otherwise require quotation marks, you need to use the following syntax: "","",..."". - To add or remove one or more values without affecting any existing entries, use the following syntax: @{Add="",""...; Remove="",""...}. - The combination of encryption methods and ports that are specified for this parameter need to match the corresponding encryption methods and ports that are specified by the SSLBindings and UnencryptedOrTLSBindings parameters. - .PARAMETER X509CertificateName The X509CertificateName parameter specifies the certificate that's used for encrypting IMAP4 client connections. A valid value for this parameter is the FQDN from the ExternalConnectionSettings or InternalConnectionSettings parameters (for example, mail.contoso.com or mailbox01.contoso.com). @@ -757,6 +757,14 @@ function Set-TargetResource * Require: Extended Protection for Authentication is required for all IMAP4 connections. If the incoming IMAP4 connection doesn't support it, the connection is rejected. Extended Protection for Authentication enhances the protection and handling of credentials by Integrated Windows authentication (also known as NTLM), so we strongly recommend that you use it if it's supported by your clients (default installations of Windows 7 or later and Windows Server 2008 R2 or later support it). + .PARAMETER ExternalConnectionSettings + The ExternalConnectionSettings parameter specifies the host name, port, and encryption method that's used by external IMAP4 clients (IMAP4 connections from outside your corporate network). + This parameter uses the syntax ::[]. The encryption method value is optional (blank indicates unencrypted connections). + The default value is blank ($null), which means no external IMAP4 connection settings are configured. + To enter multiple values and overwrite any existing entries, use the following syntax: ,,.... If the values contain spaces or otherwise require quotation marks, you need to use the following syntax: "","",..."". + To add or remove one or more values without affecting any existing entries, use the following syntax: @{Add="",""...; Remove="",""...}. + The combination of encryption methods and ports that are specified for this parameter need to match the corresponding encryption methods and ports that are specified by the SSLBindings and UnencryptedOrTLSBindings parameters. + .Parameter InternalConnectionSettings The InternalConnectionSettings parameter specifies the host name, port, and encryption method that's used by internal IMAP4 clients (IMAP4 connections from inside your corporate network). This setting is also used when a IMAP4 connection is forwarded to another Exchange server that's running the Microsoft Exchange IMAP4 service. This parameter uses the syntax ::[]. The encryption method value is optional (blank indicates unencrypted connections). @@ -855,14 +863,6 @@ function Set-TargetResource To enter multiple values and overwrite any existing entries, use the following syntax: ,,.... If the values contain spaces or otherwise require quotation marks, you need to use the following syntax: "","",..."". To add or remove one or more values without affecting any existing entries, use the following syntax: @{Add="",""...; Remove="",""...}. - .PARAMETER ExternalConnectionSettings - The ExternalConnectionSettings parameter specifies the host name, port, and encryption method that's used by external IMAP4 clients (IMAP4 connections from outside your corporate network). - This parameter uses the syntax ::[]. The encryption method value is optional (blank indicates unencrypted connections). - The default value is blank ($null), which means no external IMAP4 connection settings are configured. - To enter multiple values and overwrite any existing entries, use the following syntax: ,,.... If the values contain spaces or otherwise require quotation marks, you need to use the following syntax: "","",..."". - To add or remove one or more values without affecting any existing entries, use the following syntax: @{Add="",""...; Remove="",""...}. - The combination of encryption methods and ports that are specified for this parameter need to match the corresponding encryption methods and ports that are specified by the SSLBindings and UnencryptedOrTLSBindings parameters. - .PARAMETER X509CertificateName The X509CertificateName parameter specifies the certificate that's used for encrypting IMAP4 client connections. A valid value for this parameter is the FQDN from the ExternalConnectionSettings or InternalConnectionSettings parameters (for example, mail.contoso.com or mailbox01.contoso.com). From 3a1ee8b84a2045a5400fbb1573b43e1f711c3b79 Mon Sep 17 00:00:00 2001 From: Ariel Moisis Date: Fri, 8 Nov 2019 09:20:00 +1100 Subject: [PATCH 28/28] update help for get-imapsettingsinternal --- .../MSFT_xExchImapSettings.psm1 | 16 ++++++++-------- 1 file changed, 8 insertions(+), 8 deletions(-) diff --git a/DSCResources/MSFT_xExchImapSettings/MSFT_xExchImapSettings.psm1 b/DSCResources/MSFT_xExchImapSettings/MSFT_xExchImapSettings.psm1 index c3e5733d..01e8e836 100644 --- a/DSCResources/MSFT_xExchImapSettings/MSFT_xExchImapSettings.psm1 +++ b/DSCResources/MSFT_xExchImapSettings/MSFT_xExchImapSettings.psm1 @@ -1233,6 +1233,14 @@ function Test-TargetResource * Require: Extended Protection for Authentication is required for all IMAP4 connections. If the incoming IMAP4 connection doesn't support it, the connection is rejected. Extended Protection for Authentication enhances the protection and handling of credentials by Integrated Windows authentication (also known as NTLM), so we strongly recommend that you use it if it's supported by your clients (default installations of Windows 7 or later and Windows Server 2008 R2 or later support it). + .PARAMETER ExternalConnectionSettings + The ExternalConnectionSettings parameter specifies the host name, port, and encryption method that's used by external IMAP4 clients (IMAP4 connections from outside your corporate network). + This parameter uses the syntax ::[]. The encryption method value is optional (blank indicates unencrypted connections). + The default value is blank ($null), which means no external IMAP4 connection settings are configured. + To enter multiple values and overwrite any existing entries, use the following syntax: ,,.... If the values contain spaces or otherwise require quotation marks, you need to use the following syntax: "","",..."". + To add or remove one or more values without affecting any existing entries, use the following syntax: @{Add="",""...; Remove="",""...}. + The combination of encryption methods and ports that are specified for this parameter need to match the corresponding encryption methods and ports that are specified by the SSLBindings and UnencryptedOrTLSBindings parameters. + .Parameter InternalConnectionSettings The InternalConnectionSettings parameter specifies the host name, port, and encryption method that's used by internal IMAP4 clients (IMAP4 connections from inside your corporate network). This setting is also used when a IMAP4 connection is forwarded to another Exchange server that's running the Microsoft Exchange IMAP4 service. This parameter uses the syntax ::[]. The encryption method value is optional (blank indicates unencrypted connections). @@ -1331,14 +1339,6 @@ function Test-TargetResource To enter multiple values and overwrite any existing entries, use the following syntax: ,,.... If the values contain spaces or otherwise require quotation marks, you need to use the following syntax: "","",..."". To add or remove one or more values without affecting any existing entries, use the following syntax: @{Add="",""...; Remove="",""...}. - .PARAMETER ExternalConnectionSettings - The ExternalConnectionSettings parameter specifies the host name, port, and encryption method that's used by external IMAP4 clients (IMAP4 connections from outside your corporate network). - This parameter uses the syntax ::[]. The encryption method value is optional (blank indicates unencrypted connections). - The default value is blank ($null), which means no external IMAP4 connection settings are configured. - To enter multiple values and overwrite any existing entries, use the following syntax: ,,.... If the values contain spaces or otherwise require quotation marks, you need to use the following syntax: "","",..."". - To add or remove one or more values without affecting any existing entries, use the following syntax: @{Add="",""...; Remove="",""...}. - The combination of encryption methods and ports that are specified for this parameter need to match the corresponding encryption methods and ports that are specified by the SSLBindings and UnencryptedOrTLSBindings parameters. - .PARAMETER X509CertificateName The X509CertificateName parameter specifies the certificate that's used for encrypting IMAP4 client connections. A valid value for this parameter is the FQDN from the ExternalConnectionSettings or InternalConnectionSettings parameters (for example, mail.contoso.com or mailbox01.contoso.com).