Merge pull request 'bar_branche' (#51) from bar_branche into master
continuous-integration/drone/push Build is passing Details

Reviewed-on: #51
pull/53/head
Alexis Drai 2 years ago
commit af57954b45

@ -7,6 +7,10 @@ using Microsoft.AspNetCore.Mvc;
using Microsoft.EntityFrameworkCore; using Microsoft.EntityFrameworkCore;
using cat_cafe.Entities; using cat_cafe.Entities;
using cat_cafe.Repositories; using cat_cafe.Repositories;
using AutoMapper;
using cat_cafe.Dto;
using System.Collections;
using System.Xml.Linq;
namespace cat_cafe.Controllers namespace cat_cafe.Controllers
{ {
@ -15,43 +19,63 @@ namespace cat_cafe.Controllers
public class BarsController : ControllerBase public class BarsController : ControllerBase
{ {
private readonly BarContext _context; private readonly BarContext _context;
private readonly IMapper _mapper;
private readonly ILogger <BarsController> _logger;
public BarsController(BarContext context) public BarsController(BarContext context,IMapper mapper, ILogger<BarsController> logger)
{ {
_context = context; _context = context;
_mapper = mapper;
_logger = logger;
} }
// GET: api/Bars // GET: api/Bars
[HttpGet] [HttpGet]
public async Task<ActionResult<IEnumerable<Bar>>> GetBars() public async Task<ActionResult<IEnumerable<BarDto>>> GetBars()
{ {
return await _context.Bars.ToListAsync(); var bars = _context.Bars
.Include(a => a.cats)
.Select(a => new Bar
{
Id = a.Id,
Name = a.Name,
cats = a.cats.Select(p => new Cat { Name = p.Name, Age = p.Age, Id= p.Id}).ToList()
})
.ToList();
return _mapper.Map<List<BarDto>>(bars);
} }
// GET: api/Bars/5 // GET: api/Bars/5
[HttpGet("{id}")] [HttpGet("{id}")]
public async Task<ActionResult<Bar>> GetBar(long id) public async Task<ActionResult<BarDto>> GetBar(long id)
{ {
var bar = await _context.Bars.FindAsync(id); var bar = _context.Bars.Include(p => p.cats)
.Select(a => new Bar
{
Id = a.Id,
Name = a.Name,
cats = a.cats.Select(p => new Cat { Name = p.Name, Age = p.Age, Id = p.Id }).ToList()
}).FirstOrDefaultAsync(p => p.Id == id);
if (bar == null) if (bar == null)
{ {
return NotFound(); return NotFound();
} }
return bar; return _mapper.Map<BarDto>(bar.Result);
} }
// PUT: api/Bars/5 // PUT: api/Bars/5
// To protect from overposting attacks, see https://go.microsoft.com/fwlink/?linkid=2123754 // To protect from overposting attacks, see https://go.microsoft.com/fwlink/?linkid=2123754
[HttpPut("{id}")] [HttpPut("{id}")]
public async Task<IActionResult> PutBar(long id, Bar bar) public async Task<IActionResult> PutBar(long id, BarDto barDto)
{ {
if (id != bar.Id) if (id != barDto.Id)
{ {
return BadRequest(); return BadRequest();
} }
Bar bar = _mapper.Map<Bar>(barDto);
_context.Entry(bar).State = EntityState.Modified; _context.Entry(bar).State = EntityState.Modified;
try try
@ -76,12 +100,16 @@ namespace cat_cafe.Controllers
// POST: api/Bars // POST: api/Bars
// To protect from overposting attacks, see https://go.microsoft.com/fwlink/?linkid=2123754 // To protect from overposting attacks, see https://go.microsoft.com/fwlink/?linkid=2123754
[HttpPost] [HttpPost]
public async Task<ActionResult<Bar>> PostBar(Bar bar) public async Task<ActionResult<BarDto>> PostBar(BarDto barDto)
{ {
// Bar bar = _mapper.Map<Bar>(barDto);
var bar = _mapper.Map<Bar>(barDto);
_context.Bars.Add(bar); _context.Bars.Add(bar);
await _context.SaveChangesAsync(); await _context.SaveChangesAsync();
return CreatedAtAction("GetBar", new { id = bar.Id }, bar); return CreatedAtAction("GetBar", new { id = barDto.Id }, _mapper.Map<BarDto>(bar));
} }
// DELETE: api/Bars/5 // DELETE: api/Bars/5

@ -0,0 +1,13 @@
using System;
using cat_cafe.Entities;
namespace cat_cafe.Dto
{
public class BarDto
{
public long Id { get; set; }
public string? Name { get; set; }
public List<CatDto> cats { get; set; } = new List<CatDto>();
}
}

@ -5,5 +5,6 @@ namespace cat_cafe.Dto
{ {
public long Id { get; set; } public long Id { get; set; }
public string? Name { get; set; } public string? Name { get; set; }
public int Age { get; set; }
} }
} }

@ -0,0 +1,18 @@
using System;
using AutoMapper;
using cat_cafe.Dto;
using cat_cafe.Entities;
namespace cat_cafe.Mappers
{
public class BarMapper:Profile
{
public BarMapper()
{
// var mapper = config.CreateMapper();
CreateMap<Bar, BarDto>().ReverseMap();
}
}
}

@ -0,0 +1,28 @@
2023-01-21 09:37:45.148 +01:00 [INF] program start
2023-01-28 08:16:52.320 +01:00 [INF] program start
2023-01-28 08:30:32.772 +01:00 [INF] program start
2023-01-28 08:31:51.147 +01:00 [INF] program start
2023-01-28 08:35:42.533 +01:00 [INF] program start
2023-01-28 08:37:29.403 +01:00 [INF] program start
2023-01-28 08:38:02.513 +01:00 [INF] program start
2023-01-28 08:38:24.151 +01:00 [INF] program start
2023-01-28 08:39:11.319 +01:00 [INF] program start
2023-01-28 08:54:25.005 +01:00 [INF] program start
2023-01-28 08:55:19.776 +01:00 [INF] program start
2023-01-28 08:57:05.150 +01:00 [INF] POST => post customer
2023-01-28 08:57:05.326 +01:00 [INF] POST => 201 cat_cafe.Entities.Customer {"Id":1,"FullName":"string","Age":0}
2023-01-28 08:57:13.908 +01:00 [INF] GET => get All customers
2023-01-28 08:57:13.997 +01:00 [INF] GET => 200 System.Collections.Generic.List`1[cat_cafe.Entities.Customer] length[1]
2023-01-28 08:58:25.856 +01:00 [INF] program start
2023-01-28 09:05:05.071 +01:00 [INF] program start
2023-01-28 09:13:54.542 +01:00 [INF] program start
2023-01-28 09:17:54.058 +01:00 [INF] program start
2023-01-28 09:24:15.797 +01:00 [INF] program start
2023-01-28 09:26:42.943 +01:00 [INF] program start
2023-01-28 09:31:25.523 +01:00 [INF] program start
2023-01-28 09:38:42.245 +01:00 [INF] program start
2023-01-28 09:40:40.846 +01:00 [INF] program start
2023-01-28 09:49:33.194 +01:00 [INF] program start
2023-01-28 09:52:36.098 +01:00 [INF] program start
2023-01-28 09:56:02.340 +01:00 [INF] program start
2023-01-28 09:57:05.155 +01:00 [INF] program start
Loading…
Cancel
Save