about summary refs log tree commit diff
path: root/Tests/LibMatrix.HomeserverEmulator/Controllers/Users
diff options
context:
space:
mode:
Diffstat (limited to 'Tests/LibMatrix.HomeserverEmulator/Controllers/Users')
-rw-r--r--Tests/LibMatrix.HomeserverEmulator/Controllers/Users/AccountDataController.cs68
-rw-r--r--Tests/LibMatrix.HomeserverEmulator/Controllers/Users/FilterController.cs46
-rw-r--r--Tests/LibMatrix.HomeserverEmulator/Controllers/Users/ProfileController.cs52
-rw-r--r--Tests/LibMatrix.HomeserverEmulator/Controllers/Users/UserController.cs80
4 files changed, 0 insertions, 246 deletions
diff --git a/Tests/LibMatrix.HomeserverEmulator/Controllers/Users/AccountDataController.cs b/Tests/LibMatrix.HomeserverEmulator/Controllers/Users/AccountDataController.cs
deleted file mode 100644
index a32d283..0000000
--- a/Tests/LibMatrix.HomeserverEmulator/Controllers/Users/AccountDataController.cs
+++ /dev/null
@@ -1,68 +0,0 @@
-using System.Text.Json.Nodes;
-using ArcaneLibs.Extensions;
-using LibMatrix.EventTypes.Spec.State;
-using LibMatrix.Filters;
-using LibMatrix.HomeserverEmulator.Services;
-using LibMatrix.Responses;
-using Microsoft.AspNetCore.Mvc;
-
-namespace LibMatrix.HomeserverEmulator.Controllers;
-
-[ApiController]
-[Route("/_matrix/client/{version}/")]
-public class AccountDataController(ILogger<AccountDataController> logger, TokenService tokenService, UserStore userStore, RoomStore roomStore) : ControllerBase {
-    [HttpGet("user/{mxid}/account_data/{type}")]
-    public async Task<object> GetAccountData(string type) {
-        var token = tokenService.GetAccessToken(HttpContext);
-        var user = await userStore.GetUserByToken(token, false);
-        if (user is null)
-            throw new MatrixException() {
-                ErrorCode = "M_UNAUTHORIZED",
-                Error = "Invalid token."
-            };
-
-        var value = user.AccountData.FirstOrDefault(x => x.Type == type);
-        if (value is null)
-            throw new MatrixException() {
-                ErrorCode = "M_NOT_FOUND",
-                Error = "Key not found."
-            };
-        return value;
-    }
-
-    [HttpPut("user/{mxid}/account_data/{type}")]
-    public async Task<object> SetAccountData(string type, [FromBody] JsonObject data) {
-        var token = tokenService.GetAccessToken(HttpContext);
-        var user = await userStore.GetUserByToken(token, false);
-        if (user is null)
-            throw new MatrixException() {
-                ErrorCode = "M_UNAUTHORIZED",
-                Error = "Invalid token."
-            };
-
-        user.AccountData.Add(new() {
-            Type = type,
-            RawContent = data
-        });
-        return data;
-    }
-
-    // specialised account data...
-    [HttpGet("pushrules")]
-    public async Task<object> GetPushRules() {
-        var token = tokenService.GetAccessToken(HttpContext);
-        if (token is null)
-            throw new MatrixException() {
-                ErrorCode = "M_UNAUTHORIZED",
-                Error = "No token passed."
-            };
-
-        var user = await userStore.GetUserByToken(token, false);
-        if (user is null)
-            throw new MatrixException() {
-                ErrorCode = "M_UNAUTHORIZED",
-                Error = "Invalid token."
-            };
-        return new { };
-    }
-}
\ No newline at end of file
diff --git a/Tests/LibMatrix.HomeserverEmulator/Controllers/Users/FilterController.cs b/Tests/LibMatrix.HomeserverEmulator/Controllers/Users/FilterController.cs
deleted file mode 100644
index bdee7bc..0000000
--- a/Tests/LibMatrix.HomeserverEmulator/Controllers/Users/FilterController.cs
+++ /dev/null
@@ -1,46 +0,0 @@
-using System.Text.Json.Nodes;

-using ArcaneLibs.Extensions;

-using LibMatrix.EventTypes.Spec.State;

-using LibMatrix.Filters;

-using LibMatrix.HomeserverEmulator.Services;

-using LibMatrix.Responses;

-using Microsoft.AspNetCore.Mvc;

-

-namespace LibMatrix.HomeserverEmulator.Controllers;

-

-[ApiController]

-[Route("/_matrix/client/{version}/")]

-public class FilterController(ILogger<FilterController> logger, TokenService tokenService, UserStore userStore, RoomStore roomStore) : ControllerBase {

-    [HttpPost("user/{mxid}/filter")]

-    public async Task<object> CreateFilter(string mxid, [FromBody] SyncFilter filter) {

-        var token = tokenService.GetAccessToken(HttpContext);

-        var user = await userStore.GetUserByToken(token, false);

-        if (user is null)

-            throw new MatrixException() {

-                ErrorCode = "M_UNAUTHORIZED",

-                Error = "Invalid token."

-            };

-        var filterId = Guid.NewGuid().ToString();

-        user.Filters[filterId] = filter;

-        return new {

-            filter_id = filterId

-        };

-    }

-    

-    [HttpGet("user/{mxid}/filter/{filterId}")]

-    public async Task<SyncFilter> GetFilter(string mxid, string filterId) {

-        var token = tokenService.GetAccessToken(HttpContext);

-        var user = await userStore.GetUserByToken(token, false);

-        if (user is null)

-            throw new MatrixException() {

-                ErrorCode = "M_UNAUTHORIZED",

-                Error = "Invalid token."

-            };

-        if (!user.Filters.ContainsKey(filterId))

-            throw new MatrixException() {

-                ErrorCode = "M_NOT_FOUND",

-                Error = "Filter not found."

-            };

-        return user.Filters[filterId];

-    }

-}
\ No newline at end of file
diff --git a/Tests/LibMatrix.HomeserverEmulator/Controllers/Users/ProfileController.cs b/Tests/LibMatrix.HomeserverEmulator/Controllers/Users/ProfileController.cs
deleted file mode 100644
index 98c41da..0000000
--- a/Tests/LibMatrix.HomeserverEmulator/Controllers/Users/ProfileController.cs
+++ /dev/null
@@ -1,52 +0,0 @@
-using System.Text.Json.Nodes;

-using ArcaneLibs.Extensions;

-using LibMatrix.EventTypes.Spec.State;

-using LibMatrix.Filters;

-using LibMatrix.HomeserverEmulator.Services;

-using LibMatrix.Responses;

-using Microsoft.AspNetCore.Mvc;

-

-namespace LibMatrix.HomeserverEmulator.Controllers;

-

-[ApiController]

-[Route("/_matrix/client/{version}/")]

-public class ProfileController(ILogger<ProfileController> logger, TokenService tokenService, UserStore userStore, RoomStore roomStore) : ControllerBase {

-    [HttpGet("profile/{userId}")]

-    public async Task<IDictionary<string, object>> GetProfile(string userId) {

-        var user = await userStore.GetUserById(userId, false);

-        if (user is null)

-            throw new MatrixException() {

-                ErrorCode = "M_NOT_FOUND",

-                Error = "User not found."

-            };

-        return user.Profile;

-    }

-

-    [HttpGet("profile/{userId}/{key}")]

-    public async Task<object> GetProfile(string userId, string key) {

-        var user = await userStore.GetUserById(userId, false);

-        if (user is null)

-            throw new MatrixException() {

-                ErrorCode = "M_NOT_FOUND",

-                Error = "User not found."

-            };

-        if (!user.Profile.TryGetValue(key, out var value))

-            throw new MatrixException() {

-                ErrorCode = "M_NOT_FOUND",

-                Error = "Key not found."

-            };

-        return value;

-    }

-

-    [HttpPut("profile/{userId}/{key}")]

-    public async Task<object> SetProfile(string userId, string key, [FromBody] JsonNode value) {

-        var user = await userStore.GetUserById(userId, false);

-        if (user is null)

-            throw new MatrixException() {

-                ErrorCode = "M_NOT_FOUND",

-                Error = "User not found."

-            };

-        user.Profile[key] = value[key]?.AsObject();

-        return value;

-    }

-}
\ No newline at end of file
diff --git a/Tests/LibMatrix.HomeserverEmulator/Controllers/Users/UserController.cs b/Tests/LibMatrix.HomeserverEmulator/Controllers/Users/UserController.cs
deleted file mode 100644
index 2be3896..0000000
--- a/Tests/LibMatrix.HomeserverEmulator/Controllers/Users/UserController.cs
+++ /dev/null
@@ -1,80 +0,0 @@
-using System.Text.Json.Nodes;

-using System.Text.Json.Serialization;

-using ArcaneLibs.Extensions;

-using LibMatrix.EventTypes.Spec.State;

-using LibMatrix.Filters;

-using LibMatrix.HomeserverEmulator.Services;

-using LibMatrix.Responses;

-using Microsoft.AspNetCore.Mvc;

-

-namespace LibMatrix.HomeserverEmulator.Controllers;

-

-[ApiController]

-[Route("/_matrix/client/{version}/")]

-public class UserController(ILogger<UserController> logger, TokenService tokenService, UserStore userStore, RoomStore roomStore) : ControllerBase {

-    [HttpGet("account/whoami")]

-    public async Task<WhoAmIResponse> Login() {

-        var token = tokenService.GetAccessToken(HttpContext);

-        var user = await userStore.GetUserByToken(token, Random.Shared.Next(101) <= 10, tokenService.GenerateServerName(HttpContext));

-        if (user is null)

-            throw new MatrixException() {

-                ErrorCode = "M_UNKNOWN_TOKEN",

-                Error = "Invalid token."

-            };

-        var whoAmIResponse = new WhoAmIResponse {

-            UserId = user.UserId

-        };

-        return whoAmIResponse;

-    }

-

-    [HttpGet("joined_rooms")]

-    public async Task<object> GetJoinedRooms() {

-        var token = tokenService.GetAccessToken(HttpContext);

-        var user = await userStore.GetUserByToken(token, false);

-        if (user is null)

-            throw new MatrixException() {

-                ErrorCode = "M_UNAUTHORIZED",

-                Error = "Invalid token."

-            };

-        // return user.JoinedRooms;

-

-        return new {

-            joined_rooms = roomStore._rooms.Where(r =>

-                r.State.Any(s => s.StateKey == user.UserId && s.Type == RoomMemberEventContent.EventId && (s.TypedContent as RoomMemberEventContent).Membership == "join")

-            ).Select(r => r.RoomId).ToList()

-        };

-    }

-    

-    [HttpGet("devices")]

-    public async Task<DevicesResponse> GetDevices() {

-        var token = tokenService.GetAccessToken(HttpContext);

-        var user = await userStore.GetUserByToken(token, false);

-        if (user is null)

-            throw new MatrixException() {

-                ErrorCode = "M_UNAUTHORIZED",

-                Error = "Invalid token."

-            };

-        return new() {

-            Devices = user.AccessTokens.Select(x=>new DevicesResponse.Device() {

-                DeviceId = x.Value.DeviceId,

-                DisplayName = x.Value.DeviceId

-            }).ToList()

-        };

-    }

-

-    public class DevicesResponse {

-        [JsonPropertyName("devices")]

-        public List<Device> Devices { get; set; }

-        

-        public class Device {

-            [JsonPropertyName("device_id")]

-            public string DeviceId { get; set; }

-            [JsonPropertyName("display_name")]

-            public string DisplayName { get; set; }

-            [JsonPropertyName("last_seen_ip")]

-            public string LastSeenIp { get; set; }

-            [JsonPropertyName("last_seen_ts")]

-            public long LastSeenTs { get; set; }

-        }

-    }

-}
\ No newline at end of file