DocumentoService.cs 3.1 KB

123456789101112131415161718192021222324252627282930313233343536373839404142434445464748495051525354555657585960616263646566676869707172737475767778798081828384858687888990919293949596979899100101102103104105106107
  1. using ConcursoProjetos.Data;
  2. using ConcursoProjetos.Domain.Entities;
  3. using Microsoft.CodeAnalysis;
  4. using Microsoft.EntityFrameworkCore;
  5. namespace ConcursoProjetos.Service;
  6. public interface IDocumentoService
  7. {
  8. Documento Gravar(Documento documento);
  9. bool Excluir(long documentoId);
  10. bool ExcluirPorProjetoTipoDocumento(long projetoId, long tipoDocumentoId, string projetoPath);
  11. Documento ObterPorId(long documentoId);
  12. IEnumerable<Documento> Listar(long projetoId);
  13. }
  14. public class DocumentoService : IDocumentoService
  15. {
  16. private readonly IDbContextFactory<ApplicationDbContext> _dbContextFactory;
  17. public DocumentoService(IDbContextFactory<ApplicationDbContext> dbContextFactory)
  18. {
  19. _dbContextFactory = dbContextFactory;
  20. }
  21. public Documento Gravar(Documento documento)
  22. {
  23. try
  24. {
  25. using var context = _dbContextFactory.CreateDbContext();
  26. var existingDocumento = context.Documento.Where(d => d.ProjetoId == documento.ProjetoId && d.TipoDocumentoId == documento.TipoDocumentoId).FirstOrDefault();
  27. if (existingDocumento != null)
  28. context.Documento.Remove(existingDocumento);
  29. context.Documento.Add(documento);
  30. context.SaveChanges();
  31. return documento;
  32. }
  33. catch (Exception ex)
  34. {
  35. return null;
  36. }
  37. }
  38. public bool Excluir(long documentoId)
  39. {
  40. using var context = _dbContextFactory.CreateDbContext();
  41. var documento = context.Documento.Find(documentoId);
  42. if (documento != null)
  43. {
  44. context.Documento.Remove(documento);
  45. context.SaveChanges();
  46. return true;
  47. }
  48. return false;
  49. }
  50. public Documento ObterPorId(long documentoId)
  51. {
  52. using var context = _dbContextFactory.CreateDbContext();
  53. return context.Documento.Find(documentoId);
  54. }
  55. public IEnumerable<Documento> Listar(long projetoId)
  56. {
  57. using var context = _dbContextFactory.CreateDbContext();
  58. return context.Documento
  59. .Include(d => d.TipoDocumento)
  60. .Where(d => d.ProjetoId == projetoId)
  61. .OrderBy(d => d.TipoDocumento.Nome)
  62. .ToList();
  63. }
  64. public bool ExcluirPorProjetoTipoDocumento(long projetoId, long tipoDocumentoId, string projetoPath)
  65. {
  66. using var context = _dbContextFactory.CreateDbContext();
  67. var documento = context.Documento.Where(d => d.ProjetoId == projetoId && d.TipoDocumentoId == tipoDocumentoId).SingleOrDefault() ;
  68. if (documento != null)
  69. {
  70. string filename = $"{projetoPath}\\{documento.ArquivoNomeOriginal}";
  71. if (File.Exists(filename))
  72. {
  73. try
  74. {
  75. File.Delete(filename);
  76. }
  77. catch (Exception ex)
  78. {
  79. return false;
  80. }
  81. }
  82. context.Documento.Remove(documento);
  83. context.SaveChanges();
  84. return true;
  85. }
  86. return true;
  87. }
  88. }