File: AntiforgeryTokenSet.cs
Web Access
Project: src\src\Antiforgery\src\Microsoft.AspNetCore.Antiforgery.csproj (Microsoft.AspNetCore.Antiforgery)
// Licensed to the .NET Foundation under one or more agreements.
// The .NET Foundation licenses this file to you under the MIT license.
 
namespace Microsoft.AspNetCore.Antiforgery;
 
/// <summary>
/// The antiforgery token pair (cookie and request token) for a request.
/// </summary>
public class AntiforgeryTokenSet
{
    /// <summary>
    /// Creates the antiforgery token pair (cookie and request token) for a request.
    /// </summary>
    /// <param name="requestToken">The token that is supplied in the request.</param>
    /// <param name="cookieToken">The token that is supplied in the request cookie.</param>
    /// <param name="formFieldName">The name of the form field used for the request token.</param>
    /// <param name="headerName">The name of the header used for the request token.</param>
    public AntiforgeryTokenSet(
        string? requestToken,
        string? cookieToken,
        string formFieldName,
        string? headerName)
    {
        ArgumentNullException.ThrowIfNull(formFieldName);
 
        RequestToken = requestToken;
        CookieToken = cookieToken;
        FormFieldName = formFieldName;
        HeaderName = headerName;
    }
 
    /// <summary>
    /// Gets the request token.
    /// </summary>
    public string? RequestToken { get; }
 
    /// <summary>
    /// Gets the name of the form field used for the request token.
    /// </summary>
    public string FormFieldName { get; }
 
    /// <summary>
    /// Gets the name of the header used for the request token.
    /// </summary>
    public string? HeaderName { get; }
 
    /// <summary>
    /// Gets the cookie token.
    /// </summary>
    public string? CookieToken { get; }
}