mirror of
https://github.com/fergalmoran/podnoms.git
synced 2025-12-25 18:58:12 +00:00
Merge Repos
This commit is contained in:
95
server/Controllers/EntryController.cs
Normal file
95
server/Controllers/EntryController.cs
Normal file
@@ -0,0 +1,95 @@
|
||||
using System;
|
||||
using System.Collections.Generic;
|
||||
using System.IO;
|
||||
using System.Linq;
|
||||
using System.Threading.Tasks;
|
||||
using AutoMapper;
|
||||
using Hangfire;
|
||||
using Microsoft.AspNetCore.Mvc;
|
||||
using Microsoft.Extensions.Logging;
|
||||
using Microsoft.Extensions.Options;
|
||||
using PodNoms.Api.Models;
|
||||
using PodNoms.Api.Models.ViewModels;
|
||||
using PodNoms.Api.Persistence;
|
||||
using PodNoms.Api.Services.Processor;
|
||||
using PodNoms.Api.Services.Storage;
|
||||
|
||||
namespace PodNoms.Api.Controllers
|
||||
{
|
||||
[Route("[controller]")]
|
||||
public class EntryController : Controller
|
||||
{
|
||||
private readonly IPodcastRepository _podcastRepository;
|
||||
private readonly IEntryRepository _repository;
|
||||
private readonly IUnitOfWork _uow;
|
||||
private readonly IMapper _mapper;
|
||||
private readonly IUrlProcessService _processor;
|
||||
private readonly ILogger _logger;
|
||||
private readonly AudioFileStorageSettings _audioFileStorageSettings;
|
||||
|
||||
public EntryController(IEntryRepository repository,
|
||||
IPodcastRepository podcastRepository,
|
||||
IUnitOfWork unitOfWork, IMapper mapper,
|
||||
IOptions<AudioFileStorageSettings> audioFileStorageSettings,
|
||||
IUrlProcessService processor, ILoggerFactory logger)
|
||||
{
|
||||
this._logger = logger.CreateLogger<EntryController>();
|
||||
this._podcastRepository = podcastRepository;
|
||||
this._repository = repository;
|
||||
this._uow = unitOfWork;
|
||||
this._audioFileStorageSettings = audioFileStorageSettings.Value;
|
||||
this._mapper = mapper;
|
||||
this._processor = processor;
|
||||
}
|
||||
|
||||
private void _processEntry(PodcastEntry entry)
|
||||
{
|
||||
try
|
||||
{
|
||||
var infoJobId = BackgroundJob.Enqueue<IUrlProcessService>(service => service.GetInformation(entry.Id));
|
||||
var extract = BackgroundJob.ContinueWith<IUrlProcessService>(infoJobId, service => service.DownloadAudio(entry.Id));
|
||||
var upload = BackgroundJob.ContinueWith<IAudioUploadProcessService>(extract, service => service.UploadAudio(entry.Id));
|
||||
}
|
||||
catch (InvalidOperationException ex)
|
||||
{
|
||||
_logger.LogError($"Failed submitting job to processor\n{ex.Message}");
|
||||
entry.ProcessingStatus = ProcessingStatus.Failed;
|
||||
}
|
||||
}
|
||||
[HttpGet("all/{podcastSlug}")]
|
||||
public async Task<IEnumerable<PodcastEntryViewModel>> GetAllForSlug(string podcastSlug)
|
||||
{
|
||||
var entries = await _repository.GetAllAsync(podcastSlug);
|
||||
return _mapper.Map<List<PodcastEntry>, List<PodcastEntryViewModel>>(entries.ToList());
|
||||
}
|
||||
|
||||
[HttpPost]
|
||||
public async Task<IActionResult> Post([FromBody] PodcastEntryViewModel item)
|
||||
{
|
||||
var entry = _mapper.Map<PodcastEntryViewModel, PodcastEntry>(item);
|
||||
if (entry.ProcessingStatus == ProcessingStatus.Accepted)
|
||||
{
|
||||
var podcast = await _podcastRepository.GetAsync(item.PodcastId);
|
||||
entry.Podcast = podcast;
|
||||
entry.Processed = false;
|
||||
}
|
||||
await _repository.AddOrUpdateAsync(entry);
|
||||
await _uow.CompleteAsync();
|
||||
|
||||
if (entry.ProcessingStatus.Equals(ProcessingStatus.Accepted) && entry.Id != 0)
|
||||
{
|
||||
_processEntry(entry);
|
||||
}
|
||||
var result = _mapper.Map<PodcastEntry, PodcastEntryViewModel>(entry);
|
||||
return Ok(result);
|
||||
}
|
||||
|
||||
[HttpDelete("{id}")]
|
||||
public async Task<IActionResult> Delete(int id)
|
||||
{
|
||||
await this._repository.DeleteAsync(id);
|
||||
await _uow.CompleteAsync();
|
||||
return Ok();
|
||||
}
|
||||
}
|
||||
}
|
||||
Reference in New Issue
Block a user