Skip to content

Commit

Permalink
add-mask is leaking a secret in master if debug or ::echo::on is set (#…
Browse files Browse the repository at this point in the history
…158)

* Output after processing command to avoid leaking mask

* Remove extra noise output from echo changes

* Omit Echoing of add-mask command

* avoid echoing on debug/warning/error
  • Loading branch information
thboop authored Nov 4, 2019
1 parent 61f9d3f commit 3ba55f8
Showing 1 changed file with 26 additions and 20 deletions.
46 changes: 26 additions & 20 deletions src/Runner.Worker/ActionCommandManager.cs
Original file line number Diff line number Diff line change
Expand Up @@ -73,7 +73,7 @@ public bool TryProcessCommand(IExecutionContext context, string input)
return false;
}

// process action command in serialize oreder.
// process action command in serialize order.
lock (_commandSerializeLock)
{
if (_stopProcessCommand)
Expand Down Expand Up @@ -107,32 +107,19 @@ public bool TryProcessCommand(IExecutionContext context, string input)
}
else if (_commandExtensions.TryGetValue(actionCommand.Command, out IActionCommandExtension extension))
{
bool commandHasBeenOutput = false;
if (context.EchoOnActionCommand && !extension.OmitEcho)
{
context.Output(input);
}

try
{
if (context.EchoOnActionCommand)
{
context.Output(input);
context.Debug($"Processing command '{actionCommand.Command}'");
commandHasBeenOutput = true;
}

extension.ProcessCommand(context, input, actionCommand);

if (context.EchoOnActionCommand)
{
context.Debug($"Processed command '{actionCommand.Command}' successfully");
}
}
catch (Exception ex)
{
if (!commandHasBeenOutput)
{
context.Output(input);
}

context.Error($"Unable to process command '{input}' successfully.");
var commandInformation = extension.OmitEcho ? extension.Command : input;
context.Error($"Unable to process command '{commandInformation}' successfully.");
context.Error(ex);
context.CommandResult = TaskResult.Failed;
}
Expand All @@ -151,13 +138,15 @@ public bool TryProcessCommand(IExecutionContext context, string input)
public interface IActionCommandExtension : IExtension
{
string Command { get; }
bool OmitEcho { get; }

void ProcessCommand(IExecutionContext context, string line, ActionCommand command);
}

public sealed class InternalPluginSetRepoPathCommandExtension : RunnerService, IActionCommandExtension
{
public string Command => "internal-set-repo-path";
public bool OmitEcho => false;

public Type ExtensionType => typeof(IActionCommandExtension);

Expand Down Expand Up @@ -187,6 +176,7 @@ private static class SetRepoPathCommandProperties
public sealed class SetEnvCommandExtension : RunnerService, IActionCommandExtension
{
public string Command => "set-env";
public bool OmitEcho => false;

public Type ExtensionType => typeof(IActionCommandExtension);

Expand All @@ -211,6 +201,7 @@ private static class SetEnvCommandProperties
public sealed class SetOutputCommandExtension : RunnerService, IActionCommandExtension
{
public string Command => "set-output";
public bool OmitEcho => false;

public Type ExtensionType => typeof(IActionCommandExtension);

Expand All @@ -234,6 +225,7 @@ private static class SetOutputCommandProperties
public sealed class SaveStateCommandExtension : RunnerService, IActionCommandExtension
{
public string Command => "save-state";
public bool OmitEcho => false;

public Type ExtensionType => typeof(IActionCommandExtension);

Expand All @@ -257,6 +249,7 @@ private static class SaveStateCommandProperties
public sealed class AddMaskCommandExtension : RunnerService, IActionCommandExtension
{
public string Command => "add-mask";
public bool OmitEcho => true;

public Type ExtensionType => typeof(IActionCommandExtension);

Expand All @@ -268,6 +261,11 @@ public void ProcessCommand(IExecutionContext context, string line, ActionCommand
}
else
{
if (context.EchoOnActionCommand)
{
context.Output($"::{Command}::***");
}

HostContext.SecretMasker.AddValue(command.Data);
Trace.Info($"Add new secret mask with length of {command.Data.Length}");
}
Expand All @@ -277,6 +275,7 @@ public void ProcessCommand(IExecutionContext context, string line, ActionCommand
public sealed class AddPathCommandExtension : RunnerService, IActionCommandExtension
{
public string Command => "add-path";
public bool OmitEcho => false;

public Type ExtensionType => typeof(IActionCommandExtension);

Expand All @@ -291,6 +290,7 @@ public void ProcessCommand(IExecutionContext context, string line, ActionCommand
public sealed class AddMatcherCommandExtension : RunnerService, IActionCommandExtension
{
public string Command => "add-matcher";
public bool OmitEcho => false;

public Type ExtensionType => typeof(IActionCommandExtension);

Expand Down Expand Up @@ -337,6 +337,7 @@ public void ProcessCommand(IExecutionContext context, string line, ActionCommand
public sealed class RemoveMatcherCommandExtension : RunnerService, IActionCommandExtension
{
public string Command => "remove-matcher";
public bool OmitEcho => false;

public Type ExtensionType => typeof(IActionCommandExtension);

Expand Down Expand Up @@ -404,6 +405,7 @@ private static class RemoveMatcherCommandProperties
public sealed class DebugCommandExtension : RunnerService, IActionCommandExtension
{
public string Command => "debug";
public bool OmitEcho => true;

public Type ExtensionType => typeof(IActionCommandExtension);

Expand Down Expand Up @@ -431,6 +433,7 @@ public abstract class IssueCommandExtension : RunnerService, IActionCommandExten
{
public abstract IssueType Type { get; }
public abstract string Command { get; }
public bool OmitEcho => true;

public Type ExtensionType => typeof(IActionCommandExtension);

Expand Down Expand Up @@ -510,6 +513,8 @@ public sealed class EndGroupCommandExtension : GroupingCommandExtension
public abstract class GroupingCommandExtension : RunnerService, IActionCommandExtension
{
public abstract string Command { get; }
public bool OmitEcho => false;

public Type ExtensionType => typeof(IActionCommandExtension);

public void ProcessCommand(IExecutionContext context, string line, ActionCommand command)
Expand All @@ -522,6 +527,7 @@ public void ProcessCommand(IExecutionContext context, string line, ActionCommand
public sealed class EchoCommandExtension : RunnerService, IActionCommandExtension
{
public string Command => "echo";
public bool OmitEcho => false;

public Type ExtensionType => typeof(IActionCommandExtension);

Expand Down

0 comments on commit 3ba55f8

Please sign in to comment.