Files
OwinOAuthProviders/Owin.Security.Providers/Backlog/Provider/BacklogAuthenticationProvider.cs
2015-07-23 19:28:17 +09:00

50 lines
2.1 KiB
C#

using System;
using System.Threading.Tasks;
namespace Owin.Security.Providers.Backlog
{
/// <summary>
/// Default <see cref="IBacklogAuthenticationProvider"/> implementation.
/// </summary>
public class BacklogAuthenticationProvider : IBacklogAuthenticationProvider
{
/// <summary>
/// Initializes a <see cref="BacklogAuthenticationProvider"/>
/// </summary>
public BacklogAuthenticationProvider()
{
OnAuthenticated = context => Task.FromResult<object>(null);
OnReturnEndpoint = context => Task.FromResult<object>(null);
}
/// <summary>
/// Gets or sets the function that is invoked when the Authenticated method is invoked.
/// </summary>
public Func<BacklogAuthenticatedContext, Task> OnAuthenticated { get; set; }
/// <summary>
/// Gets or sets the function that is invoked when the ReturnEndpoint method is invoked.
/// </summary>
public Func<BacklogReturnEndpointContext, Task> OnReturnEndpoint { get; set; }
/// <summary>
/// Invoked whenever Google+ succesfully authenticates a user
/// </summary>
/// <param name="context">Contains information about the login session as well as the user <see cref="System.Security.Claims.ClaimsIdentity"/>.</param>
/// <returns>A <see cref="Task"/> representing the completed operation.</returns>
public virtual Task Authenticated(BacklogAuthenticatedContext context)
{
return OnAuthenticated(context);
}
/// <summary>
/// Invoked prior to the <see cref="System.Security.Claims.ClaimsIdentity"/> being saved in a local cookie and the browser being redirected to the originally requested URL.
/// </summary>
/// <param name="context"></param>
/// <returns>A <see cref="Task"/> representing the completed operation.</returns>
public virtual Task ReturnEndpoint(BacklogReturnEndpointContext context)
{
return OnReturnEndpoint(context);
}
}
}