To install the GitHub.Actions.Core
NuGet package:
<PackageReference Include="GitHub.Actions.Core" Version="[Version]" />
Or use the dotnet add package
.NET CLI command:
dotnet add package GitHub.Actions.Core
To use the ICoreService
in your .NET project, register the services with an IServiceCollection
instance by calling AddGitHubActionsCore
and then your consuming code can require the ICoreService
via constructor dependency injection.
using Microsoft.Extensions.DependencyInjection;
using Actions.Core;
using Actions.Core.Extensions;
using var provider = new ServiceCollection()
.AddGitHubActionsCore()
.BuildServiceProvider();
var core = provider.GetRequiredService<ICoreService>();
This was modified, but borrowed from the core/README.md.
Core functions for setting results, logging, registering secrets and exporting variables across actions
global using Actions.Core;
Action inputs can be read with GetInput
which returns a string
or GetBoolInput
which parses a bool
based on the yaml 1.2 specification. If required
is false
, the input should have a default value in action.yml
.
Outputs can be set with SetOutputAsync
which makes them available to be mapped into inputs of other actions to ensure they are decoupled.
var myInput = core.GetInput("inputName", new InputOptions(true));
var myBoolInput = core.GetBoolInput("boolInputName", new InputOptions(true));
var myMultilineInput = core.GetMultilineInput("multilineInputName", new InputOptions(true));
await core.SetOutputAsync("outputKey", "outputVal");
Since each step runs in a separate process, you can use ExportVariableAsync
to add it to this step and future steps environment blocks.
await core.ExportVariableAsync("envVar", "Val");
Setting a secret registers the secret with the runner to ensure it is masked in logs.
core.SetSecret("myPassword");
To make a tool's path available in the path for the remainder of the job (without altering the machine or containers state), use AddPathAsync
. The runner will prepend the path given to the jobs PATH.
await core.AddPathAsync("/path/to/mytool");
You should use this library to set the failing exit code for your action. If status is not set and the script runs to completion, that will lead to a success.
using var provider = new ServiceCollection()
.AddGitHubActions()
.BuildServiceProvider();
var core = provider.GetRequiredService<ICoreService>();
try
{
// Do stuff
}
catch (Exception ex)
{
// SetFailed logs the message and sets a failing exit code
core.SetFailed($"Action failed with error {ex}"");
}
Finally, this library provides some utilities for logging. Note that debug logging is hidden from the logs by default. This behavior can be toggled by enabling the Step Debug Logs.
using var provider = new ServiceCollection()
.AddGitHubActions()
.BuildServiceProvider();
var core = provider.GetRequiredService<ICoreService>();
var myInput = core.GetInput("input");
try
{
core.Debug("Inside try block");
if (!myInput)
{
core.Warning("myInput was not set");
}
if (core.IsDebug)
{
// curl -v https://github.com
}
else
{
// curl https://github.com
}
// Do stuff
core.Info("Output to the actions build log");
core.Notice("This is a message that will also emit an annotation");
}
catch (Exception ex)
{
core.Error($"Error {ex}, action may still succeed though");
}
This library can also wrap chunks of output in foldable groups.
using var provider = new ServiceCollection()
.AddGitHubActions()
.BuildServiceProvider();
var core = provider.GetRequiredService<ICoreService>();
// Manually wrap output
core.StartGroup("Do some function");
SomeFunction();
core.EndGroup();
// Wrap an asynchronous function call
var result = await core.GroupAsync("Do something async", async () =>
{
var response = await MakeHttpRequestAsync();
return response
});
Colored output is supported in the Action logs via standard ANSI escape codes. 3/4 bit, 8 bit and 24 bit colors are all supported.
Foreground colors:
// 3/4 bit
core.Info("\u001b[35mThis foreground will be magenta");
// 8 bit
core.Info("\u001b[38;5;6mThis foreground will be cyan");
// 24 bit
core.Info("\u001b[38;2;255;0;0mThis foreground will be bright red");
Background colors:
// 3/4 bit
core.Info("\u001b[43mThis background will be yellow");
// 8 bit
core.Info("\u001b[48;5;6mThis background will be cyan");
// 24 bit
core.Info("\u001b[48;2;255;0;0mThis background will be bright red");
Special styles:
core.Info("\u001b[1mBold text");
core.Info("\u001b[3mItalic text");
core.Info("\u001b[4mUnderlined text");
ANSI escape codes can be combined with one another:
core.Info("\u001b[31;46mRed foreground with a cyan background and \u001b[1mbold text at the end");
Note
Escape codes reset at the start of each line.
core.Info("\u001b[35mThis foreground will be magenta");
core.Info("This foreground will reset to the default");