GitHubApps.AspNetCore.Mvc
0.1.0-rc.1
dotnet add package GitHubApps.AspNetCore.Mvc --version 0.1.0-rc.1
NuGet\Install-Package GitHubApps.AspNetCore.Mvc -Version 0.1.0-rc.1
<PackageReference Include="GitHubApps.AspNetCore.Mvc" Version="0.1.0-rc.1" />
paket add GitHubApps.AspNetCore.Mvc --version 0.1.0-rc.1
#r "nuget: GitHubApps.AspNetCore.Mvc, 0.1.0-rc.1"
// Install GitHubApps.AspNetCore.Mvc as a Cake Addin #addin nuget:?package=GitHubApps.AspNetCore.Mvc&version=0.1.0-rc.1&prerelease // Install GitHubApps.AspNetCore.Mvc as a Cake Tool #tool nuget:?package=GitHubApps.AspNetCore.Mvc&version=0.1.0-rc.1&prerelease
GitHubApps.AspNetCore.Mvc
The GitHub Apps AspNetCore Mvc is a component that allows the creation of GitHub Apps using .NET.
A GitHub App is a service that receives a post request from GitHub when certain actions are executed.
This component uses the Nuget Package GitHubApps and exposes a class GitHubAppController
, which inherits from the ControllerBase
class, exposing a MVC Controller.
Refer to the API Documentation to have a better understanding of each class and how to use it.
Usage
Creating the GitHub App
Add the nuget package GitHubApps.AspNetCore.Mvc into your project. It will automatically add the GitHubApps, and GitHubAuth to your project.
Create your own GitHubApp
, by creating a class that inherits from the GitHubAppBase
class.
using GitHubApps;
// If your App does not need to connect to GitHub and do any action, you don't need authentication
public class MyGitHubAppWithoutAuthentication: GitHubAppBase
{
public MyGitHubApp()
{
}
//TODO: Override the virtual methods for each event
}
// If your App needs to connect to GitHub and do any action, you will need authentication
public class MyGitHubAppWithAuthentication: GitHubAppBase
{
// override the property to a non-nullable property, this will prevent the warning CS8602 (Dereference of a possibly null reference) from being displayed
public new IAuthenticator Authenticator { get; set; }
// require the authenticator to come from dependency injection
public MyGitHubApp(IAuthenticator authenticator)
{
Authenticator = authenticator;
}
//TODO: Override the virtual methods for each event
}
This class contains several virtual methods that can be overwritten to handle the proper event and action. For example, to handle the GitHub event installation
with action created
, you can override the OnEventInstallationCreated()
method.
using GitHubApps;
public class MyGitHubApp: GitHubAppBase
{
//TODO: Initialization of the class goes here
public class MyGitHubApp()
{
...
}
public override EventResult OnEventInstallationCreated(GitHubDelivery<GitHubEventInstallation> payload)
{
// Your code goes here...
}
}
For more information, refer to the API Documentation.
Optionally, you can create a class that implements the
IGitHubApp
interface. However, this is not recommended as all the handling of the GitHub Post request will have to be handled manually.
Creating the ASP.Net Core Web Api
After you created the GitHubApp
, you need to implement the Controller.
In a ASP.Net Core Web Api, create a class that derives from the GitHubAppController
class. This will allow you to define a Route
for the class.
[ApiController]
[Route("GitHubApp")]
public class MyGitHubAppController: GitHubAppController
{
public MyGitHubAppController(IGitHubApp gitHubApp): base(null, gitHubApp)
{
}
}
On your Program.cs
class, add your custom GitHub App. This will configure Dependency Injection to recognize your GitHubApp.
// Program.cs
// Adds the GitHub App With the Default JWT (GitHubJwtWithRS256)
// This method automaticaly adds the IGitHubJwt into the dependency injection framework
builder.Services.AddGitHubApp<MyGitHubApp, AppAuthenticator>("path_to_pem_file.pem", 123456, provider =>
{
var authenticator = new AppAuthenticator(provider.GetRequiredService<GitHubAuth.Jwt.IGitHubJwt>())
{
GetClient = () =>
{
//TODO: Implement a function to return a client to the GitHub API
}
};
return authenticator;
});
// MyGitHubAppController.cs
public class MyGitHubAppController: GitHubAppController
{
public MyGitHubAppController(IGitHubApp gitHubApp): base(null, gitHubApp)
{
}
}
There could be cases when you need to implement more than one GitHub App in the same project. If this is the case, you can call the method and add multiple GitHubApps. However, you will need to specify which GitHub App to use in your controller, instead of refering to the IGitHubApp
interface.
// Program.cs
// Adds a Typed GitHub App
builder.Services.AddTypedGitHubApp<MyGitHubApp01, AppAuthenticator>("path_to_pem_file01.pem", 123456, provider =>
{
var authenticator = new AppAuthenticator(provider.GetRequiredService<GitHubAuth.Jwt.IGitHubJwt>())
{
GetClient = () =>
{
//TODO: Implement a function to return a client to the GitHub API }
};
return authenticator;
});
builder.Services.AddTypedGitHubApp<MyGitHubApp02, AppAuthenticator>("path_to_pem_file02.pem", 789012, provider =>
{
var authenticator = new AppAuthenticator(provider.GetRequiredService<GitHubAuth.Jwt.IGitHubJwt>())
{
GetClient = () =>
{
//TODO: Implement a function to return a client to the GitHub API
}
};
return authenticator;
});
// MyController01.cs
[ApiController]
[Route("GitHubApp01")]
public class MyController01: GitHubAppController
{
// Note that you have to refer to the MyGitHubApp02, instead of the IGitHubApp
public MyController01(MyGitHubApp01 gitHubApp01): base(null, gitHubApp01)
{
}
}
// MyController02.cs
[ApiController]
[Route("GitHubApp02")]
public class MyController02: GitHubAppController
{
// Note that you have to refer to the MyGitHubApp02, instead of the IGitHubApp
public MyController02(MyGitHubApp02 gitHubApp01): base(null, gitHubApp01)
{
}
}
Refer to the Project
GitHubApps.AspNetCore.Mvc.Example
to see a working example.
Links
This section contains links that are relevant to this repository.
Link | Description |
---|---|
GitHub Webhook Events and Payloads | The specification of webhooks events and payloads |
Project Roadmap | The project roadmap and expected delivery dates |
Project Board | The project board containing the tasks and its status |
API Documentation | The API Documentation |
Product | Versions Compatible and additional computed target framework versions. |
---|---|
.NET | net5.0 was computed. net5.0-windows was computed. net6.0 is compatible. net6.0-android was computed. net6.0-ios was computed. net6.0-maccatalyst was computed. net6.0-macos was computed. net6.0-tvos was computed. net6.0-windows was computed. net7.0 was computed. net7.0-android was computed. net7.0-ios was computed. net7.0-maccatalyst was computed. net7.0-macos was computed. net7.0-tvos was computed. net7.0-windows was computed. net8.0 was computed. net8.0-android was computed. net8.0-browser was computed. net8.0-ios was computed. net8.0-maccatalyst was computed. net8.0-macos was computed. net8.0-tvos was computed. net8.0-windows was computed. net9.0 was computed. net9.0-android was computed. net9.0-browser was computed. net9.0-ios was computed. net9.0-maccatalyst was computed. net9.0-macos was computed. net9.0-tvos was computed. net9.0-windows was computed. |
.NET Core | netcoreapp2.0 was computed. netcoreapp2.1 was computed. netcoreapp2.2 was computed. netcoreapp3.0 was computed. netcoreapp3.1 was computed. |
.NET Standard | netstandard2.0 is compatible. netstandard2.1 was computed. |
.NET Framework | net461 was computed. net462 was computed. net463 was computed. net47 was computed. net471 was computed. net472 was computed. net48 was computed. net481 was computed. |
MonoAndroid | monoandroid was computed. |
MonoMac | monomac was computed. |
MonoTouch | monotouch was computed. |
Tizen | tizen40 was computed. tizen60 was computed. |
Xamarin.iOS | xamarinios was computed. |
Xamarin.Mac | xamarinmac was computed. |
Xamarin.TVOS | xamarintvos was computed. |
Xamarin.WatchOS | xamarinwatchos was computed. |
-
.NETStandard 2.0
- GitHubApps (>= 1.2.1)
- Microsoft.AspNetCore.Http (>= 2.2.2)
- Microsoft.AspNetCore.Mvc (>= 2.2.0)
-
net6.0
- GitHubApps (>= 1.2.1)
- Microsoft.AspNetCore.Http (>= 2.2.2)
- Microsoft.AspNetCore.Mvc (>= 2.2.0)
NuGet packages
This package is not used by any NuGet packages.
GitHub repositories
This package is not used by any popular GitHub repositories.
Version | Downloads | Last updated |
---|---|---|
0.1.0-rc.1 | 190 | 11/11/2023 |