From 4049e9ff78cdd8fe3559d3fc1839088e09f9b650 Mon Sep 17 00:00:00 2001 From: Aram Date: Sun, 27 Oct 2024 23:57:22 +0400 Subject: [PATCH] Refactor user interaction interfaces --- src/Argon.Contracts/IUserInteraction.cs | 175 ++++++++++++++++++------ 1 file changed, 132 insertions(+), 43 deletions(-) diff --git a/src/Argon.Contracts/IUserInteraction.cs b/src/Argon.Contracts/IUserInteraction.cs index 98363e98..5c9e6635 100644 --- a/src/Argon.Contracts/IUserInteraction.cs +++ b/src/Argon.Contracts/IUserInteraction.cs @@ -7,65 +7,154 @@ namespace Argon.Contracts; public interface IUserInteraction : IRpcService { - Task GetMe(string username); - Task CreateServer(string username, CreateServerRequest request); - Task> GetServers(string username); + Task GetMe(); + Task CreateServer(CreateServerRequest request); + Task> GetServers(); - Task> GetServerDetails(string username); + Task> GetServerDetails(); // Task CreateChannel(string username); - Task JoinChannel(string username, ChannelJoinRequest request); + Task JoinChannel(ChannelJoinRequest request); } -[DataContract, MemoryPackable(GenerateType.VersionTolerant), MessagePackObject] +[DataContract] +[MemoryPackable(GenerateType.VersionTolerant)] +[MessagePackObject] public sealed partial record UserResponse( - [property: DataMember(Order = 0), MemoryPackOrder(0), Key(0)] Guid Id, - [property: DataMember(Order = 1), MemoryPackOrder(1), Key(1)] string Username, - [property: DataMember(Order = 2), MemoryPackOrder(2), Key(2)] string AvatarUrl, - [property: DataMember(Order = 3), MemoryPackOrder(3), Key(3)] DateTime CreatedAt, - [property: DataMember(Order = 4), MemoryPackOrder(4), Key(4)] DateTime UpdatedAt + [property: DataMember(Order = 0)] + [property: MemoryPackOrder(0)] + [property: Key(0)] + Guid Id, + [property: DataMember(Order = 1)] + [property: MemoryPackOrder(1)] + [property: Key(1)] + string Username, + [property: DataMember(Order = 2)] + [property: MemoryPackOrder(2)] + [property: Key(2)] + string AvatarUrl, + [property: DataMember(Order = 3)] + [property: MemoryPackOrder(3)] + [property: Key(3)] + DateTime CreatedAt, + [property: DataMember(Order = 4)] + [property: MemoryPackOrder(4)] + [property: Key(4)] + DateTime UpdatedAt ); -[DataContract, MemoryPackable(GenerateType.VersionTolerant), MessagePackObject] +[DataContract] +[MemoryPackable(GenerateType.VersionTolerant)] +[MessagePackObject] public sealed partial record CreateServerRequest( - [property: DataMember(Order = 0), MemoryPackOrder(0), Key(0)] string Name, - [property: DataMember(Order = 1), MemoryPackOrder(1), Key(1)] string Description, - [property: DataMember(Order = 2), MemoryPackOrder(2), Key(2)] string AvatarUrl - ); + [property: DataMember(Order = 0)] + [property: MemoryPackOrder(0)] + [property: Key(0)] + string Name, + [property: DataMember(Order = 1)] + [property: MemoryPackOrder(1)] + [property: Key(1)] + string Description, + [property: DataMember(Order = 2)] + [property: MemoryPackOrder(2)] + [property: Key(2)] + string AvatarUrl +); -[DataContract, MemoryPackable(GenerateType.VersionTolerant), MessagePackObject] +[DataContract] +[MemoryPackable(GenerateType.VersionTolerant)] +[MessagePackObject] public sealed partial record ServerResponse( - [property: DataMember(Order = 0), MemoryPackOrder(0), Key(0)] Guid Id, - [property: DataMember(Order = 1), MemoryPackOrder(1), Key(1)] string Name, - [property: DataMember(Order = 2), MemoryPackOrder(2), Key(2)] string Description, - [property: DataMember(Order = 3), MemoryPackOrder(3), Key(3)] string AvatarUrl, - [property: DataMember(Order = 4), MemoryPackOrder(4), Key(4)] List Channels, - [property: DataMember(Order = 5), MemoryPackOrder(5), Key(5)] DateTime CreatedAt, - [property: DataMember(Order = 6), MemoryPackOrder(6), Key(6)] DateTime UpdatedAt + [property: DataMember(Order = 0)] + [property: MemoryPackOrder(0)] + [property: Key(0)] + Guid Id, + [property: DataMember(Order = 1)] + [property: MemoryPackOrder(1)] + [property: Key(1)] + string Name, + [property: DataMember(Order = 2)] + [property: MemoryPackOrder(2)] + [property: Key(2)] + string Description, + [property: DataMember(Order = 3)] + [property: MemoryPackOrder(3)] + [property: Key(3)] + string AvatarUrl, + [property: DataMember(Order = 4)] + [property: MemoryPackOrder(4)] + [property: Key(4)] + List Channels, + [property: DataMember(Order = 5)] + [property: MemoryPackOrder(5)] + [property: Key(5)] + DateTime CreatedAt, + [property: DataMember(Order = 6)] + [property: MemoryPackOrder(6)] + [property: Key(6)] + DateTime UpdatedAt // TODO: all users of the server with their statuses(online/offline/in channel) - ); +); -[DataContract, MemoryPackable(GenerateType.VersionTolerant), MessagePackObject] +[DataContract] +[MemoryPackable(GenerateType.VersionTolerant)] +[MessagePackObject] public sealed partial record ServerDetailsResponse( - [property: DataMember(Order = 0), MemoryPackOrder(0), Key(0)] Guid Id, - [property: DataMember(Order = 1), MemoryPackOrder(1), Key(1)] string Name, - [property: DataMember(Order = 2), MemoryPackOrder(2), Key(2)] string Description, - [property: DataMember(Order = 3), MemoryPackOrder(3), Key(3)] string CreatedBy, - [property: DataMember(Order = 4), MemoryPackOrder(4), Key(4)] string ChannelType, - [property: DataMember(Order = 5), MemoryPackOrder(5), Key(5)] string AccessLevel, - [property: DataMember(Order = 6), MemoryPackOrder(6), Key(6)] DateTime CreatedAt, - [property: DataMember(Order = 7), MemoryPackOrder(7), Key(7)] DateTime UpdatedAt + [property: DataMember(Order = 0)] + [property: MemoryPackOrder(0)] + [property: Key(0)] + Guid Id, + [property: DataMember(Order = 1)] + [property: MemoryPackOrder(1)] + [property: Key(1)] + string Name, + [property: DataMember(Order = 2)] + [property: MemoryPackOrder(2)] + [property: Key(2)] + string Description, + [property: DataMember(Order = 3)] + [property: MemoryPackOrder(3)] + [property: Key(3)] + string CreatedBy, + [property: DataMember(Order = 4)] + [property: MemoryPackOrder(4)] + [property: Key(4)] + string ChannelType, + [property: DataMember(Order = 5)] + [property: MemoryPackOrder(5)] + [property: Key(5)] + string AccessLevel, + [property: DataMember(Order = 6)] + [property: MemoryPackOrder(6)] + [property: Key(6)] + DateTime CreatedAt, + [property: DataMember(Order = 7)] + [property: MemoryPackOrder(7)] + [property: Key(7)] + DateTime UpdatedAt // TODO: all users currently connected to this channel - ); +); -[DataContract, MemoryPackable(GenerateType.VersionTolerant), MessagePackObject] +[DataContract] +[MemoryPackable(GenerateType.VersionTolerant)] +[MessagePackObject] public sealed partial record ChannelJoinRequest( - [property: DataMember(Order = 0), MemoryPackOrder(0), Key(0)] Guid ServerId, - [property: DataMember(Order = 1), MemoryPackOrder(1), Key(1)] Guid ChannelId - ); + [property: DataMember(Order = 0)] + [property: MemoryPackOrder(0)] + [property: Key(0)] + Guid ServerId, + [property: DataMember(Order = 1)] + [property: MemoryPackOrder(1)] + [property: Key(1)] + Guid ChannelId +); -[DataContract, MemoryPackable(GenerateType.VersionTolerant), MessagePackObject] +[DataContract] +[MemoryPackable(GenerateType.VersionTolerant)] +[MessagePackObject] public sealed partial record ChannelJoinResponse( - [property: DataMember(Order = 0), MemoryPackOrder(0), Key(0)] string Token - ); - + [property: DataMember(Order = 0)] + [property: MemoryPackOrder(0)] + [property: Key(0)] + string Token +); \ No newline at end of file