92 lines
3.5 KiB
C#
92 lines
3.5 KiB
C#
using AS1024.GeoFeed.Core.CacheService;
|
|
using AS1024.GeoFeed.Core.GeoFeedPreloader;
|
|
using AS1024.GeoFeed.Core.Interfaces;
|
|
using AS1024.GeoFeed.Core.Tools;
|
|
using AS1024.GeoFeed.Models;
|
|
using Microsoft.Extensions.Caching.Memory;
|
|
using System.Text;
|
|
|
|
namespace AS1024.GeoFeed.MinimalAPI
|
|
{
|
|
public class Program
|
|
{
|
|
|
|
public static void Main(string[] args)
|
|
{
|
|
var builder = WebApplication.CreateSlimBuilder(args);
|
|
builder.Services.AddTransient<IGeoFeedProvider, NetboxAoTGeoFeedProvider>();
|
|
builder.Services.AddHostedService<GeoFeedCacheService>();
|
|
builder.Services.AddHostedService<PreLoadGeoFeed>();
|
|
builder.Services.AddTransient<IGeoFeedPersistentCacheProvider, GeoFeedLocalFileCache>();
|
|
builder.Services.AddMemoryCache();
|
|
builder.Services.AddLogging();
|
|
builder.Services.AddHttpClient();
|
|
builder.Services.ConfigureHttpJsonOptions(options => {
|
|
options.SerializerOptions.TypeInfoResolverChain.Insert(0, AppJsonSerializerContext.Default);
|
|
});
|
|
var app = builder.Build();
|
|
|
|
app.Map("/geofeed.csv", async (IGeoFeedProvider provider,
|
|
ILogger<Program> logger,
|
|
IGeoFeedPersistentCacheProvider cacheProvider,
|
|
IMemoryCache memoryCache,
|
|
IWebHostEnvironment environment) => {
|
|
return await GeoFeedDataRunner(provider, logger, cacheProvider, memoryCache, environment);
|
|
});
|
|
|
|
app.Map("/geofeed", async (IGeoFeedProvider provider,
|
|
ILogger<Program> logger,
|
|
IGeoFeedPersistentCacheProvider cacheProvider,
|
|
IMemoryCache memoryCache,
|
|
IWebHostEnvironment environment) => {
|
|
return await GeoFeedDataRunner(provider, logger, cacheProvider, memoryCache, environment);
|
|
});
|
|
|
|
app.Run();
|
|
}
|
|
|
|
protected static async Task<IResult> GeoFeedDataRunner(IGeoFeedProvider provider,
|
|
ILogger<Program> logger,
|
|
IGeoFeedPersistentCacheProvider cacheProvider,
|
|
IMemoryCache memoryCache,
|
|
IWebHostEnvironment environment)
|
|
{
|
|
bool isCached = true;
|
|
try
|
|
{
|
|
if (!memoryCache.TryGetValue("GeoFeedData", out List<IPGeoFeed>? feed))
|
|
{
|
|
isCached = false;
|
|
feed = await provider.GetGeoFeedData();
|
|
if (environment.IsProduction())
|
|
{
|
|
MemoryCacheEntryOptions cacheEntryOptions = new MemoryCacheEntryOptions()
|
|
.SetSlidingExpiration(TimeSpan.FromMinutes(15));
|
|
memoryCache.Set("GeoFeedData", feed, cacheEntryOptions);
|
|
}
|
|
}
|
|
|
|
return Results.File(Encoding.UTF8.GetBytes(feed.ToGeoFeedCsv(true, isCached)),
|
|
"text/csv",
|
|
"geofeed.csv");
|
|
|
|
}
|
|
catch (HttpRequestException ex)
|
|
{
|
|
logger.LogWarning($"Temporary failure of retrieving GeoData from upstream. {ex}");
|
|
string geoFeedData = cacheProvider.GetGeoFeed();
|
|
|
|
return Results.File(Encoding.UTF8.GetBytes(geoFeedData),
|
|
"text/csv",
|
|
"geofeed.csv");
|
|
}
|
|
catch (Exception ex)
|
|
{
|
|
logger.LogError($"Error: {ex}");
|
|
}
|
|
|
|
return Results.NoContent();
|
|
}
|
|
}
|
|
}
|