James Tombleson
521940ca4f
* exposing connectionStrings to controllers * First controller added to start testing * corrected param to be page not age * new model to map connection strings to for the controllers * HelloWorldJob uses options now to make hangfire happy * improved the html reader to find some rss feeds and start to extract the body of the content * moved html parser to its own namespace and make a sub client to process theh header * helpful vsc changes * updated rss watcher to include the sourceId so it can be added to the db call * updated tests to reflect changes * updated gitignore to avoid trash and moved over my makefile * More routes and added serilog * adding more database calls for the controllers * Updated interfaces for the tables * Added Serilog to jobs * removed default files * Added more routes and added DTO * Added DTO objects and SourceType Consts for easy usage * updated discord model name to follow the pattern * updated formatting * new dto objects and Subscriptions repo interface * added subscription db and api calls * focusing on the twitter tags as most sites focus on them * updated test to pull a html based feed
65 lines
1.9 KiB
C#
65 lines
1.9 KiB
C#
using Microsoft.AspNetCore.Mvc;
|
|
using Microsoft.Extensions.Options;
|
|
using Newsbot.Collector.Database.Repositories;
|
|
using Newsbot.Collector.Domain.Dto;
|
|
using Newsbot.Collector.Domain.Interfaces;
|
|
using Newsbot.Collector.Domain.Models;
|
|
|
|
namespace Newsbot.Collector.Api.Controllers;
|
|
|
|
[ApiController]
|
|
[Route("api/articles")]
|
|
public class ArticlesController : ControllerBase
|
|
{
|
|
private readonly ILogger<ArticlesController> _logger;
|
|
private readonly ConnectionStrings _settings;
|
|
private readonly IArticlesRepository _articles;
|
|
private readonly ISourcesRepository _sources;
|
|
|
|
public ArticlesController(ILogger<ArticlesController> logger, IOptions<ConnectionStrings> settings)
|
|
{
|
|
_logger = logger;
|
|
_settings = settings.Value;
|
|
_articles = new ArticlesTable(_settings.Database);
|
|
_sources = new SourcesTable(_settings.Database);
|
|
}
|
|
|
|
[HttpGet(Name = "GetArticles")]
|
|
public IEnumerable<ArticleDto> Get()
|
|
{
|
|
var res = new List<ArticleDto>();
|
|
var items = _articles.List(0, 25);
|
|
foreach (var item in items)
|
|
{
|
|
res.Add(ArticleDto.Convert(item));
|
|
}
|
|
return res;
|
|
}
|
|
|
|
[HttpGet("{id}")]
|
|
public ArticleDto GetById(Guid id)
|
|
{
|
|
var item = _articles.GetById(id);
|
|
return ArticleDto.Convert(item);
|
|
}
|
|
|
|
[HttpGet("{id}/details")]
|
|
public ArticleDetailsDto GetDetailsById(Guid id)
|
|
{
|
|
var item = _articles.GetById(id);
|
|
var sourceItem = _sources.GetByID(item.SourceID);
|
|
return ArticleDetailsDto.Convert(item, sourceItem);
|
|
}
|
|
|
|
[HttpGet("by/{sourceid}")]
|
|
public IEnumerable<ArticleDto> GetBySourceID(Guid sourceid, int page = 0, int count = 25)
|
|
{
|
|
var res = new List<ArticleDto>();
|
|
var items = _articles.ListBySourceId(sourceid, page, count);
|
|
foreach (var item in items)
|
|
{
|
|
res.Add(ArticleDto.Convert(item));
|
|
}
|
|
return res;
|
|
}
|
|
} |