diff --git a/LibMatrix.EventTypes/Common/MjolnirShortcodeEventContent.cs b/LibMatrix.EventTypes/Common/MjolnirShortcodeEventContent.cs
deleted file mode 100644
index a31cbbb..0000000
--- a/LibMatrix.EventTypes/Common/MjolnirShortcodeEventContent.cs
+++ /dev/null
@@ -1,11 +0,0 @@
-using System.Text.Json.Serialization;
-
-namespace LibMatrix.EventTypes.Common;
-
-[MatrixEvent(EventName = EventId)]
-public class MjolnirShortcodeEventContent : TimelineEventContent {
- public const string EventId = "org.matrix.mjolnir.shortcode";
-
- [JsonPropertyName("shortcode")]
- public string? Shortcode { get; set; }
-}
\ No newline at end of file
diff --git a/LibMatrix.EventTypes/Common/RoomEmotesEventContent.cs b/LibMatrix.EventTypes/Common/RoomEmotesEventContent.cs
deleted file mode 100644
index b9a837f..0000000
--- a/LibMatrix.EventTypes/Common/RoomEmotesEventContent.cs
+++ /dev/null
@@ -1,24 +0,0 @@
-using System.Text.Json.Serialization;
-
-namespace LibMatrix.EventTypes.Common;
-
-[MatrixEvent(EventName = EventId)]
-public class RoomEmotesEventContent : TimelineEventContent {
- public const string EventId = "im.ponies.room_emotes";
-
- [JsonPropertyName("emoticons")]
- public Dictionary<string, EmoticonData>? Emoticons { get; set; }
-
- [JsonPropertyName("images")]
- public Dictionary<string, EmoticonData>? Images { get; set; }
-
- [JsonPropertyName("pack")]
- public PackInfo? Pack { get; set; }
-
- public class EmoticonData {
- [JsonPropertyName("url")]
- public string? Url { get; set; }
- }
-
- public class PackInfo; // TODO: Implement this
-}
\ No newline at end of file
diff --git a/LibMatrix.EventTypes/EventContent.cs b/LibMatrix.EventTypes/EventContent.cs
deleted file mode 100644
index c582cf2..0000000
--- a/LibMatrix.EventTypes/EventContent.cs
+++ /dev/null
@@ -1,48 +0,0 @@
-using System.Text.Json;
-using System.Text.Json.Nodes;
-using System.Text.Json.Serialization;
-
-namespace LibMatrix.EventTypes;
-
-public abstract class EventContent;
-
-public class UnknownEventContent : TimelineEventContent;
-
-public abstract class TimelineEventContent : EventContent {
- [JsonPropertyName("m.relates_to")]
- public MessageRelatesTo? RelatesTo { get; set; }
-
- [JsonPropertyName("m.new_content")]
- public JsonObject? NewContent { get; set; }
-
- public TimelineEventContent SetReplaceRelation(string eventId) {
- NewContent = JsonSerializer.SerializeToNode(this, GetType())!.AsObject();
- // NewContent = JsonSerializer.Deserialize(jsonText, GetType());
- RelatesTo = new MessageRelatesTo {
- RelationType = "m.replace",
- EventId = eventId
- };
- return this;
- }
-
- public T SetReplaceRelation<T>(string eventId) where T : TimelineEventContent => SetReplaceRelation(eventId) as T ?? throw new InvalidOperationException();
-
- public class MessageRelatesTo {
- [JsonPropertyName("m.in_reply_to")]
- public EventInReplyTo? InReplyTo { get; set; }
-
- [JsonPropertyName("event_id")]
- public string? EventId { get; set; }
-
- [JsonPropertyName("rel_type")]
- public string? RelationType { get; set; }
-
- public class EventInReplyTo {
- [JsonPropertyName("event_id")]
- public string? EventId { get; set; }
-
- [JsonPropertyName("rel_type")]
- public string? RelType { get; set; }
- }
- }
-}
\ No newline at end of file
diff --git a/LibMatrix.EventTypes/LibMatrix.EventTypes.csproj b/LibMatrix.EventTypes/LibMatrix.EventTypes.csproj
index 4276003..3a63532 100644
--- a/LibMatrix.EventTypes/LibMatrix.EventTypes.csproj
+++ b/LibMatrix.EventTypes/LibMatrix.EventTypes.csproj
@@ -6,17 +6,4 @@
<Nullable>enable</Nullable>
</PropertyGroup>
- <ItemGroup>
- <ProjectReference Condition="Exists('..\ArcaneLibs\ArcaneLibs\ArcaneLibs.csproj')" Include="..\ArcaneLibs\ArcaneLibs\ArcaneLibs.csproj"/>
- <!-- This is dangerous, but eases development since locking the version will drift out of sync without noticing,
- which causes build errors due to missing functions.
- Using the NuGet version in development is annoying due to delays between pushing and being able to consume.
- If you want to use a time-appropriate version of the library, recursively clone https://cgit.rory.gay/matrix/MatrixUtils.git
- instead, since this will be locked by the MatrixUtils project, which contains both LibMatrix and ArcaneLibs as a submodule. -->
- <PackageReference Condition="!Exists('..\ArcaneLibs\ArcaneLibs\ArcaneLibs.csproj')" Include="ArcaneLibs" Version="*-preview*"/>
- </ItemGroup>
-
- <Target Name="ArcaneLibsNugetWarning" AfterTargets="AfterBuild">
- <Warning Text="ArcaneLibs is being referenced from NuGet, which is dangerous. Please read the warning in LibMatrix.csproj!" Condition="!Exists('..\ArcaneLibs\ArcaneLibs\ArcaneLibs.csproj')"/>
- </Target>
</Project>
diff --git a/LibMatrix.EventTypes/MatrixEventAttribute.cs b/LibMatrix.EventTypes/MatrixEventAttribute.cs
deleted file mode 100644
index 5f06cec..0000000
--- a/LibMatrix.EventTypes/MatrixEventAttribute.cs
+++ /dev/null
@@ -1,7 +0,0 @@
-namespace LibMatrix.EventTypes;
-
-[AttributeUsage(AttributeTargets.Class, AllowMultiple = true)]
-public class MatrixEventAttribute : Attribute {
- public required string EventName { get; set; }
- public bool Legacy { get; set; }
-}
\ No newline at end of file
diff --git a/LibMatrix.EventTypes/Spec/Ephemeral/PresenceStateEventContent.cs b/LibMatrix.EventTypes/Spec/Ephemeral/PresenceStateEventContent.cs
deleted file mode 100644
index fc2c355..0000000
--- a/LibMatrix.EventTypes/Spec/Ephemeral/PresenceStateEventContent.cs
+++ /dev/null
@@ -1,30 +0,0 @@
-using System.Text.Json.Serialization;
-
-namespace LibMatrix.EventTypes.Spec.Ephemeral;
-
-[MatrixEvent(EventName = EventId)]
-public class PresenceEventContent : EventContent {
- public const string EventId = "m.presence";
-
- [JsonPropertyName("presence")]
- [JsonIgnore(Condition = JsonIgnoreCondition.WhenWritingNull)]
- public string? Presence { get; set; }
-
- [JsonPropertyName("last_active_ago")]
- public long LastActiveAgo { get; set; }
-
- [JsonPropertyName("currently_active")]
- public bool CurrentlyActive { get; set; }
-
- [JsonPropertyName("status_msg")]
- [JsonIgnore(Condition = JsonIgnoreCondition.WhenWritingNull)]
- public string? StatusMessage { get; set; }
-
- [JsonPropertyName("avatar_url")]
- [JsonIgnore(Condition = JsonIgnoreCondition.WhenWritingNull)]
- public string? AvatarUrl { get; set; }
-
- [JsonPropertyName("displayname")]
- [JsonIgnore(Condition = JsonIgnoreCondition.WhenWritingNull)]
- public string? DisplayName { get; set; }
-}
\ No newline at end of file
diff --git a/LibMatrix.EventTypes/Spec/Ephemeral/RoomTypingEventContent.cs b/LibMatrix.EventTypes/Spec/Ephemeral/RoomTypingEventContent.cs
deleted file mode 100644
index 494936d..0000000
--- a/LibMatrix.EventTypes/Spec/Ephemeral/RoomTypingEventContent.cs
+++ /dev/null
@@ -1,11 +0,0 @@
-using System.Text.Json.Serialization;
-
-namespace LibMatrix.EventTypes.Spec.State;
-
-[MatrixEvent(EventName = EventId)]
-public class RoomTypingEventContent : EventContent {
- public const string EventId = "m.typing";
-
- [JsonPropertyName("user_ids")]
- public string[]? UserIds { get; set; }
-}
\ No newline at end of file
diff --git a/LibMatrix.EventTypes/Spec/RoomMessageEventContent.cs b/LibMatrix.EventTypes/Spec/RoomMessageEventContent.cs
deleted file mode 100644
index ae893f8..0000000
--- a/LibMatrix.EventTypes/Spec/RoomMessageEventContent.cs
+++ /dev/null
@@ -1,56 +0,0 @@
-using System.Text.Json.Serialization;
-
-namespace LibMatrix.EventTypes.Spec;
-
-[MatrixEvent(EventName = EventId)]
-public class RoomMessageEventContent : TimelineEventContent {
- public const string EventId = "m.room.message";
-
- public RoomMessageEventContent(string messageType = "m.notice", string? body = null) {
- MessageType = messageType;
- Body = body ?? "";
- }
-
- [JsonPropertyName("body")]
- public string Body { get; set; }
-
- [JsonPropertyName("msgtype")]
- public string MessageType { get; set; } = "m.notice";
-
- [JsonPropertyName("formatted_body")]
- public string? FormattedBody { get; set; }
-
- [JsonPropertyName("format")]
- public string? Format { get; set; }
-
- /// <summary>
- /// Media URI for this message, if any
- /// </summary>
- [JsonPropertyName("url")]
- public string? Url { get; set; }
-
- public string? FileName { get; set; }
-
- [JsonPropertyName("info")]
- public FileInfoStruct? FileInfo { get; set; }
-
- [JsonIgnore]
- public string BodyWithoutReplyFallback => Body.Split('\n').SkipWhile(x => x.StartsWith(">")).SkipWhile(x=>x.Trim().Length == 0).Aggregate((x, y) => $"{x}\n{y}");
-
- public class FileInfoStruct {
- [JsonPropertyName("mimetype")]
- public string? MimeType { get; set; }
-
- [JsonPropertyName("size")]
- public long Size { get; set; }
-
- [JsonPropertyName("thumbnail_url")]
- public string? ThumbnailUrl { get; set; }
-
- [JsonPropertyName("w")]
- public int? Width { get; set; }
-
- [JsonPropertyName("h")]
- public int? Height { get; set; }
- }
-}
\ No newline at end of file
diff --git a/LibMatrix.EventTypes/Spec/RoomMessageReactionEventContent.cs b/LibMatrix.EventTypes/Spec/RoomMessageReactionEventContent.cs
deleted file mode 100644
index e2c0c8f..0000000
--- a/LibMatrix.EventTypes/Spec/RoomMessageReactionEventContent.cs
+++ /dev/null
@@ -1,6 +0,0 @@
-namespace LibMatrix.EventTypes.Spec;
-
-[MatrixEvent(EventName = EventId)]
-public class RoomMessageReactionEventContent : TimelineEventContent {
- public const string EventId = "m.reaction";
-}
\ No newline at end of file
diff --git a/LibMatrix.EventTypes/Spec/State/Policy/PolicyRuleStateEventContent.cs b/LibMatrix.EventTypes/Spec/State/Policy/PolicyRuleStateEventContent.cs
deleted file mode 100644
index 6006048..0000000
--- a/LibMatrix.EventTypes/Spec/State/Policy/PolicyRuleStateEventContent.cs
+++ /dev/null
@@ -1,107 +0,0 @@
-using System.Text.Json.Serialization;
-using ArcaneLibs.Attributes;
-
-namespace LibMatrix.EventTypes.Spec.State.Policy;
-
-//spec
-[MatrixEvent(EventName = EventId)] //spec
-[MatrixEvent(EventName = "m.room.rule.server", Legacy = true)] //???
-[MatrixEvent(EventName = "org.matrix.mjolnir.rule.server", Legacy = true)] //legacy
-[FriendlyName(Name = "Server policy", NamePlural = "Server policies")]
-public class ServerPolicyRuleEventContent : PolicyRuleEventContent {
- public const string EventId = "m.policy.rule.server";
-}
-
-[MatrixEvent(EventName = EventId)] //spec
-[MatrixEvent(EventName = "m.room.rule.user", Legacy = true)] //???
-[MatrixEvent(EventName = "org.matrix.mjolnir.rule.user", Legacy = true)] //legacy
-[FriendlyName(Name = "User policy", NamePlural = "User policies")]
-public class UserPolicyRuleEventContent : PolicyRuleEventContent {
- public const string EventId = "m.policy.rule.user";
-}
-
-[MatrixEvent(EventName = EventId)] //spec
-[MatrixEvent(EventName = "m.room.rule.room", Legacy = true)] //???
-[MatrixEvent(EventName = "org.matrix.mjolnir.rule.room", Legacy = true)] //legacy
-[FriendlyName(Name = "Room policy", NamePlural = "Room policies")]
-public class RoomPolicyRuleEventContent : PolicyRuleEventContent {
- public const string EventId = "m.policy.rule.room";
-}
-
-public abstract class PolicyRuleEventContent : EventContent {
- public PolicyRuleEventContent() => Console.WriteLine($"init policy {GetType().Name}");
- private string? _reason;
-
- /// <summary>
- /// Entity this ban applies to, can use * and ? as globs.
- /// Policy is invalid if entity is null
- /// </summary>
- [JsonPropertyName("entity")]
- [FriendlyName(Name = "Entity")]
- public string? Entity { get; set; }
-
- private bool init;
-
- /// <summary>
- /// Reason this user is banned
- /// </summary>
- [JsonPropertyName("reason")]
- [FriendlyName(Name = "Reason")]
- public virtual string? Reason {
- get =>
- // Console.WriteLine($"Read policy reason: {_reason}");
- _reason;
- set =>
- // Console.WriteLine($"Set policy reason: {value}");
- // if(init)
- // Console.WriteLine(string.Join('\n', Environment.StackTrace.Split('\n')[..5]));
- // init = true;
- _reason = value;
- }
-
- /// <summary>
- /// Suggested action to take
- /// </summary>
- [JsonPropertyName("recommendation")]
- [FriendlyName(Name = "Recommendation")]
- public string? Recommendation { get; set; }
-
- /// <summary>
- /// Expiry time in milliseconds since the unix epoch, or null if the ban has no expiry.
- /// </summary>
- [JsonPropertyName("support.feline.policy.expiry.rev.2")] //stable prefix: expiry, msc pending
- [TableHide]
- public long? Expiry { get; set; }
-
- //utils
- /// <summary>
- /// Readable expiry time, provided for easy interaction
- /// </summary>
- [JsonPropertyName("gay.rory.matrix_room_utils.readable_expiry_time_utc")]
- [FriendlyName(Name = "Expires at")]
- public DateTime? ExpiryDateTime {
- get => Expiry == null ? null : DateTimeOffset.FromUnixTimeMilliseconds(Expiry.Value).DateTime;
- set {
- if (value is not null)
- Expiry = ((DateTimeOffset)value).ToUnixTimeMilliseconds();
- }
- }
-}
-
-public static class PolicyRecommendationTypes {
- /// <summary>
- /// Ban this user
- /// </summary>
- public static string Ban = "m.ban";
-
- /// <summary>
- /// Mute this user
- /// </summary>
- public static string Mute = "support.feline.policy.recommendation_mute"; //stable prefix: m.mute, msc pending
-}
-
-// public class PolicySchemaDefinition {
-// public required string Name { get; set; }
-// public required bool Optional { get; set; }
-//
-// }
\ No newline at end of file
diff --git a/LibMatrix.EventTypes/Spec/State/RoomInfo/RoomAliasEventContent.cs b/LibMatrix.EventTypes/Spec/State/RoomInfo/RoomAliasEventContent.cs
deleted file mode 100644
index 4e82ac1..0000000
--- a/LibMatrix.EventTypes/Spec/State/RoomInfo/RoomAliasEventContent.cs
+++ /dev/null
@@ -1,11 +0,0 @@
-using System.Text.Json.Serialization;
-
-namespace LibMatrix.EventTypes.Spec.State.RoomInfo;
-
-[MatrixEvent(EventName = EventId)]
-public class RoomAliasEventContent : EventContent {
- public const string EventId = "m.room.alias";
-
- [JsonPropertyName("aliases")]
- public List<string>? Aliases { get; set; }
-}
\ No newline at end of file
diff --git a/LibMatrix.EventTypes/Spec/State/RoomInfo/RoomAvatarEventContent.cs b/LibMatrix.EventTypes/Spec/State/RoomInfo/RoomAvatarEventContent.cs
deleted file mode 100644
index c718826..0000000
--- a/LibMatrix.EventTypes/Spec/State/RoomInfo/RoomAvatarEventContent.cs
+++ /dev/null
@@ -1,28 +0,0 @@
-using System.Text.Json.Serialization;
-
-namespace LibMatrix.EventTypes.Spec.State.RoomInfo;
-
-[MatrixEvent(EventName = EventId)]
-public class RoomAvatarEventContent : EventContent {
- public const string EventId = "m.room.avatar";
-
- [JsonPropertyName("url")]
- public string? Url { get; set; }
-
- [JsonPropertyName("info")]
- public RoomAvatarInfo? Info { get; set; }
-
- public class RoomAvatarInfo {
- [JsonPropertyName("h")]
- public int? Height { get; set; }
-
- [JsonPropertyName("w")]
- public int? Width { get; set; }
-
- [JsonPropertyName("mimetype")]
- public string? MimeType { get; set; }
-
- [JsonPropertyName("size")]
- public int? Size { get; set; }
- }
-}
\ No newline at end of file
diff --git a/LibMatrix.EventTypes/Spec/State/RoomInfo/RoomCanonicalAliasEventContent.cs b/LibMatrix.EventTypes/Spec/State/RoomInfo/RoomCanonicalAliasEventContent.cs
deleted file mode 100644
index 93f13ac..0000000
--- a/LibMatrix.EventTypes/Spec/State/RoomInfo/RoomCanonicalAliasEventContent.cs
+++ /dev/null
@@ -1,14 +0,0 @@
-using System.Text.Json.Serialization;
-
-namespace LibMatrix.EventTypes.Spec.State;
-
-[MatrixEvent(EventName = EventId)]
-public class RoomCanonicalAliasEventContent : EventContent {
- public const string EventId = "m.room.canonical_alias";
-
- [JsonPropertyName("alias")]
- public string? Alias { get; set; }
-
- [JsonPropertyName("alt_aliases")]
- public string[]? AltAliases { get; set; }
-}
\ No newline at end of file
diff --git a/LibMatrix.EventTypes/Spec/State/RoomInfo/RoomCreateEventContent.cs b/LibMatrix.EventTypes/Spec/State/RoomInfo/RoomCreateEventContent.cs
deleted file mode 100644
index c619d0e..0000000
--- a/LibMatrix.EventTypes/Spec/State/RoomInfo/RoomCreateEventContent.cs
+++ /dev/null
@@ -1,31 +0,0 @@
-using System.Text.Json.Serialization;
-
-namespace LibMatrix.EventTypes.Spec.State;
-
-[MatrixEvent(EventName = EventId)]
-public class RoomCreateEventContent : EventContent {
- public const string EventId = "m.room.create";
-
- [JsonPropertyName("room_version")]
- public string? RoomVersion { get; set; }
-
- [JsonPropertyName("creator")]
- public string? Creator { get; set; }
-
- [JsonPropertyName("m.federate")]
- public bool? Federate { get; set; }
-
- [JsonPropertyName("predecessor")]
- public RoomCreatePredecessor? Predecessor { get; set; }
-
- [JsonPropertyName("type")]
- public string? Type { get; set; }
-
- public class RoomCreatePredecessor {
- [JsonPropertyName("room_id")]
- public string? RoomId { get; set; }
-
- [JsonPropertyName("event_id")]
- public string? EventId { get; set; }
- }
-}
\ No newline at end of file
diff --git a/LibMatrix.EventTypes/Spec/State/RoomInfo/RoomEncryptionEventContent.cs b/LibMatrix.EventTypes/Spec/State/RoomInfo/RoomEncryptionEventContent.cs
deleted file mode 100644
index b49abfa..0000000
--- a/LibMatrix.EventTypes/Spec/State/RoomInfo/RoomEncryptionEventContent.cs
+++ /dev/null
@@ -1,17 +0,0 @@
-using System.Text.Json.Serialization;
-
-namespace LibMatrix.EventTypes.Spec.State;
-
-[MatrixEvent(EventName = EventId)]
-public class RoomEncryptionEventContent : EventContent {
- public const string EventId = "m.room.encryption";
-
- [JsonPropertyName("algorithm")]
- public string? Algorithm { get; set; }
-
- [JsonPropertyName("rotation_period_ms")]
- public ulong? RotationPeriodMs { get; set; }
-
- [JsonPropertyName("rotation_period_msgs")]
- public ulong? RotationPeriodMsgs { get; set; }
-}
\ No newline at end of file
diff --git a/LibMatrix.EventTypes/Spec/State/RoomInfo/RoomGuestAccessEventContent.cs b/LibMatrix.EventTypes/Spec/State/RoomInfo/RoomGuestAccessEventContent.cs
deleted file mode 100644
index a7811bf..0000000
--- a/LibMatrix.EventTypes/Spec/State/RoomInfo/RoomGuestAccessEventContent.cs
+++ /dev/null
@@ -1,17 +0,0 @@
-using System.Text.Json.Serialization;
-
-namespace LibMatrix.EventTypes.Spec.State;
-
-[MatrixEvent(EventName = EventId)]
-public class RoomGuestAccessEventContent : EventContent {
- public const string EventId = "m.room.guest_access";
-
- [JsonPropertyName("guest_access")]
- public string GuestAccess { get; set; }
-
- [JsonIgnore]
- public bool IsGuestAccessEnabled {
- get => GuestAccess == "can_join";
- set => GuestAccess = value ? "can_join" : "forbidden";
- }
-}
\ No newline at end of file
diff --git a/LibMatrix.EventTypes/Spec/State/RoomInfo/RoomHistoryVisibilityEventContent.cs b/LibMatrix.EventTypes/Spec/State/RoomInfo/RoomHistoryVisibilityEventContent.cs
deleted file mode 100644
index 7676dad..0000000
--- a/LibMatrix.EventTypes/Spec/State/RoomInfo/RoomHistoryVisibilityEventContent.cs
+++ /dev/null
@@ -1,11 +0,0 @@
-using System.Text.Json.Serialization;
-
-namespace LibMatrix.EventTypes.Spec.State;
-
-[MatrixEvent(EventName = EventId)]
-public class RoomHistoryVisibilityEventContent : EventContent {
- public const string EventId = "m.room.history_visibility";
-
- [JsonPropertyName("history_visibility")]
- public string HistoryVisibility { get; set; }
-}
\ No newline at end of file
diff --git a/LibMatrix.EventTypes/Spec/State/RoomInfo/RoomJoinRulesEventContent.cs b/LibMatrix.EventTypes/Spec/State/RoomInfo/RoomJoinRulesEventContent.cs
deleted file mode 100644
index 349c8a7..0000000
--- a/LibMatrix.EventTypes/Spec/State/RoomInfo/RoomJoinRulesEventContent.cs
+++ /dev/null
@@ -1,60 +0,0 @@
-using System.Text.Json.Serialization;
-
-namespace LibMatrix.EventTypes.Spec.State;
-
-[MatrixEvent(EventName = EventId)]
-public class RoomJoinRulesEventContent : EventContent {
- public const string EventId = "m.room.join_rules";
-
- /// <summary>
- /// one of ["public", "invite", "knock", "restricted", "knock_restricted"]
- /// "private" is reserved without implementation!
- /// unknown values are treated as "private"
- /// </summary>
- [JsonPropertyName("join_rule")]
- public string JoinRuleValue { get; set; }
-
- [JsonIgnore]
- public JoinRules JoinRule {
- get => JoinRuleValue switch {
- "public" => JoinRules.Public,
- "invite" => JoinRules.Invite,
- "knock" => JoinRules.Knock,
- "restricted" => JoinRules.Restricted,
- "knock_restricted" => JoinRules.KnockRestricted,
- _ => JoinRules.Private
- };
- set => JoinRuleValue = value switch {
- JoinRules.Public => "public",
- JoinRules.Invite => "invite",
- JoinRules.Knock => "knock",
- JoinRules.Restricted => "restricted",
- JoinRules.KnockRestricted => "knock_restricted",
- _ => "private"
- };
- }
-
- [JsonPropertyName("allow")]
- public List<AllowEntry>? Allow { get; set; }
-
- public class AllowEntry {
- [JsonPropertyName("type")]
- public required string Type { get; set; }
-
- [JsonPropertyName("room_id")]
- public required string RoomId { get; set; }
-
- public static class Types {
- public const string RoomMembership = "m.room_membership";
- }
- }
-
- public enum JoinRules {
- Public,
- Invite,
- Knock,
- Restricted,
- KnockRestricted,
- Private // reserved without implementation!
- }
-}
\ No newline at end of file
diff --git a/LibMatrix.EventTypes/Spec/State/RoomInfo/RoomMemberEventContent.cs b/LibMatrix.EventTypes/Spec/State/RoomInfo/RoomMemberEventContent.cs
deleted file mode 100644
index b2d5596..0000000
--- a/LibMatrix.EventTypes/Spec/State/RoomInfo/RoomMemberEventContent.cs
+++ /dev/null
@@ -1,37 +0,0 @@
-using System.Text.Json.Serialization;
-
-namespace LibMatrix.EventTypes.Spec.State;
-
-[MatrixEvent(EventName = EventId)]
-public class RoomMemberEventContent : EventContent {
- public const string EventId = "m.room.member";
-
- [JsonPropertyName("reason")]
- public string? Reason { get; set; }
-
- [JsonPropertyName("membership")]
- public required string Membership { get; set; }
-
- [JsonPropertyName("displayname")]
- public string? DisplayName { get; set; }
-
- [JsonPropertyName("is_direct")]
- public bool? IsDirect { get; set; }
-
- [JsonPropertyName("avatar_url")]
- public string? AvatarUrl { get; set; }
-
- [JsonPropertyName("kind")]
- public string? Kind { get; set; }
-
- [JsonPropertyName("join_authorised_via_users_server")]
- public string? JoinAuthorisedViaUsersServer { get; set; }
-
- public static class MembershipTypes {
- public const string Invite = "invite";
- public const string Join = "join";
- public const string Leave = "leave";
- public const string Ban = "ban";
- public const string Knock = "knock";
- }
-}
\ No newline at end of file
diff --git a/LibMatrix.EventTypes/Spec/State/RoomInfo/RoomNameEventContent.cs b/LibMatrix.EventTypes/Spec/State/RoomInfo/RoomNameEventContent.cs
deleted file mode 100644
index 3ea5730..0000000
--- a/LibMatrix.EventTypes/Spec/State/RoomInfo/RoomNameEventContent.cs
+++ /dev/null
@@ -1,11 +0,0 @@
-using System.Text.Json.Serialization;
-
-namespace LibMatrix.EventTypes.Spec.State;
-
-[MatrixEvent(EventName = EventId)]
-public class RoomNameEventContent : EventContent {
- public const string EventId = "m.room.name";
-
- [JsonPropertyName("name")]
- public string? Name { get; set; }
-}
\ No newline at end of file
diff --git a/LibMatrix.EventTypes/Spec/State/RoomInfo/RoomPinnedEventContent.cs b/LibMatrix.EventTypes/Spec/State/RoomInfo/RoomPinnedEventContent.cs
deleted file mode 100644
index b4474e9..0000000
--- a/LibMatrix.EventTypes/Spec/State/RoomInfo/RoomPinnedEventContent.cs
+++ /dev/null
@@ -1,11 +0,0 @@
-using System.Text.Json.Serialization;
-
-namespace LibMatrix.EventTypes.Spec.State;
-
-[MatrixEvent(EventName = EventId)]
-public class RoomPinnedEventContent : EventContent {
- public const string EventId = "m.room.pinned_events";
-
- [JsonPropertyName("pinned")]
- public string[]? PinnedEvents { get; set; }
-}
\ No newline at end of file
diff --git a/LibMatrix.EventTypes/Spec/State/RoomInfo/RoomPowerLevelEventContent.cs b/LibMatrix.EventTypes/Spec/State/RoomInfo/RoomPowerLevelEventContent.cs
deleted file mode 100644
index 49a1b62..0000000
--- a/LibMatrix.EventTypes/Spec/State/RoomInfo/RoomPowerLevelEventContent.cs
+++ /dev/null
@@ -1,93 +0,0 @@
-using System.Text.Json.Serialization;
-
-namespace LibMatrix.EventTypes.Spec.State;
-
-[MatrixEvent(EventName = EventId)]
-[JsonNumberHandling(JsonNumberHandling.AllowReadingFromString)]
-public class RoomPowerLevelEventContent : EventContent {
- public const string EventId = "m.room.power_levels";
-
- [JsonPropertyName("ban")]
- public long? Ban { get; set; } = 50;
-
- [JsonPropertyName("events_default")]
- public long? EventsDefault { get; set; } = 0;
-
- [JsonPropertyName("invite")]
- public long? Invite { get; set; } = 0;
-
- [JsonPropertyName("kick")]
- public long? Kick { get; set; } = 50;
-
- [JsonPropertyName("notifications")]
- public NotificationsPL? NotificationsPl { get; set; } // = null!;
-
- [JsonPropertyName("redact")]
- public long? Redact { get; set; } = 50;
-
- [JsonPropertyName("state_default")]
- public long? StateDefault { get; set; } = 50;
-
- [JsonPropertyName("events")]
- public Dictionary<string, long>? Events { get; set; } // = null!;
-
- [JsonPropertyName("users")]
- public Dictionary<string, long>? Users { get; set; } // = null!;
-
- [JsonPropertyName("users_default")]
- public long? UsersDefault { get; set; } = 0;
-
- [Obsolete("Historical was a key related to MSC2716, a spec change on backfill that was dropped!", true)]
- [JsonIgnore]
- [JsonPropertyName("historical")]
- public long Historical { get; set; } // = 50;
-
- public class NotificationsPL {
- [JsonPropertyName("room")]
- public long Room { get; set; } = 50;
- }
-
- public bool IsUserAdmin(string userId) {
- ArgumentNullException.ThrowIfNull(userId);
- return Users.TryGetValue(userId, out var level) && level >= Events.Max(x => x.Value);
- }
-
- public bool UserHasTimelinePermission(string userId, string eventType) {
- ArgumentNullException.ThrowIfNull(userId);
- return Users.TryGetValue(userId, out var level) && level >= Events.GetValueOrDefault(eventType, EventsDefault ?? 0);
- }
-
- public bool UserHasStatePermission(string userId, string eventType) {
- ArgumentNullException.ThrowIfNull(userId);
- var userLevel = GetUserPowerLevel(userId);
- var eventLevel = GetStateEventPowerLevel(eventType);
-
- Console.WriteLine($"{userId}={userLevel} >= {eventType}={eventLevel} = {userLevel >= eventLevel}");
-
- return userLevel >= eventLevel;
- }
-
- public long GetUserPowerLevel(string userId) {
- ArgumentNullException.ThrowIfNull(userId);
- if (Users is null) return UsersDefault ?? 0;
- return Users.TryGetValue(userId, out var level) ? level : UsersDefault ?? 0;
- }
-
- public long GetStateEventPowerLevel(string eventType) {
- ArgumentNullException.ThrowIfNull(eventType);
- if (Events is null) return StateDefault ?? 0;
- return Events.TryGetValue(eventType, out var level) ? level : StateDefault ?? 0;
- }
-
- public long GetTimelineEventPowerLevel(string eventType) {
- ArgumentNullException.ThrowIfNull(eventType);
- if (Events is null) return EventsDefault ?? 0;
- return Events.TryGetValue(eventType, out var level) ? level : EventsDefault ?? 0;
- }
-
- public void SetUserPowerLevel(string userId, long powerLevel) {
- ArgumentNullException.ThrowIfNull(userId);
- Users ??= new Dictionary<string, long>();
- Users[userId] = powerLevel;
- }
-}
\ No newline at end of file
diff --git a/LibMatrix.EventTypes/Spec/State/RoomInfo/RoomServerACLEventContent.cs b/LibMatrix.EventTypes/Spec/State/RoomInfo/RoomServerACLEventContent.cs
deleted file mode 100644
index be83e37..0000000
--- a/LibMatrix.EventTypes/Spec/State/RoomInfo/RoomServerACLEventContent.cs
+++ /dev/null
@@ -1,17 +0,0 @@
-using System.Text.Json.Serialization;
-
-namespace LibMatrix.EventTypes.Spec.State;
-
-[MatrixEvent(EventName = EventId)]
-public class RoomServerACLEventContent : EventContent {
- public const string EventId = "m.room.server_acl";
-
- [JsonPropertyName("allow")]
- public List<string>? Allow { get; set; } // = null!;
-
- [JsonPropertyName("deny")]
- public List<string>? Deny { get; set; } // = null!;
-
- [JsonPropertyName("allow_ip_literals")]
- public bool AllowIpLiterals { get; set; } // = false;
-}
\ No newline at end of file
diff --git a/LibMatrix.EventTypes/Spec/State/RoomInfo/RoomTopicEventContent.cs b/LibMatrix.EventTypes/Spec/State/RoomInfo/RoomTopicEventContent.cs
deleted file mode 100644
index 92fa75d..0000000
--- a/LibMatrix.EventTypes/Spec/State/RoomInfo/RoomTopicEventContent.cs
+++ /dev/null
@@ -1,12 +0,0 @@
-using System.Text.Json.Serialization;
-
-namespace LibMatrix.EventTypes.Spec.State;
-
-[MatrixEvent(EventName = EventId)]
-[MatrixEvent(EventName = "org.matrix.msc3765.topic", Legacy = true)]
-public class RoomTopicEventContent : EventContent {
- public const string EventId = "m.room.topic";
-
- [JsonPropertyName("topic")]
- public string? Topic { get; set; }
-}
\ No newline at end of file
diff --git a/LibMatrix.EventTypes/Spec/State/Space/SpaceChildEventContent.cs b/LibMatrix.EventTypes/Spec/State/Space/SpaceChildEventContent.cs
deleted file mode 100644
index d233be4..0000000
--- a/LibMatrix.EventTypes/Spec/State/Space/SpaceChildEventContent.cs
+++ /dev/null
@@ -1,17 +0,0 @@
-using System.Text.Json.Serialization;
-
-namespace LibMatrix.EventTypes.Spec.State;
-
-[MatrixEvent(EventName = EventId)]
-public class SpaceChildEventContent : EventContent {
- public const string EventId = "m.space.child";
-
- [JsonPropertyName("auto_join")]
- public bool? AutoJoin { get; set; }
-
- [JsonPropertyName("via")]
- public List<string>? Via { get; set; }
-
- [JsonPropertyName("suggested")]
- public bool? Suggested { get; set; }
-}
\ No newline at end of file
diff --git a/LibMatrix.EventTypes/Spec/State/Space/SpaceParentEventContent.cs b/LibMatrix.EventTypes/Spec/State/Space/SpaceParentEventContent.cs
deleted file mode 100644
index 2ab79a4..0000000
--- a/LibMatrix.EventTypes/Spec/State/Space/SpaceParentEventContent.cs
+++ /dev/null
@@ -1,14 +0,0 @@
-using System.Text.Json.Serialization;
-
-namespace LibMatrix.EventTypes.Spec.State;
-
-[MatrixEvent(EventName = EventId)]
-public class SpaceParentEventContent : EventContent {
- public const string EventId = "m.space.parent";
-
- [JsonPropertyName("via")]
- public string[]? Via { get; set; }
-
- [JsonPropertyName("canonical")]
- public bool? Canonical { get; set; }
-}
\ No newline at end of file
|