From 597cf2be884456aa2be9a1c252f99284256de8f5 Mon Sep 17 00:00:00 2001 From: Ariel Moisis Date: Tue, 10 Dec 2019 14:53:41 +1100 Subject: [PATCH 1/3] add params to ExchMailboxTransportService --- CHANGELOG.md | 1 + .../MSFT_xExchMailboxTransportService.psm1 | 1255 ++++++++++++++++- ...FT_xExchMailboxTransportService.schema.mof | 68 +- ...SFT_xExchMailboxTransportService.tests.ps1 | 134 +- 4 files changed, 1385 insertions(+), 73 deletions(-) diff --git a/CHANGELOG.md b/CHANGELOG.md index b71da4d2..ff5e8baa 100644 --- a/CHANGELOG.md +++ b/CHANGELOG.md @@ -5,6 +5,7 @@ - Added xExchAddressList ressource - Added xExchSendConnector resource - Added additional parameters to the MSFT_xExchImapSettings resource +- Added additional parameters to the xExchMailboxTransportService resource ## 1.30.0.0 diff --git a/DSCResources/MSFT_xExchMailboxTransportService/MSFT_xExchMailboxTransportService.psm1 b/DSCResources/MSFT_xExchMailboxTransportService/MSFT_xExchMailboxTransportService.psm1 index ec13009b..79474dc7 100644 --- a/DSCResources/MSFT_xExchMailboxTransportService/MSFT_xExchMailboxTransportService.psm1 +++ b/DSCResources/MSFT_xExchMailboxTransportService/MSFT_xExchMailboxTransportService.psm1 @@ -1,3 +1,296 @@ +<# + .SYNOPSIS + Retrieves the current DSC configuration for this resource. + + .PARAMETER Identity + 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 ConnectivityLogEnabled + The ConnectivityLogEnabled parameter specifies whether the connectivity log is enabled. The default value is $true. + + .PARAMETER ConnectivityLogMaxAge + The ConnectivityLogMaxAge parameter specifies the maximum age for the connectivity log file. Log files older than the specified value are deleted. The default value is 30 days. + To specify a value, enter it as a time span: dd.hh:mm:ss where dd = days, hh = hours, mm = minutes, and ss = seconds. + For example, to specify 25 days for this parameter, use 25.00:00:00. The valid input range for this parameter is from 00:00:00 through 24855.03:14:07. Setting the value of the ConnectivityLogMaxAge parameter to 00:00:00 prevents the automatic removal of connectivity log files because of their age. + + .PARAMETER ConnectivityLogMaxDirectorySize + The ConnectivityLogMaxDirectorySize parameter specifies the maximum size of all connectivity logs in the connectivity log directory. When a directory reaches its maximum file size, the server deletes the oldest log files first. The default value is 1000 MB. + 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 value of the ConnectivityLogMaxFileSize parameter must be less than or equal to the value of the ConnectivityLogMaxDirectorySize parameter. The valid input range for either parameter is from 1 through 9223372036854775807 bytes. If you enter a value of unlimited, no size limit is imposed on the connectivity log directory. + + .PARAMETER ConnectivityLogMaxFileSize + The ConnectivityLogMaxFileSize parameter specifies the maximum size of each connectivity log file. When a log file reaches its maximum file size, a new log file is created. The default value is 10 MB. + 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 value of the ConnectivityLogMaxFileSize parameter must be less than or equal to the value of the ConnectivityLogMaxDirectorySize parameter. The valid input range for either parameter is from 1 through 9223372036854775807 bytes. If you enter a value of unlimited, no size limit is imposed on the connectivity log files. + + .PARAMETER ConnectivityLogPath + The ConnectivityLogPath parameter specifies the default connectivity log directory location. The default location is %ExchangeInstallPath%TransportRoles\Logs\Mailbox\Connectivity. Setting the value of this parameter to $null disables connectivity logging. However, setting this parameter to $null when the value of the ConnectivityLogEnabled attribute is $true generates event log errors. + + .PARAMETER ContentConversionTracingEnabled + The ContentConversionTracingEnabled parameter specifies whether content conversion tracing is enabled. Content conversion tracing captures content conversion failures that occur in the Transport service or in the Mailbox Transport service on the Mailbox server. The default value is $false. Content conversion tracing captures a maximum of 128 MB of content conversion failures. When the 128 MB limit is reached, no more content conversion failures are captured. Content conversion tracing captures the complete contents of email messages to the path specified by the PipelineTracingPath parameter. Make sure that you restrict access to this directory. The permissions required on the directory specified by the PipelineTracingPath parameter are as follows: + * Administrators: Full Control + * Network Service: Full Control + * System: Full Control + + .PARAMETER DomainController + 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. + + .PARAMETER MailboxDeliveryAgentLogEnabled + The MailboxDeliveryAgentLogEnabled parameter specifies whether the agent log for the Mailbox Transport Delivery service is enabled. The default value is $true. + + .PARAMETER MailboxDeliveryAgentLogMaxAge + The MailboxDeliveryAgentLogMaxAge parameter specifies the maximum age for the agent log file of the Mailbox Transport Delivery service. Log files older than the specified value are deleted. The default value is 7.00:00:00 or 7 days. + To specify a value, enter it as a time span: dd.hh:mm:ss where dd = days, hh = hours, mm = minutes, and ss = seconds. + Setting the value of the MailboxDeliveryAgentLogMaxAge parameter to 00:00:00 prevents the automatic removal of agent log files because of their age. + + .PARAMETER MailboxDeliveryAgentLogMaxDirectorySize + The MailboxDeliveryAgentLogMaxDirectorySize parameter specifies the maximum size of all Mailbox Transport Delivery service agent logs in the agent log directory. When a directory reaches its maximum file size, the server deletes the oldest log files first. The default value is 250 MB. + 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 value of the MailboxDeliveryAgentLogMaxFileSize parameter must be less than or equal to the value of the MailboxDeliveryAgentLogMaxDirectorySize parameter. If you enter a value of unlimited, no size limit is imposed on the agent log directory. + + .PARAMETER MailboxDeliveryAgentLogMaxFileSize + The MailboxDeliveryAgentLogMaxFileSize parameter specifies the maximum size of each agent log file for the Mailbox Transport Delivery service. When a log file reaches its maximum file size, a new log file is created. The default value is 10 MB. + 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 value of the MailboxDeliveryAgentLogMaxFileSize parameter must be less than or equal to the value of the MailboxDeliveryAgentLogMaxDirectorySize parameter. If you enter a value of unlimited, no size limit is imposed on the agent log files. + + .PARAMETER MailboxDeliveryAgentLogPath + The MailboxDeliveryAgentLogPath parameter specifies the default agent log directory location for the Mailbox Transport Delivery service. The default location is %ExchangeInstallPath%TransportRoles\Logs\Mailbox\AgentLog\Delivery. Setting the value of this parameter to $null disables agent logging. However, setting this parameter to $null when the value of the MailboxDeliveryAgentLogEnabled attribute is $true generates event log errors. + + .PARAMETER MailboxDeliveryConnectorMaxInboundConnection + The MailboxDeliveryConnectorMaxInboundConnection parameter specifies the maximum number of inbound connections for the implicit and invisible mailbox delivery Receive connector in the Mailbox Transport Delivery service. The default value is 5000. If you enter the value unlimited, no connection limit is imposed on the mailbox delivery Receive connector. + + .PARAMETER MailboxDeliveryConnectorProtocolLoggingLevel + The MailboxDeliveryConnectorProtocolLoggingLevel parameter enables or disables SMTP protocol logging for the implicit and invisible mailbox delivery Receive connector in the Mailbox Transport Delivery service. Valid values are: + * None: Protocol logging is disabled for the mailbox delivery Receive connector. This is the default value. + * Verbose: Protocol logging is enabled for the mailbox delivery Receive connector. The location of the log files is controlled by the ReceiveProtocolLogPath parameter. + + .PARAMETER MailboxDeliveryConnectorSmtpUtf8Enabled + The MailboxDeliveryConnectorSmtpUtf8Enabled parameters or disables email address internationalization (EAI) support for the implicit and invisible mailbox delivery Receive connector in the Mailbox Transport Delivery service. Valid values are: + * $true: Mail can be delivered to local mailboxes that have international characters in email addresses. This is the default value + * $false: Mail can't be delivered to local mailboxes that have international characters in email addresses. + + .PARAMETER MailboxDeliveryThrottlingLogEnabled + The MailboxDeliveryThrottlingLogEnabled parameter specifies whether the mailbox delivery throttling log is enabled. The default value is $true. + + .PARAMETER MailboxDeliveryThrottlingLogMaxAge + The MailboxDeliveryThrottlingLogMaxAge parameter specifies the maximum age for the mailbox delivery throttling log file. Log files older than the specified value are deleted. The default value is 7.00:00:00 or 7 days. + To specify a value, enter it as a time span: dd.hh:mm:ss where dd = days, hh = hours, mm = minutes, and ss = seconds. + Setting the value of the MailboxDeliveryThrottlingLogMaxAge parameter to 00:00:00 prevents the automatic removal of mailbox delivery throttling log files because of their age. + + .PARAMETER MailboxDeliveryThrottlingLogMaxDirectorySize + The MailboxDeliveryThrottlingLogMaxDirectorySize parameter specifies the maximum size of all mailbox delivery throttling logs in the mailbox delivery throttling log directory. When a directory reaches its maximum file size, the server deletes the oldest log files first. The default value is 200 MB. + 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 value of the MailboxDeliveryThrottlingLogMaxFileSize parameter must be less than or equal to the value of the MailboxDeliveryThrottlingLogMaxDirectorySize parameter. If you enter a value of unlimited, no size limit is imposed on the mailbox delivery throttling log directory. + + .PARAMETER MailboxDeliveryThrottlingLogMaxFileSize + The MailboxDeliveryThrottlingLogMaxFileSize parameter specifies the maximum size of each mailbox delivery throttling log file. When a log file reaches its maximum file size, a new log file is created. The default value is 10 MB. + 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 value of the MailboxDeliveryThrottlingLogMaxFileSize parameter must be less than or equal to the value of the MailboxDeliveryThrottlingLogMaxDirectorySize parameter. If you enter a value of unlimited, no size limit is imposed on the mailbox delivery throttling log files. + + .PARAMETER MailboxDeliveryThrottlingLogPath + The MailboxDeliveryThrottlingLogPath parameter specifies the default mailbox delivery throttling log directory location. The default location is %ExchangeInstallPath%TransportRoles\Logs\Throttling\Delivery. Setting the value of this parameter to $null disables mailbox delivery throttling logging. However, setting this parameter to $null when the value of the MailboxDeliveryThrottlingLogEnabled attribute is $true generates event log errors. + + .PARAMETER MailboxSubmissionAgentLogEnabled + The MailboxSubmissionAgentLogEnabled parameter specifies whether the agent log is enabled for the Mailbox Transport Submission service. The default value is $true. + + .PARAMETER MailboxSubmissionAgentLogMaxAge + The MailboxSubmissionAgentLogMaxAge parameter specifies the maximum age for the agent log file of the Mailbox Transport Submission service. Log files older than the specified value are deleted. The default value is 7.00:00:00 or 7 days. + To specify a value, enter it as a time span: dd.hh:mm:ss where dd = days, hh = hours, mm = minutes, and ss = seconds. + Setting the value of the MailboxSubmissionAgentLogMaxAge parameter to 00:00:00 prevents the automatic removal of agent log files because of their age. + + .PARAMETER MailboxSubmissionAgentLogMaxDirectorySize + The MailboxSubmissionAgentLogMaxDirectorySize parameter specifies the maximum size of all Mailbox Transport Submission service agent logs in the agent log directory. When a directory reaches its maximum file size, the server deletes the oldest log files first. The default value is 250 MB. + 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 value of the MailboxSubmissionAgentLogMaxFileSize parameter must be less than or equal to the value of the MailboxSubmissionAgentLogMaxDirectorySize parameter. If you enter a value of unlimited, no size limit is imposed on the agent log directory. + + .PARAMETER MailboxSubmissionAgentLogMaxFileSize + The MailboxSubmissionAgentLogMaxFileSize parameter specifies the maximum size of each agent log file for the Mailbox Transport Submission service. When a log file reaches its maximum file size, a new log file is created. The default value is 10 MB. + 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 value of the MailboxSubmissionAgentLogMaxFileSize parameter must be less than or equal to the value of the MailboxSubmissionAgentLogMaxDirectorySize parameter. If you enter a value of unlimited, no size limit is imposed on the agent log files. + + .PARAMETER MailboxSubmissionAgentLogPath + The MailboxSubmissionAgentLogPath parameter specifies the default agent log directory location for the Mailbox Transport Submission service. The default location is %ExchangeInstallPath%TransportRoles\Logs\Mailbox\AgentLog\Submission. Setting the value of this parameter to $null disables agent logging. However, setting this parameter to $null when the value of the MailboxSubmissionAgentLogEnabled attribute is $true generates event log errors. + + .PARAMETER MaxConcurrentMailboxDeliveries + The MaxConcurrentMailboxDeliveries parameter specifies the maximum number of delivery threads that the transport service can have open at the same time to deliver messages to mailboxes. The default value is 20. The valid input range for this parameter is from 1 through 256. We recommend that you don't modify the default value unless Microsoft Customer Service and Support advises you to do this. + + .PARAMETER MaxConcurrentMailboxSubmissions + The MaxConcurrentMailboxSubmissions parameter specifies the maximum number of submission threads that the transport service can have open at the same time to send messages from mailboxes. The default value is 20. The valid input range for this parameter is from 1 through 256. + + .PARAMETER PipelineTracingEnabled + The PipelineTracingEnabled parameter specifies whether to enable pipeline tracing. Pipeline tracing captures message snapshot files that record the changes made to the message by each transport agent configured in the transport service on the server. Pipeline tracing creates verbose log files that accumulate quickly. Pipeline tracing should only be enabled for a short time to provide in-depth diagnostic information that enables you to troubleshoot problems. In addition to troubleshooting, you can use pipeline tracing to validate changes that you make to the configuration of the transport service where you enable pipeline tracing. The default value is $false. + + .PARAMETER PipelineTracingPath + The PipelineTracingPath parameter specifies the location of the pipeline tracing logs. The default location is %ExchangeInstallPath%TransportRoles\Mailbox\Hub\PipelineTracing. The path must be local to the Exchange computer. Setting the value of this parameter to $null disables pipeline tracing. However, setting this parameter to $null when the value of the PipelineTracingEnabled attribute is $true generates event log errors. The preferred method to disable pipeline tracing is to use the PipelineTracingEnabled parameter. Pipeline tracing captures the complete contents of email messages to the path specified by the PipelineTracingPath parameter. Make sure that you restrict access to this directory. The permissions required on the directory specified by the PipelineTracingPath parameter are as follows: + * Administrators: Full Control + * Network Service: Full Control + * System: Full Control + + .PARAMETER PipelineTracingSenderAddress + The PipelineTracingSenderAddress parameter specifies the sender email address that invokes pipeline tracing. Only messages from this address generate pipeline tracing output. The address can be either inside or outside the Exchange organization. Depending on your requirements, you may have to set this parameter to different sender addresses and send new messages to start the transport agents or routes that you want to test. The default value of this parameter is $null. + + .PARAMETER ReceiveProtocolLogMaxAge + The ReceiveProtocolLogMaxAge parameter specifies the maximum age of a protocol log file for the implicit and invisible mailbox delivery Receive connector in the Mailbox Transport Delivery service. Log files that are older than the specified value are automatically deleted. + 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:00 to 24855.03:14:07. The default value is 30.00:00:00 (30 days). + The value00:00:00 prevents the automatic removal of Receive connector protocol log files because of their age. + This parameter is only meaningful when the MailboxDeliveryConnectorProtocolLoggingLevel parameter is set to the value Verbose. + + .PARAMETER ReceiveProtocolLogMaxDirectorySize + The ReceiveProtocolLogMaxDirectorySize parameter specifies the maximum size of the protocol log directory for the implicit and invisible mailbox delivery Receive connector in the Mailbox Transport Delivery service. When the maximum directory size is reached, the server deletes the oldest log files first. + A valid value is a number up to 909.5 terabytes (999999999999999 bytes) or the value unlimited. The default value is 250 megabytes (262144000 bytes). + 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 value of this parameter must be greater than or equal to the value of the ReceiveProtocolLogMaxFileSize parameter. + This parameter is only meaningful when the MailboxDeliveryConnectorProtocolLoggingLevel parameter is set to the value Verbose. + + .PARAMETER ReceiveProtocolLogMaxFileSize + The ReceiveProtocolLogMaxFileSize parameter specifies the maximum size of a protocol log file for the implicit and invisible mailbox delivery Receive connector in the Mailbox Transport Delivery service. When a log file reaches its maximum file size, a new log file is created. + A valid value is a number up to 909.5 terabytes (999999999999999 bytes) or the value unlimited. The default value is 10 megabytes (10485760 bytes). + 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 value of this parameter must be less than or equal to the value of the ReceiveProtocolLogMaxDirectorySize parameter. + This parameter is only meaningful when the MailboxDeliveryConnectorProtocolLoggingLevel parameter is set to the value Verbose. + + .PARAMETER ReceiveProtocolLogPath + The ReceiveProtocolLogPath parameter specifies the location of the protocol log directory for the implicit and invisible mailbox delivery Receive connector in the Mailbox Transport Delivery service. The default location is %ExchangeInstallPath%TransportRoles\Logs\Mailbox\ProtocolLog\SmtpReceive. The log files are automatically stored in the Delivery subdirectory. + Don't use the value $null for this parameter, because event log errors are generated if protocol logging is enabled for the mailbox delivery Receive connector. To disable protocol logging for this connector, use the value None for the MailboxDeliveryConnectorProtocolLoggingLevel parameter. + + .PARAMETER RoutingTableLogMaxAge + The RoutingTableLogMaxAge parameter specifies the maximum routing table log age. Log files older than the specified value are deleted. The default value is 7 days. + To specify a value, enter it as a time span: dd.hh:mm:ss where dd = days, hh = hours, mm = minutes, and ss = seconds. + For example, to specify 5 days for this parameter, use 5.00:00:00. The valid input range for this parameter is from 00:00:00 through 24855.03:14:07. Setting this parameter to 00:00:00 prevents the automatic removal of routing table log files because of their age. + + .PARAMETER RoutingTableLogMaxDirectorySize + The RoutingTableLogMaxDirectorySize parameter specifies the maximum size of the routing table log directory. When the maximum directory size is reached, the server deletes the oldest log files first. The default value is 250 MB. + 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 valid input range for this parameter is from 1 through 9223372036854775807 bytes. If you enter a value of unlimited, no size limit is imposed on the routing table log directory. + + .PARAMETER RoutingTableLogPath + The RoutingTableLogPath parameter specifies the directory location where routing table log files should be stored. The default location is %ExchangeInstallPath%TransportRoles\Logs\Mailbox\Routing. Setting this parameter to $null disables routing table logging. + + .PARAMETER SendProtocolLogMaxAge + The SendProtocolLogMaxAge parameter specifies the maximum age of a protocol log file for the implicit and invisible intra-organization Send connector in the Mailbox Transport Submission service. Log files that are older than the specified value are automatically deleted. + 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:00 to 24855.03:14:07. The default value is 30.00:00:00 (30 days). The value 00:00:00 prevents the automatic removal of Send connector protocol log files because of their age. + This parameter is only meaningful when the IntraOrgConnectorProtocolLoggingLevel parameter on the Set-TransportService cmdlet is set to the value Verbose. + + .PARAMETER SendProtocolLogMaxDirectorySize + The SendProtocolLogMaxDirectorySize parameter specifies the maximum size of the protocol log directory for the implicit and invisible intra-organization Send connector in the Mailbox Transport Submission service. When the maximum directory size is reached, the server deletes the oldest log files first. + A valid value is a number up to 909.5 terabytes (999999999999999 bytes) or the value unlimited. The default value is 250 megabytes (262144000 bytes). + 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 value of this parameter must be less than or equal to the value of the SendProtocolLogMaxDirectorySize parameter. + This parameter is only meaningful when the IntraOrgConnectorProtocolLoggingLevel parameter on the Set-TransportService cmdlet is set to the value Verbose. + + .PARAMETER SendProtocolLogMaxFileSize + The SendProtocolLogMaxFileSize parameter specifies the maximum size of a protocol log file for the implicit and invisible intra-organization Send connector in the Mailbox Transport Submission service. When a log file reaches its maximum file size, a new log file is created. + A valid value is a number up to 909.5 terabytes (999999999999999 bytes) or the value unlimited. The default value is 10 megabytes (10485760 bytes). + 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 value this parameter must be less than or equal to the value of the SendProtocolLogMaxDirectorySize parameter. + This parameter is only meaningful when the IntraOrgConnectorProtocolLoggingLevel parameter on the Set-TransportService cmdlet is set to the value Verbose. + + .PARAMETER SendProtocolLogPath + The SendProtocolLogPath parameter specifies the location of the protocol log directory for the implicit and invisible intra-organization Send connector in the Mailbox Transport Submission service. The default location is %ExchangeInstallPath%TransportRoles\Logs\Mailbox\ProtocolLog\SmtpSend. Log files are automatically stored in the following subdirectories: + * Submission: Protocol log files for the intra-organization Send connector in the Mailbox Transport Submission service. + * Delivery: Protocol log files for side effect messages that are submitted after messages are delivered to mailboxes. For example, a message delivered to a mailbox triggers an Inbox rule that redirects the message to another recipient. + + Don't use the value $null for this parameter, because event log errors are generated if protocol logging is enabled for the intra-organization Send connector in the Mailbox Transport Submission service. To disable protocol logging for this connector, use the value None for the IntraOrgConnectorProtocolLoggingLevel parameter on the Set-TransportService cmdlet. +#> + function Get-TargetResource { [Diagnostics.CodeAnalysis.SuppressMessageAttribute("PSDSCUseVerboseMessageInDSCResource", "")] @@ -42,6 +335,82 @@ function Get-TargetResource [System.Boolean] $ContentConversionTracingEnabled, + [Parameter()] + [System.String] + $DomainController, + + [parameter()] + [System.Boolean] + $MailboxDeliveryAgentLogEnabled, + + [Parameter()] + [System.String] + $MailboxDeliveryAgentLogMaxAge, + + [Parameter()] + [System.String] + $MailboxDeliveryAgentLogMaxDirectorySize, + + [Parameter()] + [System.String] + $MailboxDeliveryAgentLogMaxFileSize, + + [Parameter()] + [System.String] + $MailboxDeliveryAgentLogPath, + + [Parameter()] + [System.String] + $MailboxDeliveryConnectorMaxInboundConnection, + + [Parameter()] + [System.String] + $MailboxDeliveryConnectorProtocolLoggingLevel, + + [parameter()] + [System.Boolean] + $MailboxDeliveryConnectorSMTPUtf8Enabled, + + [parameter()] + [System.Boolean] + $MailboxDeliveryThrottlingLogEnabled, + + [Parameter()] + [System.String] + $MailboxDeliveryThrottlingLogMaxAge, + + [Parameter()] + [System.String] + $MailboxDeliveryThrottlingLogMaxDirectorySize, + + [Parameter()] + [System.String] + $MailboxDeliveryThrottlingLogMaxFileSize, + + [Parameter()] + [System.String] + $MailboxDeliveryThrottlingLogPath, + + [parameter()] + [System.Boolean] + $MailboxSubmissionAgentLogEnabled, + + [Parameter()] + [System.String] + $MailboxSubmissionAgentLogMaxAge, + + [Parameter()] + [System.String] + $MailboxSubmissionAgentLogMaxDirectorySize, + + [Parameter()] + [System.String] + $MailboxSubmissionAgentLogMaxFileSize, + + [Parameter()] + [System.String] + $MailboxSubmissionAgentLogPath, + [Parameter()] [System.Int32] $MaxConcurrentMailboxDeliveries, @@ -122,32 +491,343 @@ function Get-TargetResource if ($null -ne $mbxTransportService) { $returnValue = @{ - Identity = [System.String] $Identity - ConnectivityLogEnabled = [System.Boolean] $mbxTransportService.ConnectivityLogEnabled - ConnectivityLogMaxAge = [System.String] $mbxTransportService.ConnectivityLogMaxAge - ConnectivityLogMaxDirectorySize = [System.String] $mbxTransportService.ConnectivityLogMaxDirectorySize - ConnectivityLogMaxFileSize = [System.String] $mbxTransportService.ConnectivityLogMaxFileSize - ConnectivityLogPath = [System.String] $mbxTransportService.ConnectivityLogPath - ContentConversionTracingEnabled = [System.Boolean] $mbxTransportService.ContentConversionTracingEnabled - MaxConcurrentMailboxDeliveries = [System.Int32] $mbxTransportService.MaxConcurrentMailboxDeliveries - MaxConcurrentMailboxSubmissions = [System.Int32] $mbxTransportService.MaxConcurrentMailboxSubmissions - PipelineTracingEnabled = [System.Boolean] $mbxTransportService.PipelineTracingEnabled - PipelineTracingPath = [System.String] $mbxTransportService.PipelineTracingPath - PipelineTracingSenderAddress = [System.String] $mbxTransportService.PipelineTracingSenderAddress - ReceiveProtocolLogMaxAge = [System.String] $mbxTransportService.ReceiveProtocolLogMaxAge - ReceiveProtocolLogMaxDirectorySize = [System.String] $mbxTransportService.ReceiveProtocolLogMaxDirectorySize - ReceiveProtocolLogMaxFileSize = [System.String] $mbxTransportService.ReceiveProtocolLogMaxFileSize - ReceiveProtocolLogPath = [System.String] $mbxTransportService.ReceiveProtocolLogPath - SendProtocolLogMaxAge = [System.String] $mbxTransportService.SendProtocolLogMaxAge - SendProtocolLogMaxDirectorySize = [System.String] $mbxTransportService.SendProtocolLogMaxDirectorySize - SendProtocolLogMaxFileSize = [System.String] $mbxTransportService.SendProtocolLogMaxFileSize - SendProtocolLogPath = [System.String] $mbxTransportService.SendProtocolLogPath + Identity = [System.String] $Identity + ConnectivityLogEnabled = [System.Boolean] $mbxTransportService.ConnectivityLogEnabled + ConnectivityLogMaxAge = [System.String] $mbxTransportService.ConnectivityLogMaxAge + ConnectivityLogMaxDirectorySize = [System.String] $mbxTransportService.ConnectivityLogMaxDirectorySize + ConnectivityLogMaxFileSize = [System.String] $mbxTransportService.ConnectivityLogMaxFileSize + ConnectivityLogPath = [System.String] $mbxTransportService.ConnectivityLogPath + ContentConversionTracingEnabled = [System.Boolean] $mbxTransportService.ContentConversionTracingEnabled + MailboxDeliveryAgentLogEnabled = [System.Boolean] $mbxTransportService.MailboxDeliveryAgentLogEnabled + MailboxDeliveryAgentLogMaxAge = [System.String] $mbxTransportService.MailboxDeliveryAgentLogMaxAge + MailboxDeliveryAgentLogMaxDirectorySize = [System.String] $mbxTransportService.MailboxDeliveryAgentLogMaxDirectorySize + MailboxDeliveryAgentLogMaxFileSize = [System.String] $mbxTransportService.MailboxDeliveryAgentLogMaxFileSize + MailboxDeliveryAgentLogPath = [System.String] $mbxTransportService.MailboxDeliveryAgentLogPath + MailboxDeliveryConnectorMaxInboundConnection = [System.String] $mbxTransportService.MailboxDeliveryConnectorMaxInboundConnection + MailboxDeliveryConnectorProtocolLoggingLevel = [System.String] $mbxTransportService.MailboxDeliveryConnectorProtocolLoggingLevel + MailboxDeliveryConnectorSMTPUtf8Enabled = [System.Boolean] $mbxTransportService.MailboxDeliveryConnectorSMTPUtf8Enabled + MailboxDeliveryThrottlingLogEnabled = [System.Boolean] $mbxTransportService.MailboxDeliveryThrottlingLogEnabled + MailboxDeliveryThrottlingLogMaxAge = [System.String] $mbxTransportService.MailboxDeliveryThrottlingLogMaxAge + MailboxDeliveryThrottlingLogMaxDirectorySize = [System.String] $mbxTransportService.MailboxDeliveryThrottlingLogMaxDirectorySize + MailboxDeliveryThrottlingLogMaxFileSize = [System.String] $mbxTransportService.MailboxDeliveryThrottlingLogMaxFileSize + MailboxDeliveryThrottlingLogPath = [System.String] $mbxTransportService.MailboxDeliveryThrottlingLogPath + MailboxSubmissionAgentLogEnabled = [System.Boolean] $mbxTransportService.MailboxSubmissionAgentLogEnabled + MailboxSubmissionAgentLogMaxAge = [System.String] $mbxTransportService.MailboxSubmissionAgentLogMaxAge + MailboxSubmissionAgentLogMaxDirectorySize = [System.String] $mbxTransportService.MailboxSubmissionAgentLogMaxDirectorySize + MailboxSubmissionAgentLogMaxFileSize = [System.String] $mbxTransportService.MailboxSubmissionAgentLogMaxFileSize + MailboxSubmissionAgentLogPath = [System.String] $mbxTransportService.MailboxSubmissionAgentLogPath + MaxConcurrentMailboxDeliveries = [System.Int32] $mbxTransportService.MaxConcurrentMailboxDeliveries + MaxConcurrentMailboxSubmissions = [System.Int32] $mbxTransportService.MaxConcurrentMailboxSubmissions + PipelineTracingEnabled = [System.Boolean] $mbxTransportService.PipelineTracingEnabled + PipelineTracingPath = [System.String] $mbxTransportService.PipelineTracingPath + PipelineTracingSenderAddress = [System.String] $mbxTransportService.PipelineTracingSenderAddress + ReceiveProtocolLogMaxAge = [System.String] $mbxTransportService.ReceiveProtocolLogMaxAge + ReceiveProtocolLogMaxDirectorySize = [System.String] $mbxTransportService.ReceiveProtocolLogMaxDirectorySize + ReceiveProtocolLogMaxFileSize = [System.String] $mbxTransportService.ReceiveProtocolLogMaxFileSize + ReceiveProtocolLogPath = [System.String] $mbxTransportService.ReceiveProtocolLogPath + SendProtocolLogMaxAge = [System.String] $mbxTransportService.SendProtocolLogMaxAge + SendProtocolLogMaxDirectorySize = [System.String] $mbxTransportService.SendProtocolLogMaxDirectorySize + SendProtocolLogMaxFileSize = [System.String] $mbxTransportService.SendProtocolLogMaxFileSize + SendProtocolLogPath = [System.String] $mbxTransportService.SendProtocolLogPath } } $returnValue } +<# + .SYNOPSIS + Retrieves the current DSC configuration for this resource. + + .PARAMETER Identity + 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 ConnectivityLogEnabled + The ConnectivityLogEnabled parameter specifies whether the connectivity log is enabled. The default value is $true. + + .PARAMETER ConnectivityLogMaxAge + The ConnectivityLogMaxAge parameter specifies the maximum age for the connectivity log file. Log files older than the specified value are deleted. The default value is 30 days. + To specify a value, enter it as a time span: dd.hh:mm:ss where dd = days, hh = hours, mm = minutes, and ss = seconds. + For example, to specify 25 days for this parameter, use 25.00:00:00. The valid input range for this parameter is from 00:00:00 through 24855.03:14:07. Setting the value of the ConnectivityLogMaxAge parameter to 00:00:00 prevents the automatic removal of connectivity log files because of their age. + + .PARAMETER ConnectivityLogMaxDirectorySize + The ConnectivityLogMaxDirectorySize parameter specifies the maximum size of all connectivity logs in the connectivity log directory. When a directory reaches its maximum file size, the server deletes the oldest log files first. The default value is 1000 MB. + 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 value of the ConnectivityLogMaxFileSize parameter must be less than or equal to the value of the ConnectivityLogMaxDirectorySize parameter. The valid input range for either parameter is from 1 through 9223372036854775807 bytes. If you enter a value of unlimited, no size limit is imposed on the connectivity log directory. + + .PARAMETER ConnectivityLogMaxFileSize + The ConnectivityLogMaxFileSize parameter specifies the maximum size of each connectivity log file. When a log file reaches its maximum file size, a new log file is created. The default value is 10 MB. + 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 value of the ConnectivityLogMaxFileSize parameter must be less than or equal to the value of the ConnectivityLogMaxDirectorySize parameter. The valid input range for either parameter is from 1 through 9223372036854775807 bytes. If you enter a value of unlimited, no size limit is imposed on the connectivity log files. + + .PARAMETER ConnectivityLogPath + The ConnectivityLogPath parameter specifies the default connectivity log directory location. The default location is %ExchangeInstallPath%TransportRoles\Logs\Mailbox\Connectivity. Setting the value of this parameter to $null disables connectivity logging. However, setting this parameter to $null when the value of the ConnectivityLogEnabled attribute is $true generates event log errors. + + .PARAMETER ContentConversionTracingEnabled + The ContentConversionTracingEnabled parameter specifies whether content conversion tracing is enabled. Content conversion tracing captures content conversion failures that occur in the Transport service or in the Mailbox Transport service on the Mailbox server. The default value is $false. Content conversion tracing captures a maximum of 128 MB of content conversion failures. When the 128 MB limit is reached, no more content conversion failures are captured. Content conversion tracing captures the complete contents of email messages to the path specified by the PipelineTracingPath parameter. Make sure that you restrict access to this directory. The permissions required on the directory specified by the PipelineTracingPath parameter are as follows: + * Administrators: Full Control + * Network Service: Full Control + * System: Full Control + + .PARAMETER DomainController + 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. + + .PARAMETER MailboxDeliveryAgentLogEnabled + The MailboxDeliveryAgentLogEnabled parameter specifies whether the agent log for the Mailbox Transport Delivery service is enabled. The default value is $true. + + .PARAMETER MailboxDeliveryAgentLogMaxAge + The MailboxDeliveryAgentLogMaxAge parameter specifies the maximum age for the agent log file of the Mailbox Transport Delivery service. Log files older than the specified value are deleted. The default value is 7.00:00:00 or 7 days. + To specify a value, enter it as a time span: dd.hh:mm:ss where dd = days, hh = hours, mm = minutes, and ss = seconds. + Setting the value of the MailboxDeliveryAgentLogMaxAge parameter to 00:00:00 prevents the automatic removal of agent log files because of their age. + + .PARAMETER MailboxDeliveryAgentLogMaxDirectorySize + The MailboxDeliveryAgentLogMaxDirectorySize parameter specifies the maximum size of all Mailbox Transport Delivery service agent logs in the agent log directory. When a directory reaches its maximum file size, the server deletes the oldest log files first. The default value is 250 MB. + 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 value of the MailboxDeliveryAgentLogMaxFileSize parameter must be less than or equal to the value of the MailboxDeliveryAgentLogMaxDirectorySize parameter. If you enter a value of unlimited, no size limit is imposed on the agent log directory. + + .PARAMETER MailboxDeliveryAgentLogMaxFileSize + The MailboxDeliveryAgentLogMaxFileSize parameter specifies the maximum size of each agent log file for the Mailbox Transport Delivery service. When a log file reaches its maximum file size, a new log file is created. The default value is 10 MB. + 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 value of the MailboxDeliveryAgentLogMaxFileSize parameter must be less than or equal to the value of the MailboxDeliveryAgentLogMaxDirectorySize parameter. If you enter a value of unlimited, no size limit is imposed on the agent log files. + + .PARAMETER MailboxDeliveryAgentLogPath + The MailboxDeliveryAgentLogPath parameter specifies the default agent log directory location for the Mailbox Transport Delivery service. The default location is %ExchangeInstallPath%TransportRoles\Logs\Mailbox\AgentLog\Delivery. Setting the value of this parameter to $null disables agent logging. However, setting this parameter to $null when the value of the MailboxDeliveryAgentLogEnabled attribute is $true generates event log errors. + + .PARAMETER MailboxDeliveryConnectorMaxInboundConnection + The MailboxDeliveryConnectorMaxInboundConnection parameter specifies the maximum number of inbound connections for the implicit and invisible mailbox delivery Receive connector in the Mailbox Transport Delivery service. The default value is 5000. If you enter the value unlimited, no connection limit is imposed on the mailbox delivery Receive connector. + + .PARAMETER MailboxDeliveryConnectorProtocolLoggingLevel + The MailboxDeliveryConnectorProtocolLoggingLevel parameter enables or disables SMTP protocol logging for the implicit and invisible mailbox delivery Receive connector in the Mailbox Transport Delivery service. Valid values are: + * None: Protocol logging is disabled for the mailbox delivery Receive connector. This is the default value. + * Verbose: Protocol logging is enabled for the mailbox delivery Receive connector. The location of the log files is controlled by the ReceiveProtocolLogPath parameter. + + .PARAMETER MailboxDeliveryConnectorSmtpUtf8Enabled + The MailboxDeliveryConnectorSmtpUtf8Enabled parameters or disables email address internationalization (EAI) support for the implicit and invisible mailbox delivery Receive connector in the Mailbox Transport Delivery service. Valid values are: + * $true: Mail can be delivered to local mailboxes that have international characters in email addresses. This is the default value + * $false: Mail can't be delivered to local mailboxes that have international characters in email addresses. + + .PARAMETER MailboxDeliveryThrottlingLogEnabled + The MailboxDeliveryThrottlingLogEnabled parameter specifies whether the mailbox delivery throttling log is enabled. The default value is $true. + + .PARAMETER MailboxDeliveryThrottlingLogMaxAge + The MailboxDeliveryThrottlingLogMaxAge parameter specifies the maximum age for the mailbox delivery throttling log file. Log files older than the specified value are deleted. The default value is 7.00:00:00 or 7 days. + To specify a value, enter it as a time span: dd.hh:mm:ss where dd = days, hh = hours, mm = minutes, and ss = seconds. + Setting the value of the MailboxDeliveryThrottlingLogMaxAge parameter to 00:00:00 prevents the automatic removal of mailbox delivery throttling log files because of their age. + + .PARAMETER MailboxDeliveryThrottlingLogMaxDirectorySize + The MailboxDeliveryThrottlingLogMaxDirectorySize parameter specifies the maximum size of all mailbox delivery throttling logs in the mailbox delivery throttling log directory. When a directory reaches its maximum file size, the server deletes the oldest log files first. The default value is 200 MB. + 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 value of the MailboxDeliveryThrottlingLogMaxFileSize parameter must be less than or equal to the value of the MailboxDeliveryThrottlingLogMaxDirectorySize parameter. If you enter a value of unlimited, no size limit is imposed on the mailbox delivery throttling log directory. + + .PARAMETER MailboxDeliveryThrottlingLogMaxFileSize + The MailboxDeliveryThrottlingLogMaxFileSize parameter specifies the maximum size of each mailbox delivery throttling log file. When a log file reaches its maximum file size, a new log file is created. The default value is 10 MB. + 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 value of the MailboxDeliveryThrottlingLogMaxFileSize parameter must be less than or equal to the value of the MailboxDeliveryThrottlingLogMaxDirectorySize parameter. If you enter a value of unlimited, no size limit is imposed on the mailbox delivery throttling log files. + + .PARAMETER MailboxDeliveryThrottlingLogPath + The MailboxDeliveryThrottlingLogPath parameter specifies the default mailbox delivery throttling log directory location. The default location is %ExchangeInstallPath%TransportRoles\Logs\Throttling\Delivery. Setting the value of this parameter to $null disables mailbox delivery throttling logging. However, setting this parameter to $null when the value of the MailboxDeliveryThrottlingLogEnabled attribute is $true generates event log errors. + + .PARAMETER MailboxSubmissionAgentLogEnabled + The MailboxSubmissionAgentLogEnabled parameter specifies whether the agent log is enabled for the Mailbox Transport Submission service. The default value is $true. + + .PARAMETER MailboxSubmissionAgentLogMaxAge + The MailboxSubmissionAgentLogMaxAge parameter specifies the maximum age for the agent log file of the Mailbox Transport Submission service. Log files older than the specified value are deleted. The default value is 7.00:00:00 or 7 days. + To specify a value, enter it as a time span: dd.hh:mm:ss where dd = days, hh = hours, mm = minutes, and ss = seconds. + Setting the value of the MailboxSubmissionAgentLogMaxAge parameter to 00:00:00 prevents the automatic removal of agent log files because of their age. + + .PARAMETER MailboxSubmissionAgentLogMaxDirectorySize + The MailboxSubmissionAgentLogMaxDirectorySize parameter specifies the maximum size of all Mailbox Transport Submission service agent logs in the agent log directory. When a directory reaches its maximum file size, the server deletes the oldest log files first. The default value is 250 MB. + 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 value of the MailboxSubmissionAgentLogMaxFileSize parameter must be less than or equal to the value of the MailboxSubmissionAgentLogMaxDirectorySize parameter. If you enter a value of unlimited, no size limit is imposed on the agent log directory. + + .PARAMETER MailboxSubmissionAgentLogMaxFileSize + The MailboxSubmissionAgentLogMaxFileSize parameter specifies the maximum size of each agent log file for the Mailbox Transport Submission service. When a log file reaches its maximum file size, a new log file is created. The default value is 10 MB. + 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 value of the MailboxSubmissionAgentLogMaxFileSize parameter must be less than or equal to the value of the MailboxSubmissionAgentLogMaxDirectorySize parameter. If you enter a value of unlimited, no size limit is imposed on the agent log files. + + .PARAMETER MailboxSubmissionAgentLogPath + The MailboxSubmissionAgentLogPath parameter specifies the default agent log directory location for the Mailbox Transport Submission service. The default location is %ExchangeInstallPath%TransportRoles\Logs\Mailbox\AgentLog\Submission. Setting the value of this parameter to $null disables agent logging. However, setting this parameter to $null when the value of the MailboxSubmissionAgentLogEnabled attribute is $true generates event log errors. + + .PARAMETER MaxConcurrentMailboxDeliveries + The MaxConcurrentMailboxDeliveries parameter specifies the maximum number of delivery threads that the transport service can have open at the same time to deliver messages to mailboxes. The default value is 20. The valid input range for this parameter is from 1 through 256. We recommend that you don't modify the default value unless Microsoft Customer Service and Support advises you to do this. + + .PARAMETER MaxConcurrentMailboxSubmissions + The MaxConcurrentMailboxSubmissions parameter specifies the maximum number of submission threads that the transport service can have open at the same time to send messages from mailboxes. The default value is 20. The valid input range for this parameter is from 1 through 256. + + .PARAMETER PipelineTracingEnabled + The PipelineTracingEnabled parameter specifies whether to enable pipeline tracing. Pipeline tracing captures message snapshot files that record the changes made to the message by each transport agent configured in the transport service on the server. Pipeline tracing creates verbose log files that accumulate quickly. Pipeline tracing should only be enabled for a short time to provide in-depth diagnostic information that enables you to troubleshoot problems. In addition to troubleshooting, you can use pipeline tracing to validate changes that you make to the configuration of the transport service where you enable pipeline tracing. The default value is $false. + + .PARAMETER PipelineTracingPath + The PipelineTracingPath parameter specifies the location of the pipeline tracing logs. The default location is %ExchangeInstallPath%TransportRoles\Mailbox\Hub\PipelineTracing. The path must be local to the Exchange computer. Setting the value of this parameter to $null disables pipeline tracing. However, setting this parameter to $null when the value of the PipelineTracingEnabled attribute is $true generates event log errors. The preferred method to disable pipeline tracing is to use the PipelineTracingEnabled parameter. Pipeline tracing captures the complete contents of email messages to the path specified by the PipelineTracingPath parameter. Make sure that you restrict access to this directory. The permissions required on the directory specified by the PipelineTracingPath parameter are as follows: + * Administrators: Full Control + * Network Service: Full Control + * System: Full Control + + .PARAMETER PipelineTracingSenderAddress + The PipelineTracingSenderAddress parameter specifies the sender email address that invokes pipeline tracing. Only messages from this address generate pipeline tracing output. The address can be either inside or outside the Exchange organization. Depending on your requirements, you may have to set this parameter to different sender addresses and send new messages to start the transport agents or routes that you want to test. The default value of this parameter is $null. + + .PARAMETER ReceiveProtocolLogMaxAge + The ReceiveProtocolLogMaxAge parameter specifies the maximum age of a protocol log file for the implicit and invisible mailbox delivery Receive connector in the Mailbox Transport Delivery service. Log files that are older than the specified value are automatically deleted. + 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:00 to 24855.03:14:07. The default value is 30.00:00:00 (30 days). + The value00:00:00 prevents the automatic removal of Receive connector protocol log files because of their age. + This parameter is only meaningful when the MailboxDeliveryConnectorProtocolLoggingLevel parameter is set to the value Verbose. + + .PARAMETER ReceiveProtocolLogMaxDirectorySize + The ReceiveProtocolLogMaxDirectorySize parameter specifies the maximum size of the protocol log directory for the implicit and invisible mailbox delivery Receive connector in the Mailbox Transport Delivery service. When the maximum directory size is reached, the server deletes the oldest log files first. + A valid value is a number up to 909.5 terabytes (999999999999999 bytes) or the value unlimited. The default value is 250 megabytes (262144000 bytes). + 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 value of this parameter must be greater than or equal to the value of the ReceiveProtocolLogMaxFileSize parameter. + This parameter is only meaningful when the MailboxDeliveryConnectorProtocolLoggingLevel parameter is set to the value Verbose. + + .PARAMETER ReceiveProtocolLogMaxFileSize + The ReceiveProtocolLogMaxFileSize parameter specifies the maximum size of a protocol log file for the implicit and invisible mailbox delivery Receive connector in the Mailbox Transport Delivery service. When a log file reaches its maximum file size, a new log file is created. + A valid value is a number up to 909.5 terabytes (999999999999999 bytes) or the value unlimited. The default value is 10 megabytes (10485760 bytes). + 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 value of this parameter must be less than or equal to the value of the ReceiveProtocolLogMaxDirectorySize parameter. + This parameter is only meaningful when the MailboxDeliveryConnectorProtocolLoggingLevel parameter is set to the value Verbose. + + .PARAMETER ReceiveProtocolLogPath + The ReceiveProtocolLogPath parameter specifies the location of the protocol log directory for the implicit and invisible mailbox delivery Receive connector in the Mailbox Transport Delivery service. The default location is %ExchangeInstallPath%TransportRoles\Logs\Mailbox\ProtocolLog\SmtpReceive. The log files are automatically stored in the Delivery subdirectory. + Don't use the value $null for this parameter, because event log errors are generated if protocol logging is enabled for the mailbox delivery Receive connector. To disable protocol logging for this connector, use the value None for the MailboxDeliveryConnectorProtocolLoggingLevel parameter. + + .PARAMETER RoutingTableLogMaxAge + The RoutingTableLogMaxAge parameter specifies the maximum routing table log age. Log files older than the specified value are deleted. The default value is 7 days. + To specify a value, enter it as a time span: dd.hh:mm:ss where dd = days, hh = hours, mm = minutes, and ss = seconds. + For example, to specify 5 days for this parameter, use 5.00:00:00. The valid input range for this parameter is from 00:00:00 through 24855.03:14:07. Setting this parameter to 00:00:00 prevents the automatic removal of routing table log files because of their age. + + .PARAMETER RoutingTableLogMaxDirectorySize + The RoutingTableLogMaxDirectorySize parameter specifies the maximum size of the routing table log directory. When the maximum directory size is reached, the server deletes the oldest log files first. The default value is 250 MB. + 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 valid input range for this parameter is from 1 through 9223372036854775807 bytes. If you enter a value of unlimited, no size limit is imposed on the routing table log directory. + + .PARAMETER RoutingTableLogPath + The RoutingTableLogPath parameter specifies the directory location where routing table log files should be stored. The default location is %ExchangeInstallPath%TransportRoles\Logs\Mailbox\Routing. Setting this parameter to $null disables routing table logging. + + .PARAMETER SendProtocolLogMaxAge + The SendProtocolLogMaxAge parameter specifies the maximum age of a protocol log file for the implicit and invisible intra-organization Send connector in the Mailbox Transport Submission service. Log files that are older than the specified value are automatically deleted. + 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:00 to 24855.03:14:07. The default value is 30.00:00:00 (30 days). The value 00:00:00 prevents the automatic removal of Send connector protocol log files because of their age. + This parameter is only meaningful when the IntraOrgConnectorProtocolLoggingLevel parameter on the Set-TransportService cmdlet is set to the value Verbose. + + .PARAMETER SendProtocolLogMaxDirectorySize + The SendProtocolLogMaxDirectorySize parameter specifies the maximum size of the protocol log directory for the implicit and invisible intra-organization Send connector in the Mailbox Transport Submission service. When the maximum directory size is reached, the server deletes the oldest log files first. + A valid value is a number up to 909.5 terabytes (999999999999999 bytes) or the value unlimited. The default value is 250 megabytes (262144000 bytes). + 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 value of this parameter must be less than or equal to the value of the SendProtocolLogMaxDirectorySize parameter. + This parameter is only meaningful when the IntraOrgConnectorProtocolLoggingLevel parameter on the Set-TransportService cmdlet is set to the value Verbose. + + .PARAMETER SendProtocolLogMaxFileSize + The SendProtocolLogMaxFileSize parameter specifies the maximum size of a protocol log file for the implicit and invisible intra-organization Send connector in the Mailbox Transport Submission service. When a log file reaches its maximum file size, a new log file is created. + A valid value is a number up to 909.5 terabytes (999999999999999 bytes) or the value unlimited. The default value is 10 megabytes (10485760 bytes). + 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 value this parameter must be less than or equal to the value of the SendProtocolLogMaxDirectorySize parameter. + This parameter is only meaningful when the IntraOrgConnectorProtocolLoggingLevel parameter on the Set-TransportService cmdlet is set to the value Verbose. + + .PARAMETER SendProtocolLogPath + The SendProtocolLogPath parameter specifies the location of the protocol log directory for the implicit and invisible intra-organization Send connector in the Mailbox Transport Submission service. The default location is %ExchangeInstallPath%TransportRoles\Logs\Mailbox\ProtocolLog\SmtpSend. Log files are automatically stored in the following subdirectories: + * Submission: Protocol log files for the intra-organization Send connector in the Mailbox Transport Submission service. + * Delivery: Protocol log files for side effect messages that are submitted after messages are delivered to mailboxes. For example, a message delivered to a mailbox triggers an Inbox rule that redirects the message to another recipient. + + Don't use the value $null for this parameter, because event log errors are generated if protocol logging is enabled for the intra-organization Send connector in the Mailbox Transport Submission service. To disable protocol logging for this connector, use the value None for the IntraOrgConnectorProtocolLoggingLevel parameter on the Set-TransportService cmdlet. +#> + function Set-TargetResource { [CmdletBinding()] @@ -190,6 +870,82 @@ function Set-TargetResource [System.Boolean] $ContentConversionTracingEnabled, + [Parameter()] + [System.String] + $DomainController, + + [parameter()] + [System.Boolean] + $MailboxDeliveryAgentLogEnabled, + + [Parameter()] + [System.String] + $MailboxDeliveryAgentLogMaxAge, + + [Parameter()] + [System.String] + $MailboxDeliveryAgentLogMaxDirectorySize, + + [Parameter()] + [System.String] + $MailboxDeliveryAgentLogMaxFileSize, + + [Parameter()] + [System.String] + $MailboxDeliveryAgentLogPath, + + [Parameter()] + [System.String] + $MailboxDeliveryConnectorMaxInboundConnection, + + [Parameter()] + [System.String] + $MailboxDeliveryConnectorProtocolLoggingLevel, + + [parameter()] + [System.Boolean] + $MailboxDeliveryConnectorSMTPUtf8Enabled, + + [parameter()] + [System.Boolean] + $MailboxDeliveryThrottlingLogEnabled, + + [Parameter()] + [System.String] + $MailboxDeliveryThrottlingLogMaxAge, + + [Parameter()] + [System.String] + $MailboxDeliveryThrottlingLogMaxDirectorySize, + + [Parameter()] + [System.String] + $MailboxDeliveryThrottlingLogMaxFileSize, + + [Parameter()] + [System.String] + $MailboxDeliveryThrottlingLogPath, + + [parameter()] + [System.Boolean] + $MailboxSubmissionAgentLogEnabled, + + [Parameter()] + [System.String] + $MailboxSubmissionAgentLogMaxAge, + + [Parameter()] + [System.String] + $MailboxSubmissionAgentLogMaxDirectorySize, + + [Parameter()] + [System.String] + $MailboxSubmissionAgentLogMaxFileSize, + + [Parameter()] + [System.String] + $MailboxSubmissionAgentLogPath, + [Parameter()] [System.Int32] $MaxConcurrentMailboxDeliveries, @@ -283,6 +1039,299 @@ function Set-TargetResource } } +<# + .SYNOPSIS + Retrieves the current DSC configuration for this resource. + + .PARAMETER Identity + 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 ConnectivityLogEnabled + The ConnectivityLogEnabled parameter specifies whether the connectivity log is enabled. The default value is $true. + + .PARAMETER ConnectivityLogMaxAge + The ConnectivityLogMaxAge parameter specifies the maximum age for the connectivity log file. Log files older than the specified value are deleted. The default value is 30 days. + To specify a value, enter it as a time span: dd.hh:mm:ss where dd = days, hh = hours, mm = minutes, and ss = seconds. + For example, to specify 25 days for this parameter, use 25.00:00:00. The valid input range for this parameter is from 00:00:00 through 24855.03:14:07. Setting the value of the ConnectivityLogMaxAge parameter to 00:00:00 prevents the automatic removal of connectivity log files because of their age. + + .PARAMETER ConnectivityLogMaxDirectorySize + The ConnectivityLogMaxDirectorySize parameter specifies the maximum size of all connectivity logs in the connectivity log directory. When a directory reaches its maximum file size, the server deletes the oldest log files first. The default value is 1000 MB. + 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 value of the ConnectivityLogMaxFileSize parameter must be less than or equal to the value of the ConnectivityLogMaxDirectorySize parameter. The valid input range for either parameter is from 1 through 9223372036854775807 bytes. If you enter a value of unlimited, no size limit is imposed on the connectivity log directory. + + .PARAMETER ConnectivityLogMaxFileSize + The ConnectivityLogMaxFileSize parameter specifies the maximum size of each connectivity log file. When a log file reaches its maximum file size, a new log file is created. The default value is 10 MB. + 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 value of the ConnectivityLogMaxFileSize parameter must be less than or equal to the value of the ConnectivityLogMaxDirectorySize parameter. The valid input range for either parameter is from 1 through 9223372036854775807 bytes. If you enter a value of unlimited, no size limit is imposed on the connectivity log files. + + .PARAMETER ConnectivityLogPath + The ConnectivityLogPath parameter specifies the default connectivity log directory location. The default location is %ExchangeInstallPath%TransportRoles\Logs\Mailbox\Connectivity. Setting the value of this parameter to $null disables connectivity logging. However, setting this parameter to $null when the value of the ConnectivityLogEnabled attribute is $true generates event log errors. + + .PARAMETER ContentConversionTracingEnabled + The ContentConversionTracingEnabled parameter specifies whether content conversion tracing is enabled. Content conversion tracing captures content conversion failures that occur in the Transport service or in the Mailbox Transport service on the Mailbox server. The default value is $false. Content conversion tracing captures a maximum of 128 MB of content conversion failures. When the 128 MB limit is reached, no more content conversion failures are captured. Content conversion tracing captures the complete contents of email messages to the path specified by the PipelineTracingPath parameter. Make sure that you restrict access to this directory. The permissions required on the directory specified by the PipelineTracingPath parameter are as follows: + * Administrators: Full Control + * Network Service: Full Control + * System: Full Control + + .PARAMETER DomainController + 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. + + .PARAMETER MailboxDeliveryAgentLogEnabled + The MailboxDeliveryAgentLogEnabled parameter specifies whether the agent log for the Mailbox Transport Delivery service is enabled. The default value is $true. + + .PARAMETER MailboxDeliveryAgentLogMaxAge + The MailboxDeliveryAgentLogMaxAge parameter specifies the maximum age for the agent log file of the Mailbox Transport Delivery service. Log files older than the specified value are deleted. The default value is 7.00:00:00 or 7 days. + To specify a value, enter it as a time span: dd.hh:mm:ss where dd = days, hh = hours, mm = minutes, and ss = seconds. + Setting the value of the MailboxDeliveryAgentLogMaxAge parameter to 00:00:00 prevents the automatic removal of agent log files because of their age. + + .PARAMETER MailboxDeliveryAgentLogMaxDirectorySize + The MailboxDeliveryAgentLogMaxDirectorySize parameter specifies the maximum size of all Mailbox Transport Delivery service agent logs in the agent log directory. When a directory reaches its maximum file size, the server deletes the oldest log files first. The default value is 250 MB. + 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 value of the MailboxDeliveryAgentLogMaxFileSize parameter must be less than or equal to the value of the MailboxDeliveryAgentLogMaxDirectorySize parameter. If you enter a value of unlimited, no size limit is imposed on the agent log directory. + + .PARAMETER MailboxDeliveryAgentLogMaxFileSize + The MailboxDeliveryAgentLogMaxFileSize parameter specifies the maximum size of each agent log file for the Mailbox Transport Delivery service. When a log file reaches its maximum file size, a new log file is created. The default value is 10 MB. + 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 value of the MailboxDeliveryAgentLogMaxFileSize parameter must be less than or equal to the value of the MailboxDeliveryAgentLogMaxDirectorySize parameter. If you enter a value of unlimited, no size limit is imposed on the agent log files. + + .PARAMETER MailboxDeliveryAgentLogPath + The MailboxDeliveryAgentLogPath parameter specifies the default agent log directory location for the Mailbox Transport Delivery service. The default location is %ExchangeInstallPath%TransportRoles\Logs\Mailbox\AgentLog\Delivery. Setting the value of this parameter to $null disables agent logging. However, setting this parameter to $null when the value of the MailboxDeliveryAgentLogEnabled attribute is $true generates event log errors. + + .PARAMETER MailboxDeliveryConnectorMaxInboundConnection + The MailboxDeliveryConnectorMaxInboundConnection parameter specifies the maximum number of inbound connections for the implicit and invisible mailbox delivery Receive connector in the Mailbox Transport Delivery service. The default value is 5000. If you enter the value unlimited, no connection limit is imposed on the mailbox delivery Receive connector. + + .PARAMETER MailboxDeliveryConnectorProtocolLoggingLevel + The MailboxDeliveryConnectorProtocolLoggingLevel parameter enables or disables SMTP protocol logging for the implicit and invisible mailbox delivery Receive connector in the Mailbox Transport Delivery service. Valid values are: + * None: Protocol logging is disabled for the mailbox delivery Receive connector. This is the default value. + * Verbose: Protocol logging is enabled for the mailbox delivery Receive connector. The location of the log files is controlled by the ReceiveProtocolLogPath parameter. + + .PARAMETER MailboxDeliveryConnectorSmtpUtf8Enabled + The MailboxDeliveryConnectorSmtpUtf8Enabled parameters or disables email address internationalization (EAI) support for the implicit and invisible mailbox delivery Receive connector in the Mailbox Transport Delivery service. Valid values are: + * $true: Mail can be delivered to local mailboxes that have international characters in email addresses. This is the default value + * $false: Mail can't be delivered to local mailboxes that have international characters in email addresses. + + .PARAMETER MailboxDeliveryThrottlingLogEnabled + The MailboxDeliveryThrottlingLogEnabled parameter specifies whether the mailbox delivery throttling log is enabled. The default value is $true. + + .PARAMETER MailboxDeliveryThrottlingLogMaxAge + The MailboxDeliveryThrottlingLogMaxAge parameter specifies the maximum age for the mailbox delivery throttling log file. Log files older than the specified value are deleted. The default value is 7.00:00:00 or 7 days. + To specify a value, enter it as a time span: dd.hh:mm:ss where dd = days, hh = hours, mm = minutes, and ss = seconds. + Setting the value of the MailboxDeliveryThrottlingLogMaxAge parameter to 00:00:00 prevents the automatic removal of mailbox delivery throttling log files because of their age. + + .PARAMETER MailboxDeliveryThrottlingLogMaxDirectorySize + The MailboxDeliveryThrottlingLogMaxDirectorySize parameter specifies the maximum size of all mailbox delivery throttling logs in the mailbox delivery throttling log directory. When a directory reaches its maximum file size, the server deletes the oldest log files first. The default value is 200 MB. + 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 value of the MailboxDeliveryThrottlingLogMaxFileSize parameter must be less than or equal to the value of the MailboxDeliveryThrottlingLogMaxDirectorySize parameter. If you enter a value of unlimited, no size limit is imposed on the mailbox delivery throttling log directory. + + .PARAMETER MailboxDeliveryThrottlingLogMaxFileSize + The MailboxDeliveryThrottlingLogMaxFileSize parameter specifies the maximum size of each mailbox delivery throttling log file. When a log file reaches its maximum file size, a new log file is created. The default value is 10 MB. + 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 value of the MailboxDeliveryThrottlingLogMaxFileSize parameter must be less than or equal to the value of the MailboxDeliveryThrottlingLogMaxDirectorySize parameter. If you enter a value of unlimited, no size limit is imposed on the mailbox delivery throttling log files. + + .PARAMETER MailboxDeliveryThrottlingLogPath + The MailboxDeliveryThrottlingLogPath parameter specifies the default mailbox delivery throttling log directory location. The default location is %ExchangeInstallPath%TransportRoles\Logs\Throttling\Delivery. Setting the value of this parameter to $null disables mailbox delivery throttling logging. However, setting this parameter to $null when the value of the MailboxDeliveryThrottlingLogEnabled attribute is $true generates event log errors. + + .PARAMETER MailboxSubmissionAgentLogEnabled + The MailboxSubmissionAgentLogEnabled parameter specifies whether the agent log is enabled for the Mailbox Transport Submission service. The default value is $true. + + .PARAMETER MailboxSubmissionAgentLogMaxAge + The MailboxSubmissionAgentLogMaxAge parameter specifies the maximum age for the agent log file of the Mailbox Transport Submission service. Log files older than the specified value are deleted. The default value is 7.00:00:00 or 7 days. + To specify a value, enter it as a time span: dd.hh:mm:ss where dd = days, hh = hours, mm = minutes, and ss = seconds. + Setting the value of the MailboxSubmissionAgentLogMaxAge parameter to 00:00:00 prevents the automatic removal of agent log files because of their age. + + .PARAMETER MailboxSubmissionAgentLogMaxDirectorySize + The MailboxSubmissionAgentLogMaxDirectorySize parameter specifies the maximum size of all Mailbox Transport Submission service agent logs in the agent log directory. When a directory reaches its maximum file size, the server deletes the oldest log files first. The default value is 250 MB. + 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 value of the MailboxSubmissionAgentLogMaxFileSize parameter must be less than or equal to the value of the MailboxSubmissionAgentLogMaxDirectorySize parameter. If you enter a value of unlimited, no size limit is imposed on the agent log directory. + + .PARAMETER MailboxSubmissionAgentLogMaxFileSize + The MailboxSubmissionAgentLogMaxFileSize parameter specifies the maximum size of each agent log file for the Mailbox Transport Submission service. When a log file reaches its maximum file size, a new log file is created. The default value is 10 MB. + 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 value of the MailboxSubmissionAgentLogMaxFileSize parameter must be less than or equal to the value of the MailboxSubmissionAgentLogMaxDirectorySize parameter. If you enter a value of unlimited, no size limit is imposed on the agent log files. + + .PARAMETER MailboxSubmissionAgentLogPath + The MailboxSubmissionAgentLogPath parameter specifies the default agent log directory location for the Mailbox Transport Submission service. The default location is %ExchangeInstallPath%TransportRoles\Logs\Mailbox\AgentLog\Submission. Setting the value of this parameter to $null disables agent logging. However, setting this parameter to $null when the value of the MailboxSubmissionAgentLogEnabled attribute is $true generates event log errors. + + .PARAMETER MaxConcurrentMailboxDeliveries + The MaxConcurrentMailboxDeliveries parameter specifies the maximum number of delivery threads that the transport service can have open at the same time to deliver messages to mailboxes. The default value is 20. The valid input range for this parameter is from 1 through 256. We recommend that you don't modify the default value unless Microsoft Customer Service and Support advises you to do this. + + .PARAMETER MaxConcurrentMailboxSubmissions + The MaxConcurrentMailboxSubmissions parameter specifies the maximum number of submission threads that the transport service can have open at the same time to send messages from mailboxes. The default value is 20. The valid input range for this parameter is from 1 through 256. + + .PARAMETER PipelineTracingEnabled + The PipelineTracingEnabled parameter specifies whether to enable pipeline tracing. Pipeline tracing captures message snapshot files that record the changes made to the message by each transport agent configured in the transport service on the server. Pipeline tracing creates verbose log files that accumulate quickly. Pipeline tracing should only be enabled for a short time to provide in-depth diagnostic information that enables you to troubleshoot problems. In addition to troubleshooting, you can use pipeline tracing to validate changes that you make to the configuration of the transport service where you enable pipeline tracing. The default value is $false. + + .PARAMETER PipelineTracingPath + The PipelineTracingPath parameter specifies the location of the pipeline tracing logs. The default location is %ExchangeInstallPath%TransportRoles\Mailbox\Hub\PipelineTracing. The path must be local to the Exchange computer. Setting the value of this parameter to $null disables pipeline tracing. However, setting this parameter to $null when the value of the PipelineTracingEnabled attribute is $true generates event log errors. The preferred method to disable pipeline tracing is to use the PipelineTracingEnabled parameter. Pipeline tracing captures the complete contents of email messages to the path specified by the PipelineTracingPath parameter. Make sure that you restrict access to this directory. The permissions required on the directory specified by the PipelineTracingPath parameter are as follows: + * Administrators: Full Control + * Network Service: Full Control + * System: Full Control + + .PARAMETER PipelineTracingSenderAddress + The PipelineTracingSenderAddress parameter specifies the sender email address that invokes pipeline tracing. Only messages from this address generate pipeline tracing output. The address can be either inside or outside the Exchange organization. Depending on your requirements, you may have to set this parameter to different sender addresses and send new messages to start the transport agents or routes that you want to test. The default value of this parameter is $null. + + .PARAMETER ReceiveProtocolLogMaxAge + The ReceiveProtocolLogMaxAge parameter specifies the maximum age of a protocol log file for the implicit and invisible mailbox delivery Receive connector in the Mailbox Transport Delivery service. Log files that are older than the specified value are automatically deleted. + 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:00 to 24855.03:14:07. The default value is 30.00:00:00 (30 days). + The value00:00:00 prevents the automatic removal of Receive connector protocol log files because of their age. + This parameter is only meaningful when the MailboxDeliveryConnectorProtocolLoggingLevel parameter is set to the value Verbose. + + .PARAMETER ReceiveProtocolLogMaxDirectorySize + The ReceiveProtocolLogMaxDirectorySize parameter specifies the maximum size of the protocol log directory for the implicit and invisible mailbox delivery Receive connector in the Mailbox Transport Delivery service. When the maximum directory size is reached, the server deletes the oldest log files first. + A valid value is a number up to 909.5 terabytes (999999999999999 bytes) or the value unlimited. The default value is 250 megabytes (262144000 bytes). + 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 value of this parameter must be greater than or equal to the value of the ReceiveProtocolLogMaxFileSize parameter. + This parameter is only meaningful when the MailboxDeliveryConnectorProtocolLoggingLevel parameter is set to the value Verbose. + + .PARAMETER ReceiveProtocolLogMaxFileSize + The ReceiveProtocolLogMaxFileSize parameter specifies the maximum size of a protocol log file for the implicit and invisible mailbox delivery Receive connector in the Mailbox Transport Delivery service. When a log file reaches its maximum file size, a new log file is created. + A valid value is a number up to 909.5 terabytes (999999999999999 bytes) or the value unlimited. The default value is 10 megabytes (10485760 bytes). + 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 value of this parameter must be less than or equal to the value of the ReceiveProtocolLogMaxDirectorySize parameter. + This parameter is only meaningful when the MailboxDeliveryConnectorProtocolLoggingLevel parameter is set to the value Verbose. + + .PARAMETER ReceiveProtocolLogPath + The ReceiveProtocolLogPath parameter specifies the location of the protocol log directory for the implicit and invisible mailbox delivery Receive connector in the Mailbox Transport Delivery service. The default location is %ExchangeInstallPath%TransportRoles\Logs\Mailbox\ProtocolLog\SmtpReceive. The log files are automatically stored in the Delivery subdirectory. + Don't use the value $null for this parameter, because event log errors are generated if protocol logging is enabled for the mailbox delivery Receive connector. To disable protocol logging for this connector, use the value None for the MailboxDeliveryConnectorProtocolLoggingLevel parameter. + + .PARAMETER RoutingTableLogMaxAge + The RoutingTableLogMaxAge parameter specifies the maximum routing table log age. Log files older than the specified value are deleted. The default value is 7 days. + To specify a value, enter it as a time span: dd.hh:mm:ss where dd = days, hh = hours, mm = minutes, and ss = seconds. + For example, to specify 5 days for this parameter, use 5.00:00:00. The valid input range for this parameter is from 00:00:00 through 24855.03:14:07. Setting this parameter to 00:00:00 prevents the automatic removal of routing table log files because of their age. + + .PARAMETER RoutingTableLogMaxDirectorySize + The RoutingTableLogMaxDirectorySize parameter specifies the maximum size of the routing table log directory. When the maximum directory size is reached, the server deletes the oldest log files first. The default value is 250 MB. + 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 valid input range for this parameter is from 1 through 9223372036854775807 bytes. If you enter a value of unlimited, no size limit is imposed on the routing table log directory. + + .PARAMETER RoutingTableLogPath + The RoutingTableLogPath parameter specifies the directory location where routing table log files should be stored. The default location is %ExchangeInstallPath%TransportRoles\Logs\Mailbox\Routing. Setting this parameter to $null disables routing table logging. + + .PARAMETER SendProtocolLogMaxAge + The SendProtocolLogMaxAge parameter specifies the maximum age of a protocol log file for the implicit and invisible intra-organization Send connector in the Mailbox Transport Submission service. Log files that are older than the specified value are automatically deleted. + 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:00 to 24855.03:14:07. The default value is 30.00:00:00 (30 days). The value 00:00:00 prevents the automatic removal of Send connector protocol log files because of their age. + This parameter is only meaningful when the IntraOrgConnectorProtocolLoggingLevel parameter on the Set-TransportService cmdlet is set to the value Verbose. + + .PARAMETER SendProtocolLogMaxDirectorySize + The SendProtocolLogMaxDirectorySize parameter specifies the maximum size of the protocol log directory for the implicit and invisible intra-organization Send connector in the Mailbox Transport Submission service. When the maximum directory size is reached, the server deletes the oldest log files first. + A valid value is a number up to 909.5 terabytes (999999999999999 bytes) or the value unlimited. The default value is 250 megabytes (262144000 bytes). + 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 value of this parameter must be less than or equal to the value of the SendProtocolLogMaxDirectorySize parameter. + This parameter is only meaningful when the IntraOrgConnectorProtocolLoggingLevel parameter on the Set-TransportService cmdlet is set to the value Verbose. + + .PARAMETER SendProtocolLogMaxFileSize + The SendProtocolLogMaxFileSize parameter specifies the maximum size of a protocol log file for the implicit and invisible intra-organization Send connector in the Mailbox Transport Submission service. When a log file reaches its maximum file size, a new log file is created. + A valid value is a number up to 909.5 terabytes (999999999999999 bytes) or the value unlimited. The default value is 10 megabytes (10485760 bytes). + 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 value this parameter must be less than or equal to the value of the SendProtocolLogMaxDirectorySize parameter. + This parameter is only meaningful when the IntraOrgConnectorProtocolLoggingLevel parameter on the Set-TransportService cmdlet is set to the value Verbose. + + .PARAMETER SendProtocolLogPath + The SendProtocolLogPath parameter specifies the location of the protocol log directory for the implicit and invisible intra-organization Send connector in the Mailbox Transport Submission service. The default location is %ExchangeInstallPath%TransportRoles\Logs\Mailbox\ProtocolLog\SmtpSend. Log files are automatically stored in the following subdirectories: + * Submission: Protocol log files for the intra-organization Send connector in the Mailbox Transport Submission service. + * Delivery: Protocol log files for side effect messages that are submitted after messages are delivered to mailboxes. For example, a message delivered to a mailbox triggers an Inbox rule that redirects the message to another recipient. + + Don't use the value $null for this parameter, because event log errors are generated if protocol logging is enabled for the intra-organization Send connector in the Mailbox Transport Submission service. To disable protocol logging for this connector, use the value None for the IntraOrgConnectorProtocolLoggingLevel parameter on the Set-TransportService cmdlet. +#> + function Test-TargetResource { [Diagnostics.CodeAnalysis.SuppressMessageAttribute("PSDSCUseVerboseMessageInDSCResource", "")] @@ -327,6 +1376,82 @@ function Test-TargetResource [System.Boolean] $ContentConversionTracingEnabled, + [Parameter()] + [System.String] + $DomainController, + + [parameter()] + [System.Boolean] + $MailboxDeliveryAgentLogEnabled, + + [Parameter()] + [System.String] + $MailboxDeliveryAgentLogMaxAge, + + [Parameter()] + [System.String] + $MailboxDeliveryAgentLogMaxDirectorySize, + + [Parameter()] + [System.String] + $MailboxDeliveryAgentLogMaxFileSize, + + [Parameter()] + [System.String] + $MailboxDeliveryAgentLogPath, + + [Parameter()] + [System.String] + $MailboxDeliveryConnectorMaxInboundConnection, + + [Parameter()] + [System.String] + $MailboxDeliveryConnectorProtocolLoggingLevel, + + [parameter()] + [System.Boolean] + $MailboxDeliveryConnectorSMTPUtf8Enabled, + + [parameter()] + [System.Boolean] + $MailboxDeliveryThrottlingLogEnabled, + + [Parameter()] + [System.String] + $MailboxDeliveryThrottlingLogMaxAge, + + [Parameter()] + [System.String] + $MailboxDeliveryThrottlingLogMaxDirectorySize, + + [Parameter()] + [System.String] + $MailboxDeliveryThrottlingLogMaxFileSize, + + [Parameter()] + [System.String] + $MailboxDeliveryThrottlingLogPath, + + [parameter()] + [System.Boolean] + $MailboxSubmissionAgentLogEnabled, + + [Parameter()] + [System.String] + $MailboxSubmissionAgentLogMaxAge, + + [Parameter()] + [System.String] + $MailboxSubmissionAgentLogMaxDirectorySize, + + [Parameter()] + [System.String] + $MailboxSubmissionAgentLogMaxFileSize, + + [Parameter()] + [System.String] + $MailboxSubmissionAgentLogPath, + [Parameter()] [System.Int32] $MaxConcurrentMailboxDeliveries, @@ -441,6 +1566,96 @@ function Test-TargetResource $testResults = $false } + if (!(Test-ExchangeSetting -Name 'MailboxDeliveryAgentLogEnabled' -Type 'Boolean' -ExpectedValue $MailboxDeliveryAgentLogEnabled -ActualValue $mbxTransportService.MailboxDeliveryAgentLogEnabled -PSBoundParametersIn $PSBoundParameters -Verbose:$VerbosePreference)) + { + $testResults = $false + } + + if (!(Test-ExchangeSetting -Name 'MailboxDeliveryAgentLogMaxAge' -Type 'TimeSpan' -ExpectedValue $MailboxDeliveryAgentLogMaxAge -ActualValue $mbxTransportService.MailboxDeliveryAgentLogMaxAge -PSBoundParametersIn $PSBoundParameters -Verbose:$VerbosePreference)) + { + $testResults = $false + } + + if (!(Test-ExchangeSetting -Name 'MailboxDeliveryAgentLogMaxDirectorySize' -Type 'Unlimited' -ExpectedValue $MailboxDeliveryAgentLogMaxDirectorySize -ActualValue $mbxTransportService.MailboxDeliveryAgentLogMaxDirectorySize -PSBoundParametersIn $PSBoundParameters -Verbose:$VerbosePreference)) + { + $testResults = $false + } + + if (!(Test-ExchangeSetting -Name 'MailboxDeliveryAgentLogMaxFileSize' -Type 'Unlimited' -ExpectedValue $MailboxDeliveryAgentLogMaxFileSize -ActualValue $mbxTransportService.MailboxDeliveryAgentLogMaxFileSize -PSBoundParametersIn $PSBoundParameters -Verbose:$VerbosePreference)) + { + $testResults = $false + } + + if (!(Test-ExchangeSetting -Name 'MailboxDeliveryAgentLogPath' -Type 'String' -ExpectedValue $MailboxDeliveryAgentLogPath -ActualValue $mbxTransportService.MailboxDeliveryAgentLogPath -PSBoundParametersIn $PSBoundParameters -Verbose:$VerbosePreference)) + { + $testResults = $false + } + + if (!(Test-ExchangeSetting -Name 'MailboxDeliveryConnectorMaxInboundConnection' -Type 'Unlimited' -ExpectedValue $MailboxDeliveryConnectorMaxInboundConnection -ActualValue $mbxTransportService.MailboxDeliveryConnectorMaxInboundConnection -PSBoundParametersIn $PSBoundParameters -Verbose:$VerbosePreference)) + { + $testResults = $false + } + + if (!(Test-ExchangeSetting -Name 'MailboxDeliveryConnectorProtocolLoggingLevel' -Type 'String' -ExpectedValue $MailboxDeliveryConnectorProtocolLoggingLevel -ActualValue $mbxTransportService.MailboxDeliveryConnectorProtocolLoggingLevel -PSBoundParametersIn $PSBoundParameters -Verbose:$VerbosePreference)) + { + $testResults = $false + } + + if (!(Test-ExchangeSetting -Name 'MailboxDeliveryConnectorSMTPUtf8Enabled' -Type 'Boolean' -ExpectedValue $MailboxDeliveryConnectorSMTPUtf8Enabled -ActualValue $mbxTransportService.MailboxDeliveryConnectorSMTPUtf8Enabled -PSBoundParametersIn $PSBoundParameters -Verbose:$VerbosePreference)) + { + $testResults = $false + } + + if (!(Test-ExchangeSetting -Name 'MailboxDeliveryThrottlingLogEnabled' -Type 'Boolean' -ExpectedValue $MailboxDeliveryThrottlingLogEnabled -ActualValue $mbxTransportService.MailboxDeliveryThrottlingLogEnabled -PSBoundParametersIn $PSBoundParameters -Verbose:$VerbosePreference)) + { + $testResults = $false + } + + if (!(Test-ExchangeSetting -Name 'MailboxDeliveryThrottlingLogMaxAge' -Type 'TimeSpan' -ExpectedValue $MailboxDeliveryThrottlingLogMaxAge -ActualValue $mbxTransportService.MailboxDeliveryThrottlingLogMaxAge -PSBoundParametersIn $PSBoundParameters -Verbose:$VerbosePreference)) + { + $testResults = $false + } + + if (!(Test-ExchangeSetting -Name 'MailboxDeliveryThrottlingLogMaxDirectorySize' -Type 'Unlimited' -ExpectedValue $MailboxDeliveryThrottlingLogMaxDirectorySize -ActualValue $mbxTransportService.MailboxDeliveryThrottlingLogMaxDirectorySize -PSBoundParametersIn $PSBoundParameters -Verbose:$VerbosePreference)) + { + $testResults = $false + } + + if (!(Test-ExchangeSetting -Name 'MailboxDeliveryThrottlingLogMaxFileSize' -Type 'Unlimited' -ExpectedValue $MailboxDeliveryThrottlingLogMaxFileSize -ActualValue $mbxTransportService.MailboxDeliveryThrottlingLogMaxFileSize -PSBoundParametersIn $PSBoundParameters -Verbose:$VerbosePreference)) + { + $testResults = $false + } + + if (!(Test-ExchangeSetting -Name 'MailboxDeliveryThrottlingLogPath' -Type 'String' -ExpectedValue $MailboxDeliveryThrottlingLogPath -ActualValue $mbxTransportService.MailboxDeliveryThrottlingLogPath -PSBoundParametersIn $PSBoundParameters -Verbose:$VerbosePreference)) + { + $testResults = $false + } + + if (!(Test-ExchangeSetting -Name 'MailboxSubmissionAgentLogEnabled' -Type 'Boolean' -ExpectedValue $MailboxSubmissionAgentLogEnabled -ActualValue $mbxTransportService.MailboxSubmissionAgentLogEnabled -PSBoundParametersIn $PSBoundParameters -Verbose:$VerbosePreference)) + { + $testResults = $false + } + + if (!(Test-ExchangeSetting -Name 'MailboxSubmissionAgentLogMaxAge' -Type 'TimeSpan' -ExpectedValue $MailboxSubmissionAgentLogMaxAge -ActualValue $mbxTransportService.MailboxSubmissionAgentLogMaxAge -PSBoundParametersIn $PSBoundParameters -Verbose:$VerbosePreference)) + { + $testResults = $false + } + + if (!(Test-ExchangeSetting -Name 'MailboxSubmissionAgentLogMaxDirectorySize' -Type 'Unlimited' -ExpectedValue $MailboxSubmissionAgentLogMaxDirectorySize -ActualValue $mbxTransportService.MailboxSubmissionAgentLogMaxDirectorySize -PSBoundParametersIn $PSBoundParameters -Verbose:$VerbosePreference)) + { + $testResults = $false + } + + if (!(Test-ExchangeSetting -Name 'MailboxSubmissionAgentLogMaxFileSize' -Type 'Unlimited' -ExpectedValue $MailboxSubmissionAgentLogMaxFileSize -ActualValue $mbxTransportService.MailboxSubmissionAgentLogMaxFileSize -PSBoundParametersIn $PSBoundParameters -Verbose:$VerbosePreference)) + { + $testResults = $false + } + + if (!(Test-ExchangeSetting -Name 'MailboxDeliveryThrottlingLogPath' -Type 'String' -ExpectedValue $MailboxSubmissionAgentLogPath -ActualValue $mbxTransportService.MailboxSubmissionAgentLogPath -PSBoundParametersIn $PSBoundParameters -Verbose:$VerbosePreference)) + { + $testResults = $false + } + if (!(Test-ExchangeSetting -Name 'MaxConcurrentMailboxDeliveries' -Type 'Int' -ExpectedValue $MaxConcurrentMailboxDeliveries -ActualValue $mbxTransportService.MaxConcurrentMailboxDeliveries -PSBoundParametersIn $PSBoundParameters -Verbose:$VerbosePreference)) { $testResults = $false diff --git a/DSCResources/MSFT_xExchMailboxTransportService/MSFT_xExchMailboxTransportService.schema.mof b/DSCResources/MSFT_xExchMailboxTransportService/MSFT_xExchMailboxTransportService.schema.mof index 2a8f2b5f..9074186e 100644 --- a/DSCResources/MSFT_xExchMailboxTransportService/MSFT_xExchMailboxTransportService.schema.mof +++ b/DSCResources/MSFT_xExchMailboxTransportService/MSFT_xExchMailboxTransportService.schema.mof @@ -1,29 +1,47 @@ [ClassVersion("1.0.0.0"), FriendlyName("xExchMailboxTransportService")] class MSFT_xExchMailboxTransportService : OMI_BaseResource { - [Key] String Identity; //Exchange server - [Required, EmbeddedInstance("MSFT_Credential")] String Credential; //Credentials used to establish a remote PowerShell session to Exchange - [Write] Boolean AllowServiceRestart; //Whether it is OK to restart service MSExchangeTransport; - [Write] Boolean ConnectivityLogEnabled; - [Write] String ConnectivityLogMaxAge; - [Write] String ConnectivityLogMaxDirectorySize; - [Write] String ConnectivityLogMaxFileSize; - [Write] String ConnectivityLogPath; - [Write] Boolean ContentConversionTracingEnabled; - [Write] SInt32 MaxConcurrentMailboxDeliveries; - [Write] SInt32 MaxConcurrentMailboxSubmissions; - [Write] Boolean PipelineTracingEnabled; - [Write] String PipelineTracingPath; - [Write] String PipelineTracingSenderAddress; - [Write] String ReceiveProtocolLogMaxAge; - [Write] String ReceiveProtocolLogMaxDirectorySize; - [Write] String ReceiveProtocolLogMaxFileSize; - [Write] String ReceiveProtocolLogPath; - [Write] String RoutingTableLogMaxAge; - [Write] String RoutingTableLogMaxDirectorySize; - [Write] String RoutingTableLogPath; - [Write] String SendProtocolLogMaxAge; - [Write] String SendProtocolLogMaxDirectorySize; - [Write] String SendProtocolLogMaxFileSize; - [Write] String SendProtocolLogPath; + [Key, Description("Exchange server")] String Identity; + [Required, EmbeddedInstance("MSFT_Credential"), Description("Credentials used to establish a remote PowerShell session to Exchange")] String Credential; + [Write, Description("Whether it is OK to restart service MSExchangeTransport")] Boolean AllowServiceRestart; + [Write, Description("The ConnectivityLogEnabled parameter specifies whether the connectivity log is enabled.")] Boolean ConnectivityLogEnabled; + [Write, Description("The ConnectivityLogMaxAge parameter specifies the maximum age for the connectivity log file.")] String ConnectivityLogMaxAge; + [Write, Description("The ConnectivityLogMaxDirectorySize parameter specifies the maximum size of all connectivity logs in the connectivity log directory.")] String ConnectivityLogMaxDirectorySize; + [Write, Description("The ConnectivityLogMaxFileSize parameter specifies the maximum size of each connectivity log file.")] String ConnectivityLogMaxFileSize; + [Write, Description("The ConnectivityLogPath parameter specifies the default connectivity log directory location.")] String ConnectivityLogPath; + [Write, Description("The ContentConversionTracingEnabled parameter specifies whether content conversion tracing is enabled.")] Boolean ContentConversionTracingEnabled; + [Write, Description("The MailboxDeliveryAgentLogEnabled parameter specifies whether the agent log for the Mailbox Transport Delivery service is enabled.")] Boolean MailboxDeliveryAgentLogEnabled; + [Write, Description("The MailboxDeliveryAgentLogMaxAge parameter specifies the maximum age for the agent log file of the Mailbox Transport Delivery service.")] String MailboxDeliveryAgentLogMaxAge; + [Write, Description("The MailboxDeliveryAgentLogMaxDirectorySize parameter specifies the maximum size of all Mailbox Transport Delivery service agent logs in the agent log directory.")] String MailboxDeliveryAgentLogMaxDirectorySize; + [Write, Description("The MailboxDeliveryAgentLogMaxFileSize parameter specifies the maximum size of each agent log file for the Mailbox Transport Delivery service.")] String MailboxDeliveryAgentLogMaxFileSize; + [Write, Description("The MailboxDeliveryAgentLogPath parameter specifies the default agent log directory location for the Mailbox Transport Delivery service.")] String MailboxDeliveryAgentLogPath; + [Write, Description("The MailboxDeliveryConnectorMaxInboundConnection parameter specifies the maximum number of inbound connections for the implicit and invisible mailbox delivery Receive connector in the Mailbox Transport Delivery service.")] String MailboxDeliveryConnectorMaxInboundConnection; + [Write, Description("The MailboxDeliveryConnectorProtocolLoggingLevel parameter enables or disables SMTP protocol logging for the implicit and invisible mailbox delivery Receive connector in the Mailbox Transport Delivery service.")] String MailboxDeliveryConnectorProtocolLoggingLevel; + [Write, Description("The MailboxDeliveryConnectorSmtpUtf8Enabled parameters or disables email address internationalization (EAI) support for the implicit and invisible mailbox delivery Receive connector in the Mailbox Transport Delivery service.")] Boolean MailboxDeliveryConnectorSMTPUtf8Enabled; + [Write, Description("The MailboxDeliveryThrottlingLogEnabled parameter specifies whether the mailbox delivery throttling log is enabled.")] Boolean MailboxDeliveryThrottlingLogEnabled; + [Write, Description("The MailboxDeliveryThrottlingLogMaxAge parameter specifies the maximum age for the mailbox delivery throttling log file.")] String MailboxDeliveryThrottlingLogMaxAge; + [Write, Description("The MailboxDeliveryThrottlingLogMaxDirectorySize parameter specifies the maximum size of all mailbox delivery throttling logs in the mailbox delivery throttling log directory.")] String MailboxDeliveryThrottlingLogMaxDirectorySize; + [Write, Description("The MailboxDeliveryThrottlingLogMaxFileSize parameter specifies the maximum size of each mailbox delivery throttling log file.")] String MailboxDeliveryThrottlingLogMaxFileSize; + [Write, Description("The MailboxDeliveryThrottlingLogPath parameter specifies the default mailbox delivery throttling log directory location.")] String MailboxDeliveryThrottlingLogPath; + [Write, Description("The MailboxSubmissionAgentLogEnabled parameter specifies whether the agent log is enabled for the Mailbox Transport Submission service.")] Boolean MailboxSubmissionAgentLogEnabled; + [Write, Description("The MailboxSubmissionAgentLogMaxAge parameter specifies the maximum age for the agent log file of the Mailbox Transport Submission service.")] String MailboxSubmissionAgentLogMaxAge; + [Write, Description("The MailboxSubmissionAgentLogMaxDirectorySize parameter specifies the maximum size of all Mailbox Transport Submission service agent logs in the agent log directory.")] String MailboxSubmissionAgentLogMaxDirectorySize; + [Write, Description("The MailboxSubmissionAgentLogMaxFileSize parameter specifies the maximum size of each agent log file for the Mailbox Transport Submission service.")] String MailboxSubmissionAgentLogMaxFileSize; + [Write, Description("The MailboxSubmissionAgentLogPath parameter specifies the default agent log directory location for the Mailbox Transport Submission service.")] String MailboxSubmissionAgentLogPath; + [Write, Description("The MaxConcurrentMailboxDeliveries parameter specifies the maximum number of delivery threads that the transport service can have open at the same time to deliver messages to mailboxes.")] SInt32 MaxConcurrentMailboxDeliveries; + [Write, Description("The MaxConcurrentMailboxSubmissions parameter specifies the maximum number of submission threads that the transport service can have open at the same time to send messages from mailboxes.")] SInt32 MaxConcurrentMailboxSubmissions; + [Write, Description("The PipelineTracingEnabled parameter specifies whether to enable pipeline tracing.")] Boolean PipelineTracingEnabled; + [Write, Description("The PipelineTracingPath parameter specifies the location of the pipeline tracing logs.")] String PipelineTracingPath; + [Write, Description("The PipelineTracingSenderAddress parameter specifies the sender email address that invokes pipeline tracing.")] String PipelineTracingSenderAddress; + [Write, Description("The ReceiveProtocolLogMaxAge parameter specifies the maximum age of a protocol log file for the implicit and invisible mailbox delivery Receive connector in the Mailbox Transport Delivery service.")] String ReceiveProtocolLogMaxAge; + [Write, Description("The ReceiveProtocolLogMaxDirectorySize parameter specifies the maximum size of the protocol log directory for the implicit and invisible mailbox delivery Receive connector in the Mailbox Transport Delivery service.")] String ReceiveProtocolLogMaxDirectorySize; + [Write, Description("The ReceiveProtocolLogMaxFileSize parameter specifies the maximum size of a protocol log file for the implicit and invisible mailbox delivery Receive connector in the Mailbox Transport Delivery service.")] String ReceiveProtocolLogMaxFileSize; + [Write, Description("The ReceiveProtocolLogPath parameter specifies the location of the protocol log directory for the implicit and invisible mailbox delivery Receive connector in the Mailbox Transport Delivery service.")] String ReceiveProtocolLogPath; + [Write, Description("The RoutingTableLogMaxAge parameter specifies the maximum routing table log age.")] String RoutingTableLogMaxAge; + [Write, Description("The RoutingTableLogMaxDirectorySize parameter specifies the maximum size of the routing table log directory.")] String RoutingTableLogMaxDirectorySize; + [Write, Description("The RoutingTableLogPath parameter specifies the directory location where routing table log files should be stored.")] String RoutingTableLogPath; + [Write, Description("The SendProtocolLogMaxAge parameter specifies the maximum age of a protocol log file for the implicit and invisible intra-organization Send connector in the Mailbox Transport Submission service.")] String SendProtocolLogMaxAge; + [Write, Description("The SendProtocolLogMaxDirectorySize parameter specifies the maximum size of the protocol log directory for the implicit and invisible intra-organization Send connector in the Mailbox Transport Submission service.")] String SendProtocolLogMaxDirectorySize; + [Write, Description("The SendProtocolLogMaxFileSize parameter specifies the maximum size of a protocol log file for the implicit and invisible intra-organization Send connector in the Mailbox Transport Submission service.")] String SendProtocolLogMaxFileSize; + [Write, Description("The SendProtocolLogPath parameter specifies the location of the protocol log directory for the implicit and invisible intra-organization Send connector in the Mailbox Transport Submission service.")] String SendProtocolLogPath; }; diff --git a/Tests/Unit/MSFT_xExchMailboxTransportService.tests.ps1 b/Tests/Unit/MSFT_xExchMailboxTransportService.tests.ps1 index c135f32b..09e3aa8d 100644 --- a/Tests/Unit/MSFT_xExchMailboxTransportService.tests.ps1 +++ b/Tests/Unit/MSFT_xExchMailboxTransportService.tests.ps1 @@ -37,6 +37,54 @@ try Invoke-TestSetup InModuleScope $script:DSCResourceName { + + $commonMailboxTransportServiceStandardOutput = @{ + ConnectivityLogEnabled = [System.Boolean] $false + ConnectivityLogMaxAge = [System.String] '' + ConnectivityLogMaxDirectorySize = [System.String] '' + ConnectivityLogMaxFileSize = [System.String] '' + ConnectivityLogPath = [System.String] '' + ContentConversionTracingEnabled = [System.Boolean] $false + MailboxDeliveryAgentLogEnabled = [System.Boolean] $false + MailboxDeliveryAgentLogMaxAge = [System.String] '' + MailboxDeliveryAgentLogMaxDirectorySize = [System.String] '' + MailboxDeliveryAgentLogMaxFileSize = [System.String] '' + MailboxDeliveryAgentLogPath = [System.String] '' + MailboxDeliveryConnectorMaxInboundConnection = [System.String] '' + MailboxDeliveryConnectorProtocolLoggingLevel = [System.String] '' + MailboxDeliveryConnectorSMTPUtf8Enabled = [System.Boolean] $false + MailboxDeliveryThrottlingLogEnabled = [System.Boolean] $false + MailboxDeliveryThrottlingLogMaxAge = [System.String] '' + MailboxDeliveryThrottlingLogMaxDirectorySize = [System.String] '' + MailboxDeliveryThrottlingLogMaxFileSize = [System.String] '' + MailboxDeliveryThrottlingLogPath = [System.String] '' + MailboxSubmissionAgentLogEnabled = [System.Boolean] $false + MailboxSubmissionAgentLogMaxAge = [System.String] '' + MailboxSubmissionAgentLogMaxDirectorySize = [System.String] '' + MailboxSubmissionAgentLogMaxFileSize = [System.String] '' + MailboxSubmissionAgentLogPath = [System.String] '' + MaxConcurrentMailboxDeliveries = [System.Int32] 1 + MaxConcurrentMailboxSubmissions = [System.Int32] 1 + PipelineTracingEnabled = [System.Boolean] $false + PipelineTracingPath = [System.String] '' + PipelineTracingSenderAddress = [System.String] '' + ReceiveProtocolLogMaxAge = [System.String] '' + ReceiveProtocolLogMaxDirectorySize = [System.String] '' + ReceiveProtocolLogMaxFileSize = [System.String] '' + ReceiveProtocolLogPath = [System.String] '' + SendProtocolLogMaxAge = [System.String] '' + SendProtocolLogMaxDirectorySize = [System.String] '' + SendProtocolLogMaxFileSize = [System.String] '' + SendProtocolLogPath = [System.String] '' + } + + $commonTargetResourceParams = @{ + Identity = 'MailboxTransportService' + Credential = New-Object -TypeName System.Management.Automation.PSCredential -ArgumentList 'fakeuser', (New-Object -TypeName System.Security.SecureString) + } + + Mock -CommandName Get-RemoteExchangeSession -Verifiable + Describe 'MSFT_xExchMailboxTransportService\Get-TargetResource' -Tag 'Get' { # Override Exchange cmdlets function Get-MailboxTransportService {} @@ -45,39 +93,69 @@ try Assert-VerifiableMock } - $getTargetResourceParams = @{ - Identity = 'MailboxTransportService' - Credential = New-Object -TypeName System.Management.Automation.PSCredential -ArgumentList 'fakeuser', (New-Object -TypeName System.Security.SecureString) + Context 'When Get-TargetResource is called' { + Mock -CommandName Write-FunctionEntry -Verifiable + Mock -CommandName Get-MailboxTransportService -Verifiable -MockWith { return $commonMailboxTransportServiceStandardOutput } + + Test-CommonGetTargetResourceFunctionality -GetTargetResourceParams $commonTargetResourceParams } + } - $getMailboxTransportServiceStandardOutput = @{ - ConnectivityLogEnabled = [System.Boolean] $false - ConnectivityLogMaxAge = [System.String] '' - ConnectivityLogMaxDirectorySize = [System.String] '' - ConnectivityLogMaxFileSize = [System.String] '' - ConnectivityLogPath = [System.String] '' - ContentConversionTracingEnabled = [System.Boolean] $false - MaxConcurrentMailboxDeliveries = [System.Int32] 1 - MaxConcurrentMailboxSubmissions = [System.Int32] 1 - PipelineTracingEnabled = [System.Boolean] $false - PipelineTracingPath = [System.String] '' - PipelineTracingSenderAddress = [System.String] '' - ReceiveProtocolLogMaxAge = [System.String] '' - ReceiveProtocolLogMaxDirectorySize = [System.String] '' - ReceiveProtocolLogMaxFileSize = [System.String] '' - ReceiveProtocolLogPath = [System.String] '' - SendProtocolLogMaxAge = [System.String] '' - SendProtocolLogMaxDirectorySize = [System.String] '' - SendProtocolLogMaxFileSize = [System.String] '' - SendProtocolLogPath = [System.String] '' + Describe 'MSFT_xExchMailboxTransportService\Set-TargetResource' -Tag 'Set' { + AfterEach { + Assert-VerifiableMock } - Context 'When Get-TargetResource is called' { - Mock -CommandName Write-FunctionEntry -Verifiable - Mock -CommandName Get-RemoteExchangeSession -Verifiable - Mock -CommandName Get-MailboxTransportService -Verifiable -MockWith { return $getMailboxTransportServiceStandardOutput } + Context 'When Set-TargetResource is called' { + function Set-MailboxTransportService { } + + #Mock -CommandName Get-RemoteExchangeSession -Verifiable + It 'Should warn about restarting the MSExchangeDelivery and/or MSExchangeSubmission services' { + Mock -CommandName Set-MailboxTransportService -Verifiable + Mock -CommandName Write-Warning -ParameterFilter {$Message -eq 'The configuration will not take effect until the MSExchangeDelivery and/or MSExchangeSubmission services are manually restarted.'} + + Set-TargetResource @commonTargetResourceParams + } + + It 'Should call expected functions' { + $commonTargetResourceParams.AllowServiceRestart = $true + Mock -CommandName Set-MailboxTransportService -Verifiable + Mock -CommandName Restart-Service -Verifiable + + Set-TargetResource @commonTargetResourceParams + $commonTargetResourceParams.Remove('AllowServiceRestart') + } + } + } + + Describe 'MSFT_xExchMailboxTransportService\Test-TargetResource' -Tag 'Test' { + # Override Exchange cmdlets + AfterEach { + Assert-VerifiableMock + } + + function Get-MailboxTransportService {} + + Context 'When Test-TargetResource is called' { + It 'Should return False when Get-MailboxTransportService returns null' { + Mock -CommandName Get-MailboxTransportService -Verifiable + + Test-TargetResource @commonTargetResourceParams -ErrorAction SilentlyContinue | Should -Be $false + } + + It 'Should return False when Test-ExchangeSetting returns False' { + Mock -CommandName Get-MailboxTransportService -Verifiable -MockWith { return $commonMailboxTransportServiceStandardOutput } + 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-MailboxTransportService -Verifiable -MockWith { return $commonMailboxTransportServiceStandardOutput } + Mock -CommandName Test-ExchangeSetting -Verifiable -MockWith { return $true } - Test-CommonGetTargetResourceFunctionality -GetTargetResourceParams $getTargetResourceParams + Test-TargetResource @commonTargetResourceParams | Should -Be $true + } } } } From 620f75e600f7c98fda39769aece3439abd953743 Mon Sep 17 00:00:00 2001 From: Ariel Moisis Date: Tue, 10 Dec 2019 15:04:15 +1100 Subject: [PATCH 2/3] update param block to capital P in Parameter --- .../MSFT_xExchMailboxTransportService.psm1 | 24 +++++++++---------- 1 file changed, 12 insertions(+), 12 deletions(-) diff --git a/DSCResources/MSFT_xExchMailboxTransportService/MSFT_xExchMailboxTransportService.psm1 b/DSCResources/MSFT_xExchMailboxTransportService/MSFT_xExchMailboxTransportService.psm1 index 79474dc7..3ef18107 100644 --- a/DSCResources/MSFT_xExchMailboxTransportService/MSFT_xExchMailboxTransportService.psm1 +++ b/DSCResources/MSFT_xExchMailboxTransportService/MSFT_xExchMailboxTransportService.psm1 @@ -339,7 +339,7 @@ function Get-TargetResource [System.String] $DomainController, - [parameter()] + [Parameter()] [System.Boolean] $MailboxDeliveryAgentLogEnabled, @@ -367,11 +367,11 @@ function Get-TargetResource [System.String] $MailboxDeliveryConnectorProtocolLoggingLevel, - [parameter()] + [Parameter()] [System.Boolean] $MailboxDeliveryConnectorSMTPUtf8Enabled, - [parameter()] + [Parameter()] [System.Boolean] $MailboxDeliveryThrottlingLogEnabled, @@ -391,7 +391,7 @@ function Get-TargetResource [System.String] $MailboxDeliveryThrottlingLogPath, - [parameter()] + [Parameter()] [System.Boolean] $MailboxSubmissionAgentLogEnabled, @@ -874,7 +874,7 @@ function Set-TargetResource [System.String] $DomainController, - [parameter()] + [Parameter()] [System.Boolean] $MailboxDeliveryAgentLogEnabled, @@ -902,11 +902,11 @@ function Set-TargetResource [System.String] $MailboxDeliveryConnectorProtocolLoggingLevel, - [parameter()] + [Parameter()] [System.Boolean] $MailboxDeliveryConnectorSMTPUtf8Enabled, - [parameter()] + [Parameter()] [System.Boolean] $MailboxDeliveryThrottlingLogEnabled, @@ -926,7 +926,7 @@ function Set-TargetResource [System.String] $MailboxDeliveryThrottlingLogPath, - [parameter()] + [Parameter()] [System.Boolean] $MailboxSubmissionAgentLogEnabled, @@ -1380,7 +1380,7 @@ function Test-TargetResource [System.String] $DomainController, - [parameter()] + [Parameter()] [System.Boolean] $MailboxDeliveryAgentLogEnabled, @@ -1408,11 +1408,11 @@ function Test-TargetResource [System.String] $MailboxDeliveryConnectorProtocolLoggingLevel, - [parameter()] + [Parameter()] [System.Boolean] $MailboxDeliveryConnectorSMTPUtf8Enabled, - [parameter()] + [Parameter()] [System.Boolean] $MailboxDeliveryThrottlingLogEnabled, @@ -1432,7 +1432,7 @@ function Test-TargetResource [System.String] $MailboxDeliveryThrottlingLogPath, - [parameter()] + [Parameter()] [System.Boolean] $MailboxSubmissionAgentLogEnabled, From 84c03271396db00d699ccff42fe1dc3ca0366fa4 Mon Sep 17 00:00:00 2001 From: Ariel Moisis Date: Wed, 11 Dec 2019 09:53:34 +1100 Subject: [PATCH 3/3] update mof file to include domaincontroller --- .../MSFT_xExchMailboxTransportService.schema.mof | 1 + 1 file changed, 1 insertion(+) diff --git a/DSCResources/MSFT_xExchMailboxTransportService/MSFT_xExchMailboxTransportService.schema.mof b/DSCResources/MSFT_xExchMailboxTransportService/MSFT_xExchMailboxTransportService.schema.mof index 9074186e..185bfe41 100644 --- a/DSCResources/MSFT_xExchMailboxTransportService/MSFT_xExchMailboxTransportService.schema.mof +++ b/DSCResources/MSFT_xExchMailboxTransportService/MSFT_xExchMailboxTransportService.schema.mof @@ -10,6 +10,7 @@ class MSFT_xExchMailboxTransportService : OMI_BaseResource [Write, Description("The ConnectivityLogMaxFileSize parameter specifies the maximum size of each connectivity log file.")] String ConnectivityLogMaxFileSize; [Write, Description("The ConnectivityLogPath parameter specifies the default connectivity log directory location.")] String ConnectivityLogPath; [Write, Description("The ContentConversionTracingEnabled parameter specifies whether content conversion tracing is enabled.")] Boolean ContentConversionTracingEnabled; + [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.")] String DomainController; [Write, Description("The MailboxDeliveryAgentLogEnabled parameter specifies whether the agent log for the Mailbox Transport Delivery service is enabled.")] Boolean MailboxDeliveryAgentLogEnabled; [Write, Description("The MailboxDeliveryAgentLogMaxAge parameter specifies the maximum age for the agent log file of the Mailbox Transport Delivery service.")] String MailboxDeliveryAgentLogMaxAge; [Write, Description("The MailboxDeliveryAgentLogMaxDirectorySize parameter specifies the maximum size of all Mailbox Transport Delivery service agent logs in the agent log directory.")] String MailboxDeliveryAgentLogMaxDirectorySize;