Microsoft.SqlServer.Core.CustomMonitoring.UIPageSet.CustomQueryThreeStateMonitor (UIPageSet)

Element properties:

Type DefinitionMicrosoft.SqlServer.Core.CustomMonitoring.MonitorType.DBEngine.CustomQueryThreeState

Source Code:

<UIPageSet ID="Microsoft.SqlServer.Core.CustomMonitoring.UIPageSet.CustomQueryThreeStateMonitor" TypeDefinitionID="Microsoft.SqlServer.Core.CustomMonitoring.MonitorType.DBEngine.CustomQueryThreeState">
<UIPageReferences>
<UIPageReference ID="Microsoft.SqlServer.Core.CustomMonitoring.UIPageSet.CustomQueryThreeStateMonitor.Reference1" PageID="Microsoft.SqlServer.Core.CustomMonitoring.UIPage.MonitorGeneralPage">
<InputParameters/>
<InputTransform/>
</UIPageReference>
<UIPageReference ID="Microsoft.SqlServer.Core.CustomMonitoring.UIPageSet.CustomQueryThreeStateMonitor.Reference2" PageID="Microsoft.SqlServer.Core.CustomMonitoring.UIPage.SqlQueryPage">
<InputParameters/>
<InputTransform>
<xsl:stylesheet xmlns:xsl="http://www.w3.org/1999/XSL/Transform" version="1.0">
<xsl:output method="xml" indent="yes" omit-xml-declaration="yes"/>
<xsl:template match="/">
<xsl:element name="Configuration">
<xsl:copy-of select="DatabaseName"/>
<xsl:copy-of select="SqlQuery"/>
<xsl:copy-of select="TimeoutSeconds"/>
<xsl:copy-of select="SqlTimeoutSeconds"/>
<xsl:copy-of select="SqlExecTimeoutSeconds"/>
</xsl:element>
</xsl:template>
</xsl:stylesheet>
</InputTransform>
</UIPageReference>
<UIPageReference ID="Microsoft.SqlServer.Core.CustomMonitoring.UIPageSet.CustomQueryThreeStateMonitor.Reference3" PageID="Microsoft.SqlServer.Core.CustomMonitoring.UIPage.TestConditionsPage">
<InputParameters>
<ConditionsElementName>WarningConditions</ConditionsElementName>
<ConditionPredicateElementName>WarningConditionPredicate</ConditionPredicateElementName>
</InputParameters>
<InputTransform>
<xsl:stylesheet xmlns:xsl="http://www.w3.org/1999/XSL/Transform" version="1.0">
<xsl:output method="xml" indent="yes" omit-xml-declaration="yes"/>
<xsl:template match="/">
<xsl:element name="Configuration">
<xsl:copy-of select="WarningConditions"/>
<xsl:copy-of select="WarningConditionPredicate"/>
</xsl:element>
</xsl:template>
</xsl:stylesheet>
</InputTransform>
<Title ID="Title"/>
<SubTitle ID="SubTitle"/>
<TabName ID="TabName"/>
</UIPageReference>
<UIPageReference ID="Microsoft.SqlServer.Core.CustomMonitoring.UIPageSet.CustomQueryThreeStateMonitor.Reference4" PageID="Microsoft.SqlServer.Core.CustomMonitoring.UIPage.TestConditionsPage">
<InputParameters>
<ConditionsElementName>CriticalConditions</ConditionsElementName>
<ConditionPredicateElementName>CriticalConditionPredicate</ConditionPredicateElementName>
</InputParameters>
<InputTransform>
<xsl:stylesheet xmlns:xsl="http://www.w3.org/1999/XSL/Transform" version="1.0">
<xsl:output method="xml" indent="yes" omit-xml-declaration="yes"/>
<xsl:template match="/">
<xsl:element name="Configuration">
<xsl:copy-of select="CriticalConditions"/>
<xsl:copy-of select="CriticalConditionPredicate"/>
</xsl:element>
</xsl:template>
</xsl:stylesheet>
</InputTransform>
<Title ID="Title"/>
<SubTitle ID="SubTitle"/>
<TabName ID="TabName"/>
</UIPageReference>
<UIPageReference ID="Microsoft.SqlServer.Core.CustomMonitoring.UIPageSet.CustomQueryThreeStateMonitor.Reference5" PageID="System!System.SimpleSchedulerPage">
<InputParameters/>
<InputTransform>
<xsl:stylesheet xmlns:xsl="http://www.w3.org/1999/XSL/Transform" version="1.0">
<xsl:output method="xml" indent="yes" omit-xml-declaration="yes"/>
<xsl:template match="/">
<xsl:element name="SimpleReccuringSchedule">
<xsl:element name="Interval">
<xsl:choose>
<xsl:when test="IntervalSeconds">
<xsl:value-of select="IntervalSeconds"/>
</xsl:when>
<xsl:otherwise>900</xsl:otherwise>
</xsl:choose>
</xsl:element>
<xsl:if test="boolean(string-length(SyncTime))">
<xsl:copy-of select="SyncTime"/>
</xsl:if>
</xsl:element>
</xsl:template>
</xsl:stylesheet>
</InputTransform>
</UIPageReference>
<UIPageReference ID="Microsoft.SqlServer.Core.CustomMonitoring.UIPageSet.CustomQueryThreeStateMonitor.ReferenceSchedulerFilter" PageID="System!System.SchedulerFilterPage">
<InputParameters/>
<InputTransform>
<xsl:stylesheet xmlns:xsl="http://www.w3.org/1999/XSL/Transform" version="1.0">
<xsl:output method="xml" indent="yes" omit-xml-declaration="yes"/>
<xsl:template match="/">
<xsl:if test="SchedulerFilterSchedule/WeeklySchedule">
<xsl:element name="SchedulerFilter">
<xsl:element name="ProcessDataMode">
<xsl:choose>
<xsl:when test="SchedulerFilterProcessDataMode">
<xsl:value-of select="SchedulerFilterProcessDataMode"/>
</xsl:when>
<xsl:otherwise>Always</xsl:otherwise>
</xsl:choose>
</xsl:element>
<xsl:element name="Schedule">
<xsl:copy-of select="SchedulerFilterSchedule/WeeklySchedule"/>
<xsl:copy-of select="SchedulerFilterSchedule/ExcludeDates"/>
</xsl:element>
</xsl:element>
</xsl:if>
</xsl:template>
</xsl:stylesheet>
</InputTransform>
<Title ID="Title"/>
<SubTitle ID="SubTitle"/>
<TabName ID="TabName"/>
</UIPageReference>
<UIPageReference ID="Microsoft.SqlServer.Core.CustomMonitoring.UIPageSet.CustomQueryThreeStateMonitor.Reference6" PageID="Health!System.Health.OperationalStatesConfigPage">
<InputParameters>
<CriticalFailed>Error</CriticalFailed>
<WarningFailed>Warning</WarningFailed>
<Passed>Success</Passed>
</InputParameters>
<InputTransform/>
</UIPageReference>
<UIPageReference ID="Microsoft.SqlServer.Core.CustomMonitoring.UIPageSet.CustomQueryThreeStateMonitor.Reference7" PageID="Health!System.Health.ProductKnowledgePage">
<InputParameters/>
<InputTransform/>
</UIPageReference>
<UIPageReference ID="Microsoft.SqlServer.Core.CustomMonitoring.UIPageSet.CustomQueryThreeStateMonitor.Reference8" PageID="Microsoft.SqlServer.Core.CustomMonitoring.UIPage.AlertingPage">
<InputParameters/>
<InputTransform/>
</UIPageReference>
</UIPageReferences>
<OutputTransform>
<xsl:stylesheet xmlns:xsl="http://www.w3.org/1999/XSL/Transform" version="1.0">
<xsl:output method="xml" indent="yes" omit-xml-declaration="yes"/>
<xsl:template match="/">
<xsl:element name="MachineName">
<xsl:value-of select="/PropertyReferenceMachineName"/>
</xsl:element>
<xsl:element name="NetbiosComputerName">
<xsl:value-of select="/PropertyReferenceNetbiosComputerName"/>
</xsl:element>
<xsl:element name="InstanceName">
<xsl:value-of select="/PropertyReferenceInstanceName"/>
</xsl:element>
<xsl:element name="ConnectionString">
<xsl:value-of select="/PropertyReferenceConnectionString"/>
</xsl:element>
<xsl:element name="InstanceVersion">
<xsl:value-of select="/PropertyReferenceInstanceVersion"/>
</xsl:element>
<xsl:element name="InstanceEdition">
<xsl:value-of select="/PropertyReferenceInstanceEdition"/>
</xsl:element>
<xsl:if test="/PropertyReferenceMonitoringType">
<xsl:element name="MonitoringType">
<xsl:value-of select="/PropertyReferenceMonitoringType"/>
</xsl:element>
</xsl:if>
<xsl:copy-of select="/MonitorName"/>
<xsl:copy-of select="/DatabaseName"/>
<xsl:copy-of select="/SqlQuery"/>
<xsl:copy-of select="/WarningConditions"/>
<xsl:copy-of select="/WarningConditionPredicate"/>
<xsl:copy-of select="/CriticalConditions"/>
<xsl:copy-of select="/CriticalConditionPredicate"/>
<xsl:copy-of select="/SqlExecTimeoutSeconds"/>
<xsl:copy-of select="/SqlTimeoutSeconds"/>
<xsl:copy-of select="/TimeoutSeconds"/>
<xsl:element name="IntervalSeconds">
<xsl:variable name="RawInterval" select="/SimpleReccuringSchedule/Interval"/>
<xsl:variable name="Units" select="/SimpleReccuringSchedule/Interval/@Unit"/>
<xsl:choose>
<xsl:when test="not(boolean($Units)) or $Units='Seconds'">
<xsl:value-of select="$RawInterval"/>
</xsl:when>
<xsl:when test="$Units='Minutes'">
<xsl:value-of select="$RawInterval*60"/>
</xsl:when>
<xsl:when test="$Units='Hours'">
<xsl:value-of select="$RawInterval*3600"/>
</xsl:when>
<xsl:when test="$Units='Days'">
<xsl:value-of select="$RawInterval*86400"/>
</xsl:when>
</xsl:choose>
</xsl:element>
<xsl:element name="SyncTime">
<xsl:value-of select="/SimpleReccuringSchedule/SyncTime"/>
</xsl:element>
<xsl:element name="SchedulerFilterSchedule">
<xsl:choose>
<xsl:when test="/SchedulerFilter/ProcessDataMode != 'Always'">
<xsl:copy-of select="/SchedulerFilter/Schedule/WeeklySchedule"/>
</xsl:when>
<xsl:otherwise>
<xsl:element name="SimpleReccuringSchedule">
<xsl:element name="Interval">1</xsl:element>
</xsl:element>
</xsl:otherwise>
</xsl:choose>
<xsl:choose>
<xsl:when test="/SchedulerFilter/Schedule/ExcludeDates">
<xsl:copy-of select="/SchedulerFilter/Schedule/ExcludeDates"/>
</xsl:when>
<xsl:otherwise>
<xsl:element name="ExcludeDates"/>
</xsl:otherwise>
</xsl:choose>
</xsl:element>
<xsl:element name="SchedulerFilterProcessDataMode">
<xsl:value-of select="/SchedulerFilter/ProcessDataMode"/>
</xsl:element>
<xsl:element name="Publisher">
<xsl:value-of select="/PropertyReferencePublisher"/>
</xsl:element>
</xsl:template>
</xsl:stylesheet>
</OutputTransform>
</UIPageSet>