Created endpoints to managed messages
This commit is contained in:
@@ -1,3 +1,4 @@
|
|||||||
<wpf:ResourceDictionary xml:space="preserve" xmlns:x="http://schemas.microsoft.com/winfx/2006/xaml" xmlns:s="clr-namespace:System;assembly=mscorlib" xmlns:ss="urn:shemas-jetbrains-com:settings-storage-xaml" xmlns:wpf="http://schemas.microsoft.com/winfx/2006/xaml/presentation">
|
<wpf:ResourceDictionary xml:space="preserve" xmlns:x="http://schemas.microsoft.com/winfx/2006/xaml" xmlns:s="clr-namespace:System;assembly=mscorlib" xmlns:ss="urn:shemas-jetbrains-com:settings-storage-xaml" xmlns:wpf="http://schemas.microsoft.com/winfx/2006/xaml/presentation">
|
||||||
<s:String x:Key="/Default/CodeInspection/ExcludedFiles/FilesAndFoldersToSkip2/=7020124F_002D9FFC_002D4AC3_002D8F3D_002DAAB8E0240759_002Ff_003AIHubContext_00601_002Ecs_002Fl_003A_002E_002E_003F_002E_002E_003F_002E_002E_003FAppData_003FRoaming_003FJetBrains_003FRider2025_002E3_003Fresharper_002Dhost_003FDecompilerCache_003Fdecompiler_003F731dbe51d65849048244493644b992cd78910_003Fda_003Fd14ae6ee_003FIHubContext_00601_002Ecs/@EntryIndexedValue">ForceIncluded</s:String>
|
<s:String x:Key="/Default/CodeInspection/ExcludedFiles/FilesAndFoldersToSkip2/=7020124F_002D9FFC_002D4AC3_002D8F3D_002DAAB8E0240759_002Ff_003AIHubContext_00601_002Ecs_002Fl_003A_002E_002E_003F_002E_002E_003F_002E_002E_003FAppData_003FRoaming_003FJetBrains_003FRider2025_002E3_003Fresharper_002Dhost_003FDecompilerCache_003Fdecompiler_003F731dbe51d65849048244493644b992cd78910_003Fda_003Fd14ae6ee_003FIHubContext_00601_002Ecs/@EntryIndexedValue">ForceIncluded</s:String>
|
||||||
<s:String x:Key="/Default/CodeInspection/ExcludedFiles/FilesAndFoldersToSkip2/=7020124F_002D9FFC_002D4AC3_002D8F3D_002DAAB8E0240759_002Ff_003ARepositoryBaseOfT_002Ecs_002Fl_003A_002E_002E_003F_002E_002E_003F_002E_002E_003FAppData_003FRoaming_003FJetBrains_003FRider2025_002E2_003Fresharper_002Dhost_003FSourcesCache_003F5023b5be698d783ffe9f42b2e944a85a7a66b61bc5e19c76c591036343fd16_003FRepositoryBaseOfT_002Ecs/@EntryIndexedValue">ForceIncluded</s:String></wpf:ResourceDictionary>
|
<s:String x:Key="/Default/CodeInspection/ExcludedFiles/FilesAndFoldersToSkip2/=7020124F_002D9FFC_002D4AC3_002D8F3D_002DAAB8E0240759_002Ff_003ARepositoryBaseOfT_002Ecs_002Fl_003A_002E_002E_003F_002E_002E_003F_002E_002E_003FAppData_003FRoaming_003FJetBrains_003FRider2025_002E2_003Fresharper_002Dhost_003FSourcesCache_003F5023b5be698d783ffe9f42b2e944a85a7a66b61bc5e19c76c591036343fd16_003FRepositoryBaseOfT_002Ecs/@EntryIndexedValue">ForceIncluded</s:String>
|
||||||
|
<s:String x:Key="/Default/CodeInspection/ExcludedFiles/FilesAndFoldersToSkip2/=7020124F_002D9FFC_002D4AC3_002D8F3D_002DAAB8E0240759_002Ff_003ARepositoryBaseOfT_002Ecs_002Fl_003A_002E_002E_003F_002E_002E_003F_002E_002E_003FAppData_003FRoaming_003FJetBrains_003FRider2025_002E3_003Fresharper_002Dhost_003FSourcesCache_003F5023b5be698d783ffe9f42b2e944a85a7a66b61bc5e19c76c591036343fd16_003FRepositoryBaseOfT_002Ecs/@EntryIndexedValue">ForceIncluded</s:String></wpf:ResourceDictionary>
|
||||||
@@ -0,0 +1,8 @@
|
|||||||
|
namespace BeReadyBackend.DTO.Messages;
|
||||||
|
|
||||||
|
public class CreateMessageDto
|
||||||
|
{
|
||||||
|
public int GroupId { get; set; }
|
||||||
|
public string? Libelle { get; set; }
|
||||||
|
public DateTime SendDate { get; set; }
|
||||||
|
}
|
||||||
@@ -0,0 +1,35 @@
|
|||||||
|
using BeReadyBackend.Models;
|
||||||
|
using BeReadyBackend.Repositories;
|
||||||
|
using BeReadyBackend.Specifications.Messages;
|
||||||
|
using FastEndpoints;
|
||||||
|
|
||||||
|
namespace BeReadyBackend.Endpoints.Messages;
|
||||||
|
|
||||||
|
public class DeleteMessageRequest
|
||||||
|
{
|
||||||
|
public int Id { get; set; }
|
||||||
|
public int GroupId { get; set; }
|
||||||
|
}
|
||||||
|
|
||||||
|
public class DeleteMessageEndpoint(MessagesRepository messagesRepository) : Endpoint<DeleteMessageRequest>
|
||||||
|
{
|
||||||
|
public override void Configure()
|
||||||
|
{
|
||||||
|
Delete("/Messages/{@Id}/Groups/{@GroupId}/", x => new { x.Id, x.GroupId });
|
||||||
|
}
|
||||||
|
|
||||||
|
public override async Task HandleAsync(DeleteMessageRequest req, CancellationToken ct)
|
||||||
|
{
|
||||||
|
Message? message = await messagesRepository.SingleOrDefaultAsync(new GetMessageByIdSpec(req.Id), ct);
|
||||||
|
|
||||||
|
if (message is null)
|
||||||
|
{
|
||||||
|
await Send.NotFoundAsync(ct);
|
||||||
|
return;
|
||||||
|
}
|
||||||
|
|
||||||
|
await messagesRepository.DeleteAsync(message, ct);
|
||||||
|
await messagesRepository.SaveChangesAsync(ct);
|
||||||
|
await Send.OkAsync(ct);
|
||||||
|
}
|
||||||
|
}
|
||||||
@@ -0,0 +1,25 @@
|
|||||||
|
using BeReadyBackend.DTO.Messages;
|
||||||
|
using BeReadyBackend.Repositories;
|
||||||
|
using BeReadyBackend.Specifications.Messages;
|
||||||
|
using FastEndpoints;
|
||||||
|
|
||||||
|
namespace BeReadyBackend.Endpoints.Messages;
|
||||||
|
|
||||||
|
public class GetMessagesRequest
|
||||||
|
{
|
||||||
|
public int GroupId { get; set; }
|
||||||
|
}
|
||||||
|
|
||||||
|
public class GetMessagesEndpoint(MessagesRepository messagesRepository) : Endpoint<GetMessagesRequest, List<GetMessageDto>>
|
||||||
|
{
|
||||||
|
public override void Configure()
|
||||||
|
{
|
||||||
|
Post("/Messages/Groups/{@GroupId}/", x => new { x.GroupId });
|
||||||
|
}
|
||||||
|
|
||||||
|
public override async Task HandleAsync(GetMessagesRequest req, CancellationToken ct)
|
||||||
|
{
|
||||||
|
List<GetMessageDto> messages = await messagesRepository.ProjectToListAsync<GetMessageDto>(new GetMessageByGroupIdSpec(req.GroupId), ct);
|
||||||
|
await Send.OkAsync(messages, ct);
|
||||||
|
}
|
||||||
|
}
|
||||||
@@ -0,0 +1,32 @@
|
|||||||
|
using BeReadyBackend.DTO.Messages;
|
||||||
|
using BeReadyBackend.Hubs;
|
||||||
|
using BeReadyBackend.Models;
|
||||||
|
using BeReadyBackend.Repositories;
|
||||||
|
using BeReadyBackend.Services;
|
||||||
|
using FastEndpoints;
|
||||||
|
using Microsoft.AspNetCore.SignalR;
|
||||||
|
|
||||||
|
namespace BeReadyBackend.Endpoints.Messages;
|
||||||
|
|
||||||
|
public class SendMessageEndpoint(UserService userService, AutoMapper.IMapper mapper, MessagesRepository messagesRepository, IHubContext<GroupHub> hubContext)
|
||||||
|
: Endpoint<CreateMessageDto>
|
||||||
|
{
|
||||||
|
public override void Configure()
|
||||||
|
{
|
||||||
|
Post("/Messages/Groups/{@GroupId}/", x => new { x.GroupId });
|
||||||
|
}
|
||||||
|
|
||||||
|
public override async Task HandleAsync(CreateMessageDto req, CancellationToken ct)
|
||||||
|
{
|
||||||
|
Message message = new();
|
||||||
|
mapper.Map(req, message);
|
||||||
|
message.UserId = userService.GetUserIdFromToken();
|
||||||
|
|
||||||
|
await messagesRepository.AddAsync(message, ct);
|
||||||
|
await messagesRepository.SaveChangesAsync(ct);
|
||||||
|
|
||||||
|
await hubContext.Clients.Group($"group-{req.GroupId}").SendAsync("ReceiveMessage", message, cancellationToken: ct);
|
||||||
|
|
||||||
|
await Send.OkAsync(ct);
|
||||||
|
}
|
||||||
|
}
|
||||||
@@ -1,6 +1,7 @@
|
|||||||
using AutoMapper;
|
using AutoMapper;
|
||||||
using BeReadyBackend.DTO.Achievements;
|
using BeReadyBackend.DTO.Achievements;
|
||||||
using BeReadyBackend.DTO.Groups;
|
using BeReadyBackend.DTO.Groups;
|
||||||
|
using BeReadyBackend.DTO.Messages;
|
||||||
using BeReadyBackend.DTO.Users;
|
using BeReadyBackend.DTO.Users;
|
||||||
using BeReadyBackend.Models;
|
using BeReadyBackend.Models;
|
||||||
|
|
||||||
@@ -18,5 +19,7 @@ public class DtoToEntityMappings : Profile
|
|||||||
|
|
||||||
CreateMap<CreateGroupDto, Group>()
|
CreateMap<CreateGroupDto, Group>()
|
||||||
.ForMember(dest => dest.UserGroups, opt => opt.Ignore());
|
.ForMember(dest => dest.UserGroups, opt => opt.Ignore());
|
||||||
|
|
||||||
|
CreateMap<CreateMessageDto, Message>();
|
||||||
}
|
}
|
||||||
}
|
}
|
||||||
@@ -5,7 +5,6 @@ using BeReadyBackend.DTO.Groups;
|
|||||||
using BeReadyBackend.DTO.Messages;
|
using BeReadyBackend.DTO.Messages;
|
||||||
using BeReadyBackend.DTO.Users;
|
using BeReadyBackend.DTO.Users;
|
||||||
using BeReadyBackend.Models;
|
using BeReadyBackend.Models;
|
||||||
using NSwag.Generation.Processors;
|
|
||||||
|
|
||||||
namespace BeReadyBackend.MappingProfiles;
|
namespace BeReadyBackend.MappingProfiles;
|
||||||
|
|
||||||
|
|||||||
@@ -0,0 +1,13 @@
|
|||||||
|
using Ardalis.Specification;
|
||||||
|
using BeReadyBackend.Models;
|
||||||
|
|
||||||
|
namespace BeReadyBackend.Specifications.Messages;
|
||||||
|
|
||||||
|
public class GetMessageByGroupIdSpec : Specification<Message>
|
||||||
|
{
|
||||||
|
public GetMessageByGroupIdSpec(int groupId)
|
||||||
|
{
|
||||||
|
Query
|
||||||
|
.Where(x => x.GroupId == groupId);
|
||||||
|
}
|
||||||
|
}
|
||||||
@@ -0,0 +1,13 @@
|
|||||||
|
using Ardalis.Specification;
|
||||||
|
using BeReadyBackend.Models;
|
||||||
|
|
||||||
|
namespace BeReadyBackend.Specifications.Messages;
|
||||||
|
|
||||||
|
public class GetMessageByIdSpec : SingleResultSpecification<Message>
|
||||||
|
{
|
||||||
|
public GetMessageByIdSpec(int id)
|
||||||
|
{
|
||||||
|
Query
|
||||||
|
.Where(x => x.Id == id);
|
||||||
|
}
|
||||||
|
}
|
||||||
Reference in New Issue
Block a user