Skip to content

darizotas/ta-windows-wec

Folders and files

NameName
Last commit message
Last commit date

Latest commit

 

History

28 Commits
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 

Repository files navigation

TA-windows-wec add-on for Splunk

This Add-on for Splunk ingests the output of the wecutil command-line utility. Namely,

  • Subscriptions list.
  • Subscription details and related event log statistics.
  • Subscription runtime status.

And registry pruning activities to remove inactive event sources. An event source is considered inactive when it has not sent an event or heartbeat for longer than a defined period.

Subscriptions list

It retrieves the subscriptions from the output of the command:

wecutil es

Subscription details and related event log statistics

Subscription details are a combination of the output of the command:

wecutil gs SUBSCRIPTION_NAME

And some statistics from the EventLog where the events are stored. From both, the following fields are present in the details (sourcetype = windows:wec:subscription:details):

  • Subscription: Subscription Id.
  • Enabled: True whether the subscription is enabled.
  • ConfigurationMode: Custom, Normal, MinBandwidth, MinLatency.
  • DeliveryMode: push, pull
  • DeliveryMaxItems: Maximum number of items for batched delivery. Only valid for "custom" configuration mode.
  • DeliveryMaxLatencyTime: Delivery max latency time (milliseconds)
  • HeartbeatInterval: Heartbeat interval (milliseconds)
  • AllowedSourceDomainComputers: SDDL ACL that contains the allowed computers to participate in the subscription
  • EventSource: list of computers (pairs: Address, Enabled) that can forward events to the event collector. This value is typically used for collector initated subscriptions. It can be used for source inititated subscriptions to disable the collection of events from a particular event source.
  • LogName: Log name where the events are saved.
  • EventPerSecond: Number of events per seconds (EPS).
  • TotalEvents: Total number of events.
  • NewestEventTime: Time stamp of the newest event in the log.
  • OldestEventTime: Time stamp of the oldest event in the log.
  • LogSize: Log size in Bytes.

Note: The list of event sources by default will not be included (see event source splitting). As it would be the case of parsing the XML format. That is,

wecutil gs SUBSCRIPTION_NAME /f:XML

References

Subscription runtime status

It parses the output from the command:

wecutil gr SUBSCRIPTION_NAME

The following fields are created (sourcetype = windows:wec:subscription:runtime):

  • Subscription : subscription name.
  • RunTimeStatus : runtime status.
  • LastError: last error value.
  • ErrorMessage: Error message (note: only in case of error)
  • ErrorTime: Timestamp of the error occurrence (note: only in case of error)
  • EventSource : list of event sources (note: see event source splitting). For collector initiated subscriptions, this list will be identical to the one in the subscription's configuration. For source initiated subscriptions, this list will be the set of event sources that collector has heard from in the last 30 days. Each event source contains the following fields:
    • ComputerName : event source computer name.
    • RunTimeStatus : runtime status.
    • LastError: last error value.
    • LastHeartbeatTime : Time stamp with the last check-in.

References

Registry pruning

For each unique device that connects to a WEF subscription, there is a registry key (corresponding to the FQDN of the WEF Client) created to store bookmark and source heartbeat information.

The root registry key is:

HKLM:\SOFTWARE\Microsoft\Windows\CurrentVersion\EventCollector\Subscriptions\

It parses the registry key for each subscription searching for inactive event sources and for those whose hearbeat is older than a defined retention period (in days) or null, they are removed. The following fields are created according to that operation (sourcetype = windows:wec:subscription:registry):

  • Subscription : subscription name.
  • Status : status of the pruning operation.
  • ErrorMessage: null or the error message produced by not being able to remove an event source.
  • ErrorTime: null or timestamp of the error.
  • EventSource : list of event sources removed from the registry (note: see event source splitting). Each event source contains the following fields:
    • ComputerName : event source computer name.
    • LastHeartbeatTime : Time stamp with the last check-in (in UTC).

References

Install the TA-wecutil add-on for Splunk

Instance type Supported Required Description
Search head No No Check out Windows WEC App for Splunk.
Indexer Yes No This add-on should be installed on a heavy forwarder present on the WEC server. There is no need to install this add-on on an indexer too.
Universal forwarder No No This add-on is not supported on a Universal Forwarder because it performs time formatting.
Heavy forwarder Yes Yes Install this add-on on the heavy forwarder present on the WEC server.

That is, this add-on must be installed on the WEC server itself. It requires wecsvc running, wecutil command-line utility and PowerShell v5 or newer. But also read-write access on HKLM registry key.

Configuration and troubleshooting

The TA-windows-wec brings only two configuration items that are present in the configuration file etc\default\ta-windows-wec_settings.conf.

Logging

    [logging]
    ; Log levels: DEBUG = Verbose, NONE = Default (Only warnings and errors)
    ; Errors and Warnings are also redirected to: splunk-powershell.ps1.log
    log_level=NONE   

The logs are generated to var/log/splunk/splunk_ta-windows-wec-details.log, var/log/splunk/splunk_ta-windows-wec-runtime.log and var/log/splunk/splunk_ta-windows-wec-prune-registry.log according to their sourcetype, and therefore parsed by Splunk.

index=_internal source=*ta-windows-wec*

Note: the log files are overwritten when they reach 150MB size.

Said all that, you should check splunk_ta-windows-wec-details.log, splunk_ta-windows-wec-runtime.log, splunk_ta-windows-wec-prune-registry.log and splunk-powershell.ps1.log.

Event source splitting

The list of event sources associated to a subscription can be enormous from just a few to thousands. This last makes the Splunk event very dense causing trouble to the browser to render the JSON array, think of arrays of thousands values for each event. But also, this can lead to easily reach the KV JSON event limit, and hence, truncate events.

For those reasons two settings have been added:

  • rt_splitafter indicates the number of event sources after which the Splunk event of the subscription runtime status will be splitted. By default is set to 70, that is, after 70 event sources, the Splunk event is splitted. Zero or negative value will not split the event sources, but may cause undesirable side effects when inspecting the Splunk events as aboved mentioned.
  • sd_splitafter indicates the number of event sources after which the Splunk event will be splitted. By default is a negative value, that means no event sources are included in the Splunk event of the subscription details. A zero value will not split the event sources, but may cause undesirable side effects when inspecting the Splunk events as aboved mentioned.
  • pr_splitafter indicates the number of event sources after which the Splunk event of the subscription prune registry status will be splitted. By default is set to 70, that is, after 70 event sources, the Splunk event is splitted. Zero or negative value will not split the event sources, but may cause undesirable side effects when inspecting the Splunk events as aboved mentioned.
[eventsource]
; - Zero or negative integer value will not split the event sources. Warning! in case of having thousands of
;   event sources the browser may have problems rendering the events, but also you may reach the KV JSON char limit.
; - Positive integer value will split the event source into batches. 
rt_splitafter=70
; - Negative integer value it will not include the event sources for the subscription details.
; - Zero value will include and will not split the event sources. Warning! in case of having thousands of
;   event sources the browser may have problems rendering the events, but also you may reach the KV JSON char limit.  
; - Positive integer value will split the event sources into batches. 
sd_splitafter=-1
; - Zero or negative integer value will not split the event sources for the subscription prune registry status.  
;   Warning! in case of having thousands of event sources the browser may have problems rendering the events, but 
;   also you may reach the KV JSON char limit.
; - Positive integer value will split the event source into batches. 
pr_splitafter=70

Registry pruning

[pruning]
; Those event sources with a LastHeartbetTime older than this number of days from today will be removed from the
; registry or reported as candidate to remove, if report_only is true. 
days_old=60
; If true, it will only report for event sources whose LastHeartbeatTime is older than the maximum number of days
; from today instead of directly removing them from the regisry.
report_only=true

References

TO DO List