using AutoMapper; using IdentityServer.Application.Commands; using IdentityServer.Application.Services; using IdentityServer.PublishedLanguage.Dto; using MediatR; using Microsoft.Extensions.Logging; using System.Threading; using System.Threading.Tasks; namespace IdentityServer.Application.CommandHandlers { public class AuthorizeTokenHandler : IRequestHandler { private readonly IUserService _userService; private readonly IMapper _mapper; private readonly ILogger _logger; public AuthorizeTokenHandler(IUserService userService, IMapper mapper, ILogger logger) { _userService = userService; _mapper = mapper; _logger = logger; } public Task Handle(AuthorizeToken command, CancellationToken cancellationToken) { var tokenCore = _userService.Authorize(command.Token); if (tokenCore == null) { _logger.LogDebug($"Authorization failed for token '{command.Token}'."); return null; } _logger.LogDebug($"Authorization succeeded for token '{command.Token}'."); var tokenCoreResult = _mapper.Map(tokenCore); return Task.FromResult(tokenCoreResult); } } }