Merged PR 129: Change and Delete messages
Change and Delete messages
This commit is contained in:
@@ -28,46 +28,6 @@ public class GetContentsByCreatorHandler(
|
|||||||
GetContentsByCreatorRequest req,
|
GetContentsByCreatorRequest req,
|
||||||
CancellationToken ct)
|
CancellationToken ct)
|
||||||
{
|
{
|
||||||
// var queryBuilder = new StringBuilder();
|
|
||||||
// queryBuilder.AppendLine($"""
|
|
||||||
// SELECT content."Id",
|
|
||||||
// content."CreatedBy",
|
|
||||||
// creator."Name" as CreatedByName,
|
|
||||||
// i."Logo" as CreatedByPortraitUrl,
|
|
||||||
// c."Menu" as ColorMenu,
|
|
||||||
// c."Accent" as ColorAccent,
|
|
||||||
// content."CreatedAt",
|
|
||||||
// content."DeletedBy",
|
|
||||||
// content."DeletedAt",
|
|
||||||
// content."Title",
|
|
||||||
// content."Description",
|
|
||||||
// content."Urls",
|
|
||||||
// FROM "Content"."Contents" AS content
|
|
||||||
// INNER JOIN "Content"."Creators" AS creator ON content."CreatedBy" = creator."Id"
|
|
||||||
// LEFT JOIN "Content"."Images" AS i ON creator."Id" = i."CreatorId"
|
|
||||||
// LEFT JOIN "Content"."Colors" AS c ON creator."Id" = c."CreatorId"
|
|
||||||
// WHERE content."CreatedBy" = '{req.CreatorId}'
|
|
||||||
// AND content."DeletedBy" IS NULL
|
|
||||||
// """);
|
|
||||||
//
|
|
||||||
// if (req.LastId.HasValue)
|
|
||||||
// {
|
|
||||||
// queryBuilder.AppendLine($"""AND content."Id" > '{req.LastId.Value}'""");
|
|
||||||
// }
|
|
||||||
//
|
|
||||||
// queryBuilder.AppendLine($"""
|
|
||||||
// ORDER BY content."CreatedAt" DESC
|
|
||||||
// LIMIT {req.PageSize}
|
|
||||||
// """);
|
|
||||||
//
|
|
||||||
// var query = queryBuilder.ToString();
|
|
||||||
//
|
|
||||||
// var results = await context
|
|
||||||
// .Database
|
|
||||||
// .SqlQueryRaw<ContentModel>(query)
|
|
||||||
// .ToListAsync(cancellationToken: ct);
|
|
||||||
|
|
||||||
|
|
||||||
var query = context.Contents
|
var query = context.Contents
|
||||||
.Where(c => c.CreatedBy == req.CreatorId && c.DeletedAt == null)
|
.Where(c => c.CreatedBy == req.CreatorId && c.DeletedAt == null)
|
||||||
.OrderByDescending(c => c.CreatedAt);
|
.OrderByDescending(c => c.CreatedAt);
|
||||||
|
|||||||
64
src/Web/Features/Messages/Handlers/ChangeMessage.cs
Normal file
64
src/Web/Features/Messages/Handlers/ChangeMessage.cs
Normal file
@@ -0,0 +1,64 @@
|
|||||||
|
using Hutopy.Web.Common;
|
||||||
|
using Hutopy.Web.Features.Messages.Data;
|
||||||
|
|
||||||
|
namespace Hutopy.Web.Features.Messages.Handlers;
|
||||||
|
|
||||||
|
public sealed class ChangeMessageRequest
|
||||||
|
{
|
||||||
|
public Guid? Id { get; set; }
|
||||||
|
public required Guid SubjectId { get; set; }
|
||||||
|
public required string Message { get; set; }
|
||||||
|
}
|
||||||
|
|
||||||
|
internal sealed class ChangeMessageRequestValidator
|
||||||
|
: Validator<ChangeMessageRequest>
|
||||||
|
{
|
||||||
|
public ChangeMessageRequestValidator()
|
||||||
|
{
|
||||||
|
RuleFor(r => r.SubjectId)
|
||||||
|
.NotNull().WithMessage("You must specify a SubjectId")
|
||||||
|
.NotEmpty().WithMessage("You must specify a non-empty SubjectId");
|
||||||
|
|
||||||
|
RuleFor(r => r.Message)
|
||||||
|
.NotNull().WithMessage("You must specify a Message")
|
||||||
|
.NotEmpty().WithMessage("You must specify a non-empty Message");
|
||||||
|
}
|
||||||
|
}
|
||||||
|
|
||||||
|
public class ChangeMessage(
|
||||||
|
MessagingDbContext context)
|
||||||
|
: Endpoint<ChangeMessageRequest>
|
||||||
|
{
|
||||||
|
public override void Configure()
|
||||||
|
{
|
||||||
|
Post("/api/messages/update");
|
||||||
|
Options(o => o.WithTags("Messages"));
|
||||||
|
}
|
||||||
|
|
||||||
|
public override async Task HandleAsync(
|
||||||
|
ChangeMessageRequest req,
|
||||||
|
CancellationToken ct)
|
||||||
|
{
|
||||||
|
var message = await context.Messages.FirstOrDefaultAsync(x => x.Id == req.Id, ct);
|
||||||
|
|
||||||
|
if (message is null)
|
||||||
|
{
|
||||||
|
await SendNotFoundAsync(ct);
|
||||||
|
return;
|
||||||
|
}
|
||||||
|
|
||||||
|
var userId = HttpContext.User.GetUserId();
|
||||||
|
if (message.CreatedBy != userId)
|
||||||
|
{
|
||||||
|
await SendForbiddenAsync(ct);
|
||||||
|
return;
|
||||||
|
}
|
||||||
|
|
||||||
|
message.SubjectId = req.SubjectId;
|
||||||
|
message.Value = req.Message;
|
||||||
|
|
||||||
|
context.Update(message);
|
||||||
|
|
||||||
|
await context.SaveChangesAsync(ct);
|
||||||
|
}
|
||||||
|
}
|
||||||
52
src/Web/Features/Messages/Handlers/DeleteMessage.cs
Normal file
52
src/Web/Features/Messages/Handlers/DeleteMessage.cs
Normal file
@@ -0,0 +1,52 @@
|
|||||||
|
using Hutopy.Web.Common;
|
||||||
|
using Hutopy.Web.Features.Messages.Data;
|
||||||
|
|
||||||
|
namespace Hutopy.Web.Features.Messages.Handlers;
|
||||||
|
|
||||||
|
public record DeleteMessageRequest(Guid MessageId);
|
||||||
|
|
||||||
|
internal sealed class DeleteMessageRequestValidator
|
||||||
|
: Validator<DeleteMessageRequest>
|
||||||
|
{
|
||||||
|
public DeleteMessageRequestValidator()
|
||||||
|
{
|
||||||
|
RuleFor(r => r.MessageId)
|
||||||
|
.NotNull().WithMessage("You must specify a MessageId")
|
||||||
|
.NotEmpty().WithMessage("You must specify a non-empty MessageId");
|
||||||
|
}
|
||||||
|
}
|
||||||
|
|
||||||
|
public class DeleteMessage(
|
||||||
|
MessagingDbContext context)
|
||||||
|
: Endpoint<DeleteMessageRequest>
|
||||||
|
{
|
||||||
|
public override void Configure()
|
||||||
|
{
|
||||||
|
Delete("/api/messages/{MessageId}");
|
||||||
|
Options(o => o.WithTags("Messages"));
|
||||||
|
}
|
||||||
|
|
||||||
|
public override async Task HandleAsync(
|
||||||
|
DeleteMessageRequest req,
|
||||||
|
CancellationToken ct)
|
||||||
|
{
|
||||||
|
var message = await context.Messages.FirstOrDefaultAsync(x => x.Id == req.MessageId, ct);
|
||||||
|
|
||||||
|
if (message is null)
|
||||||
|
{
|
||||||
|
await SendNotFoundAsync(ct);
|
||||||
|
return;
|
||||||
|
}
|
||||||
|
|
||||||
|
var userId = HttpContext.User.GetUserId();
|
||||||
|
if (message.CreatedBy != userId)
|
||||||
|
{
|
||||||
|
await SendForbiddenAsync(ct);
|
||||||
|
return;
|
||||||
|
}
|
||||||
|
|
||||||
|
context.Messages.Remove(message);
|
||||||
|
|
||||||
|
await context.SaveChangesAsync(ct);
|
||||||
|
}
|
||||||
|
}
|
||||||
Reference in New Issue
Block a user