diff --git a/src/System.Management.Automation/engine/PSConfiguration.cs b/src/System.Management.Automation/engine/PSConfiguration.cs index 8c60d6735d8..8861e676c44 100644 --- a/src/System.Management.Automation/engine/PSConfiguration.cs +++ b/src/System.Management.Automation/engine/PSConfiguration.cs @@ -247,8 +247,6 @@ internal PSLevel GetLogLevel() /// const string LogDefaultValue = "default"; - const PSChannel DefaultChannels = PSChannel.Operational; - /// /// Gets the bitmask of the PSChannel values to log. /// @@ -282,15 +280,12 @@ internal PSChannel GetLogChannels() if (result == 0) { - result = DefaultChannels; + result = System.Management.Automation.Tracing.PSSysLogProvider.DefaultChannels; } return result; } - // by default, do not include analytic events. - const PSKeyword DefaultKeywords = (PSKeyword) (0xFFFFFFFFFFFFFFFF & ~(ulong)PSKeyword.UseAlwaysAnalytic); - /// /// Gets the bitmask of keywords to log. /// @@ -324,7 +319,7 @@ internal PSKeyword GetLogKeywords() if (result == 0) { - result = DefaultKeywords; + result = System.Management.Automation.Tracing.PSSysLogProvider.DefaultKeywords; } return result; diff --git a/src/System.Management.Automation/engine/remoting/common/PSETWTracer.cs b/src/System.Management.Automation/engine/remoting/common/PSETWTracer.cs index 5008ab57dde..0088f2f136f 100644 --- a/src/System.Management.Automation/engine/remoting/common/PSETWTracer.cs +++ b/src/System.Management.Automation/engine/remoting/common/PSETWTracer.cs @@ -195,12 +195,26 @@ internal enum PSEventId : int /// /// Defines enumerations for channels /// + /// + /// On Windows, PSChannel is the numeric channel id value. + /// On Non-Windows, PSChannel is used to filter events and + /// the underlying channel bitmask values are used instead. + /// The bit values are the same as used on Windows. + /// +#if UNIX [Flags] + internal enum PSChannel : byte + { + Operational = 0x80, + Analytic = 0x40 + } +#else internal enum PSChannel : byte { Operational = 0x10, Analytic = 0x11 } +#endif /// /// Defines enumerations for tasks diff --git a/src/System.Management.Automation/engine/runtime/CompiledScriptBlock.cs b/src/System.Management.Automation/engine/runtime/CompiledScriptBlock.cs index 6362edd0bcf..6b69f89d997 100644 --- a/src/System.Management.Automation/engine/runtime/CompiledScriptBlock.cs +++ b/src/System.Management.Automation/engine/runtime/CompiledScriptBlock.cs @@ -1321,7 +1321,7 @@ private static bool WriteScriptBlockToLog(ScriptBlock scriptBlock, int segment, // they can just wait on the compromised box and see the sensitive data eventually anyways. string errorMessage = StringUtil.Format(SecuritySupportStrings.CouldNotEncryptContent, textToLog, error.ToString()); - PSEtwLog.LogOperationalError(PSEventId.ScriptBlock_Compile_Detail, PSOpcode.Create, PSTask.ExecuteCommand, PSKeyword.UseAlwaysAnalytic, + PSEtwLog.LogOperationalError(PSEventId.ScriptBlock_Compile_Detail, PSOpcode.Create, PSTask.ExecuteCommand, PSKeyword.UseAlwaysOperational, 0, 0, errorMessage, scriptBlock.Id.ToString(), scriptBlock.File ?? String.Empty); } else @@ -1334,12 +1334,12 @@ private static bool WriteScriptBlockToLog(ScriptBlock scriptBlock, int segment, if (scriptBlock._scriptBlockData.HasSuspiciousContent) { - PSEtwLog.LogOperationalWarning(PSEventId.ScriptBlock_Compile_Detail, PSOpcode.Create, PSTask.ExecuteCommand, PSKeyword.UseAlwaysAnalytic, + PSEtwLog.LogOperationalWarning(PSEventId.ScriptBlock_Compile_Detail, PSOpcode.Create, PSTask.ExecuteCommand, PSKeyword.UseAlwaysOperational, segment + 1, segments, textToLog, scriptBlock.Id.ToString(), scriptBlock.File ?? String.Empty); } else { - PSEtwLog.LogOperationalVerbose(PSEventId.ScriptBlock_Compile_Detail, PSOpcode.Create, PSTask.ExecuteCommand, PSKeyword.UseAlwaysAnalytic, + PSEtwLog.LogOperationalVerbose(PSEventId.ScriptBlock_Compile_Detail, PSOpcode.Create, PSTask.ExecuteCommand, PSKeyword.UseAlwaysOperational, segment + 1, segments, textToLog, scriptBlock.Id.ToString(), scriptBlock.File ?? String.Empty); } @@ -1405,7 +1405,7 @@ private static bool GetAndValidateEncryptionRecipients(ScriptBlock scriptBlock, // attacker seeing potentially sensitive data. Because if they aren't detected, then // they can just wait on the compromised box and see the sensitive data eventually anyways. string errorMessage = StringUtil.Format(SecuritySupportStrings.CouldNotUseCertificate, error.ToString()); - PSEtwLog.LogOperationalError(PSEventId.ScriptBlock_Compile_Detail, PSOpcode.Create, PSTask.ExecuteCommand, PSKeyword.UseAlwaysAnalytic, + PSEtwLog.LogOperationalError(PSEventId.ScriptBlock_Compile_Detail, PSOpcode.Create, PSTask.ExecuteCommand, PSKeyword.UseAlwaysOperational, 0, 0, errorMessage, scriptBlock.Id.ToString(), scriptBlock.File ?? String.Empty); return true; @@ -1430,7 +1430,7 @@ private static bool GetAndValidateEncryptionRecipients(ScriptBlock scriptBlock, } string errorMessage = StringUtil.Format(SecuritySupportStrings.CertificateContainsPrivateKey, certificateForLog); - PSEtwLog.LogOperationalError(PSEventId.ScriptBlock_Compile_Detail, PSOpcode.Create, PSTask.ExecuteCommand, PSKeyword.UseAlwaysAnalytic, + PSEtwLog.LogOperationalError(PSEventId.ScriptBlock_Compile_Detail, PSOpcode.Create, PSTask.ExecuteCommand, PSKeyword.UseAlwaysOperational, 0, 0, errorMessage, scriptBlock.Id.ToString(), scriptBlock.File ?? String.Empty); } } @@ -1794,7 +1794,7 @@ internal static void LogScriptBlockStart(ScriptBlock scriptBlock, Guid runspaceI if (GetScriptBlockLoggingSetting()?.EnableScriptBlockInvocationLogging == true) { - PSEtwLog.LogOperationalVerbose(PSEventId.ScriptBlock_Invoke_Start_Detail, PSOpcode.Create, PSTask.CommandStart, PSKeyword.UseAlwaysAnalytic, + PSEtwLog.LogOperationalVerbose(PSEventId.ScriptBlock_Invoke_Start_Detail, PSOpcode.Create, PSTask.CommandStart, PSKeyword.UseAlwaysOperational, scriptBlock.Id.ToString(), runspaceId.ToString()); } } @@ -1803,7 +1803,7 @@ internal static void LogScriptBlockEnd(ScriptBlock scriptBlock, Guid runspaceId) { if (GetScriptBlockLoggingSetting()?.EnableScriptBlockInvocationLogging == true) { - PSEtwLog.LogOperationalVerbose(PSEventId.ScriptBlock_Invoke_Complete_Detail, PSOpcode.Create, PSTask.CommandStop, PSKeyword.UseAlwaysAnalytic, + PSEtwLog.LogOperationalVerbose(PSEventId.ScriptBlock_Invoke_Complete_Detail, PSOpcode.Create, PSTask.CommandStop, PSKeyword.UseAlwaysOperational, scriptBlock.Id.ToString(), runspaceId.ToString()); } } diff --git a/src/System.Management.Automation/utils/tracing/PSSysLogProvider.cs b/src/System.Management.Automation/utils/tracing/PSSysLogProvider.cs index 49d5c8c2f29..7507c1c4402 100755 --- a/src/System.Management.Automation/utils/tracing/PSSysLogProvider.cs +++ b/src/System.Management.Automation/utils/tracing/PSSysLogProvider.cs @@ -17,8 +17,11 @@ internal class PSSysLogProvider : LogProvider { private static SysLogProvider s_provider; - // by default, do not include analytic events - internal const PSKeyword DefaultKeywords = (PSKeyword) (0xFFFFFFFFFFFFFFFF & ~(ulong)PSKeyword.UseAlwaysAnalytic); + // by default, do not include channel bits + internal const PSKeyword DefaultKeywords = (PSKeyword) (0x00FFFFFFFFFFFFFF); + + // the default enabled channel(s) + internal const PSChannel DefaultChannels = PSChannel.Operational; /// /// Class constructor. diff --git a/src/System.Management.Automation/utils/tracing/SysLogProvider.cs b/src/System.Management.Automation/utils/tracing/SysLogProvider.cs index 614bdbdc9ec..cd6d9d73927 100755 --- a/src/System.Management.Automation/utils/tracing/SysLogProvider.cs +++ b/src/System.Management.Automation/utils/tracing/SysLogProvider.cs @@ -102,6 +102,14 @@ public SysLogProvider(string applicationId, PSLevel level, PSKeyword keywords, P _keywordFilter = (ulong)keywords; _levelFilter = (byte) level; _channelFilter = (byte) channels; + if ((_channelFilter & (ulong) PSChannel.Operational) != 0) + { + _keywordFilter |= (ulong) PSKeyword.UseAlwaysOperational; + } + if ((_channelFilter & (ulong) PSChannel.Analytic) != 0) + { + _keywordFilter |= (ulong) PSKeyword.UseAlwaysAnalytic; + } } /// @@ -313,13 +321,6 @@ public void SetActivity(Guid activity) /// The payload for the log message. public void Log(PSEventId eventId, PSChannel channel, PSTask task, PSOpcode opcode, PSLevel level, PSKeyword keyword, params object[] args) { - if (keyword == PSKeyword.UseAlwaysAnalytic) - { - // Use the 'DefaultKeywords' to work around the default keyword filter. - // Note that the PSKeyword argument is not really used in writing SysLog. - keyword = PSSysLogProvider.DefaultKeywords; - } - if (ShouldLog(level, keyword, channel)) { int threadId = Thread.CurrentThread.ManagedThreadId;