diff --git a/app/index.js b/app/index.js
index dddbea095..eb7fa5545 100644
--- a/app/index.js
+++ b/app/index.js
@@ -605,9 +605,6 @@ export default class Root extends React.Component {
}
init = async() => {
- if (isIOS) {
- await RNUserDefaults.setName('group.ios.chat.rocket');
- }
RNUserDefaults.objectForKey(THEME_PREFERENCES_KEY).then(this.setTheme);
const [notification, deepLinking] = await Promise.all([initializePushNotifications(), Linking.getInitialURL()]);
const parsedDeepLinkingURL = parseDeepLinking(deepLinking);
diff --git a/app/share.js b/app/share.js
index 3d2484a7d..5ab50599a 100644
--- a/app/share.js
+++ b/app/share.js
@@ -15,7 +15,7 @@ import {
import Navigation from './lib/ShareNavigation';
import store from './lib/createStore';
import sharedStyles from './views/Styles';
-import { isNotch, isIOS, supportSystemTheme } from './utils/deviceInfo';
+import { isNotch, supportSystemTheme } from './utils/deviceInfo';
import { defaultHeader, onNavigationStateChange, cardStyle } from './utils/navigation';
import RocketChat, { THEME_PREFERENCES_KEY } from './lib/rocketchat';
import { ThemeContext } from './theme';
@@ -77,9 +77,6 @@ class Root extends React.Component {
}
init = async() => {
- if (isIOS) {
- await RNUserDefaults.setName('group.ios.chat.rocket');
- }
RNUserDefaults.objectForKey(THEME_PREFERENCES_KEY).then(this.setTheme);
const currentServer = await RNUserDefaults.get('currentServer');
const token = await RNUserDefaults.get(RocketChat.TOKEN_KEY);
diff --git a/ios/Podfile.lock b/ios/Podfile.lock
index 2fa005932..f5c448138 100644
--- a/ios/Podfile.lock
+++ b/ios/Podfile.lock
@@ -397,7 +397,7 @@ PODS:
- React
- RNScreens (2.0.0-alpha.3):
- React
- - RNUserDefaults (1.7.0):
+ - RNUserDefaults (1.8.1):
- React
- RNVectorIcons (6.6.0):
- React
@@ -786,7 +786,7 @@ SPEC CHECKSUMS:
RNReanimated: b2ab0b693dddd2339bd2f300e770f6302d2e960c
RNRootView: 895a4813dedeaca82db2fa868ca1c333d790e494
RNScreens: 402a99b0a27c0c32f079cec12d3ccbd35e20cd7f
- RNUserDefaults: af71a1cdf1c12baf8210bc741c65f5faba9826d6
+ RNUserDefaults: c421fd97ad06b35c16608c5d0fe675db353f632d
RNVectorIcons: 0bb4def82230be1333ddaeee9fcba45f0b288ed4
RSKImageCropper: a446db0e8444a036b34f3c43db01b2373baa4b2a
SDWebImage: 4d5c027c935438f341ed33dbac53ff9f479922ca
diff --git a/ios/Pods/Local Podspecs/RNUserDefaults.podspec.json b/ios/Pods/Local Podspecs/RNUserDefaults.podspec.json
index 07aed251b..b54949a2b 100644
--- a/ios/Pods/Local Podspecs/RNUserDefaults.podspec.json
+++ b/ios/Pods/Local Podspecs/RNUserDefaults.podspec.json
@@ -1,6 +1,6 @@
{
"name": "RNUserDefaults",
- "version": "1.7.0",
+ "version": "1.8.1",
"summary": "Use `UserDefaults` (iOS) with React Native and `SharedPreferences` on AndroidOS.",
"description": "Use `UserDefaults` (iOS) with React Native and `SharedPreferences` on AndroidOS.",
"license": "MIT",
diff --git a/ios/Pods/Manifest.lock b/ios/Pods/Manifest.lock
index 2fa005932..f5c448138 100644
--- a/ios/Pods/Manifest.lock
+++ b/ios/Pods/Manifest.lock
@@ -397,7 +397,7 @@ PODS:
- React
- RNScreens (2.0.0-alpha.3):
- React
- - RNUserDefaults (1.7.0):
+ - RNUserDefaults (1.8.1):
- React
- RNVectorIcons (6.6.0):
- React
@@ -786,7 +786,7 @@ SPEC CHECKSUMS:
RNReanimated: b2ab0b693dddd2339bd2f300e770f6302d2e960c
RNRootView: 895a4813dedeaca82db2fa868ca1c333d790e494
RNScreens: 402a99b0a27c0c32f079cec12d3ccbd35e20cd7f
- RNUserDefaults: af71a1cdf1c12baf8210bc741c65f5faba9826d6
+ RNUserDefaults: c421fd97ad06b35c16608c5d0fe675db353f632d
RNVectorIcons: 0bb4def82230be1333ddaeee9fcba45f0b288ed4
RSKImageCropper: a446db0e8444a036b34f3c43db01b2373baa4b2a
SDWebImage: 4d5c027c935438f341ed33dbac53ff9f479922ca
diff --git a/ios/RocketChatRN/Info.plist b/ios/RocketChatRN/Info.plist
index 9b18ce355..a4541cbfb 100644
--- a/ios/RocketChatRN/Info.plist
+++ b/ios/RocketChatRN/Info.plist
@@ -67,7 +67,7 @@
NSMicrophoneUsageDescription
Use your microphone to record audio messages
NSMotionUsageDescription
- Allow $(PRODUCT_NAME) to access your device's accelerometer
+ Allow $(PRODUCT_NAME) to access your device's accelerometer
NSPhotoLibraryAddUsageDescription
Give $(PRODUCT_NAME) permission to save photos
NSPhotoLibraryUsageDescription
@@ -110,5 +110,7 @@
firefox
brave
+ AppGroup
+ group.ios.chat.rocket
diff --git a/ios/ShareRocketChatRN/Info.plist b/ios/ShareRocketChatRN/Info.plist
index 1a75bed69..3e98094be 100644
--- a/ios/ShareRocketChatRN/Info.plist
+++ b/ios/ShareRocketChatRN/Info.plist
@@ -60,5 +60,7 @@
custom.ttf
+ AppGroup
+ group.ios.chat.rocket
diff --git a/package.json b/package.json
index 4a872b5b4..09818f0e5 100644
--- a/package.json
+++ b/package.json
@@ -105,7 +105,7 @@
"rn-extensions-share": "^2.3.10",
"rn-fetch-blob": "0.11.2",
"rn-root-view": "^1.0.3",
- "rn-user-defaults": "1.7.0",
+ "rn-user-defaults": "^1.8.1",
"semver": "6.3.0",
"snyk": "1.210.0",
"strip-ansi": "5.2.0",
diff --git a/patches/react-native+0.61.5.patch b/patches/react-native+0.61.5.patch
index 400994539..328cdf232 100644
--- a/patches/react-native+0.61.5.patch
+++ b/patches/react-native+0.61.5.patch
@@ -1,8 +1,16 @@
diff --git a/node_modules/react-native/Libraries/Network/RCTHTTPRequestHandler.mm b/node_modules/react-native/Libraries/Network/RCTHTTPRequestHandler.mm
-index e72e943..ec0a0ba 100644
+index e72e943..ee0c7a1 100644
--- a/node_modules/react-native/Libraries/Network/RCTHTTPRequestHandler.mm
+++ b/node_modules/react-native/Libraries/Network/RCTHTTPRequestHandler.mm
-@@ -55,6 +55,59 @@ - (BOOL)canHandleRequest:(NSURLRequest *)request
+@@ -10,6 +10,7 @@
+ #import
+
+ #import
++#import "RNUserDefaults.h"
+
+ @interface RCTHTTPRequestHandler ()
+
+@@ -55,6 +56,59 @@ - (BOOL)canHandleRequest:(NSURLRequest *)request
return [schemes containsObject:request.URL.scheme.lowercaseString];
}
@@ -62,14 +70,14 @@ index e72e943..ec0a0ba 100644
- (NSURLSessionDataTask *)sendRequest:(NSURLRequest *)request
withDelegate:(id)delegate
{
-@@ -171,4 +224,20 @@ - (void)URLSession:(NSURLSession *)session task:(NSURLSessionTask *)task didComp
+@@ -171,4 +225,20 @@ - (void)URLSession:(NSURLSession *)session task:(NSURLSessionTask *)task didComp
[delegate URLRequest:task didCompleteWithError:error];
}
+-(void)URLSession:(NSURLSession *)session didReceiveChallenge:(NSURLAuthenticationChallenge *)challenge completionHandler:(void (^)(NSURLSessionAuthChallengeDisposition, NSURLCredential * _Nullable))completionHandler {
+
+ NSString *host = challenge.protectionSpace.host;
-+ NSDictionary *clientSSL = [[[NSUserDefaults alloc] initWithSuiteName:@"group.ios.chat.rocket"] objectForKey:host];
++ NSDictionary *clientSSL = [[RNUserDefaults getDefaultUser] objectForKey:host];
+
+ NSURLCredential *credential = [NSURLCredential credentialForTrust:challenge.protectionSpace.serverTrust];
+
@@ -84,10 +92,19 @@ index e72e943..ec0a0ba 100644
+
@end
diff --git a/node_modules/react-native/Libraries/WebSocket/RCTSRWebSocket.m b/node_modules/react-native/Libraries/WebSocket/RCTSRWebSocket.m
-index a134d2e..a88c099 100644
+index a134d2e..1526d60 100644
--- a/node_modules/react-native/Libraries/WebSocket/RCTSRWebSocket.m
+++ b/node_modules/react-native/Libraries/WebSocket/RCTSRWebSocket.m
-@@ -481,6 +481,29 @@ - (void)didConnect
+@@ -27,6 +27,8 @@
+ #import
+ #import
+
++#import "RNUserDefaults.h"
++
+ typedef NS_ENUM(NSInteger, RCTSROpCode) {
+ RCTSROpCodeTextFrame = 0x1,
+ RCTSROpCodeBinaryFrame = 0x2,
+@@ -481,6 +483,29 @@ - (void)didConnect
[self _readHTTPHeader];
}
@@ -117,12 +134,12 @@ index a134d2e..a88c099 100644
- (void)_initializeStreams;
{
assert(_url.port.unsignedIntValue <= UINT32_MAX);
-@@ -518,6 +541,15 @@ - (void)_initializeStreams;
+@@ -518,6 +543,15 @@ - (void)_initializeStreams;
RCTLogInfo(@"SocketRocket: In debug mode. Allowing connection to any root cert");
#endif
+ // SSL Pinning
-+ NSDictionary *clientSSL = [[[NSUserDefaults alloc] initWithSuiteName:@"group.ios.chat.rocket"] objectForKey:host];
++ NSDictionary *clientSSL = [[RNUserDefaults getDefaultUser] objectForKey:host];
+ if (clientSSL != (id)[NSNull null]) {
+ NSString *path = [clientSSL objectForKey:@"path"];
+ NSString *password = [clientSSL objectForKey:@"password"];
@@ -133,7 +150,7 @@ index a134d2e..a88c099 100644
[_outputStream setProperty:SSLOptions
forKey:(__bridge id)kCFStreamPropertySSLSettings];
}
-@@ -597,6 +629,7 @@ - (void)closeWithCode:(NSInteger)code reason:(NSString *)reason;
+@@ -597,6 +631,7 @@ - (void)closeWithCode:(NSInteger)code reason:(NSString *)reason;
}
}
diff --git a/patches/react-native-notifications+2.0.6.patch b/patches/react-native-notifications+2.0.6.patch
index b531954b4..76440b62b 100644
--- a/patches/react-native-notifications+2.0.6.patch
+++ b/patches/react-native-notifications+2.0.6.patch
@@ -1,8 +1,16 @@
diff --git a/node_modules/react-native-notifications/RNNotifications/RNNotificationEventHandler.m b/node_modules/react-native-notifications/RNNotifications/RNNotificationEventHandler.m
-index edc4fd4..aeb5eaa 100644
+index edc4fd4..7cd77f6 100644
--- a/node_modules/react-native-notifications/RNNotifications/RNNotificationEventHandler.m
+++ b/node_modules/react-native-notifications/RNNotifications/RNNotificationEventHandler.m
-@@ -28,9 +28,92 @@ - (void)didReceiveForegroundNotification:(UNNotification *)notification withComp
+@@ -3,6 +3,7 @@
+ #import "RNNotificationUtils.h"
+ #import "RCTConvert+RNNotifications.h"
+ #import "RNNotificationParser.h"
++#import "RNUserDefaults.h"
+
+ @implementation RNNotificationEventHandler {
+ RNNotificationsStore* _store;
+@@ -28,9 +29,91 @@ - (void)didReceiveForegroundNotification:(UNNotification *)notification withComp
[RNEventEmitter sendEvent:RNNotificationReceivedForeground body:[RNNotificationParser parseNotification:notification]];
}
@@ -54,10 +62,9 @@ index edc4fd4..aeb5eaa 100644
+ NSString *msg = [(UNTextInputNotificationResponse *)response userText];
+
+ // get credentials
-+ NSUserDefaults *userDefaults = [[NSUserDefaults alloc] initWithSuiteName:@"group.ios.chat.rocket"];
+ NSString *TOKEN_KEY = @"reactnativemeteor_usertoken";
-+ NSString *userId = [userDefaults stringForKey:[NSString stringWithFormat:@"%@-%@", TOKEN_KEY, [self serverURL:host]]];
-+ NSString *token = [userDefaults stringForKey:[NSString stringWithFormat:@"%@-%@", TOKEN_KEY, userId]];
++ NSString *userId = [[RNUserDefaults getDefaultUser] stringForKey:[NSString stringWithFormat:@"%@-%@", TOKEN_KEY, [self serverURL:host]]];
++ NSString *token = [[RNUserDefaults getDefaultUser] stringForKey:[NSString stringWithFormat:@"%@-%@", TOKEN_KEY, userId]];
+
+ // background task - we need this because fetch doesn't work if app is closed/killed
+ UIApplication *app = [UIApplication sharedApplication];
diff --git a/yarn.lock b/yarn.lock
index fd8a4f878..7791f26b5 100644
--- a/yarn.lock
+++ b/yarn.lock
@@ -10379,10 +10379,10 @@ rn-root-view@^1.0.3:
resolved "https://registry.yarnpkg.com/rn-root-view/-/rn-root-view-1.0.3.tgz#a2cddc717278cb2175fb29b7c006e407b7f0d0e2"
integrity sha512-BIKm8hY5q8+pxK9B5ugYjqutoI9xn2JfxIZKWoaFmAl1bOIM4oXjwFQrRM1e6lFgzz99MN6Mf2dK3Alsywnvvw==
-rn-user-defaults@1.7.0:
- version "1.7.0"
- resolved "https://registry.yarnpkg.com/rn-user-defaults/-/rn-user-defaults-1.7.0.tgz#8d1b79657dec3977e8f8983814b8591821f77236"
- integrity sha512-Qo6sIH8wldmQ0oOMMvljec4WOa/a1Up1pdatoXZGaPG1gl8OKgKH5HPKyddcABYtxPeBUTPVzCxP/6S6wPCqGQ==
+rn-user-defaults@^1.8.1:
+ version "1.8.1"
+ resolved "https://registry.yarnpkg.com/rn-user-defaults/-/rn-user-defaults-1.8.1.tgz#ccb8048f3ce43388ae40ac33eb063bfa93071702"
+ integrity sha512-pnUiB6Xn++5YGzSA1BKOsRAdz/GPkW3MViN5Yii6XGp5d6arcP4pOVIGmiFlOfxIFrHD3GU440WFnt5L7ogMSg==
rsvp@^3.3.3:
version "3.6.2"