Ação de Escrita de Fecho do Alerta dos Espaços de Armazenamento Direto do Microsoft Windows Server

Microsoft.Windows.Server.10.0.Storage.StorageSpacesDirect.CloseAlertWriteAction (WriteActionModuleType)

Ação de escrita de fecho do alerta dos Espaços de Armazenamento Direto.

Element properties:

TypeWriteActionModuleType
IsolationAny
AccessibilityInternal
RunAsDefault
InputTypeSystem.BaseData

Member Modules:

ID Module Type TypeId RunAs 
WA WriteAction Microsoft.Windows.PowerShellWriteAction Default

Overrideable Parameters:

IDParameterTypeSelectorDisplay NameDescription
TimeoutSecondsint$Config/TimeoutSeconds$Tempo limite (em segundos) para o script fechar os alertas de falhas

Source Code:

<WriteActionModuleType ID="Microsoft.Windows.Server.10.0.Storage.StorageSpacesDirect.CloseAlertWriteAction" Accessibility="Internal" Batching="true">
<Configuration>
<xsd:element xmlns:xsd="http://www.w3.org/2001/XMLSchema" minOccurs="1" name="FaultId" type="xsd:string"/>
<xsd:element xmlns:xsd="http://www.w3.org/2001/XMLSchema" minOccurs="1" name="SourceUniqueId" type="xsd:string"/>
<xsd:element xmlns:xsd="http://www.w3.org/2001/XMLSchema" minOccurs="1" name="SourceObjectId" type="xsd:string"/>
<xsd:element xmlns:xsd="http://www.w3.org/2001/XMLSchema" minOccurs="1" name="TimeoutSeconds" type="xsd:integer"/>
<xsd:element xmlns:xsd="http://www.w3.org/2001/XMLSchema" minOccurs="0" name="RuleId1" type="xsd:string"/>
<xsd:element xmlns:xsd="http://www.w3.org/2001/XMLSchema" minOccurs="0" name="RuleId2" type="xsd:string"/>
<xsd:element xmlns:xsd="http://www.w3.org/2001/XMLSchema" minOccurs="0" name="RuleId3" type="xsd:string"/>
</Configuration>
<OverrideableParameters>
<OverrideableParameter ID="TimeoutSeconds" Selector="$Config/TimeoutSeconds$" ParameterType="int"/>
</OverrideableParameters>
<ModuleImplementation>
<Composite>
<MemberModules>
<!--<WriteAction ID="WAC" TypeID="System!System.CommandExecuter">
<ApplicationName />
<WorkingDirectory />
<CommandLine>powershell.exe -NoLogo -NoProfile -Noninteractive "$ep = get-executionpolicy; if ($ep -gt 'RemoteSigned') {set-executionpolicy -Scope Process remotesigned} &amp; '$$file/CloseAlert.ps1$$' '$Config/FaultId$' '$Config/SourceUniqueId$'</CommandLine>
<SecureInput />
<TimeoutSeconds>$Config/TimeoutSeconds$</TimeoutSeconds>
<RequireOutput>false</RequireOutput>
<Files>
<File>
<Name>CloseAlert.ps1</Name>
<Contents><Script>
<![CDATA[
param($faultId, $SourceUniqueId)
$SCRIPT_NAME = "CloseAlert.ps1"
<![CDATA[# param($faultId, $sourceUniqueId, $sourceObjectId,$RuleId1,$RuleId2,$RuleId3)
# include S2DAlertCommon.ps1

#Alert Resolution State
$resolutionStateClose = 255;
$ResolutionStateActive = 0;
$AlertCriteria = "IsMonitorAlert = 'false' and ResolutionState = $ResolutionStateActive and CustomField1 = 'Fault' "

Function Get-AlertRuleCriteria()
{
$ErrorActionPreference = "Stop"

$result = $AlertCriteria
$rules = @()

$rule1 = Get-Guid -sguid $RuleId1
$rule2 = Get-Guid -sguid $RuleId2
$rule3 = Get-Guid -sguid $RuleId3

if ($null -ne $rule1){$rule = "MonitoringRuleId='{0}'" -f $rule1 ; $rules += $rule; }
if ($null -ne $rule2){$rule = "MonitoringRuleId='{0}'" -f $rule2 ; $rules += $rule; }
if ($null -ne $rule3){$rule = "MonitoringRuleId='{0}'" -f $rule3 ; $rules += $rule; }

if (0 -ne $rules.Length)
{
$result = "(" + ($rules -join " or " ) + ") and " + $result
}

return $result
}

Try
{
$error.Clear();

if([string]::IsNullOrEmpty($faultId))
{
Throw [System.NullReferenceException] "Null or empty FaultId parameter to the script.";
}

if([string]::IsNullOrEmpty($sourceUniqueId))
{
Throw [System.NullReferenceException] "Null or empty SourceUniqueId parameter to the script.";
}

if ($false -eq (Prepare-ScomConnection))
{
if ($error.Coune -ne 0)
{
$exception = $error[0].Exception
}

Log-FinalDebugData -FailureEvent $GenericFailureEvent -InformationEvent $GenericInformationEvent -exception $exception -SCRIPT_NAME $SCRIPT_NAME -traceMsg $script:traceMsg -DebugMode $true
return
}

#$FaultIdpatternToLookForInAlertContext = ("*" + $faultId +":" + $sourceUniqueId + "*");
$FaultIdpatternToLookForInAlertContext = ("*" + $faultId +":" + $sourceObjectId + "*");

AddTraceMessage -message "Searching OM Alert with these patterns: `n $FaultIdpatternToLookForInAlertContext"
$alertsCriteria = Get-AlertRuleCriteria
#$all_new_alerts = @(Get-SCOMAlert -ResolutionState 0)
$all_new_alerts = @(Get-SCOMAlert -Criteria $alertsCriteria)
$alert = $all_new_alerts | Where-Object {$_.Context -like $FaultIdpatternToLookForInAlertContext}

if($alert -ne $null)
{
AddTraceMessage -message ("Alert found. Name = " + $alert[0].Name)
Set-SCOMAlert -Alert $alert -ResolutionState $resolutionStateClose
AddTraceMessage -message "Alert is closed."
}
else
{
AddTraceMessage -message "Could not find OM Alert with given pattern."
}

AddTraceMessage -message "Storage monitoring script CloseAlert.ps1 completed."
}
Catch
{
AddTraceMessage -message $_.Exception.Message
$exception = $_.Exception
}
Finally
{
Log-FinalDebugData -FailureEvent $GenericFailureEvent -InformationEvent $GenericInformationEvent -exception $exception -SCRIPT_NAME $SCRIPT_NAME -traceMsg $script:traceMsg -DebugMode $true
}]]>
]]>
</Script></Contents>
<Unicode>true</Unicode>
</File>
</Files>
</WriteAction>-->
<WriteAction ID="WA" TypeID="Windows!Microsoft.Windows.PowerShellWriteAction">
<ScriptName>CloseAlert.ps1</ScriptName>
<ScriptBody><Script>

param($faultId, $sourceUniqueId, $sourceObjectId,$RuleId1,$RuleId2,$RuleId3)
$SCRIPT_NAME = "CloseAlert.ps1"



#general variables
#-----------------
$errorActionPreference = 'Stop'

$errEvent = [System.Diagnostics.EventLogEntryType]::Error;
$infoEvent = [System.Diagnostics.EventLogEntryType]::Information;
$GenericInformationEvent = 8671;
$GenericFailureEvent = 8672;
$script:traceMsg = "";
$momAPI = New-Object -comObject 'MOM.ScriptAPI'

$ResolutionStateClose = 255;
$ResolutionStateActive = 0;

$AlertCriteria = "IsMonitorAlert = 'false' and ResolutionState = $ResolutionStateActive and CustomField1 = 'Fault' "

if ($false -eq [string]::IsNullOrEmpty($DebugMode))
{
$DebugMode = [string]::Equals("true",$DebugMode,[System.StringComparison]::OrdinalIgnoreCase)
}
else
{
$DebugMode = $false
}

Function AddTraceMessage
{
param($message)

$errorActionPreference = 'SilentlyContinue'
$timeStamp = (get-date -format "HH:mm:ss:fff");
$script:traceMsg = $script:traceMsg + "`n[" + $timeStamp + "] " + $message;
}

Function Get-Guid([string]$sguid)
{
if ([string]::IsNullOrEmpty($sguid))
{
return $null
}

$guid = [guid]::NewGuid()
if ($false -eq [guid]::TryParse($sguid,[ref] $guid))
{
return $null;
}

return $guid
}

Function Log-FinalDebugData([int]$FailureEvent,[int]$InformationEvent,$exception,[string]$SCRIPT_NAME,[string]$traceMsg,[bool]$DebugMode = $false,$message = [string]::Empty)
{
$ErrorActionPreference = "SilentlyContinue"

if ($null -ne $exception)
{
if ([string]::Empty -eq $message) {$message = "Error occured during script execution:"}
$momAPI.LogScriptEvent($SCRIPT_NAME, $FailureEvent, 1, "$message $($exception.Message)");
}

if ($script:traceMsg -ne $null -and $true -eq $DebugMode)
{
$momAPI.LogScriptEvent($SCRIPT_NAME,$InformationEvent, 0, $traceMsg);
}
}


Function Prepare-ScomConnection()
{
$ErrorActionPreference = "Stop"
$managementServerName = "localhost"

$result = $true
try
{
#Import-Module OperationsManager
$omModule = get-module -name "OperationsManager"
if ($omModule -eq $null)
{
$SCOMPowerShellKey = "HKLM:\SOFTWARE\Microsoft\System Center Operations Manager\12\Setup\Powershell\V2"
$SCOMModulePath = Join-Path (Get-ItemProperty $SCOMPowerShellKey).InstallDirectory "OperationsManager"
[void](Import-module $SCOMModulePath)
}

AddTraceMessage -message "Connecting to $managementServerName OM management server."
New-SCManagementGroupConnection -ComputerName $managementServerName
AddTraceMessage -message "Connected to $managementServerName SDK. Now getting target class Instance"

}
catch
{
$result = $false
}

return $result
}

AddTraceMessage -message "Start on Management Server: $env:COMPUTERNAME"

# param($faultId, $sourceUniqueId, $sourceObjectId,$RuleId1,$RuleId2,$RuleId3)
# include S2DAlertCommon.ps1

#Alert Resolution State
$resolutionStateClose = 255;
$ResolutionStateActive = 0;
$AlertCriteria = "IsMonitorAlert = 'false' and ResolutionState = $ResolutionStateActive and CustomField1 = 'Fault' "

Function Get-AlertRuleCriteria()
{
$ErrorActionPreference = "Stop"

$result = $AlertCriteria
$rules = @()

$rule1 = Get-Guid -sguid $RuleId1
$rule2 = Get-Guid -sguid $RuleId2
$rule3 = Get-Guid -sguid $RuleId3

if ($null -ne $rule1){$rule = "MonitoringRuleId='{0}'" -f $rule1 ; $rules += $rule; }
if ($null -ne $rule2){$rule = "MonitoringRuleId='{0}'" -f $rule2 ; $rules += $rule; }
if ($null -ne $rule3){$rule = "MonitoringRuleId='{0}'" -f $rule3 ; $rules += $rule; }

if (0 -ne $rules.Length)
{
$result = "(" + ($rules -join " or " ) + ") and " + $result
}

return $result
}

Try
{
$error.Clear();

if([string]::IsNullOrEmpty($faultId))
{
Throw [System.NullReferenceException] "Null or empty FaultId parameter to the script.";
}

if([string]::IsNullOrEmpty($sourceUniqueId))
{
Throw [System.NullReferenceException] "Null or empty SourceUniqueId parameter to the script.";
}

if ($false -eq (Prepare-ScomConnection))
{
if ($error.Coune -ne 0)
{
$exception = $error[0].Exception
}

Log-FinalDebugData -FailureEvent $GenericFailureEvent -InformationEvent $GenericInformationEvent -exception $exception -SCRIPT_NAME $SCRIPT_NAME -traceMsg $script:traceMsg -DebugMode $true
return
}

#$FaultIdpatternToLookForInAlertContext = ("*" + $faultId +":" + $sourceUniqueId + "*");
$FaultIdpatternToLookForInAlertContext = ("*" + $faultId +":" + $sourceObjectId + "*");

AddTraceMessage -message "Searching OM Alert with these patterns: `n $FaultIdpatternToLookForInAlertContext"
$alertsCriteria = Get-AlertRuleCriteria
#$all_new_alerts = @(Get-SCOMAlert -ResolutionState 0)
$all_new_alerts = @(Get-SCOMAlert -Criteria $alertsCriteria)
$alert = $all_new_alerts | Where-Object {$_.Context -like $FaultIdpatternToLookForInAlertContext}

if($alert -ne $null)
{
AddTraceMessage -message ("Alert found. Name = " + $alert[0].Name)
Set-SCOMAlert -Alert $alert -ResolutionState $resolutionStateClose
AddTraceMessage -message "Alert is closed."
}
else
{
AddTraceMessage -message "Could not find OM Alert with given pattern."
}

AddTraceMessage -message "Storage monitoring script CloseAlert.ps1 completed."
}
Catch
{
AddTraceMessage -message $_.Exception.Message
$exception = $_.Exception
}
Finally
{
Log-FinalDebugData -FailureEvent $GenericFailureEvent -InformationEvent $GenericInformationEvent -exception $exception -SCRIPT_NAME $SCRIPT_NAME -traceMsg $script:traceMsg -DebugMode $true
}</Script></ScriptBody>
<Parameters>
<Parameter>
<Name>faultId</Name>
<Value>$Config/FaultId$</Value>
</Parameter>
<Parameter>
<Name>sourceUniqueId</Name>
<Value>$Config/SourceUniqueId$</Value>
</Parameter>
<Parameter>
<Name>sourceObjectId</Name>
<Value>$Config/SourceObjectId$</Value>
</Parameter>
<Parameter>
<Name>RuleId1</Name>
<Value>$Config/RuleId1$</Value>
</Parameter>
<Parameter>
<Name>RuleId2</Name>
<Value>$Config/RuleId2$</Value>
</Parameter>
<Parameter>
<Name>RuleId3</Name>
<Value>$Config/RuleId3$</Value>
</Parameter>
</Parameters>
<TimeoutSeconds>$Config/TimeoutSeconds$</TimeoutSeconds>
</WriteAction>
</MemberModules>
<Composition>
<Node ID="WA"/>
</Composition>
</Composite>
</ModuleImplementation>
<InputType>System!System.BaseData</InputType>
</WriteActionModuleType>