using System.Threading.Tasks; using Microsoft.AspNet.Mvc; using Microsoft.Extensions.Logging; using Microsoft.Extensions.OptionsModel; using Newtonsoft.Json; using Yavsc.Helpers; using Yavsc.Models; namespace Yavsc.ApiControllers { [Route("api/payment")] public class PaymentApiController : Controller { private ApplicationDbContext dbContext; private SiteSettings siteSettings; private readonly ILogger _logger; public PaymentApiController( ApplicationDbContext dbContext, IOptions siteSettingsReceiver, ILoggerFactory loggerFactory) { this.dbContext = dbContext; siteSettings = siteSettingsReceiver.Value; _logger = loggerFactory.CreateLogger(); } public async Task Info(string paymentId, string token) { var details = await dbContext.GetCheckoutInfo(token); _logger.LogInformation(JsonConvert.SerializeObject(details)); return Ok(details); } } }