File: DefaultEndpointDataSource.cs
Web Access
Project: src\src\aspnetcore\src\Http\Routing\src\Microsoft.AspNetCore.Routing.csproj (Microsoft.AspNetCore.Routing)
// Licensed to the .NET Foundation under one or more agreements.
// The .NET Foundation licenses this file to you under the MIT license.

using System.Diagnostics;
using Microsoft.AspNetCore.Http;
using Microsoft.Extensions.FileProviders;
using Microsoft.Extensions.Primitives;

namespace Microsoft.AspNetCore.Routing;

/// <summary>
/// Provides a collection of <see cref="Endpoint"/> instances.
/// </summary>
[DebuggerDisplay("{DebuggerDisplayString,nq}")]
public sealed class DefaultEndpointDataSource : EndpointDataSource
{
    private readonly IReadOnlyList<Endpoint> _endpoints;

    /// <summary>
    /// Initializes a new instance of the <see cref="DefaultEndpointDataSource" /> class.
    /// </summary>
    /// <param name="endpoints">The <see cref="Endpoint"/> instances that the data source will return.</param>
    public DefaultEndpointDataSource(params Endpoint[] endpoints)
    {
        ArgumentNullException.ThrowIfNull(endpoints);

        _endpoints = (Endpoint[])endpoints.Clone();
    }

    /// <summary>
    /// Initializes a new instance of the <see cref="DefaultEndpointDataSource" /> class.
    /// </summary>
    /// <param name="endpoints">The <see cref="Endpoint"/> instances that the data source will return.</param>
    public DefaultEndpointDataSource(IEnumerable<Endpoint> endpoints)
    {
        ArgumentNullException.ThrowIfNull(endpoints);

        _endpoints = new List<Endpoint>(endpoints);
    }

    /// <summary>
    /// Gets a <see cref="IChangeToken"/> used to signal invalidation of cached <see cref="Endpoint"/>
    /// instances.
    /// </summary>
    /// <returns>The <see cref="IChangeToken"/>.</returns>
    public override IChangeToken GetChangeToken() => NullChangeToken.Singleton;

    /// <summary>
    /// Returns a read-only collection of <see cref="Endpoint"/> instances.
    /// </summary>
    public override IReadOnlyList<Endpoint> Endpoints => _endpoints;

    private string DebuggerDisplayString => GetDebuggerDisplayStringForEndpoints(_endpoints);
}