-
-
Notifications
You must be signed in to change notification settings - Fork 1
/
Copy pathSend-Event.ps1
83 lines (75 loc) · 2.79 KB
/
Send-Event.ps1
1
2
3
4
5
6
7
8
9
10
11
12
13
14
15
16
17
18
19
20
21
22
23
24
25
26
27
28
29
30
31
32
33
34
35
36
37
38
39
40
41
42
43
44
45
46
47
48
49
50
51
52
53
54
55
56
57
58
59
60
61
62
63
64
65
66
67
68
69
70
71
72
73
74
75
76
77
78
79
80
81
82
83
function Send-Event
{
<#
.Synopsis
Sends Events
.Description
Sends Events to PowerShell.
Send-Event is a wrapper for the built-in command New-Event with a few key differences:
1. It allows MessageData to be piped in
2. You can send multiple sourceidentifiers
3. It does not output by default (you must pass -PassThru)
.Example
1..4 | Send-Event "Hit It"
.Link
New-Event
.Link
Watch-Event
#>
[OutputType([Nullable],[Management.Automation.PSEventArgs])]
param(
# The SourceIdentifier
[Parameter(Mandatory,Position=0,ValueFromPipelineByPropertyName)]
[string[]]
$SourceIdentifier,
# The message data
[Parameter(ValueFromPipeline,Position=1,ValueFromPipelineByPropertyName)]
[PSObject]
$MessageData,
# The sender.
[Parameter(ValueFromPipelineByPropertyName,Position=2)]
[PSObject]
$Sender,
# The event arguments.
[Parameter(ValueFromPipelineByPropertyName,Position=3)]
[Alias('SourceEventArgs','EventArgs')]
[PSObject]
$EventArguments,
# If set, will output the created event.
[Parameter(ValueFromPipelineByPropertyName)]
[switch]
$PassThru
)
begin {
# Be we start, get a reference to New-Event
$newEvent = $ExecutionContext.SessionState.InvokeCommand.GetCommand('New-Event','Cmdlet')
}
process {
#region Map New-Event Parameters
$myParameters = @{} + $PSBoundParameters
$newEventParams = @{} + $PSBoundParameters # Copy bound parameters.
foreach ($k in @($newEventParams.Keys)) {
if (-not $newEvent.Parameters[$k]) { # If a parameter isn't for New-Event
$newEventParams.Remove($k) # remove it from the copy.
}
}
# If we're piping in MessageData, but the message only contains "Sender" and "Event"
if ($newEventParams.Sender -and $newEventParams.EventArgs -and
$newEventParams.MessageData.psobject.properties.Count -eq 2 -and
$newEventParams.MessageData.Sender -and $newEventParams.MessageData.EventArgs) {
$newEventParams.Remove('MessageData') # remove the MessageData.
}
# Always remove the sourceID parameter (New-Event allows one, Send-Event allows many)
$newEventParams.Remove('SourceIdentifier')
#endregion Map New-Event Parameters
#region Send Each Event
foreach ($sourceID in $SourceIdentifier) { # Walk over each source identifier
# and call New-Event.
$evt = New-Event @newEventParams -SourceIdentifier $sourceID
if ($PassThru) { # If we want to -PassThru events
$evt # output the created event.
}
}
#endregion Send Each Event
}
}