Add support for leaving rooms

FossilOrigin-Name: 193ebad6ad2eb698fb1c14250d1319d24ee42363dbc2a053ca6e9f5f600048f2
This commit is contained in:
Jonathan Schleifer 2020-10-03 17:50:07 +00:00
parent 54f1802e89
commit 191a6412ae
7 changed files with 186 additions and 2 deletions

View file

@ -61,6 +61,13 @@ typedef void (^mtx_client_room_list_block_t)(
typedef void (^mtx_client_room_join_block_t)(OFString *_Nullable roomID, typedef void (^mtx_client_room_join_block_t)(OFString *_Nullable roomID,
id _Nullable exception); id _Nullable exception);
/**
* @brief A block called when a room was left.
*
* @param exception An exception if leaving the room failed
*/
typedef void (^mtx_client_room_leave_block_t)(id _Nullable exception);
/** /**
* @brief A class that represents a client. * @brief A class that represents a client.
*/ */
@ -143,6 +150,15 @@ typedef void (^mtx_client_room_join_block_t)(OFString *_Nullable roomID,
*/ */
- (void)joinRoom: (OFString *)room - (void)joinRoom: (OFString *)room
block: (mtx_client_room_join_block_t)block; block: (mtx_client_room_join_block_t)block;
/**
* @brief Leaves the specified room.
*
* @param roomID The room ID to leave
* @param block A block to call when the room was left
*/
- (void)leaveRoom: (OFString *)roomID
block: (mtx_client_room_leave_block_t)block;
@end @end
OF_ASSUME_NONNULL_END OF_ASSUME_NONNULL_END

View file

@ -25,6 +25,7 @@
#import "MTXFetchRoomListFailedException.h" #import "MTXFetchRoomListFailedException.h"
#import "MTXJoinRoomFailedException.h" #import "MTXJoinRoomFailedException.h"
#import "MTXLeaveRoomFailedException.h"
#import "MTXLoginFailedException.h" #import "MTXLoginFailedException.h"
#import "MTXLogoutFailedException.h" #import "MTXLogoutFailedException.h"
@ -287,4 +288,33 @@ validateHomeserver(OFURL *homeserver)
objc_autoreleasePoolPop(pool); objc_autoreleasePoolPop(pool);
} }
- (void)leaveRoom: (OFString *)roomID
block: (mtx_client_room_leave_block_t)block
{
void *pool = objc_autoreleasePoolPush();
MTXRequest *request = [self requestWithPath: [OFString
stringWithFormat: @"/_matrix/client/r0/rooms/%@/leave", roomID]];
request.method = OF_HTTP_REQUEST_METHOD_POST;
[request performWithBlock: ^ (mtx_response_t response, int statusCode,
id exception) {
if (exception != nil) {
block(exception);
return;
}
if (statusCode != 200) {
block([MTXLeaveRoomFailedException
exceptionWithRoomID: roomID
statusCode: statusCode
response: response
client: self]);
return;
}
block(nil);
}];
objc_autoreleasePoolPop(pool);
}
@end @end

View file

@ -24,5 +24,7 @@
#import "MTXRequest.h" #import "MTXRequest.h"
#import "MTXFetchRoomListFailedException.h" #import "MTXFetchRoomListFailedException.h"
#import "MTXJoinRoomFailedException.h"
#import "MTXLeaveRoomFailedException.h"
#import "MTXLoginFailedException.h" #import "MTXLoginFailedException.h"
#import "MTXLogoutFailedException.h" #import "MTXLogoutFailedException.h"

View file

@ -0,0 +1,48 @@
/*
* Copyright (c) 2020, Jonathan Schleifer <js@nil.im>
*
* https://fossil.nil.im/objmatrix
*
* Permission to use, copy, modify, and/or distribute this software for any
* purpose with or without fee is hereby granted, provided that the above
* copyright notice and this permission notice is present in all copies.
*
* THIS SOFTWARE IS PROVIDED BY THE COPYRIGHT HOLDERS AND CONTRIBUTORS "AS IS"
* AND ANY EXPRESS OR IMPLIED WARRANTIES, INCLUDING, BUT NOT LIMITED TO, THE
* IMPLIED WARRANTIES OF MERCHANTABILITY AND FITNESS FOR A PARTICULAR PURPOSE
* ARE DISCLAIMED. IN NO EVENT SHALL THE COPYRIGHT OWNER OR CONTRIBUTORS BE
* LIABLE FOR ANY DIRECT, INDIRECT, INCIDENTAL, SPECIAL, EXEMPLARY, OR
* CONSEQUENTIAL DAMAGES (INCLUDING, BUT NOT LIMITED TO, PROCUREMENT OF
* SUBSTITUTE GOODS OR SERVICES; LOSS OF USE, DATA, OR PROFITS; OR BUSINESS
* INTERRUPTION) HOWEVER CAUSED AND ON ANY THEORY OF LIABILITY, WHETHER IN
* CONTRACT, STRICT LIABILITY, OR TORT (INCLUDING NEGLIGENCE OR OTHERWISE)
* ARISING IN ANY WAY OUT OF THE USE OF THIS SOFTWARE, EVEN IF ADVISED OF THE
* POSSIBILITY OF SUCH DAMAGE.
*/
#import <ObjFW/ObjFW.h>
#import "MTXClientException.h"
OF_ASSUME_NONNULL_BEGIN
@interface MTXLeaveRoomFailedException: MTXClientException
@property (readonly, nonatomic) OFString *roomID;
+ (instancetype)exceptionWithStatusCode: (int)statusCode
response: (mtx_response_t)response
client: (MTXClient *)client OF_UNAVAILABLE;
+ (instancetype)exceptionWithRoomID: (OFString *)roomID
statusCode: (int)statusCode
response: (mtx_response_t)response
client: (MTXClient *)client;
- (instancetype)initWithStatusCode: (int)statusCode
response: (mtx_response_t)response
client: (MTXClient *)client OF_UNAVAILABLE;
- (instancetype)initWithRoomID: (OFString *)roomID
statusCode: (int)statusCode
response: (mtx_response_t)response
client: (MTXClient *)client;
@end
OF_ASSUME_NONNULL_END

View file

@ -0,0 +1,71 @@
/*
* Copyright (c) 2020, Jonathan Schleifer <js@nil.im>
*
* https://fossil.nil.im/objmatrix
*
* Permission to use, copy, modify, and/or distribute this software for any
* purpose with or without fee is hereby granted, provided that the above
* copyright notice and this permission notice is present in all copies.
*
* THIS SOFTWARE IS PROVIDED BY THE COPYRIGHT HOLDERS AND CONTRIBUTORS "AS IS"
* AND ANY EXPRESS OR IMPLIED WARRANTIES, INCLUDING, BUT NOT LIMITED TO, THE
* IMPLIED WARRANTIES OF MERCHANTABILITY AND FITNESS FOR A PARTICULAR PURPOSE
* ARE DISCLAIMED. IN NO EVENT SHALL THE COPYRIGHT OWNER OR CONTRIBUTORS BE
* LIABLE FOR ANY DIRECT, INDIRECT, INCIDENTAL, SPECIAL, EXEMPLARY, OR
* CONSEQUENTIAL DAMAGES (INCLUDING, BUT NOT LIMITED TO, PROCUREMENT OF
* SUBSTITUTE GOODS OR SERVICES; LOSS OF USE, DATA, OR PROFITS; OR BUSINESS
* INTERRUPTION) HOWEVER CAUSED AND ON ANY THEORY OF LIABILITY, WHETHER IN
* CONTRACT, STRICT LIABILITY, OR TORT (INCLUDING NEGLIGENCE OR OTHERWISE)
* ARISING IN ANY WAY OUT OF THE USE OF THIS SOFTWARE, EVEN IF ADVISED OF THE
* POSSIBILITY OF SUCH DAMAGE.
*/
#import "MTXLeaveRoomFailedException.h"
#import "MTXClient.h"
@implementation MTXLeaveRoomFailedException
+ (instancetype)exceptionWithRoomID: (OFString *)roomID
statusCode: (int)statusCode
response: (mtx_response_t)response
client: (MTXClient *)client
{
return [[[self alloc] initWithRoomID: roomID
statusCode: statusCode
response: response
client: client] autorelease];
}
- (instancetype)initWithRoomID: (OFString *)roomID
statusCode: (int)statusCode
response: (mtx_response_t)response
client: (MTXClient *)client
{
self = [super initWithStatusCode: statusCode
response: response
client: client];
@try {
_roomID = [roomID copy];
} @catch (id e) {
[self release];
@throw e;
}
return self;
}
- (void)dealloc
{
[_roomID release];
[super dealloc];
}
- (OFString *)description
{
return [OFString stringWithFormat:
@"Failed to leave room %@ for %@: %@",
_roomID, self.client.userID, self.response];
}
@end

View file

@ -6,6 +6,7 @@ STATIC_LIB_NOINST = ${EXCEPTIONS_A}
SRCS = MTXClientException.m \ SRCS = MTXClientException.m \
MTXFetchRoomListFailedException.m \ MTXFetchRoomListFailedException.m \
MTXJoinRoomFailedException.m \ MTXJoinRoomFailedException.m \
MTXLeaveRoomFailedException.m \
MTXLoginFailedException.m \ MTXLoginFailedException.m \
MTXLogoutFailedException.m MTXLogoutFailedException.m
INCLUDES = ${SRCS:.m=.h} INCLUDES = ${SRCS:.m=.h}

View file

@ -80,15 +80,31 @@ OF_APPLICATION_DELEGATE(Tests)
- (void)joinRoom - (void)joinRoom
{ {
[_client joinRoom: @"#test:nil.im" OFString *room = @"#test:nil.im";
[_client joinRoom: room
block: ^ (OFString *roomID, id exception) { block: ^ (OFString *roomID, id exception) {
if (exception != nil) { if (exception != nil) {
of_log(@"Failed to join room: %@", exception); of_log(@"Failed to join room %@: %@", room, exception);
[OFApplication terminateWithStatus: 1]; [OFApplication terminateWithStatus: 1];
} }
of_log(@"Joined room %@", roomID); of_log(@"Joined room %@", roomID);
[self leaveRoom: roomID];
}];
}
- (void)leaveRoom: (OFString *)roomID
{
[_client leaveRoom: roomID
block: ^ (id exception) {
if (exception != nil) {
of_log(@"Failed to leave room %@: %@", exception);
[OFApplication terminateWithStatus: 1];
}
of_log(@"Left room %@", roomID);
[self logOut]; [self logOut];
}]; }];
} }