2 files changed, 31 insertions, 0 deletions
diff --git a/MatrixRoomUtils.Core/Extensions/ObjectExtensions.cs b/MatrixRoomUtils.Core/Extensions/ObjectExtensions.cs
new file mode 100644
index 0000000..cf798ce
--- /dev/null
+++ b/MatrixRoomUtils.Core/Extensions/ObjectExtensions.cs
@@ -0,0 +1,14 @@
+using System.Text.Json;
+
+namespace MatrixRoomUtils.Extensions;
+
+public static class ObjectExtensions
+{
+ public static string ToJson(this object obj, bool indent = true, bool ignoreNull = false)
+ {
+ var jso = new JsonSerializerOptions();
+ if(indent) jso.WriteIndented = true;
+ if(ignoreNull) jso.IgnoreNullValues = true;
+ return JsonSerializer.Serialize(obj, jso);
+ }
+}
\ No newline at end of file
diff --git a/MatrixRoomUtils.Core/Extensions/StringExtensions.cs b/MatrixRoomUtils.Core/Extensions/StringExtensions.cs
new file mode 100644
index 0000000..e02f0b9
--- /dev/null
+++ b/MatrixRoomUtils.Core/Extensions/StringExtensions.cs
@@ -0,0 +1,17 @@
+using MatrixRoomUtils.Authentication;
+
+namespace MatrixRoomUtils.Extensions;
+
+public static class StringExtensions
+{
+ public static async Task<string> GetMediaUrl(this string MxcUrl)
+ {
+ //MxcUrl: mxc://rory.gay/ocRVanZoUTCcifcVNwXgbtTg
+ //target: https://matrix.rory.gay/_matrix/media/v3/download/rory.gay/ocRVanZoUTCcifcVNwXgbtTg
+
+ var server = MxcUrl.Split('/')[2];
+ var mediaId = MxcUrl.Split('/')[3];
+ return $"{await MatrixAccount.ResolveHomeserverFromWellKnown(server)}/_matrix/media/v3/download/{server}/{mediaId}";
+ }
+
+}
\ No newline at end of file
|