fix: Result & DTOs for GetById + cleanup

This commit is contained in:
2026-03-16 21:30:58 +01:00
parent 4b99e238ca
commit 5794c3fbb5
6 changed files with 42 additions and 28 deletions

View File

@@ -32,23 +32,4 @@ public sealed class FailureResult<T> : Result<T>
Error = error ?? throw new ArgumentNullException(nameof(error));
}
}
/*
private Result(bool success, T? value, string? error)
{
Success = success;
Value = value;
Error = error;
}
}
public static Result<T> Ok(T value)
=> new(true,value,null);
public static Result<T> Fail(string error)
=> new(false, default, error);
}
*/
}

View File

@@ -16,3 +16,12 @@ public class CreateTicketResponse
public string Title{get;set;} = "";
public string Description{get;set;} = "";
}
public class TicketResponse
{
public Guid Id {get;set;}
public string Title{get;set;} = "";
public string Description{get;set;} = "";
}

View File

@@ -9,6 +9,6 @@ public interface ITicketService
//TODO: implement Repository
IEnumerable<TicketResponse> GetAll();
Ticket? GetById(Guid id);
Result<TicketResponse> GetById(Guid id);
Result<CreateTicketResponse> Create(CreateTicketRequest request);
}

View File

@@ -1,5 +1,7 @@
using System.Runtime.CompilerServices;
using System.Runtime.ExceptionServices;
using Microsoft.AspNetCore.Http.HttpResults;
using Microsoft.Extensions.ObjectPool;
using TicketAppIncrArchi.Application.DTO;
using TicketAppIncrArchi.Application.Interfaces;
using TicketAppIncrArchi.Domain.Entities;
@@ -23,9 +25,24 @@ public class TicketService : ITicketService
}
public Ticket? GetById(Guid id)
public Result<TicketResponse> GetById(Guid id)
{
return _tickets.FirstOrDefault(ticket => ticket.Id == id);
//TODO: should use result
var found = _tickets.FirstOrDefault(ticket => ticket.Id == id);
if (found == null)
{
return Result<TicketResponse>.Fail("No Ticket Found");
}
var ticketResponse = new TicketResponse
{
Id = found.Id,
Title = found.Title,
Description = found.Description,
};
return Result<TicketResponse>.Ok(found);
}
public Result<CreateTicketResponse> Create(CreateTicketRequest request)
@@ -44,14 +61,14 @@ public class TicketService : ITicketService
//send creation to repo
_tickets.Add(ticket);
var response = new CreateTicketResponse
var ticketResponse = new CreateTicketResponse
{
Id = ticket.Id,
Title = ticket.Title,
Description = ticket.Description
};
return Result<CreateTicketResponse>.Ok(response);
return Result<CreateTicketResponse>.Ok(ticketResponse);
}