Files
mattermost-mobile/ios/Mattermost/SDWebImageDownloaderOperation+Swizzle.m
Avinash Lingaloo e8ce78f39d MM-36721 - [GEKIDOU] Porting Markdown components (#5586)
* Started with Channel Post List

* Added markdown hashtag

* Added TouchableWithFeedback component

* Added utils/bottom_sheet

* Removed BottomSheet in favor of future SlideUpPanel

* Added markdown_block_quote

* Added markdown_list_item

* Added markdown_list

* Added MarkDownTableCell component

* Markdown_table - in progress - need to verify TS

* Added markdown_table

* Update Podfile.lock

* Added deep_linking constant

* Added utils/draft

* Update config to include ExperimentalNormalizeMarkdownLinks

* Added markdown_link

* Added markdown_table_row

* Added ProgressiveImage and RetriableImage components and images utils

* Converted Retriable component to functional component

* Added type definition for commonmark

* Continuing with markdown TS

* Markdown - Typing props [ in progress ]

* Fix boolean flag with mardown block quote

* Adding observable config to markdown_link

* TS Fixes [ in progress ]

* TS fixes

* TS fixes - TextStyles

* Update markdown.tsx

* TS fixes on markdown

* TS Fixes - AtMention component

* AtMention [ IN PROGRESS ]

* Add markdown support

* Fix emoji and jumboEmoji on iOS

* Fix handleMyTeam operator

* Fix navigation style based on theme

* Fix iOS MattermostManaged deleteDatabse return error type

* wrap setNavigationStackStyles under a requestAnimationFrame

* Add preventDoubleTap to channel mention

* Increase double tap to 750ms

* Fix handleReceivedPostsInChannel chunk query

* Set initial navigation theme

* Swizzle FastImage on iOS

* fix preventDoubleTap test

Co-authored-by: Avinash Lingaloo <>
Co-authored-by: Elias Nahum <nahumhbl@gmail.com>
2021-08-02 20:30:17 +04:00

102 lines
4.6 KiB
Objective-C

// Copyright (c) 2015-present Mattermost, Inc. All Rights Reserved.
// See LICENSE.txt for license information.
//
// SDWebImageDownloaderOperation+Swizzle.m
#import "SDWebImageDownloaderOperation+Swizzle.h"
@import react_native_network_client;
#import <objc/runtime.h>
@implementation SDWebImageDownloaderOperation (Swizzle)
+ (void) load {
static dispatch_once_t onceToken;
dispatch_once(&onceToken, ^{
[self swizzleInitMethod];
[self swizzleURLSessionTaskDelegateMethod];
});
}
+ (void) swizzleInitMethod {
Class class = [self class];
SEL originalSelector = @selector(initWithRequest:inSession:options:context:);
SEL swizzledSelector = @selector(swizzled_initWithRequest:inSession:options:context:);
Method originalMethod = class_getInstanceMethod(class, originalSelector);
Method swizzledMethod = class_getInstanceMethod(class, swizzledSelector);
method_exchangeImplementations(originalMethod, swizzledMethod);
}
+ (void) swizzleURLSessionTaskDelegateMethod {
Class class = [self class];
SEL originalSelector = @selector(URLSession:task:didReceiveChallenge:completionHandler:);
SEL swizzledSelector = @selector(swizzled_URLSession:task:didReceiveChallenge:completionHandler:);
Method originalMethod = class_getInstanceMethod(class, originalSelector);
Method swizzledMethod = class_getInstanceMethod(class, swizzledSelector);
method_exchangeImplementations(originalMethod, swizzledMethod);
}
#pragma mark - Method Swizzling
- (nonnull instancetype)swizzled_initWithRequest:(NSURLRequest *)request inSession:(NSURLSession *)session options:(SDWebImageDownloaderOptions)options context:(nullable SDWebImageContext *)context {
SessionManager *nativeClientSessionManager = [SessionManager default];
NSURL *sessionBaseUrl = [nativeClientSessionManager getSessionBaseUrlFor:request];
if (sessionBaseUrl != nil) {
// If we have a session configured for this request then use its configuration
// to create a new session that SDWebImageDownloaderOperation will use for
// this request. In addition, if we have an authorization header being added
// to our session's requests, then we modify the request here as well using
// our BearerAuthenticationAdapter.
NSURLSessionConfiguration *configuration = [nativeClientSessionManager getSessionConfigurationFor:sessionBaseUrl];
NSURLSession *newSession = [NSURLSession sessionWithConfiguration:configuration
delegate:self
delegateQueue:session.delegateQueue];
NSURLRequest *authorizedRequest = [BearerAuthenticationAdapter addAuthorizationBearerTokenTo:request withSessionBaseUrlString:sessionBaseUrl.absoluteString];
return [self swizzled_initWithRequest:authorizedRequest inSession:newSession options:options context:context];
}
return [self swizzled_initWithRequest:request inSession:session options:options context:context];
}
- (void)swizzled_URLSession:(NSURLSession *)session task:(NSURLSessionTask *)task didReceiveChallenge:(NSURLAuthenticationChallenge *)challenge completionHandler:(void (^)(NSURLSessionAuthChallengeDisposition disposition, NSURLCredential *credential))completionHandler {
SessionManager *nativeClientSessionManager = [SessionManager default];
NSURL *sessionBaseUrl = [nativeClientSessionManager getSessionBaseUrlFor:task.currentRequest];
if (sessionBaseUrl != nil) {
// If we have a session configured for this request then we'll fetch and
// apply the necessary credentials for NSURLAuthenticationMethodServerTrust
// and NSURLAuthenticationMethodClientCertificate.
NSURLCredential *credential = nil;
NSURLSessionAuthChallengeDisposition disposition = NSURLSessionAuthChallengePerformDefaultHandling;
NSString *authenticationMethod = challenge.protectionSpace.authenticationMethod;
if ([authenticationMethod isEqualToString:NSURLAuthenticationMethodServerTrust]) {
if ([nativeClientSessionManager getTrustSelfSignedServerCertificateFor:sessionBaseUrl]) {
credential = [NSURLCredential credentialForTrust:challenge.protectionSpace.serverTrust];
disposition = NSURLSessionAuthChallengeUseCredential;
}
} else if ([authenticationMethod isEqualToString:NSURLAuthenticationMethodClientCertificate]) {
credential = [nativeClientSessionManager getCredentialFor:sessionBaseUrl];
disposition = NSURLSessionAuthChallengeUseCredential;
}
if (completionHandler) {
completionHandler(disposition, credential);
}
return;
}
[self swizzled_URLSession:session task:task didReceiveChallenge:challenge completionHandler:completionHandler];
}
@end