You can not select more than 25 topics Topics must start with a letter or number, can include dashes ('-') and can be up to 35 characters long.
sae_2a_anglais/Project/EntityFramework/DTOToEntity/TranslateService.cs

98 lines
3.2 KiB

using DTO;
using Microsoft.EntityFrameworkCore;
using StubbedContextLib;
using System;
using System.Collections.Generic;
using System.Linq;
using System.Text;
using System.Threading.Tasks;
namespace DTOToEntity
{
public class TranslateService : ITranslateService
{
private readonly StubbedContext _context = new StubbedContext();
public TranslateService() { }
public TranslateService(StubbedContext context)
{
_context = context;
}
public async Task<TranslateDTO> Add(TranslateDTO translate)
{
var translateEntity = translate.ToEntity();
_context.Translates.Add(translateEntity);
await _context.SaveChangesAsync();
return translateEntity.ToDTO();
}
public async Task<VocabularyDTO> AddVocabToTranslate(string vocabId, long translateId)
{
var vocab = _context.Vocabularys.Find(vocabId);
if (vocab == null)
{
throw new Exception("Vocabulary not found");
}
var translate = _context.Translates.Find(translateId);
if (translate == null)
{
throw new Exception("Translate not found");
}
translate.TransVoc.Add(vocab);
await _context.SaveChangesAsync();
return vocab.ToDTO();
}
public async Task<TranslateDTO> Delete(object id)
{
var translate = await _context.Translates.FirstOrDefaultAsync(t => t.Id == (int)id);
if (translate != null)
{
_context.Translates.Remove(translate);
await _context.SaveChangesAsync();
}
else
{
throw new Exception("Translate not found");
}
return translate.ToDTO();
}
public async Task<TranslateDTO> GetById(object id)
{
var translate = await _context.Translates.FirstOrDefaultAsync(t => t.Id == (int)id);
if (translate == null)
{
throw new Exception("Translate not found");
}
return translate.ToDTO();
}
public async Task<PageResponse<TranslateDTO>> Gets(int index, int count)
{
var translates = await _context.Translates.Skip(index * count).Take(count).ToListAsync();
if(translates == null)
{
throw new Exception("No translates found");
}
return new PageResponse<TranslateDTO>( translates.Select(t => t.ToDTO()), _context.Translates.Count());
}
public async Task<TranslateDTO> Update(TranslateDTO translate)
{
var translateEntity = await _context.Translates.FirstOrDefaultAsync(t => t.Id == translate.Id);
if (translateEntity == null)
{
throw new Exception("Translate not found");
}
translateEntity.WordsId = translate.WordsId;
translateEntity.VocabularyListVocId = translate.VocabularyListVocId;
_context.Translates.Update(translateEntity);
await _context.SaveChangesAsync();
return translateEntity.ToDTO();
}
}
}