Apply cache configuration

This commit is contained in:
Oscar Morales
2025-06-06 10:22:07 -06:00
parent f5b5f7d0f0
commit 8207048c25
9 changed files with 64 additions and 45 deletions

View File

@@ -5,13 +5,15 @@
// ***********************************************************************
using Core.Thalos.Adapters;
using Core.Blueprint.Mongo;
using Core.Blueprint.Redis;
using Core.Blueprint.Redis.Helpers;
using Core.Blueprint.Caching;
using Core.Blueprint.Caching.Helpers;
using Mapster;
using Microsoft.Extensions.Options;
using MongoDB.Driver;
using Core.Thalos.Provider.Contracts;
using Core.Thalos.Domain.Contexts.Onboarding.Request;
using Core.Blueprint.Caching.Contracts;
using Core.Blueprint.Caching.Adapters;
namespace Core.Thalos.Provider.Providers.Onboarding
{
@@ -22,14 +24,16 @@ namespace Core.Thalos.Provider.Providers.Onboarding
{
private readonly CollectionRepository<ModuleAdapter> repository;
private readonly CacheSettings cacheSettings;
//private readonly IRedisCacheProvider cacheProvider;
private readonly ICacheProvider cacheProvider;
public ModuleProvider(CollectionRepository<ModuleAdapter> repository, IOptions<CacheSettings> cacheSettings)
public ModuleProvider(CollectionRepository<ModuleAdapter> repository,
ICacheProvider cacheProvider,
IOptions<CacheSettings> cacheSettings)
{
this.repository = repository;
this.repository.CollectionInitialization();
this.cacheSettings = cacheSettings.Value;
//this.cacheProvider = cacheProvider;
this.cacheProvider = cacheProvider;
}
/// <summary>
@@ -56,13 +60,13 @@ namespace Core.Thalos.Provider.Providers.Onboarding
public async ValueTask<ModuleAdapter> GetModuleById(string _id, CancellationToken cancellationToken)
{
var cacheKey = CacheKeyHelper.GenerateCacheKey(this, "GetModuleById", _id);
//var cachedData = await cacheProvider.GetAsync<ModuleAdapter>(cacheKey);
var cachedData = await cacheProvider.GetAsync<ModuleAdapter>(cacheKey);
//if (cachedData is not null) { return cachedData; }
if (cachedData is not null) { return cachedData; }
var module = await repository.FindByIdAsync(_id);
//await cacheProvider.SetAsync(cacheKey, module);
await cacheProvider.SetAsync(cacheKey, module);
return module;
}
@@ -75,13 +79,13 @@ namespace Core.Thalos.Provider.Providers.Onboarding
public async ValueTask<IEnumerable<ModuleAdapter>> GetAllModules(CancellationToken cancellationToken)
{
var cacheKey = CacheKeyHelper.GenerateCacheKey(this, "GetModules");
//var cachedData = await cacheProvider.GetAsync<IEnumerable<ModuleAdapter>>(cacheKey) ?? [];
var cachedData = await cacheProvider.GetAsync<IEnumerable<ModuleAdapter>>(cacheKey) ?? [];
//if (cachedData.Any()) return cachedData;
if (cachedData.Any()) return cachedData;
var modules = await repository.AsQueryable();
//await cacheProvider.SetAsync(cacheKey, modules);
await cacheProvider.SetAsync(cacheKey, modules);
return modules;
}
@@ -96,9 +100,9 @@ namespace Core.Thalos.Provider.Providers.Onboarding
{
var cacheKey = CacheKeyHelper.GenerateCacheKey(this, "GetAllModulesByList", modules);
//var cachedData = await cacheProvider.GetAsync<IEnumerable<ModuleAdapter>>(cacheKey) ?? [];
var cachedData = await cacheProvider.GetAsync<IEnumerable<ModuleAdapter>>(cacheKey) ?? [];
//if (cachedData.Any()) return cachedData;
if (cachedData.Any()) return cachedData;
var builder = Builders<ModuleAdapter>.Filter;
var filters = new List<FilterDefinition<ModuleAdapter>>();
@@ -112,7 +116,7 @@ namespace Core.Thalos.Provider.Providers.Onboarding
var modulesList = await repository.FilterByMongoFilterAsync(finalFilter);
//await cacheProvider.SetAsync(cacheKey, modulesList);
await cacheProvider.SetAsync(cacheKey, modulesList);
return modulesList;
}