From 916d4529ba65c3b7c7e185b5b9841550ee09ddfd Mon Sep 17 00:00:00 2001 From: Nicolas Buquet Date: Mon, 17 Jun 2024 18:21:01 +0200 Subject: [PATCH 1/2] Update version to 2.7.9 --- Config/AppVersion.xcconfig | 2 +- towncrier.toml | 2 +- 2 files changed, 2 insertions(+), 2 deletions(-) diff --git a/Config/AppVersion.xcconfig b/Config/AppVersion.xcconfig index c2c881a12..200075ce8 100644 --- a/Config/AppVersion.xcconfig +++ b/Config/AppVersion.xcconfig @@ -15,5 +15,5 @@ // // Version -MARKETING_VERSION = 2.7.8 +MARKETING_VERSION = 2.7.9 CURRENT_PROJECT_VERSION = 1 diff --git a/towncrier.toml b/towncrier.toml index e61f87c9c..81c5824d6 100644 --- a/towncrier.toml +++ b/towncrier.toml @@ -1,6 +1,6 @@ [tool.towncrier] name = "Changes in" -version = "2.7.8" +version = "2.7.9" filename = "TCHAP_CHANGES.md" directory = "changelog.d" template = "changelog.d/_template.md.jinja" From b573db3b4130b2d97f6ff1e1ca0b1db1c6054485 Mon Sep 17 00:00:00 2001 From: Nicolas Buquet Date: Mon, 17 Jun 2024 18:23:24 +0200 Subject: [PATCH 2/2] =?UTF-8?q?Correction=20de=20la=20g=C3=A9n=C3=A9ration?= =?UTF-8?q?=20de=20lien=20de=20partage=20sur=20les=20forums=20(ou=20salon?= =?UTF-8?q?=20sans=20alias)?= MIME-Version: 1.0 Content-Type: text/plain; charset=UTF-8 Content-Transfer-Encoding: 8bit --- .../RoomAccessByLinkViewModel.swift | 13 ++++++++ Tchap/Utils/Tools.h | 11 +++++++ Tchap/Utils/Tools.m | 33 +++++++++++++++++++ changelog.d/875.bugfix | 1 + 4 files changed, 58 insertions(+) create mode 100644 changelog.d/875.bugfix diff --git a/Tchap/Modules/Room/RoomAccessByLink/RoomAccessByLinkViewModel.swift b/Tchap/Modules/Room/RoomAccessByLink/RoomAccessByLinkViewModel.swift index 13f5b97b3..4f73c941e 100644 --- a/Tchap/Modules/Room/RoomAccessByLink/RoomAccessByLinkViewModel.swift +++ b/Tchap/Modules/Room/RoomAccessByLink/RoomAccessByLinkViewModel.swift @@ -149,6 +149,19 @@ final class RoomAccessByLinkViewModel: RoomAccessByLinkViewModelType { } else { isUnrestrictedRoom = false } + } else if let permalink = Tools.permalinkToRoomWithoutAlias(from: roomState) { + // If room as no canonical alias but permalink can be computed uing roomId and homeServers from members + // use this form of permalink (Tchap on web does like this). + link = permalink + if let room = self.session.room(withRoomId: roomId), let summary = room.summary { + if case RoomAccessRule.unrestricted = summary.tc_roomAccessRule() { + isUnrestrictedRoom = true + } else { + isUnrestrictedRoom = false + } + } else { + isUnrestrictedRoom = false + } } else { link = TchapL10n.roomSettingsRoomAccessByLinkInvalid isUnrestrictedRoom = false diff --git a/Tchap/Utils/Tools.h b/Tchap/Utils/Tools.h index 3619b88ca..cd092ca6f 100644 --- a/Tchap/Utils/Tools.h +++ b/Tchap/Utils/Tools.h @@ -64,6 +64,16 @@ */ + (NSString*)permalinkToRoom:(NSString*)roomIdOrAlias; + +/* + Return a permalink to a room which has no alias. + + @param roomState the RoomState of the room, containing the roomId and the room members necessary to build the permalink. + @return the Tchap permalink. + */ ++ (NSString *)permalinkToRoomWithoutAliasFromRoomState:(MXRoomState *)roomState; + + /* Return a permalink to an event. @@ -73,4 +83,5 @@ */ + (NSString*)permalinkToEvent:(NSString*)eventId inRoom:(NSString*)roomIdOrAlias; + @end diff --git a/Tchap/Utils/Tools.m b/Tchap/Utils/Tools.m index 1f4e3930b..598ec7b43 100644 --- a/Tchap/Utils/Tools.m +++ b/Tchap/Utils/Tools.m @@ -150,10 +150,43 @@ + (NSString *)permalinkToRoom:(NSString *)roomIdOrAlias return [NSString stringWithFormat:@"%@/#/room/%@", urlPrefix, roomIdOrAlias]; } ++ (NSString *)permalinkToRoomWithoutAliasFromRoomState:(MXRoomState *)state { + NSString *roomId = state.roomId; + + NSArray *members = state.members.joinedMembers; + + NSMutableSet *memberHomeservers = [NSMutableSet setWithCapacity:members.count]; + + // Add the homeServer hosting the room. + [memberHomeservers addObject:[roomId componentsSeparatedByString:@":"].lastObject]; + + // List unique members' homeServers in memberHomeservers. Limit to 3 + [members enumerateObjectsUsingBlock:^(MXRoomMember * _Nonnull obj, NSUInteger idx, BOOL * _Nonnull stop) { + NSArray *userIdParts = [obj.userId componentsSeparatedByString:@":"]; + if (userIdParts.count > 1) + { + [memberHomeservers addObject:userIdParts.lastObject]; // NSMutableSet only add object if not already present in the Set. + + // Stop if 3 homeServers are listed. + if (memberHomeservers.count >= 3) + { + *stop = YES; + } + } + }]; + + NSString *urlPrefix = BuildSettings.clientPermalinkBaseUrl; + NSString *viaParameters = [NSString stringWithFormat:@"?via=%@", [memberHomeservers.allObjects componentsJoinedByString:@"&via="]]; + NSString *permalinkToRoom = [NSString stringWithFormat:@"%@/#/room/%@%@", urlPrefix, roomId, viaParameters]; + + return permalinkToRoom; +} + + (NSString *)permalinkToEvent:(NSString *)eventId inRoom:(NSString *)roomIdOrAlias { NSString *urlPrefix = BuildSettings.clientPermalinkBaseUrl; return [NSString stringWithFormat:@"%@/#/room/%@/%@", urlPrefix, roomIdOrAlias, eventId]; } + @end diff --git a/changelog.d/875.bugfix b/changelog.d/875.bugfix new file mode 100644 index 000000000..af30f017f --- /dev/null +++ b/changelog.d/875.bugfix @@ -0,0 +1 @@ +Correction de la génération de lien de partage sur les forums \ No newline at end of file