about summary refs log tree commit diff
path: root/MatrixRoomUtils.Core/Interfaces/IHomeServer.cs
diff options
context:
space:
mode:
Diffstat (limited to 'MatrixRoomUtils.Core/Interfaces/IHomeServer.cs')
-rw-r--r--MatrixRoomUtils.Core/Interfaces/IHomeServer.cs42
1 files changed, 22 insertions, 20 deletions
diff --git a/MatrixRoomUtils.Core/Interfaces/IHomeServer.cs b/MatrixRoomUtils.Core/Interfaces/IHomeServer.cs
index 4fa6c1b..4ee2a3e 100644
--- a/MatrixRoomUtils.Core/Interfaces/IHomeServer.cs
+++ b/MatrixRoomUtils.Core/Interfaces/IHomeServer.cs
@@ -6,34 +6,36 @@ using MatrixRoomUtils.Core.StateEventTypes;
 namespace MatrixRoomUtils.Core.Interfaces;
 
 public class IHomeServer {
-    private readonly Dictionary<string, ProfileResponse?> _profileCache = new();
+    private readonly Dictionary<string, object> _profileCache = new();
     public string HomeServerDomain { get; set; }
     public string FullHomeServerDomain { get; set; }
 
     protected internal MatrixHttpClient _httpClient { get; set; } = new();
 
-
     public async Task<ProfileResponse> GetProfile(string mxid, bool debounce = false, bool cache = true) {
-        if (cache) {
-            if (debounce) await Task.Delay(Random.Shared.Next(100, 500));
-            if (_profileCache.ContainsKey(mxid)) {
-                while (_profileCache[mxid] == null) {
-                    Console.WriteLine($"Waiting for profile cache for {mxid}, currently {_profileCache[mxid]?.ToJson() ?? "null"} within {_profileCache.Count} profiles...");
-                    await Task.Delay(Random.Shared.Next(50, 500));
-                }
-
-                return _profileCache[mxid];
-            }
+        // if (cache) {
+        //     if (debounce) await Task.Delay(Random.Shared.Next(100, 500));
+        //     if (_profileCache.ContainsKey(mxid)) {
+        //         while (_profileCache[mxid] == null) {
+        //             Console.WriteLine($"Waiting for profile cache for {mxid}, currently {_profileCache[mxid]?.ToJson() ?? "null"} within {_profileCache.Count} profiles...");
+        //             await Task.Delay(Random.Shared.Next(50, 500));
+        //         }
+        //
+        //         return _profileCache[mxid];
+        //     }
+        // }
+        if(mxid is null) throw new ArgumentNullException(nameof(mxid));
+        if (_profileCache.ContainsKey(mxid)) {
+            if (_profileCache[mxid] is SemaphoreSlim s) await s.WaitAsync();
+            if (_profileCache[mxid] is ProfileResponse p) return p;
         }
-
-        _profileCache.Add(mxid, null);
+        _profileCache[mxid] = new SemaphoreSlim(1);
+        
         var resp = await _httpClient.GetAsync($"/_matrix/client/v3/profile/{mxid}");
-        var data = await resp.Content.ReadFromJsonAsync<JsonElement>();
+        var data = await resp.Content.ReadFromJsonAsync<ProfileResponse>();
         if (!resp.IsSuccessStatusCode) Console.WriteLine("Profile: " + data);
-        var profile = data.Deserialize<ProfileResponse>();
-        _profileCache[mxid] = profile;
-        return profile;
+        _profileCache[mxid] = data;
+        
+        return data;
     }
-
-    public string? ResolveMediaUri(string mxc) => mxc.Replace("mxc://", $"{FullHomeServerDomain}/_matrix/media/v3/download/");
 }
\ No newline at end of file