Устранение ошибки внедрения зависимостей с помощью Mediatr и .NET Core 7 Minimal API

В настоящее время я получаю сообщение об ошибке, связанное с DI, когда пытаюсь запустить минимальное приложение API со следующими классами. Любая помощь будет принята с благодарностью.

Конечная точка

public static void DefineEndpoints(IEndpointRouteBuilder app)
{

        app.MapPost(BaseRoute, NewStoredFileTypeAsync)
            .WithTags(Tag);
    
    }
    
    private static async Task<Guid> NewStoredFileTypeAsync(NewStoredFileTypeDto request, IMediator mediator)
    {
        var messageId = new MessageId(Guid.NewGuid());
        var command = new NewStoredFileTypeCommand()
        {
            Id = messageId,
            CorrelationId = new CorrelationId(Guid.Parse(messageId.ToString())),
            CausationId = new CausationId(Guid.Parse(messageId.ToString())),
            CommandDto = request,
        };
    
        var response = await mediator.Send(command);
        return response;
    
    }

Команда

public class NewStoredFileTypeCommand : BaseCommand, IRequest\<Guid\>
{
    public NewStoredFileTypeDto CommandDto { get; set; } = default!;
}

Обработчик команд

public class NewStoredFileTypeCommandHandler : IRequestHandler\<NewStoredFileTypeCommand, Guid\>  
{  
private readonly IMapper \_mapper;  
private readonly IEventSourcingHandler\<StoredFileType, StoredFileTypeId\> \_eventSourcingHandler;

    public NewStoredFileTypeCommandHandler(IMapper mapper,                                                     
        IEventSourcingHandler<StoredFileType, StoredFileTypeId> eventSourcingHandler)                          
    {                                                                                                          
        _mapper = mapper;                                                                                      
        _eventSourcingHandler = eventSourcingHandler;                                                          
    }                                                                                                          
                                                                                                               
    public async Task<Guid> Handle(NewStoredFileTypeCommand request, CancellationToken cancellationToken)      
    {                                                                                                          
        var response = new BaseCommandResponse<StoredFileTypeId>();                                            
                                                                                                               
        var aggregate = new StoredFileType(                                                                    
            new StoredFileTypeId(Guid.NewGuid()),                                                              
            request.CorrelationId,                                                                             
            new CausationId(Guid.Parse(request.Id.ToString())),                                                
            request.CommandDto.Name, request.CommandDto.IsImageFileType,                                       
            _mapper.Map<BootstrapIconCode>(request.CommandDto.BootstrapIconCode)                               
            );                                                                                                 
                                                                                                               
        await _eventSourcingHandler.SaveAsync(aggregate);                                                      
        return Guid.Parse(aggregate.Id.ToString());                                                            
    }                                                                                                          

IMongoDbRepository

public interface IMongoDbRepository<TEntityId, TEntity> : IRepository<TEntityId, TEntity>
{
    
}

MongoDbRepository

public class MongoDbRepository<TObjectId, TEntity> : IMongoDbRepository<string, TEntity>
    where TEntity : IMongoDocument
{
    private readonly IMongoDbSettings _dbSettings;
    private readonly IMongoCollection<TEntity> _collection;
    
    public MongoDbRepository(IMongoDbSettings dbSettings)
    {
        _dbSettings = dbSettings;

        var connectionFactory = new MongoDbConnectionFactory<TEntity>(_dbSettings);
        _collection = connectionFactory.GetCollection();
    }


    public async Task<bool> InsertAsync(TEntity entity)
    {
        await _collection.InsertOneAsync(entity);
        return true;
    }

    public async Task<bool> UpdateAsync(TEntity entity)
    {
        throw new NotImplementedException();
    }

    public async Task<bool> DeleteAsync(TEntity entity)
    {
        throw new NotImplementedException();
    }

    public async Task<IList<TEntity>> SearchForAsync(Expression<Func<TEntity, bool>> predicate)
    {
        return await _collection.Find(predicate).ToListAsync();
    }

    public async Task<IList<TEntity>> GetAllAsync()
    {
        return await _collection.Find(_ => true).ToListAsync();
    }

    public async Task<TEntity> GetByIdAsync(string id)
    {
        throw new NotImplementedException();
    }
}

Регистрация репозитория MongoDb

public static IServiceCollection AddMongoDb(this IServiceCollection services, IConfiguration configuration)
    {
        //Get connection string from appsettings.json and population MongoDbSettings class
        services.Configure<MongoDbSettings>(configuration.GetSection(nameof(MongoDbSettings)));
        services.AddSingleton<IMongoDbSettings>(serviceProvider =>
            serviceProvider.GetRequiredService<IOptions<MongoDbSettings>>().Value);
        
        
        //Add generic repository
        services.AddScoped(typeof(IMongoDbRepository<,>), typeof(MongoDbRepository<,>));

        return services;
    }

Сообщение об ошибке

Необработанное исключение. System.AggregateException: некоторые службы не могут быть созданы (ошибка при проверке дескриптора службы «ServiceType: MediatR.IRequestHandler2[mNet.FileServer.Commands.Ui.MinimalApi.Features.StoredFileTypes.NewStoredFileType.NewStoredFileTypeCommand,System.Guid] Lifetime: Transient ImplementationType: mNet.FileServer.Commands.Ui.MinimalApi.Features.StoredFileTypes.NewStoredFileType.NewStoredFileTypeCommandHandler': Implementation type 'mNet.Common.Infrastructure.Persistence.MongoDbImplementation.MongoDbRepository2[mNet.FileServer.Commands.Domain.Aggregates.StoredFileTypes.ValueObjects.StoredFileTypeId,mNet.Common.Infrastructure. Persistence.MongoDbImplementation.MongoDbEventDocument`1[mNet.FileServer.Commands.Domain.Aggregates.StoredFileTypes.ValueObjects.StoredFileTypeId]]» не может быть преобразован в тип службы «mNet.Common.Infrastructure.Persistence.Contracts.Repositories.IMongoDbRepository`2 [mNet.FileServer.Commands.Domain.Aggregates.StoredFileTypes.ValueObjects.StoredFileTypeId,mNet.Common.Infrastructure.Persistence.MongoDbImplementation.MongoDbEventDocument`1[mNet.FileServer.Commands.Domain.Aggregates.StoredFileTypes.ValueObjects.StoredFileTypeId]]')

Все обращения к репозиториям осуществляются через интерфейсы, зарегистрированные как Scoped.

Не могли бы вы поделиться кодом для mNet.Common.Infrastructure.Persistence.MongoDbImplementation‌​.MongoDbRepository его интерфейса и регистрации?

Guru Stron 03.02.2023 11:31

Пожалуйста, обновите вопрос. И я попросил немного больше информации =)

Guru Stron 03.02.2023 12:50

Спасибо Гуру - я добавил другую информацию

dmeadley 03.02.2023 12:55
Стоит ли изучать PHP в 2023-2024 годах?
Стоит ли изучать PHP в 2023-2024 годах?
Привет всем, сегодня я хочу высказать свои соображения по поводу вопроса, который я уже много раз получал в своем сообществе: "Стоит ли изучать PHP в...
Поведение ключевого слова "this" в стрелочной функции в сравнении с нормальной функцией
Поведение ключевого слова "this" в стрелочной функции в сравнении с нормальной функцией
В JavaScript одним из самых запутанных понятий является поведение ключевого слова "this" в стрелочной и обычной функциях.
Приемы CSS-макетирования - floats и Flexbox
Приемы CSS-макетирования - floats и Flexbox
Здравствуйте, друзья-студенты! Готовы совершенствовать свои навыки веб-дизайна? Сегодня в нашем путешествии мы рассмотрим приемы CSS-верстки - в...
Тестирование функциональных ngrx-эффектов в Angular 16 с помощью Jest
В системе управления состояниями ngrx, совместимой с Angular 16, появились функциональные эффекты. Это здорово и делает код определенно легче для...
Концепция локализации и ее применение в приложениях React ⚡️
Концепция локализации и ее применение в приложениях React ⚡️
Локализация - это процесс адаптации приложения к различным языкам и культурным требованиям. Это позволяет пользователям получить опыт, соответствующий...
Пользовательский скаляр GraphQL
Пользовательский скаляр GraphQL
Листовые узлы системы типов GraphQL называются скалярами. Достигнув скалярного типа, невозможно спуститься дальше по иерархии типов. Скалярный тип...
2
3
55
1
Перейти к ответу Данный вопрос помечен как решенный

Ответы 1

Ответ принят как подходящий

Ваш MongoDbRepository неисправен - он не использует первый общий параметр и передает string как TEntityId для IMongoDbRepository:

public class MongoDbRepository<TObjectId, TEntity> : IMongoDbRepository<string, TEntity>

Измените его на:

public class MongoDbRepository<TObjectId, TEntity> : IMongoDbRepository<TObjectId, TEntity>

Возможно, вам также потребуется исправить некоторый код.

Супер - спасибо - это всегда мелочи!

dmeadley 03.02.2023 13:19

Другие вопросы по теме