diff --git a/.circleci/config.yml b/.circleci/config.yml
index 548febfd..2541bbeb 100644
--- a/.circleci/config.yml
+++ b/.circleci/config.yml
@@ -8,6 +8,11 @@ macos: &macos
bash-env: &bash-env
BASH_ENV: "~/.nvm/nvm.sh"
+android-env: &android-env
+ JAVA_OPTS: '-Xms512m -Xmx2g'
+ GRADLE_OPTS: '-Xmx3g -Dorg.gradle.daemon=false -Dorg.gradle.jvmargs="-Xmx2g -XX:+HeapDumpOnOutOfMemoryError"'
+ TERM: dumb
+
install-npm-modules: &install-npm-modules
name: Install NPM modules
command: yarn
@@ -75,6 +80,231 @@ restore_cache: &restore-gradle-cache
name: Restore gradle cache
key: android-{{ checksum "android/build.gradle" }}-{{ checksum "android/app/build.gradle" }}
+# COMMANDS
+commands:
+
+ android-build:
+ description: "Build Android app"
+ steps:
+ - checkout
+
+ - run: *install-node
+
+ - restore_cache: *restore-npm-cache-linux
+
+ - run: *install-npm-modules
+
+ - restore_cache: *restore-gradle-cache
+
+ - run:
+ name: Configure Gradle
+ command: |
+ echo -e "" > ./gradle.properties
+ # echo -e "android.enableAapt2=false" >> ./gradle.properties
+ echo -e "android.useAndroidX=true" >> ./gradle.properties
+ echo -e "android.enableJetifier=true" >> ./gradle.properties
+ echo -e "FLIPPER_VERSION=0.51.0" >> ./gradle.properties
+ echo -e "VERSIONCODE=$CIRCLE_BUILD_NUM" >> ./gradle.properties
+
+ if [[ $CIRCLE_JOB == "android-build-official" ]]; then
+ echo -e "APPLICATION_ID=chat.rocket.android" >> ./gradle.properties
+ echo -e "BugsnagAPIKey=$BUGSNAG_KEY_OFFICIAL" >> ./gradle.properties
+ echo $CHAT_ROCKET_ANDROID_STORE_FILE_BASE64_JKS | base64 --decode > ./app/$KEYSTORE_OFFICIAL
+ echo -e "KEYSTORE=$KEYSTORE_OFFICIAL" >> ./gradle.properties
+ echo -e "KEYSTORE_PASSWORD=$CHAT_ROCKET_ANDROID_STORE_PASSWORD" >> ./gradle.properties
+ echo -e "KEY_ALIAS=$CHAT_ROCKET_ANDROID_KEY_ALIAS" >> ./gradle.properties
+ echo -e "KEY_PASSWORD=$CHAT_ROCKET_ANDROID_KEY_PASSWORD" >> ./gradle.properties
+ else
+ echo -e "APPLICATION_ID=chat.rocket.reactnative" >> ./gradle.properties
+ echo -e "BugsnagAPIKey=$BUGSNAG_KEY" >> ./gradle.properties
+ echo $KEYSTORE_BASE64 | base64 --decode > ./app/$KEYSTORE
+ echo -e "KEYSTORE=$KEYSTORE" >> ./gradle.properties
+ echo -e "KEYSTORE_PASSWORD=$KEYSTORE_PASSWORD" >> ./gradle.properties
+ echo -e "KEY_ALIAS=$KEY_ALIAS" >> ./gradle.properties
+ echo -e "KEY_PASSWORD=$KEYSTORE_PASSWORD" >> ./gradle.properties
+ fi
+ working_directory: android
+
+ - run:
+ name: Set Google Services
+ command: |
+ if [[ $KEYSTORE ]]; then
+ echo $GOOGLE_SERVICES_ANDROID | base64 --decode > google-services.json
+ fi
+ working_directory: android/app
+
+ - run:
+ name: Config variables
+ command: |
+ if [[ $CIRCLE_JOB == "android-build-official" ]]; then
+ echo -e "export default { BUGSNAG_API_KEY: '$BUGSNAG_KEY_OFFICIAL' };" > ./config.js
+ else
+ echo -e "export default { BUGSNAG_API_KEY: '$BUGSNAG_KEY' };" > ./config.js
+ fi
+
+ - run:
+ name: Build App
+ command: |
+ if [[ $CIRCLE_JOB == "android-build-official" ]]; then
+ ./gradlew bundleOfficialPlayRelease
+ fi
+ if [[ $CIRCLE_JOB == "android-build-experimental" ]]; then
+ ./gradlew bundleExperimentalPlayRelease
+ fi
+ if [[ ! $KEYSTORE ]]; then
+ ./gradlew assembleExperimentalPlayDebug
+ fi
+ working_directory: android
+
+ - run:
+ name: Upload sourcemaps to Bugsnag
+ command: |
+ if [[ $CIRCLE_JOB == "android-build-official" ]]; then
+ yarn generate-source-maps-android upload \
+ --api-key=$BUGSNAG_KEY_OFFICIAL \
+ --app-version=$CIRCLE_BUILD_NUM \
+ --minifiedFile=android/app/build/generated/assets/react/officialPlay/release/app.bundle \
+ --source-map=android/app/build/generated/sourcemaps/react/officialPlay/release/app.bundle.map \
+ --minified-url=app.bundle \
+ --upload-sources
+ fi
+ if [[ $CIRCLE_JOB == "android-build-experimental" ]]; then
+ yarn generate-source-maps-android upload \
+ --api-key=$BUGSNAG_KEY \
+ --app-version=$CIRCLE_BUILD_NUM \
+ --minifiedFile=android/app/build/generated/assets/react/experimentalPlay/release/app.bundle \
+ --source-map=android/app/build/generated/sourcemaps/react/experimentalPlay/release/app.bundle.map \
+ --minified-url=app.bundle \
+ --upload-sources
+ fi
+
+ - store_artifacts:
+ path: android/app/build/outputs
+
+ - save_cache: *save-npm-cache-linux
+
+ - save_cache: *save-gradle-cache
+
+ - persist_to_workspace:
+ root: .
+ paths:
+ - android/app/build/outputs
+
+ ios-build:
+ description: "Build iOS app"
+ steps:
+ - checkout
+ - restore_cache: *restore-gems-cache
+ - restore_cache: *restore-npm-cache-mac
+ - run: *install-node
+ - run: *install-npm-modules
+ - run: *update-fastlane-ios
+ - run:
+ name: Set Google Services
+ command: |
+ if [[ $KEYSTORE ]]; then
+ echo $GOOGLE_SERVICES_IOS | base64 --decode > GoogleService-Info.plist
+ fi
+ working_directory: ios
+ - run:
+ name: Upload sourcemaps to Bugsnag
+ command: |
+ if [[ $CIRCLE_JOB == "ios-build-official" ]]; then
+ yarn generate-source-maps-ios
+ curl https://upload.bugsnag.com/react-native-source-map \
+ -F apiKey=$BUGSNAG_KEY_OFFICIAL \
+ -F appBundleVersion=$CIRCLE_BUILD_NUM \
+ -F dev=false \
+ -F platform=ios \
+ -F sourceMap=@ios-release.bundle.map \
+ -F bundle=@ios-release.bundle
+ fi
+ if [[ $CIRCLE_JOB == "ios-build-experimental" ]]; then
+ yarn generate-source-maps-ios
+ curl https://upload.bugsnag.com/react-native-source-map \
+ -F apiKey=$BUGSNAG_KEY \
+ -F appBundleVersion=$CIRCLE_BUILD_NUM \
+ -F dev=false \
+ -F platform=ios \
+ -F sourceMap=@ios-release.bundle.map \
+ -F bundle=@ios-release.bundle
+ fi
+ - run:
+ name: Fastlane Build
+ no_output_timeout: 1200
+ command: |
+ agvtool new-version -all $CIRCLE_BUILD_NUM
+ if [[ $CIRCLE_JOB == "ios-build-official" ]]; then
+ /usr/libexec/PlistBuddy -c "Set BugsnagAPIKey $BUGSNAG_KEY_OFFICIAL" ./RocketChatRN/Info.plist
+ /usr/libexec/PlistBuddy -c "Set IS_OFFICIAL YES" ./RocketChatRN/Info.plist
+ else
+ /usr/libexec/PlistBuddy -c "Set BugsnagAPIKey $BUGSNAG_KEY" ./RocketChatRN/Info.plist
+ /usr/libexec/PlistBuddy -c "Set IS_OFFICIAL NO" ./RocketChatRN/Info.plist
+ fi
+
+ if [[ $APP_STORE_CONNECT_API_KEY ]]; then
+ echo $APP_STORE_CONNECT_API_KEY | base64 --decode > ./fastlane/app_store_connect_api_key.p8
+ if [[ $CIRCLE_JOB == "ios-build-official" ]]; then
+ bundle exec fastlane ios build_official
+ else
+ if [[ $KEYSTORE ]]; then
+ bundle exec fastlane ios release # TODO: rename
+ else
+ bundle exec fastlane ios build_fork
+ fi
+ fi
+ fi
+ working_directory: ios
+ - save_cache: *save-npm-cache-mac
+ - save_cache: *save-gems-cache
+ - store_artifacts:
+ path: ios/Rocket.Chat.ipa
+ - store_artifacts:
+ path: ios/Rocket.Chat.app.dSYM.zip
+ - persist_to_workspace:
+ root: .
+ paths:
+ - ios/*.ipa
+ - ios/*.zip
+
+ upload-to-google-play-beta:
+ description: "Upload to Google Play beta"
+ parameters:
+ official:
+ type: boolean
+ steps:
+ - checkout
+ - attach_workspace:
+ at: android
+ - run:
+ name: Store the google service account key
+ command: echo "$FASTLANE_GOOGLE_SERVICE_ACCOUNT" | base64 --decode > service_account.json
+ working_directory: android
+ - run: *update-fastlane-android
+ - run:
+ name: Fastlane Play Store Upload
+ command: bundle exec fastlane android beta official:<< parameters.official >>
+ working_directory: android
+
+ upload-to-testflight:
+ description: "Upload to TestFlight"
+ parameters:
+ official:
+ type: boolean
+ steps:
+ - checkout
+ - attach_workspace:
+ at: ios
+ - restore_cache: *restore-gems-cache
+ - run: *update-fastlane-ios
+ - run:
+ name: Fastlane Tesflight Upload
+ command: |
+ echo $APP_STORE_CONNECT_API_KEY | base64 --decode > ./fastlane/app_store_connect_api_key.p8
+ bundle exec fastlane ios beta official:<< parameters.official >>
+ working_directory: ios
+ - save_cache: *save-gems-cache
+
version: 2.1
# EXECUTORS
@@ -119,304 +349,124 @@ jobs:
- save_cache: *save-npm-cache-linux
# Android builds
- android-play-build:
+ android-build-experimental:
<<: *defaults
docker:
- image: circleci/android:api-28-node
-
environment:
- JAVA_OPTS: '-Xms512m -Xmx2g'
- GRADLE_OPTS: '-Xmx3g -Dorg.gradle.daemon=false -Dorg.gradle.jvmargs="-Xmx2g -XX:+HeapDumpOnOutOfMemoryError"'
- TERM: dumb
+ <<: *android-env
<<: *bash-env
-
steps:
- - checkout
-
- - run: *install-node
-
- - restore_cache: *restore-npm-cache-linux
-
- - run: *install-npm-modules
-
- - run: *update-fastlane-android
-
- - restore_cache: *restore-gradle-cache
-
- - run:
- name: Configure Gradle
- command: |
- echo -e "" > ./gradle.properties
- # echo -e "android.enableAapt2=false" >> ./gradle.properties
- echo -e "android.useAndroidX=true" >> ./gradle.properties
- echo -e "android.enableJetifier=true" >> ./gradle.properties
- echo -e "FLIPPER_VERSION=0.51.0" >> ./gradle.properties
- echo -e "APPLICATION_ID=chat.rocket.reactnative" >> ./gradle.properties
- echo -e "VERSIONCODE=$CIRCLE_BUILD_NUM" >> ./gradle.properties
- echo -e "BugsnagAPIKey=$BUGSNAG_KEY" >> ./gradle.properties
-
- if [[ $KEYSTORE ]]; then
- echo $KEYSTORE_BASE64 | base64 --decode > ./app/$KEYSTORE
- echo -e "KEYSTORE=$KEYSTORE" >> ./gradle.properties
- echo -e "KEYSTORE_PASSWORD=$KEYSTORE_PASSWORD" >> ./gradle.properties
- echo -e "KEY_ALIAS=$KEY_ALIAS" >> ./gradle.properties
- echo -e "KEY_PASSWORD=$KEYSTORE_PASSWORD" >> ./gradle.properties
- fi
- working_directory: android
-
- - run:
- name: Set Google Services
- command: |
- if [[ $KEYSTORE ]]; then
- echo $GOOGLE_SERVICES_ANDROID | base64 --decode > google-services.json
- fi
- working_directory: android/app/src/play
-
- - run:
- name: Config variables
- command: |
- echo -e "export default { BUGSNAG_API_KEY: '$BUGSNAG_KEY' };" > ./config.js
-
- - run:
- name: Build Android Play App
- command: |
- if [[ $KEYSTORE ]]; then
- bundle exec fastlane android playRelease
- else
- bundle exec fastlane android playBuild
- fi
- working_directory: android
-
- - run:
- name: Upload sourcemaps to Bugsnag
- command: |
- if [[ $BUGSNAG_KEY ]]; then
- yarn generate-source-maps-android upload \
- --api-key=$BUGSNAG_KEY \
- --app-version=$CIRCLE_BUILD_NUM \
- --minifiedFile=android/app/build/generated/assets/react/play/release/app.bundle \
- --source-map=android/app/build/generated/sourcemaps/react/play/release/app.bundle.map \
- --minified-url=app.bundle \
- --upload-sources
- fi
-
- - store_artifacts:
- path: android/app/build/outputs
-
- - save_cache: *save-npm-cache-linux
-
- - save_cache: *save-gradle-cache
-
- - persist_to_workspace:
- root: .
- paths:
- - android/fastlane/report.xml
- - android/app/build/outputs
-
- android-foss-build:
+ - android-build
+
+ android-build-official:
<<: *defaults
docker:
- image: circleci/android:api-28-node
-
environment:
- JAVA_OPTS: '-Xms512m -Xmx2g'
- GRADLE_OPTS: '-Xmx3g -Dorg.gradle.daemon=false -Dorg.gradle.jvmargs="-Xmx2g -XX:+HeapDumpOnOutOfMemoryError"'
- TERM: dumb
+ <<: *android-env
<<: *bash-env
-
steps:
- - checkout
+ - android-build
- - run: *install-node
-
- - restore_cache: *restore-npm-cache-linux
-
- - run: *install-npm-modules
-
- - run: *update-fastlane-android
-
- - restore_cache: *restore-gradle-cache
-
- - run:
- name: Configure Gradle
- command: |
- echo -e "" > ./gradle.properties
- # echo -e "android.enableAapt2=false" >> ./gradle.properties
- echo -e "android.useAndroidX=true" >> ./gradle.properties
- echo -e "android.enableJetifier=true" >> ./gradle.properties
- echo -e "FLIPPER_VERSION=0.51.0" >> ./gradle.properties
- echo -e "VERSIONCODE=$CIRCLE_BUILD_NUM" >> ./gradle.properties
- echo -e "APPLICATION_ID=chat.rocket.android" >> ./gradle.properties
-
- if [[ $KEYSTORE ]]; then
- echo $KEYSTORE_BASE64 | base64 --decode > ./app/$KEYSTORE
- echo -e "KEYSTORE=$KEYSTORE" >> ./gradle.properties
- echo -e "KEYSTORE_PASSWORD=$KEYSTORE_PASSWORD" >> ./gradle.properties
- echo -e "KEY_ALIAS=$KEY_ALIAS" >> ./gradle.properties
- echo -e "KEY_PASSWORD=$KEYSTORE_PASSWORD" >> ./gradle.properties
- fi
- working_directory: android
-
- - run:
- name: Build Android Foss App
- command: bundle exec fastlane android fossRelease
- working_directory: android
-
- - store_artifacts:
- path: android/app/build/outputs
-
- - save_cache: *save-npm-cache-linux
-
- - save_cache: *save-gradle-cache
-
- - persist_to_workspace:
- root: .
- paths:
- - android/fastlane/report.xml
- - android/app/build/outputs
-
- android-google-play-beta:
+ android-google-play-beta-experimental:
<<: *defaults
docker:
- image: circleci/android:api-28-node
steps:
- - checkout
+ - upload-to-google-play-beta:
+ official: false
- - attach_workspace:
- at: android
+ android-google-play-beta-official:
+ <<: *defaults
+ docker:
+ - image: circleci/android:api-28-node
- - run:
- name: Store the google service account key
- command: echo "$FASTLANE_GOOGLE_SERVICE_ACCOUNT" | base64 --decode > service_account.json
- working_directory: android
-
- - run: *update-fastlane-android
-
- - run:
- name: Fastlane Play Store Upload
- command: bundle exec fastlane android beta
- working_directory: android
+ steps:
+ - upload-to-google-play-beta:
+ official: true
# iOS builds
- ios-build:
+ ios-build-experimental:
executor: mac-env
-
steps:
- - checkout
+ - ios-build
- - restore_cache: *restore-gems-cache
-
- - restore_cache: *restore-npm-cache-mac
-
- - run: *install-node
-
- - run: *install-npm-modules
-
- - run: *update-fastlane-ios
-
- - run:
- name: Set Google Services
- command: |
- if [[ $KEYSTORE ]]; then
- echo $GOOGLE_SERVICES_REACTNATIVE | base64 --decode > GoogleService-Info.plist
- fi
- working_directory: ios
-
- - run:
- name: Upload sourcemaps to Bugsnag
- command: |
- if [[ $BUGSNAG_KEY ]]; then
- yarn generate-source-maps-ios
- curl https://upload.bugsnag.com/react-native-source-map \
- -F apiKey=$BUGSNAG_KEY \
- -F appBundleVersion=$CIRCLE_BUILD_NUM \
- -F dev=false \
- -F platform=ios \
- -F sourceMap=@ios-release.bundle.map \
- -F bundle=@ios-release.bundle
- fi
-
- - run:
- name: Fastlane Build
- no_output_timeout: 1200
- command: |
- agvtool new-version -all $CIRCLE_BUILD_NUM
- /usr/libexec/PlistBuddy -c "Set BugsnagAPIKey $BUGSNAG_KEY" ./RocketChatRN/Info.plist
-
- if [[ $APP_STORE_CONNECT_API_KEY ]]; then
- echo $APP_STORE_CONNECT_API_KEY | base64 --decode > ./fastlane/app_store_connect_api_key.p8
- bundle exec fastlane ios release
- else
- bundle exec fastlane ios build_fork
- fi
- working_directory: ios
-
- - save_cache: *save-npm-cache-mac
-
- - save_cache: *save-gems-cache
-
- - store_artifacts:
- path: ios/RocketChatRN.ipa
-
- - persist_to_workspace:
- root: .
- paths:
- - ios/*.ipa
- - ios/fastlane/report.xml
-
- ios-testflight:
+ ios-build-official:
executor: mac-env
-
steps:
- - checkout
+ - ios-build
- - attach_workspace:
- at: ios
+ ios-testflight-experimental:
+ executor: mac-env
+ steps:
+ - upload-to-testflight:
+ official: false
- - restore_cache: *restore-gems-cache
-
- - run: *update-fastlane-ios
-
- - run:
- name: Fastlane Tesflight Upload
- command: |
- echo $APP_STORE_CONNECT_API_KEY | base64 --decode > ./fastlane/app_store_connect_api_key.p8
- bundle exec fastlane ios beta
- working_directory: ios
-
- - save_cache: *save-gems-cache
+ ios-testflight-official:
+ executor: mac-env
+ steps:
+ - upload-to-testflight:
+ official: true
workflows:
build-and-test:
jobs:
- lint-testunit
- - ios-build:
+ # iOS Experimental
+ - ios-build-experimental:
requires:
- lint-testunit
- - ios-hold-testflight:
+ - ios-hold-testflight-experimental:
type: approval
requires:
- - ios-build
- - ios-testflight:
+ - ios-build-experimental
+ - ios-testflight-experimental:
requires:
- - ios-hold-testflight
+ - ios-hold-testflight-experimental
- - android-play-build:
- requires:
- - lint-testunit
- - android-hold-google-play-beta:
- type: approval
- requires:
- - android-play-build
- - android-google-play-beta:
- requires:
- - android-hold-google-play-beta
- - android-hold-foss-build:
+ # iOS Official
+ - ios-hold-build-official:
type: approval
requires:
- lint-testunit
- - android-foss-build:
+ - ios-build-official:
requires:
- - android-hold-foss-build
+ - ios-hold-build-official
+ - ios-hold-testflight-official:
+ type: approval
+ requires:
+ - ios-build-official
+ - ios-testflight-official:
+ requires:
+ - ios-hold-testflight-official
+
+ # Android Experimental
+ - android-build-experimental:
+ requires:
+ - lint-testunit
+ - android-hold-google-play-beta-experimental:
+ type: approval
+ requires:
+ - android-build-experimental
+ - android-google-play-beta-experimental:
+ requires:
+ - android-hold-google-play-beta-experimental
+
+ # Android Official
+ - android-hold-build-official:
+ type: approval
+ requires:
+ - lint-testunit
+ - android-build-official:
+ requires:
+ - android-hold-build-official
+ - android-hold-google-play-beta-official:
+ type: approval
+ requires:
+ - android-build-official
+ - android-google-play-beta-official:
+ requires:
+ - android-hold-google-play-beta-official
diff --git a/.gitignore b/.gitignore
index 3d1baa21..d34d2867 100644
--- a/.gitignore
+++ b/.gitignore
@@ -21,6 +21,7 @@ DerivedData
*.ipa
*.xcuserstate
project.xcworkspace
+*.mobileprovision
# Android/IntelliJ
#
diff --git a/android/app/build.gradle b/android/app/build.gradle
index 28518d65..d25d0425 100644
--- a/android/app/build.gradle
+++ b/android/app/build.gradle
@@ -1,10 +1,10 @@
def taskRequests = getGradle().getStartParameter().getTaskRequests().toString().toLowerCase()
-def isPlay = !taskRequests.contains("foss")
+def isFoss = taskRequests.contains("foss")
apply plugin: "com.android.application"
apply plugin: 'kotlin-android'
-if (isPlay) {
+if (!isFoss) {
apply plugin: 'com.google.firebase.crashlytics'
apply plugin: 'com.bugsnag.android.gradle'
}
@@ -146,7 +146,7 @@ android {
versionCode VERSIONCODE as Integer
versionName "4.13.0"
vectorDrawables.useSupportLibrary = true
- if (isPlay) {
+ if (!isFoss) {
manifestPlaceholders = [BugsnagAPIKey: BugsnagAPIKey as String]
missingDimensionStrategy "RNNotifications.reactNativeVersion", "reactNative60" // See note below!
}
@@ -176,7 +176,7 @@ android {
minifyEnabled enableProguardInReleaseBuilds
setProguardFiles([getDefaultProguardFile('proguard-android.txt'), 'proguard-rules.pro'])
signingConfig signingConfigs.release
- if (isPlay) {
+ if (!isFoss) {
firebaseCrashlytics {
nativeSymbolUploadEnabled true
}
@@ -193,10 +193,17 @@ android {
// applicationVariants are e.g. debug, release
- flavorDimensions "type"
+ flavorDimensions "app", "type"
productFlavors {
+ official {
+ dimension = "app"
+ buildConfigField "boolean", "IS_OFFICIAL", "true"
+ }
+ experimental {
+ dimension = "app"
+ buildConfigField "boolean", "IS_OFFICIAL", "false"
+ }
foss {
- applicationId APPLICATION_ID
dimension = "type"
buildConfigField "boolean", "FDROID_BUILD", "true"
}
@@ -206,11 +213,20 @@ android {
}
}
sourceSets {
- playDebug {
+ // TODO: refactor making sure notifications are working properly both on debug and release
+ experimentalPlayDebug {
java.srcDirs = ['src/main/java', 'src/play/java']
manifest.srcFile 'src/play/AndroidManifest.xml'
}
- playRelease {
+ experimentalPlayRelease {
+ java.srcDirs = ['src/main/java', 'src/play/java']
+ manifest.srcFile 'src/play/AndroidManifest.xml'
+ }
+ officialPlayDebug {
+ java.srcDirs = ['src/main/java', 'src/play/java']
+ manifest.srcFile 'src/play/AndroidManifest.xml'
+ }
+ officialPlayRelease {
java.srcDirs = ['src/main/java', 'src/play/java']
manifest.srcFile 'src/play/AndroidManifest.xml'
}
@@ -287,6 +303,6 @@ task copyDownloadableDepsToLibs(type: Copy) {
}
apply from: file("../../node_modules/@react-native-community/cli-platform-android/native_modules.gradle"); applyNativeModulesAppBuildGradle(project)
-if (isPlay) {
+if (!isFoss) {
apply plugin: 'com.google.gms.google-services'
}
diff --git a/android/app/google-services.json b/android/app/google-services.json
new file mode 100644
index 00000000..f5014f14
--- /dev/null
+++ b/android/app/google-services.json
@@ -0,0 +1,83 @@
+{
+ "project_info": {
+ "project_number": "115198584049",
+ "firebase_url": "https://rocketchat-reactnative-test.firebaseio.com",
+ "project_id": "rocketchat-reactnative-test",
+ "storage_bucket": "rocketchat-reactnative-test.appspot.com"
+ },
+ "client": [
+ {
+ "client_info": {
+ "mobilesdk_app_id": "1:115198584049:android:a79216ae48935d2c9ab550",
+ "android_client_info": {
+ "package_name": "chat.rocket.android"
+ }
+ },
+ "oauth_client": [
+ {
+ "client_id": "115198584049-ack609b1338b827fta26s9rd2ab1aad5.apps.googleusercontent.com",
+ "client_type": 3
+ }
+ ],
+ "api_key": [
+ {
+ "current_key": "AIzaSyAWwowhAfACHBw3YxmDOXY3QyakgjhJLqc"
+ }
+ ],
+ "services": {
+ "appinvite_service": {
+ "other_platform_oauth_client": [
+ {
+ "client_id": "115198584049-ack609b1338b827fta26s9rd2ab1aad5.apps.googleusercontent.com",
+ "client_type": 3
+ },
+ {
+ "client_id": "115198584049-0efgfvm0oh9ap55g7epmqnjm27mq3j4e.apps.googleusercontent.com",
+ "client_type": 2,
+ "ios_info": {
+ "bundle_id": "chat.rocket.reactnative"
+ }
+ }
+ ]
+ }
+ }
+ },
+ {
+ "client_info": {
+ "mobilesdk_app_id": "1:115198584049:android:8be27b1f7c42a2ed",
+ "android_client_info": {
+ "package_name": "chat.rocket.reactnative"
+ }
+ },
+ "oauth_client": [
+ {
+ "client_id": "115198584049-ack609b1338b827fta26s9rd2ab1aad5.apps.googleusercontent.com",
+ "client_type": 3
+ }
+ ],
+ "api_key": [
+ {
+ "current_key": "AIzaSyAWwowhAfACHBw3YxmDOXY3QyakgjhJLqc"
+ }
+ ],
+ "services": {
+ "appinvite_service": {
+ "other_platform_oauth_client": [
+ {
+ "client_id": "115198584049-ack609b1338b827fta26s9rd2ab1aad5.apps.googleusercontent.com",
+ "client_type": 3
+ },
+ {
+ "client_id": "115198584049-0efgfvm0oh9ap55g7epmqnjm27mq3j4e.apps.googleusercontent.com",
+ "client_type": 2,
+ "ios_info": {
+ "bundle_id": "chat.rocket.reactnative"
+ }
+ }
+ ]
+ }
+ }
+ }
+ ],
+ "configuration_version": "1"
+}
\ No newline at end of file
diff --git a/android/app/src/play/ic_launcher-web.png b/android/app/src/experimental/ic_launcher-web.png
similarity index 100%
rename from android/app/src/play/ic_launcher-web.png
rename to android/app/src/experimental/ic_launcher-web.png
diff --git a/android/app/src/play/res/drawable-v24/ic_launcher_background.xml b/android/app/src/experimental/res/drawable-v24/ic_launcher_background.xml
similarity index 100%
rename from android/app/src/play/res/drawable-v24/ic_launcher_background.xml
rename to android/app/src/experimental/res/drawable-v24/ic_launcher_background.xml
diff --git a/android/app/src/play/res/drawable-xxhdpi/splash.png b/android/app/src/experimental/res/drawable-xxhdpi/splash.png
similarity index 100%
rename from android/app/src/play/res/drawable-xxhdpi/splash.png
rename to android/app/src/experimental/res/drawable-xxhdpi/splash.png
diff --git a/android/app/src/play/res/drawable/ic_launcher_foreground.xml b/android/app/src/experimental/res/drawable/ic_launcher_foreground.xml
similarity index 100%
rename from android/app/src/play/res/drawable/ic_launcher_foreground.xml
rename to android/app/src/experimental/res/drawable/ic_launcher_foreground.xml
diff --git a/android/app/src/foss/res/mipmap-anydpi-v26/ic_launcher.xml b/android/app/src/experimental/res/mipmap-anydpi-v26/ic_launcher.xml
similarity index 100%
rename from android/app/src/foss/res/mipmap-anydpi-v26/ic_launcher.xml
rename to android/app/src/experimental/res/mipmap-anydpi-v26/ic_launcher.xml
diff --git a/android/app/src/foss/res/mipmap-anydpi-v26/ic_launcher_round.xml b/android/app/src/experimental/res/mipmap-anydpi-v26/ic_launcher_round.xml
similarity index 100%
rename from android/app/src/foss/res/mipmap-anydpi-v26/ic_launcher_round.xml
rename to android/app/src/experimental/res/mipmap-anydpi-v26/ic_launcher_round.xml
diff --git a/android/app/src/play/res/mipmap-hdpi/ic_launcher.png b/android/app/src/experimental/res/mipmap-hdpi/ic_launcher.png
similarity index 100%
rename from android/app/src/play/res/mipmap-hdpi/ic_launcher.png
rename to android/app/src/experimental/res/mipmap-hdpi/ic_launcher.png
diff --git a/android/app/src/play/res/mipmap-hdpi/ic_launcher_round.png b/android/app/src/experimental/res/mipmap-hdpi/ic_launcher_round.png
similarity index 100%
rename from android/app/src/play/res/mipmap-hdpi/ic_launcher_round.png
rename to android/app/src/experimental/res/mipmap-hdpi/ic_launcher_round.png
diff --git a/android/app/src/play/res/mipmap-mdpi/ic_launcher.png b/android/app/src/experimental/res/mipmap-mdpi/ic_launcher.png
similarity index 100%
rename from android/app/src/play/res/mipmap-mdpi/ic_launcher.png
rename to android/app/src/experimental/res/mipmap-mdpi/ic_launcher.png
diff --git a/android/app/src/play/res/mipmap-mdpi/ic_launcher_round.png b/android/app/src/experimental/res/mipmap-mdpi/ic_launcher_round.png
similarity index 100%
rename from android/app/src/play/res/mipmap-mdpi/ic_launcher_round.png
rename to android/app/src/experimental/res/mipmap-mdpi/ic_launcher_round.png
diff --git a/android/app/src/play/res/mipmap-xhdpi/ic_launcher.png b/android/app/src/experimental/res/mipmap-xhdpi/ic_launcher.png
similarity index 100%
rename from android/app/src/play/res/mipmap-xhdpi/ic_launcher.png
rename to android/app/src/experimental/res/mipmap-xhdpi/ic_launcher.png
diff --git a/android/app/src/play/res/mipmap-xhdpi/ic_launcher_round.png b/android/app/src/experimental/res/mipmap-xhdpi/ic_launcher_round.png
similarity index 100%
rename from android/app/src/play/res/mipmap-xhdpi/ic_launcher_round.png
rename to android/app/src/experimental/res/mipmap-xhdpi/ic_launcher_round.png
diff --git a/android/app/src/play/res/mipmap-xxhdpi/ic_launcher.png b/android/app/src/experimental/res/mipmap-xxhdpi/ic_launcher.png
similarity index 100%
rename from android/app/src/play/res/mipmap-xxhdpi/ic_launcher.png
rename to android/app/src/experimental/res/mipmap-xxhdpi/ic_launcher.png
diff --git a/android/app/src/play/res/mipmap-xxhdpi/ic_launcher_round.png b/android/app/src/experimental/res/mipmap-xxhdpi/ic_launcher_round.png
similarity index 100%
rename from android/app/src/play/res/mipmap-xxhdpi/ic_launcher_round.png
rename to android/app/src/experimental/res/mipmap-xxhdpi/ic_launcher_round.png
diff --git a/android/app/src/play/res/mipmap-xxxhdpi/ic_launcher.png b/android/app/src/experimental/res/mipmap-xxxhdpi/ic_launcher.png
similarity index 100%
rename from android/app/src/play/res/mipmap-xxxhdpi/ic_launcher.png
rename to android/app/src/experimental/res/mipmap-xxxhdpi/ic_launcher.png
diff --git a/android/app/src/play/res/mipmap-xxxhdpi/ic_launcher_round.png b/android/app/src/experimental/res/mipmap-xxxhdpi/ic_launcher_round.png
similarity index 100%
rename from android/app/src/play/res/mipmap-xxxhdpi/ic_launcher_round.png
rename to android/app/src/experimental/res/mipmap-xxxhdpi/ic_launcher_round.png
diff --git a/android/app/src/main/res/values/colors.xml b/android/app/src/experimental/res/values/colors.xml
similarity index 100%
rename from android/app/src/main/res/values/colors.xml
rename to android/app/src/experimental/res/values/colors.xml
diff --git a/android/app/src/main/res/values/strings.xml b/android/app/src/experimental/res/values/strings.xml
similarity index 100%
rename from android/app/src/main/res/values/strings.xml
rename to android/app/src/experimental/res/values/strings.xml
diff --git a/android/app/src/foss/res/values-night/colors.xml b/android/app/src/foss/res/values-night/colors.xml
deleted file mode 100644
index 3c1a14f8..00000000
--- a/android/app/src/foss/res/values-night/colors.xml
+++ /dev/null
@@ -1,4 +0,0 @@
-
-
- - #000000
-
diff --git a/android/app/src/foss/res/values/styles.xml b/android/app/src/foss/res/values/styles.xml
deleted file mode 100644
index 50861d8e..00000000
--- a/android/app/src/foss/res/values/styles.xml
+++ /dev/null
@@ -1,28 +0,0 @@
-
-
-
-
-
-
-
-
-
diff --git a/android/app/src/main/res/values-night/colors.xml b/android/app/src/main/res/values-night/colors.xml
index d5d36f2f..3c1a14f8 100644
--- a/android/app/src/main/res/values-night/colors.xml
+++ b/android/app/src/main/res/values-night/colors.xml
@@ -1,5 +1,4 @@
- #000000
- - #1D74F5
-
\ No newline at end of file
+
diff --git a/android/app/src/foss/ic_launcher-web.png b/android/app/src/official/ic_launcher-web.png
similarity index 100%
rename from android/app/src/foss/ic_launcher-web.png
rename to android/app/src/official/ic_launcher-web.png
diff --git a/android/app/src/foss/res/drawable-xxhdpi/splash.png b/android/app/src/official/res/drawable-xxhdpi/splash.png
similarity index 100%
rename from android/app/src/foss/res/drawable-xxhdpi/splash.png
rename to android/app/src/official/res/drawable-xxhdpi/splash.png
diff --git a/android/app/src/foss/res/drawable/ic_launcher_background.xml b/android/app/src/official/res/drawable/ic_launcher_background.xml
similarity index 100%
rename from android/app/src/foss/res/drawable/ic_launcher_background.xml
rename to android/app/src/official/res/drawable/ic_launcher_background.xml
diff --git a/android/app/src/foss/res/drawable/ic_launcher_foreground.xml b/android/app/src/official/res/drawable/ic_launcher_foreground.xml
similarity index 100%
rename from android/app/src/foss/res/drawable/ic_launcher_foreground.xml
rename to android/app/src/official/res/drawable/ic_launcher_foreground.xml
diff --git a/android/app/src/foss/res/drawable/launch_screen.xml b/android/app/src/official/res/drawable/launch_screen.xml
similarity index 100%
rename from android/app/src/foss/res/drawable/launch_screen.xml
rename to android/app/src/official/res/drawable/launch_screen.xml
diff --git a/android/app/src/play/res/mipmap-anydpi-v26/ic_launcher.xml b/android/app/src/official/res/mipmap-anydpi-v26/ic_launcher.xml
similarity index 100%
rename from android/app/src/play/res/mipmap-anydpi-v26/ic_launcher.xml
rename to android/app/src/official/res/mipmap-anydpi-v26/ic_launcher.xml
diff --git a/android/app/src/play/res/mipmap-anydpi-v26/ic_launcher_round.xml b/android/app/src/official/res/mipmap-anydpi-v26/ic_launcher_round.xml
similarity index 100%
rename from android/app/src/play/res/mipmap-anydpi-v26/ic_launcher_round.xml
rename to android/app/src/official/res/mipmap-anydpi-v26/ic_launcher_round.xml
diff --git a/android/app/src/foss/res/mipmap-hdpi/ic_launcher.png b/android/app/src/official/res/mipmap-hdpi/ic_launcher.png
similarity index 100%
rename from android/app/src/foss/res/mipmap-hdpi/ic_launcher.png
rename to android/app/src/official/res/mipmap-hdpi/ic_launcher.png
diff --git a/android/app/src/foss/res/mipmap-hdpi/ic_launcher_round.png b/android/app/src/official/res/mipmap-hdpi/ic_launcher_round.png
similarity index 100%
rename from android/app/src/foss/res/mipmap-hdpi/ic_launcher_round.png
rename to android/app/src/official/res/mipmap-hdpi/ic_launcher_round.png
diff --git a/android/app/src/foss/res/mipmap-mdpi/ic_launcher.png b/android/app/src/official/res/mipmap-mdpi/ic_launcher.png
similarity index 100%
rename from android/app/src/foss/res/mipmap-mdpi/ic_launcher.png
rename to android/app/src/official/res/mipmap-mdpi/ic_launcher.png
diff --git a/android/app/src/foss/res/mipmap-mdpi/ic_launcher_round.png b/android/app/src/official/res/mipmap-mdpi/ic_launcher_round.png
similarity index 100%
rename from android/app/src/foss/res/mipmap-mdpi/ic_launcher_round.png
rename to android/app/src/official/res/mipmap-mdpi/ic_launcher_round.png
diff --git a/android/app/src/foss/res/mipmap-xhdpi/ic_launcher.png b/android/app/src/official/res/mipmap-xhdpi/ic_launcher.png
similarity index 100%
rename from android/app/src/foss/res/mipmap-xhdpi/ic_launcher.png
rename to android/app/src/official/res/mipmap-xhdpi/ic_launcher.png
diff --git a/android/app/src/foss/res/mipmap-xhdpi/ic_launcher_round.png b/android/app/src/official/res/mipmap-xhdpi/ic_launcher_round.png
similarity index 100%
rename from android/app/src/foss/res/mipmap-xhdpi/ic_launcher_round.png
rename to android/app/src/official/res/mipmap-xhdpi/ic_launcher_round.png
diff --git a/android/app/src/foss/res/mipmap-xxhdpi/ic_launcher.png b/android/app/src/official/res/mipmap-xxhdpi/ic_launcher.png
similarity index 100%
rename from android/app/src/foss/res/mipmap-xxhdpi/ic_launcher.png
rename to android/app/src/official/res/mipmap-xxhdpi/ic_launcher.png
diff --git a/android/app/src/foss/res/mipmap-xxhdpi/ic_launcher_round.png b/android/app/src/official/res/mipmap-xxhdpi/ic_launcher_round.png
similarity index 100%
rename from android/app/src/foss/res/mipmap-xxhdpi/ic_launcher_round.png
rename to android/app/src/official/res/mipmap-xxhdpi/ic_launcher_round.png
diff --git a/android/app/src/foss/res/mipmap-xxxhdpi/ic_launcher.png b/android/app/src/official/res/mipmap-xxxhdpi/ic_launcher.png
similarity index 100%
rename from android/app/src/foss/res/mipmap-xxxhdpi/ic_launcher.png
rename to android/app/src/official/res/mipmap-xxxhdpi/ic_launcher.png
diff --git a/android/app/src/foss/res/mipmap-xxxhdpi/ic_launcher_round.png b/android/app/src/official/res/mipmap-xxxhdpi/ic_launcher_round.png
similarity index 100%
rename from android/app/src/foss/res/mipmap-xxxhdpi/ic_launcher_round.png
rename to android/app/src/official/res/mipmap-xxxhdpi/ic_launcher_round.png
diff --git a/android/app/src/foss/res/values/colors.xml b/android/app/src/official/res/values/colors.xml
similarity index 100%
rename from android/app/src/foss/res/values/colors.xml
rename to android/app/src/official/res/values/colors.xml
diff --git a/android/app/src/foss/res/values/strings.xml b/android/app/src/official/res/values/strings.xml
similarity index 100%
rename from android/app/src/foss/res/values/strings.xml
rename to android/app/src/official/res/values/strings.xml
diff --git a/android/app/src/play/google-services.json b/android/app/src/play/google-services.json
deleted file mode 100644
index 4b3f409b..00000000
--- a/android/app/src/play/google-services.json
+++ /dev/null
@@ -1,40 +0,0 @@
-{
- "project_info": {
- "project_number": "115198584049",
- "firebase_url": "https://rocketchat-reactnative-test.firebaseio.com",
- "project_id": "rocketchat-reactnative-test",
- "storage_bucket": "rocketchat-reactnative-test.appspot.com"
- },
- "client": [
- {
- "client_info": {
- "mobilesdk_app_id": "1:115198584049:android:8be27b1f7c42a2ed",
- "android_client_info": {
- "package_name": "chat.rocket.reactnative"
- }
- },
- "oauth_client": [
- {
- "client_id": "115198584049-ack609b1338b827fta26s9rd2ab1aad5.apps.googleusercontent.com",
- "client_type": 3
- }
- ],
- "api_key": [
- {
- "current_key": "AIzaSyAWwowhAfACHBw3YxmDOXY3QyakgjhJLqc"
- }
- ],
- "services": {
- "appinvite_service": {
- "other_platform_oauth_client": [
- {
- "client_id": "115198584049-ack609b1338b827fta26s9rd2ab1aad5.apps.googleusercontent.com",
- "client_type": 3
- }
- ]
- }
- }
- }
- ],
- "configuration_version": "1"
-}
\ No newline at end of file
diff --git a/android/app/src/play/java/chat/rocket/reactnative/Encryption.java b/android/app/src/play/java/chat/rocket/reactnative/Encryption.java
index 83c2559c..bb7b12ff 100644
--- a/android/app/src/play/java/chat/rocket/reactnative/Encryption.java
+++ b/android/app/src/play/java/chat/rocket/reactnative/Encryption.java
@@ -1,28 +1,22 @@
package chat.rocket.reactnative;
-import android.util.Log;
-import android.util.Base64;
import android.database.Cursor;
+import android.util.Base64;
+import android.util.Log;
-import com.pedrouid.crypto.RSA;
+import com.facebook.react.bridge.Arguments;
+import com.facebook.react.bridge.ReactApplicationContext;
+import com.facebook.react.bridge.WritableMap;
+import com.google.gson.Gson;
+import com.nozbe.watermelondb.Database;
import com.pedrouid.crypto.RCTAes;
import com.pedrouid.crypto.RCTRsaUtils;
+import com.pedrouid.crypto.RSA;
import com.pedrouid.crypto.Util;
-import com.google.gson.Gson;
-
-import com.facebook.react.bridge.Promise;
-import com.facebook.react.bridge.Arguments;
-import com.facebook.react.bridge.ReactMethod;
-import com.facebook.react.bridge.ReadableMap;
-import com.facebook.react.bridge.WritableMap;
-import com.facebook.react.bridge.ReactApplicationContext;
-import com.facebook.react.bridge.ReactContextBaseJavaModule;
-
-import com.nozbe.watermelondb.Database;
-
-import java.util.Arrays;
+import java.lang.reflect.Field;
import java.security.SecureRandom;
+import java.util.Arrays;
class Message {
String _id;
@@ -69,8 +63,24 @@ class Encryption {
public static Encryption shared = new Encryption();
private ReactApplicationContext reactContext;
- public Room readRoom(final Ejson ejson) {
- Database database = new Database(ejson.serverURL().replace("https://", "") + "-experimental.db", reactContext);
+ public Room readRoom(final Ejson ejson) throws NoSuchFieldException {
+ int resId = reactContext.getResources().getIdentifier("rn_config_reader_custom_package", "string", reactContext.getPackageName());
+ String className = reactContext.getString(resId);
+ Class clazz = null;
+ Boolean isOfficial = false;
+ try {
+ clazz = Class.forName(className + ".BuildConfig");
+ Field IS_OFFICIAL = clazz.getField("IS_OFFICIAL");
+ isOfficial = (Boolean) IS_OFFICIAL.get(null);
+ } catch (ClassNotFoundException | IllegalAccessException e) {
+ e.printStackTrace();
+ }
+ String dbName = ejson.serverURL().replace("https://", "");
+ if (!isOfficial) {
+ dbName += "-experimental";
+ }
+ dbName += ".db";
+ Database database = new Database(dbName, reactContext);
String[] query = {ejson.rid};
Cursor cursor = database.rawQuery("select * from subscriptions where id == ? limit 1", query);
@@ -152,7 +162,7 @@ class Encryption {
return m.text;
} catch (Exception e) {
- Log.d("[ROCKETCHAT][ENCRYPTION]", Log.getStackTraceString(e));
+ Log.d("[ROCKETCHAT][E2E]", Log.getStackTraceString(e));
}
return null;
@@ -182,7 +192,7 @@ class Encryption {
return keyId + Base64.encodeToString(concat(bytes, data), Base64.NO_WRAP);
} catch (Exception e) {
- Log.d("[ROCKETCHAT][ENCRYPTION]", Log.getStackTraceString(e));
+ Log.d("[ROCKETCHAT][E2E]", Log.getStackTraceString(e));
}
return message;
diff --git a/android/fastlane/Fastfile b/android/fastlane/Fastfile
index d73d3381..1ac6d1fa 100644
--- a/android/fastlane/Fastfile
+++ b/android/fastlane/Fastfile
@@ -16,26 +16,20 @@
default_platform(:android)
platform :android do
- desc "Play build for development"
- lane :playBuild do
- gradle(task: "assemblePlayDebug")
- end
-
- desc "Foss build for release"
- lane :fossRelease do
- gradle(task: "assembleFossRelease")
- end
-
- desc "Play build for release"
- lane :playRelease do
- gradle(task: "bundlePlayRelease")
- end
-
desc "Upload App to Play Store Internal"
- lane :beta do
- upload_to_play_store(
- track: 'internal',
- aab: 'android/app/build/outputs/bundle/playRelease/app-play-release.aab'
- )
+ lane :beta do |options|
+ if options[:official]
+ upload_to_play_store(
+ package_name: 'chat.rocket.android',
+ track: 'internal',
+ aab: 'android/app/build/outputs/bundle/officialPlayRelease/app-official-play-release.aab'
+ )
+ else
+ upload_to_play_store(
+ package_name: 'chat.rocket.reactnative',
+ track: 'internal',
+ aab: 'android/app/build/outputs/bundle/experimentalPlayRelease/app-experimental-play-release.aab'
+ )
+ end
end
end
diff --git a/app/constants/environment.js b/app/constants/environment.js
index 099d27d1..43a1dc49 100644
--- a/app/constants/environment.js
+++ b/app/constants/environment.js
@@ -1,3 +1,5 @@
import RNConfigReader from 'react-native-config-reader';
export const isFDroidBuild = RNConfigReader.FDROID_BUILD;
+
+export const isOfficial = RNConfigReader.IS_OFFICIAL;
diff --git a/app/lib/database/index.js b/app/lib/database/index.js
index 41f13555..67ae9782 100644
--- a/app/lib/database/index.js
+++ b/app/lib/database/index.js
@@ -28,6 +28,7 @@ import serversMigrations from './model/servers/migrations';
import { isIOS } from '../../utils/deviceInfo';
import appGroup from '../../utils/appGroup';
+import { isOfficial } from '../../constants/environment';
const appGroupPath = isIOS ? appGroup.path : '';
@@ -35,9 +36,11 @@ if (__DEV__ && isIOS) {
console.log(appGroupPath);
}
+const getDatabasePath = name => `${ appGroupPath }${ name }${ isOfficial ? '' : '-experimental' }.db`;
+
export const getDatabase = (database = '') => {
const path = database.replace(/(^\w+:|^)\/\//, '').replace(/\//g, '.');
- const dbName = `${ appGroupPath }${ path }-experimental.db`;
+ const dbName = getDatabasePath(path);
const adapter = new SQLiteAdapter({
dbName,
@@ -70,7 +73,7 @@ class DB {
databases = {
serversDB: new Database({
adapter: new SQLiteAdapter({
- dbName: `${ appGroupPath }default-experimental.db`,
+ dbName: getDatabasePath('default'),
schema: serversSchema,
migrations: serversMigrations
}),
@@ -97,7 +100,7 @@ class DB {
setShareDB(database = '') {
const path = database.replace(/(^\w+:|^)\/\//, '').replace(/\//g, '.');
- const dbName = `${ appGroupPath }${ path }-experimental.db`;
+ const dbName = getDatabasePath(path);
const adapter = new SQLiteAdapter({
dbName,
diff --git a/ios/RocketChatRN/Images.xcassets/AppIcon.appiconset/100.png b/ios/Experimental.xcassets/AppIcon.appiconset/100.png
similarity index 100%
rename from ios/RocketChatRN/Images.xcassets/AppIcon.appiconset/100.png
rename to ios/Experimental.xcassets/AppIcon.appiconset/100.png
diff --git a/ios/RocketChatRN/Images.xcassets/AppIcon.appiconset/1024.png b/ios/Experimental.xcassets/AppIcon.appiconset/1024.png
similarity index 100%
rename from ios/RocketChatRN/Images.xcassets/AppIcon.appiconset/1024.png
rename to ios/Experimental.xcassets/AppIcon.appiconset/1024.png
diff --git a/ios/RocketChatRN/Images.xcassets/AppIcon.appiconset/114.png b/ios/Experimental.xcassets/AppIcon.appiconset/114.png
similarity index 100%
rename from ios/RocketChatRN/Images.xcassets/AppIcon.appiconset/114.png
rename to ios/Experimental.xcassets/AppIcon.appiconset/114.png
diff --git a/ios/RocketChatRN/Images.xcassets/AppIcon.appiconset/120.png b/ios/Experimental.xcassets/AppIcon.appiconset/120.png
similarity index 100%
rename from ios/RocketChatRN/Images.xcassets/AppIcon.appiconset/120.png
rename to ios/Experimental.xcassets/AppIcon.appiconset/120.png
diff --git a/ios/RocketChatRN/Images.xcassets/AppIcon.appiconset/144.png b/ios/Experimental.xcassets/AppIcon.appiconset/144.png
similarity index 100%
rename from ios/RocketChatRN/Images.xcassets/AppIcon.appiconset/144.png
rename to ios/Experimental.xcassets/AppIcon.appiconset/144.png
diff --git a/ios/RocketChatRN/Images.xcassets/AppIcon.appiconset/152.png b/ios/Experimental.xcassets/AppIcon.appiconset/152.png
similarity index 100%
rename from ios/RocketChatRN/Images.xcassets/AppIcon.appiconset/152.png
rename to ios/Experimental.xcassets/AppIcon.appiconset/152.png
diff --git a/ios/RocketChatRN/Images.xcassets/AppIcon.appiconset/167.png b/ios/Experimental.xcassets/AppIcon.appiconset/167.png
similarity index 100%
rename from ios/RocketChatRN/Images.xcassets/AppIcon.appiconset/167.png
rename to ios/Experimental.xcassets/AppIcon.appiconset/167.png
diff --git a/ios/RocketChatRN/Images.xcassets/AppIcon.appiconset/180.png b/ios/Experimental.xcassets/AppIcon.appiconset/180.png
similarity index 100%
rename from ios/RocketChatRN/Images.xcassets/AppIcon.appiconset/180.png
rename to ios/Experimental.xcassets/AppIcon.appiconset/180.png
diff --git a/ios/RocketChatRN/Images.xcassets/AppIcon.appiconset/20.png b/ios/Experimental.xcassets/AppIcon.appiconset/20.png
similarity index 100%
rename from ios/RocketChatRN/Images.xcassets/AppIcon.appiconset/20.png
rename to ios/Experimental.xcassets/AppIcon.appiconset/20.png
diff --git a/ios/RocketChatRN/Images.xcassets/AppIcon.appiconset/29.png b/ios/Experimental.xcassets/AppIcon.appiconset/29.png
similarity index 100%
rename from ios/RocketChatRN/Images.xcassets/AppIcon.appiconset/29.png
rename to ios/Experimental.xcassets/AppIcon.appiconset/29.png
diff --git a/ios/RocketChatRN/Images.xcassets/AppIcon.appiconset/40.png b/ios/Experimental.xcassets/AppIcon.appiconset/40.png
similarity index 100%
rename from ios/RocketChatRN/Images.xcassets/AppIcon.appiconset/40.png
rename to ios/Experimental.xcassets/AppIcon.appiconset/40.png
diff --git a/ios/RocketChatRN/Images.xcassets/AppIcon.appiconset/50.png b/ios/Experimental.xcassets/AppIcon.appiconset/50.png
similarity index 100%
rename from ios/RocketChatRN/Images.xcassets/AppIcon.appiconset/50.png
rename to ios/Experimental.xcassets/AppIcon.appiconset/50.png
diff --git a/ios/RocketChatRN/Images.xcassets/AppIcon.appiconset/57.png b/ios/Experimental.xcassets/AppIcon.appiconset/57.png
similarity index 100%
rename from ios/RocketChatRN/Images.xcassets/AppIcon.appiconset/57.png
rename to ios/Experimental.xcassets/AppIcon.appiconset/57.png
diff --git a/ios/RocketChatRN/Images.xcassets/AppIcon.appiconset/58.png b/ios/Experimental.xcassets/AppIcon.appiconset/58.png
similarity index 100%
rename from ios/RocketChatRN/Images.xcassets/AppIcon.appiconset/58.png
rename to ios/Experimental.xcassets/AppIcon.appiconset/58.png
diff --git a/ios/RocketChatRN/Images.xcassets/AppIcon.appiconset/60.png b/ios/Experimental.xcassets/AppIcon.appiconset/60.png
similarity index 100%
rename from ios/RocketChatRN/Images.xcassets/AppIcon.appiconset/60.png
rename to ios/Experimental.xcassets/AppIcon.appiconset/60.png
diff --git a/ios/RocketChatRN/Images.xcassets/AppIcon.appiconset/72.png b/ios/Experimental.xcassets/AppIcon.appiconset/72.png
similarity index 100%
rename from ios/RocketChatRN/Images.xcassets/AppIcon.appiconset/72.png
rename to ios/Experimental.xcassets/AppIcon.appiconset/72.png
diff --git a/ios/RocketChatRN/Images.xcassets/AppIcon.appiconset/76.png b/ios/Experimental.xcassets/AppIcon.appiconset/76.png
similarity index 100%
rename from ios/RocketChatRN/Images.xcassets/AppIcon.appiconset/76.png
rename to ios/Experimental.xcassets/AppIcon.appiconset/76.png
diff --git a/ios/RocketChatRN/Images.xcassets/AppIcon.appiconset/80.png b/ios/Experimental.xcassets/AppIcon.appiconset/80.png
similarity index 100%
rename from ios/RocketChatRN/Images.xcassets/AppIcon.appiconset/80.png
rename to ios/Experimental.xcassets/AppIcon.appiconset/80.png
diff --git a/ios/RocketChatRN/Images.xcassets/AppIcon.appiconset/87.png b/ios/Experimental.xcassets/AppIcon.appiconset/87.png
similarity index 100%
rename from ios/RocketChatRN/Images.xcassets/AppIcon.appiconset/87.png
rename to ios/Experimental.xcassets/AppIcon.appiconset/87.png
diff --git a/ios/RocketChatRN/Images.xcassets/AppIcon.appiconset/Contents.json b/ios/Experimental.xcassets/AppIcon.appiconset/Contents.json
similarity index 100%
rename from ios/RocketChatRN/Images.xcassets/AppIcon.appiconset/Contents.json
rename to ios/Experimental.xcassets/AppIcon.appiconset/Contents.json
diff --git a/ios/Experimental.xcassets/Contents.json b/ios/Experimental.xcassets/Contents.json
new file mode 100644
index 00000000..73c00596
--- /dev/null
+++ b/ios/Experimental.xcassets/Contents.json
@@ -0,0 +1,6 @@
+{
+ "info" : {
+ "author" : "xcode",
+ "version" : 1
+ }
+}
diff --git a/ios/RocketChatRN/Images.xcassets/Icons/logo.imageset/Contents.json b/ios/Experimental.xcassets/Launch Screen Icon.imageset/Contents.json
similarity index 100%
rename from ios/RocketChatRN/Images.xcassets/Icons/logo.imageset/Contents.json
rename to ios/Experimental.xcassets/Launch Screen Icon.imageset/Contents.json
diff --git a/ios/RocketChatRN/Images.xcassets/Launch Screen Icon.imageset/icon.png b/ios/Experimental.xcassets/Launch Screen Icon.imageset/icon.png
similarity index 100%
rename from ios/RocketChatRN/Images.xcassets/Launch Screen Icon.imageset/icon.png
rename to ios/Experimental.xcassets/Launch Screen Icon.imageset/icon.png
diff --git a/ios/RocketChatRN/Images.xcassets/Launch Screen Icon.imageset/icon@2x.png b/ios/Experimental.xcassets/Launch Screen Icon.imageset/icon@2x.png
similarity index 100%
rename from ios/RocketChatRN/Images.xcassets/Launch Screen Icon.imageset/icon@2x.png
rename to ios/Experimental.xcassets/Launch Screen Icon.imageset/icon@2x.png
diff --git a/ios/RocketChatRN/Images.xcassets/Launch Screen Icon.imageset/icon@3x.png b/ios/Experimental.xcassets/Launch Screen Icon.imageset/icon@3x.png
similarity index 100%
rename from ios/RocketChatRN/Images.xcassets/Launch Screen Icon.imageset/icon@3x.png
rename to ios/Experimental.xcassets/Launch Screen Icon.imageset/icon@3x.png
diff --git a/ios/Experimental.xcassets/splashBackgroundColor.colorset/Contents.json b/ios/Experimental.xcassets/splashBackgroundColor.colorset/Contents.json
new file mode 100644
index 00000000..76ebb74f
--- /dev/null
+++ b/ios/Experimental.xcassets/splashBackgroundColor.colorset/Contents.json
@@ -0,0 +1,59 @@
+{
+ "colors" : [
+ {
+ "color" : {
+ "color-space" : "extended-srgb",
+ "components" : {
+ "alpha" : "1.000",
+ "blue" : "0.945",
+ "green" : "0.937",
+ "red" : "0.933"
+ }
+ },
+ "idiom" : "universal"
+ },
+ {
+ "appearances" : [
+ {
+ "appearance" : "luminosity",
+ "value" : "light"
+ }
+ ],
+ "color" : {
+ "color-space" : "extended-srgb",
+ "components" : {
+ "alpha" : "1.000",
+ "blue" : "0.961",
+ "green" : "0.455",
+ "red" : "0.114"
+ }
+ },
+ "idiom" : "universal"
+ },
+ {
+ "appearances" : [
+ {
+ "appearance" : "luminosity",
+ "value" : "dark"
+ }
+ ],
+ "color" : {
+ "color-space" : "srgb",
+ "components" : {
+ "alpha" : "1.000",
+ "blue" : "0.000",
+ "green" : "0.000",
+ "red" : "0.000"
+ }
+ },
+ "idiom" : "universal"
+ }
+ ],
+ "info" : {
+ "author" : "xcode",
+ "version" : 1
+ },
+ "properties" : {
+ "localizable" : true
+ }
+}
diff --git a/ios/LaunchScreen.storyboard b/ios/LaunchScreen.storyboard
index 4cf51f28..f6ec6ade 100644
--- a/ios/LaunchScreen.storyboard
+++ b/ios/LaunchScreen.storyboard
@@ -1,9 +1,9 @@
-
+
-
+
@@ -24,6 +24,7 @@
+
@@ -32,7 +33,6 @@
-
@@ -43,7 +43,7 @@
-
+
diff --git a/ios/NotificationService/Info.plist b/ios/NotificationService/Info.plist
index 5705853e..d2f1244d 100644
--- a/ios/NotificationService/Info.plist
+++ b/ios/NotificationService/Info.plist
@@ -2,8 +2,6 @@
- KeychainGroup
- $(AppIdentifierPrefix)chat.rocket.reactnative
AppGroup
group.ios.chat.rocket
CFBundleDevelopmentRegion
@@ -24,6 +22,8 @@
$(MARKETING_VERSION)
CFBundleVersion
1
+ KeychainGroup
+ $(AppIdentifierPrefix)chat.rocket.reactnative
NSExtension
NSExtensionPointIdentifier
diff --git a/ios/Official.xcassets/AppIcon.appiconset/100.png b/ios/Official.xcassets/AppIcon.appiconset/100.png
new file mode 100644
index 00000000..7f24a267
Binary files /dev/null and b/ios/Official.xcassets/AppIcon.appiconset/100.png differ
diff --git a/ios/Official.xcassets/AppIcon.appiconset/1024.png b/ios/Official.xcassets/AppIcon.appiconset/1024.png
new file mode 100644
index 00000000..e737a61e
Binary files /dev/null and b/ios/Official.xcassets/AppIcon.appiconset/1024.png differ
diff --git a/ios/Official.xcassets/AppIcon.appiconset/114.png b/ios/Official.xcassets/AppIcon.appiconset/114.png
new file mode 100644
index 00000000..7b5b7e31
Binary files /dev/null and b/ios/Official.xcassets/AppIcon.appiconset/114.png differ
diff --git a/ios/Official.xcassets/AppIcon.appiconset/120.png b/ios/Official.xcassets/AppIcon.appiconset/120.png
new file mode 100644
index 00000000..2db61522
Binary files /dev/null and b/ios/Official.xcassets/AppIcon.appiconset/120.png differ
diff --git a/ios/Official.xcassets/AppIcon.appiconset/144.png b/ios/Official.xcassets/AppIcon.appiconset/144.png
new file mode 100644
index 00000000..9e4461b5
Binary files /dev/null and b/ios/Official.xcassets/AppIcon.appiconset/144.png differ
diff --git a/ios/Official.xcassets/AppIcon.appiconset/152.png b/ios/Official.xcassets/AppIcon.appiconset/152.png
new file mode 100644
index 00000000..ece9c43b
Binary files /dev/null and b/ios/Official.xcassets/AppIcon.appiconset/152.png differ
diff --git a/ios/Official.xcassets/AppIcon.appiconset/167.png b/ios/Official.xcassets/AppIcon.appiconset/167.png
new file mode 100644
index 00000000..c10c5fae
Binary files /dev/null and b/ios/Official.xcassets/AppIcon.appiconset/167.png differ
diff --git a/ios/Official.xcassets/AppIcon.appiconset/180.png b/ios/Official.xcassets/AppIcon.appiconset/180.png
new file mode 100644
index 00000000..e883fea3
Binary files /dev/null and b/ios/Official.xcassets/AppIcon.appiconset/180.png differ
diff --git a/ios/Official.xcassets/AppIcon.appiconset/20.png b/ios/Official.xcassets/AppIcon.appiconset/20.png
new file mode 100644
index 00000000..580f31ab
Binary files /dev/null and b/ios/Official.xcassets/AppIcon.appiconset/20.png differ
diff --git a/ios/Official.xcassets/AppIcon.appiconset/29.png b/ios/Official.xcassets/AppIcon.appiconset/29.png
new file mode 100644
index 00000000..075803b0
Binary files /dev/null and b/ios/Official.xcassets/AppIcon.appiconset/29.png differ
diff --git a/ios/Official.xcassets/AppIcon.appiconset/40.png b/ios/Official.xcassets/AppIcon.appiconset/40.png
new file mode 100644
index 00000000..cc301e7d
Binary files /dev/null and b/ios/Official.xcassets/AppIcon.appiconset/40.png differ
diff --git a/ios/Official.xcassets/AppIcon.appiconset/50.png b/ios/Official.xcassets/AppIcon.appiconset/50.png
new file mode 100644
index 00000000..4b68ad46
Binary files /dev/null and b/ios/Official.xcassets/AppIcon.appiconset/50.png differ
diff --git a/ios/Official.xcassets/AppIcon.appiconset/57.png b/ios/Official.xcassets/AppIcon.appiconset/57.png
new file mode 100644
index 00000000..5af4cfb7
Binary files /dev/null and b/ios/Official.xcassets/AppIcon.appiconset/57.png differ
diff --git a/ios/Official.xcassets/AppIcon.appiconset/58.png b/ios/Official.xcassets/AppIcon.appiconset/58.png
new file mode 100644
index 00000000..e9c3392d
Binary files /dev/null and b/ios/Official.xcassets/AppIcon.appiconset/58.png differ
diff --git a/ios/Official.xcassets/AppIcon.appiconset/60.png b/ios/Official.xcassets/AppIcon.appiconset/60.png
new file mode 100644
index 00000000..57618b80
Binary files /dev/null and b/ios/Official.xcassets/AppIcon.appiconset/60.png differ
diff --git a/ios/Official.xcassets/AppIcon.appiconset/72.png b/ios/Official.xcassets/AppIcon.appiconset/72.png
new file mode 100644
index 00000000..b5399949
Binary files /dev/null and b/ios/Official.xcassets/AppIcon.appiconset/72.png differ
diff --git a/ios/Official.xcassets/AppIcon.appiconset/76.png b/ios/Official.xcassets/AppIcon.appiconset/76.png
new file mode 100644
index 00000000..caef08f4
Binary files /dev/null and b/ios/Official.xcassets/AppIcon.appiconset/76.png differ
diff --git a/ios/Official.xcassets/AppIcon.appiconset/80.png b/ios/Official.xcassets/AppIcon.appiconset/80.png
new file mode 100644
index 00000000..1b956d3d
Binary files /dev/null and b/ios/Official.xcassets/AppIcon.appiconset/80.png differ
diff --git a/ios/Official.xcassets/AppIcon.appiconset/87.png b/ios/Official.xcassets/AppIcon.appiconset/87.png
new file mode 100644
index 00000000..17381abc
Binary files /dev/null and b/ios/Official.xcassets/AppIcon.appiconset/87.png differ
diff --git a/ios/Official.xcassets/AppIcon.appiconset/Contents.json b/ios/Official.xcassets/AppIcon.appiconset/Contents.json
new file mode 100644
index 00000000..4fdf8826
--- /dev/null
+++ b/ios/Official.xcassets/AppIcon.appiconset/Contents.json
@@ -0,0 +1,158 @@
+{
+ "images" : [
+ {
+ "filename" : "40.png",
+ "idiom" : "iphone",
+ "scale" : "2x",
+ "size" : "20x20"
+ },
+ {
+ "filename" : "60.png",
+ "idiom" : "iphone",
+ "scale" : "3x",
+ "size" : "20x20"
+ },
+ {
+ "filename" : "29.png",
+ "idiom" : "iphone",
+ "scale" : "1x",
+ "size" : "29x29"
+ },
+ {
+ "filename" : "58.png",
+ "idiom" : "iphone",
+ "scale" : "2x",
+ "size" : "29x29"
+ },
+ {
+ "filename" : "87.png",
+ "idiom" : "iphone",
+ "scale" : "3x",
+ "size" : "29x29"
+ },
+ {
+ "filename" : "80.png",
+ "idiom" : "iphone",
+ "scale" : "2x",
+ "size" : "40x40"
+ },
+ {
+ "filename" : "120.png",
+ "idiom" : "iphone",
+ "scale" : "3x",
+ "size" : "40x40"
+ },
+ {
+ "filename" : "57.png",
+ "idiom" : "iphone",
+ "scale" : "1x",
+ "size" : "57x57"
+ },
+ {
+ "filename" : "114.png",
+ "idiom" : "iphone",
+ "scale" : "2x",
+ "size" : "57x57"
+ },
+ {
+ "filename" : "120.png",
+ "idiom" : "iphone",
+ "scale" : "2x",
+ "size" : "60x60"
+ },
+ {
+ "filename" : "180.png",
+ "idiom" : "iphone",
+ "scale" : "3x",
+ "size" : "60x60"
+ },
+ {
+ "filename" : "20.png",
+ "idiom" : "ipad",
+ "scale" : "1x",
+ "size" : "20x20"
+ },
+ {
+ "filename" : "40.png",
+ "idiom" : "ipad",
+ "scale" : "2x",
+ "size" : "20x20"
+ },
+ {
+ "filename" : "29.png",
+ "idiom" : "ipad",
+ "scale" : "1x",
+ "size" : "29x29"
+ },
+ {
+ "filename" : "58.png",
+ "idiom" : "ipad",
+ "scale" : "2x",
+ "size" : "29x29"
+ },
+ {
+ "filename" : "40.png",
+ "idiom" : "ipad",
+ "scale" : "1x",
+ "size" : "40x40"
+ },
+ {
+ "filename" : "80.png",
+ "idiom" : "ipad",
+ "scale" : "2x",
+ "size" : "40x40"
+ },
+ {
+ "filename" : "50.png",
+ "idiom" : "ipad",
+ "scale" : "1x",
+ "size" : "50x50"
+ },
+ {
+ "filename" : "100.png",
+ "idiom" : "ipad",
+ "scale" : "2x",
+ "size" : "50x50"
+ },
+ {
+ "filename" : "72.png",
+ "idiom" : "ipad",
+ "scale" : "1x",
+ "size" : "72x72"
+ },
+ {
+ "filename" : "144.png",
+ "idiom" : "ipad",
+ "scale" : "2x",
+ "size" : "72x72"
+ },
+ {
+ "filename" : "76.png",
+ "idiom" : "ipad",
+ "scale" : "1x",
+ "size" : "76x76"
+ },
+ {
+ "filename" : "152.png",
+ "idiom" : "ipad",
+ "scale" : "2x",
+ "size" : "76x76"
+ },
+ {
+ "filename" : "167.png",
+ "idiom" : "ipad",
+ "scale" : "2x",
+ "size" : "83.5x83.5"
+ },
+ {
+ "filename" : "1024.png",
+ "idiom" : "ios-marketing",
+ "scale" : "1x",
+ "size" : "1024x1024"
+ }
+ ],
+ "info" : {
+ "author" : "xcode",
+ "version" : 1
+ }
+}
diff --git a/ios/Official.xcassets/Contents.json b/ios/Official.xcassets/Contents.json
new file mode 100644
index 00000000..73c00596
--- /dev/null
+++ b/ios/Official.xcassets/Contents.json
@@ -0,0 +1,6 @@
+{
+ "info" : {
+ "author" : "xcode",
+ "version" : 1
+ }
+}
diff --git a/ios/Official.xcassets/Launch Screen Icon.imageset/Contents.json b/ios/Official.xcassets/Launch Screen Icon.imageset/Contents.json
new file mode 100644
index 00000000..a7e67757
--- /dev/null
+++ b/ios/Official.xcassets/Launch Screen Icon.imageset/Contents.json
@@ -0,0 +1,23 @@
+{
+ "images" : [
+ {
+ "filename" : "Icon.png",
+ "idiom" : "universal",
+ "scale" : "1x"
+ },
+ {
+ "filename" : "Icon@2x.png",
+ "idiom" : "universal",
+ "scale" : "2x"
+ },
+ {
+ "filename" : "Icon@3x.png",
+ "idiom" : "universal",
+ "scale" : "3x"
+ }
+ ],
+ "info" : {
+ "author" : "xcode",
+ "version" : 1
+ }
+}
diff --git a/ios/Official.xcassets/Launch Screen Icon.imageset/Icon.png b/ios/Official.xcassets/Launch Screen Icon.imageset/Icon.png
new file mode 100644
index 00000000..624302b8
Binary files /dev/null and b/ios/Official.xcassets/Launch Screen Icon.imageset/Icon.png differ
diff --git a/ios/Official.xcassets/Launch Screen Icon.imageset/Icon@2x.png b/ios/Official.xcassets/Launch Screen Icon.imageset/Icon@2x.png
new file mode 100644
index 00000000..46b4dedd
Binary files /dev/null and b/ios/Official.xcassets/Launch Screen Icon.imageset/Icon@2x.png differ
diff --git a/ios/Official.xcassets/Launch Screen Icon.imageset/Icon@3x.png b/ios/Official.xcassets/Launch Screen Icon.imageset/Icon@3x.png
new file mode 100644
index 00000000..9ff1d336
Binary files /dev/null and b/ios/Official.xcassets/Launch Screen Icon.imageset/Icon@3x.png differ
diff --git a/ios/RocketChatRN/Images.xcassets/splashBackgroundColor.colorset/Contents.json b/ios/Official.xcassets/splashBackgroundColor.colorset/Contents.json
similarity index 85%
rename from ios/RocketChatRN/Images.xcassets/splashBackgroundColor.colorset/Contents.json
rename to ios/Official.xcassets/splashBackgroundColor.colorset/Contents.json
index 0e90a95d..07fb2c4e 100644
--- a/ios/RocketChatRN/Images.xcassets/splashBackgroundColor.colorset/Contents.json
+++ b/ios/Official.xcassets/splashBackgroundColor.colorset/Contents.json
@@ -23,9 +23,9 @@
"color-space" : "extended-srgb",
"components" : {
"alpha" : "1.000",
- "blue" : "0xF5",
- "green" : "0x74",
- "red" : "0x1D"
+ "blue" : "0x5C",
+ "green" : "0x45",
+ "red" : "0xF5"
}
},
"idiom" : "universal"
@@ -41,9 +41,9 @@
"color-space" : "srgb",
"components" : {
"alpha" : "1.000",
- "blue" : "0x00",
- "green" : "0x00",
- "red" : "0x00"
+ "blue" : "0.000",
+ "green" : "0.000",
+ "red" : "0.000"
}
},
"idiom" : "universal"
diff --git a/ios/RocketChatRN.xcodeproj/project.pbxproj b/ios/RocketChatRN.xcodeproj/project.pbxproj
index b9004681..2b0d2700 100644
--- a/ios/RocketChatRN.xcodeproj/project.pbxproj
+++ b/ios/RocketChatRN.xcodeproj/project.pbxproj
@@ -87,10 +87,58 @@
50046CB6BDA69B9232CF66D9 /* libPods-RocketChatRN.a in Frameworks */ = {isa = PBXBuildFile; fileRef = C235DC7B31A4D1578EDEF219 /* libPods-RocketChatRN.a */; };
7A006F14229C83B600803143 /* GoogleService-Info.plist in Resources */ = {isa = PBXBuildFile; fileRef = 7A006F13229C83B600803143 /* GoogleService-Info.plist */; };
7A0D62D2242AB187006D5C06 /* LaunchScreen.storyboard in Resources */ = {isa = PBXBuildFile; fileRef = 7A0D62D1242AB187006D5C06 /* LaunchScreen.storyboard */; };
+ 7A14FCED257FEB3A005BDCD4 /* Experimental.xcassets in Resources */ = {isa = PBXBuildFile; fileRef = 7A14FCEC257FEB3A005BDCD4 /* Experimental.xcassets */; };
+ 7A14FCF4257FEB59005BDCD4 /* Official.xcassets in Resources */ = {isa = PBXBuildFile; fileRef = 7A14FCF3257FEB59005BDCD4 /* Official.xcassets */; };
7A3268F624F04FFE0050E241 /* custom.ttf in Resources */ = {isa = PBXBuildFile; fileRef = 7A3268F524F04FFE0050E241 /* custom.ttf */; };
7A3268F724F04FFE0050E241 /* custom.ttf in Resources */ = {isa = PBXBuildFile; fileRef = 7A3268F524F04FFE0050E241 /* custom.ttf */; };
- 7AAA749E23043B1E00F1ADE9 /* Watermelon.swift in Sources */ = {isa = PBXBuildFile; fileRef = 7AAA749D23043B1E00F1ADE9 /* Watermelon.swift */; };
- 7AC99C1C2339361F0000A0CB /* Watermelon.swift in Sources */ = {isa = PBXBuildFile; fileRef = 7AAA749D23043B1E00F1ADE9 /* Watermelon.swift */; };
+ 7AAB3E15257E6A6E00707CF6 /* Sender.swift in Sources */ = {isa = PBXBuildFile; fileRef = 1E01C8282511304100FEF824 /* Sender.swift */; };
+ 7AAB3E16257E6A6E00707CF6 /* Request.swift in Sources */ = {isa = PBXBuildFile; fileRef = 1E680ED82512990700C9257A /* Request.swift */; };
+ 7AAB3E17257E6A6E00707CF6 /* ReplyNotification.swift in Sources */ = {isa = PBXBuildFile; fileRef = 1ED00BB02513E04400A1331F /* ReplyNotification.swift */; };
+ 7AAB3E18257E6A6E00707CF6 /* Storage.swift in Sources */ = {isa = PBXBuildFile; fileRef = 1EB8EF712510F1EE00F352B7 /* Storage.swift */; };
+ 7AAB3E19257E6A6E00707CF6 /* Push.swift in Sources */ = {isa = PBXBuildFile; fileRef = 1E2F61652512958900871711 /* Push.swift */; };
+ 7AAB3E1A257E6A6E00707CF6 /* RoomType.swift in Sources */ = {isa = PBXBuildFile; fileRef = 1E0426E5251A5467008F022C /* RoomType.swift */; };
+ 7AAB3E1B257E6A6E00707CF6 /* MessageType.swift in Sources */ = {isa = PBXBuildFile; fileRef = 1E51D961251263CD00DC95DE /* MessageType.swift */; };
+ 7AAB3E1C257E6A6E00707CF6 /* PushResponse.swift in Sources */ = {isa = PBXBuildFile; fileRef = 1E01C8202511301400FEF824 /* PushResponse.swift */; };
+ 7AAB3E1D257E6A6E00707CF6 /* AppDelegate.m in Sources */ = {isa = PBXBuildFile; fileRef = 13B07FB01A68108700A75B9A /* AppDelegate.m */; };
+ 7AAB3E1E257E6A6E00707CF6 /* Encryption.swift in Sources */ = {isa = PBXBuildFile; fileRef = 1EF5FBD0250C109E00614FEA /* Encryption.swift */; };
+ 7AAB3E1F257E6A6E00707CF6 /* RocketChat.swift in Sources */ = {isa = PBXBuildFile; fileRef = 1E470E822513A71E00E3DD1D /* RocketChat.swift */; };
+ 7AAB3E20257E6A6E00707CF6 /* HTTPMethod.swift in Sources */ = {isa = PBXBuildFile; fileRef = 1E2F61632512955D00871711 /* HTTPMethod.swift */; };
+ 7AAB3E21257E6A6E00707CF6 /* Payload.swift in Sources */ = {isa = PBXBuildFile; fileRef = 1E01C8262511303900FEF824 /* Payload.swift */; };
+ 7AAB3E23257E6A6E00707CF6 /* Data+Extensions.swift in Sources */ = {isa = PBXBuildFile; fileRef = 1E598AE625150660002BDFBD /* Data+Extensions.swift */; };
+ 7AAB3E24257E6A6E00707CF6 /* Date+Extensions.swift in Sources */ = {isa = PBXBuildFile; fileRef = 1E598AE32515057D002BDFBD /* Date+Extensions.swift */; };
+ 7AAB3E25257E6A6E00707CF6 /* Database.swift in Sources */ = {isa = PBXBuildFile; fileRef = 1E1C2F7F250FCB69005DCE7D /* Database.swift */; };
+ 7AAB3E26257E6A6E00707CF6 /* String+Extensions.swift in Sources */ = {isa = PBXBuildFile; fileRef = 1E67380324DC529B0009E081 /* String+Extensions.swift */; };
+ 7AAB3E27257E6A6E00707CF6 /* Notification.swift in Sources */ = {isa = PBXBuildFile; fileRef = 1E01C8242511303100FEF824 /* Notification.swift */; };
+ 7AAB3E28257E6A6E00707CF6 /* API.swift in Sources */ = {isa = PBXBuildFile; fileRef = 1E2F615A25128F9A00871711 /* API.swift */; };
+ 7AAB3E29257E6A6E00707CF6 /* Response.swift in Sources */ = {isa = PBXBuildFile; fileRef = 1E2F615C25128FA300871711 /* Response.swift */; };
+ 7AAB3E2A257E6A6E00707CF6 /* AppGroup.m in Sources */ = {isa = PBXBuildFile; fileRef = 1E068D0024FD2E0500A0FFC1 /* AppGroup.m */; };
+ 7AAB3E2B257E6A6E00707CF6 /* main.m in Sources */ = {isa = PBXBuildFile; fileRef = 13B07FB71A68108700A75B9A /* main.m */; };
+ 7AAB3E2C257E6A6E00707CF6 /* URL+Extensions.swift in Sources */ = {isa = PBXBuildFile; fileRef = 1E01C81B2511208400FEF824 /* URL+Extensions.swift */; };
+ 7AAB3E2D257E6A6E00707CF6 /* AppGroup.swift in Sources */ = {isa = PBXBuildFile; fileRef = 1E068CFD24FD2DC700A0FFC1 /* AppGroup.swift */; };
+ 7AAB3E2E257E6A6E00707CF6 /* RoomKey.swift in Sources */ = {isa = PBXBuildFile; fileRef = 1E01C82C2511337700FEF824 /* RoomKey.swift */; };
+ 7AAB3E2F257E6A6E00707CF6 /* Message.swift in Sources */ = {isa = PBXBuildFile; fileRef = 1E01C82A2511335A00FEF824 /* Message.swift */; };
+ 7AAB3E30257E6A6E00707CF6 /* NotificationType.swift in Sources */ = {isa = PBXBuildFile; fileRef = 1E51D964251263D600DC95DE /* NotificationType.swift */; };
+ 7AAB3E31257E6A6E00707CF6 /* SendMessage.swift in Sources */ = {isa = PBXBuildFile; fileRef = 1E598AE825151A63002BDFBD /* SendMessage.swift */; };
+ 7AAB3E33257E6A6E00707CF6 /* libc++.tbd in Frameworks */ = {isa = PBXBuildFile; fileRef = B37C79D9BD0742CE936B6982 /* libc++.tbd */; };
+ 7AAB3E34257E6A6E00707CF6 /* libsqlite3.tbd in Frameworks */ = {isa = PBXBuildFile; fileRef = 1E1EA8192326CD5100E22452 /* libsqlite3.tbd */; };
+ 7AAB3E35257E6A6E00707CF6 /* libc.tbd in Frameworks */ = {isa = PBXBuildFile; fileRef = 1E1EA8172326CD4B00E22452 /* libc.tbd */; };
+ 7AAB3E36257E6A6E00707CF6 /* VideoToolbox.framework in Frameworks */ = {isa = PBXBuildFile; fileRef = 1E1EA8152326CD4500E22452 /* VideoToolbox.framework */; };
+ 7AAB3E37257E6A6E00707CF6 /* CoreVideo.framework in Frameworks */ = {isa = PBXBuildFile; fileRef = 1E1EA8132326CD3E00E22452 /* CoreVideo.framework */; };
+ 7AAB3E38257E6A6E00707CF6 /* CoreAudio.framework in Frameworks */ = {isa = PBXBuildFile; fileRef = 1E1EA8112326CD3900E22452 /* CoreAudio.framework */; };
+ 7AAB3E39257E6A6E00707CF6 /* GLKit.framework in Frameworks */ = {isa = PBXBuildFile; fileRef = 1E1EA80F2326CD3300E22452 /* GLKit.framework */; };
+ 7AAB3E3A257E6A6E00707CF6 /* CoreGraphics.framework in Frameworks */ = {isa = PBXBuildFile; fileRef = 1E1EA80D2326CD2F00E22452 /* CoreGraphics.framework */; };
+ 7AAB3E3B257E6A6E00707CF6 /* AudioToolbox.framework in Frameworks */ = {isa = PBXBuildFile; fileRef = 1E1EA80B2326CD2800E22452 /* AudioToolbox.framework */; };
+ 7AAB3E3C257E6A6E00707CF6 /* AVFoundation.framework in Frameworks */ = {isa = PBXBuildFile; fileRef = 1E1EA8092326CD2200E22452 /* AVFoundation.framework */; };
+ 7AAB3E3D257E6A6E00707CF6 /* JavaScriptCore.framework in Frameworks */ = {isa = PBXBuildFile; fileRef = 7ACD4853222860DE00442C55 /* JavaScriptCore.framework */; };
+ 7AAB3E3E257E6A6E00707CF6 /* libz.tbd in Frameworks */ = {isa = PBXBuildFile; fileRef = 06BB44DD4855498082A744AD /* libz.tbd */; };
+ 7AAB3E3F257E6A6E00707CF6 /* libWatermelonDB.a in Frameworks */ = {isa = PBXBuildFile; fileRef = BA7E862283664608B3894E34 /* libWatermelonDB.a */; };
+ 7AAB3E40257E6A6E00707CF6 /* libPods-RocketChatRN.a in Frameworks */ = {isa = PBXBuildFile; fileRef = C235DC7B31A4D1578EDEF219 /* libPods-RocketChatRN.a */; };
+ 7AAB3E42257E6A6E00707CF6 /* Images.xcassets in Resources */ = {isa = PBXBuildFile; fileRef = 13B07FB51A68108700A75B9A /* Images.xcassets */; };
+ 7AAB3E43257E6A6E00707CF6 /* custom.ttf in Resources */ = {isa = PBXBuildFile; fileRef = 7A3268F524F04FFE0050E241 /* custom.ttf */; };
+ 7AAB3E44257E6A6E00707CF6 /* GoogleService-Info.plist in Resources */ = {isa = PBXBuildFile; fileRef = 7A006F13229C83B600803143 /* GoogleService-Info.plist */; };
+ 7AAB3E45257E6A6E00707CF6 /* LaunchScreen.storyboard in Resources */ = {isa = PBXBuildFile; fileRef = 7A0D62D1242AB187006D5C06 /* LaunchScreen.storyboard */; };
+ 7AAB3E49257E6A6E00707CF6 /* ShareRocketChatRN.appex in Embed App Extensions */ = {isa = PBXBuildFile; fileRef = 1EC6ACB022CB9FC300A41C61 /* ShareRocketChatRN.appex */; settings = {ATTRIBUTES = (RemoveHeadersOnCopy, ); }; };
+ 7AAB3E4A257E6A6E00707CF6 /* NotificationService.appex in Embed App Extensions */ = {isa = PBXBuildFile; fileRef = 1EFEB5952493B6640072EDC0 /* NotificationService.appex */; settings = {ATTRIBUTES = (RemoveHeadersOnCopy, ); }; };
7ACD4897222860DE00442C55 /* JavaScriptCore.framework in Frameworks */ = {isa = PBXBuildFile; fileRef = 7ACD4853222860DE00442C55 /* JavaScriptCore.framework */; };
DD2BA30A89E64F189C2C24AC /* libWatermelonDB.a in Frameworks */ = {isa = PBXBuildFile; fileRef = BA7E862283664608B3894E34 /* libWatermelonDB.a */; };
/* End PBXBuildFile section */
@@ -117,6 +165,20 @@
remoteGlobalIDString = 6E660D5E213BCCD300189354;
remoteInfo = WatermelonDB;
};
+ 7AAB3E0F257E6A6E00707CF6 /* PBXContainerItemProxy */ = {
+ isa = PBXContainerItemProxy;
+ containerPortal = 83CBB9F71A601CBA00E9B192 /* Project object */;
+ proxyType = 1;
+ remoteGlobalIDString = 1EC6ACAF22CB9FC300A41C61;
+ remoteInfo = ShareRocketChatRN;
+ };
+ 7AAB3E11257E6A6E00707CF6 /* PBXContainerItemProxy */ = {
+ isa = PBXContainerItemProxy;
+ containerPortal = 83CBB9F71A601CBA00E9B192 /* Project object */;
+ proxyType = 1;
+ remoteGlobalIDString = 1EFEB5942493B6640072EDC0;
+ remoteInfo = NotificationService;
+ };
/* End PBXContainerItemProxy section */
/* Begin PBXCopyFilesBuildPhase section */
@@ -132,6 +194,18 @@
name = "Embed App Extensions";
runOnlyForDeploymentPostprocessing = 0;
};
+ 7AAB3E48257E6A6E00707CF6 /* Embed App Extensions */ = {
+ isa = PBXCopyFilesBuildPhase;
+ buildActionMask = 2147483647;
+ dstPath = "";
+ dstSubfolderSpec = 13;
+ files = (
+ 7AAB3E49257E6A6E00707CF6 /* ShareRocketChatRN.appex in Embed App Extensions */,
+ 7AAB3E4A257E6A6E00707CF6 /* NotificationService.appex in Embed App Extensions */,
+ );
+ name = "Embed App Extensions";
+ runOnlyForDeploymentPostprocessing = 0;
+ };
/* End PBXCopyFilesBuildPhase section */
/* Begin PBXFileReference section */
@@ -139,7 +213,7 @@
037C33B0D9A54FB4CB670FB7 /* Pods-ShareRocketChatRN.release.xcconfig */ = {isa = PBXFileReference; includeInIndex = 1; lastKnownFileType = text.xcconfig; name = "Pods-ShareRocketChatRN.release.xcconfig"; path = "Pods/Target Support Files/Pods-ShareRocketChatRN/Pods-ShareRocketChatRN.release.xcconfig"; sourceTree = ""; };
0383633C4523666C176CAA52 /* Pods-ShareRocketChatRN.debug.xcconfig */ = {isa = PBXFileReference; includeInIndex = 1; lastKnownFileType = text.xcconfig; name = "Pods-ShareRocketChatRN.debug.xcconfig"; path = "Pods/Target Support Files/Pods-ShareRocketChatRN/Pods-ShareRocketChatRN.debug.xcconfig"; sourceTree = ""; };
06BB44DD4855498082A744AD /* libz.tbd */ = {isa = PBXFileReference; explicitFileType = undefined; fileEncoding = 9; includeInIndex = 0; lastKnownFileType = "sourcecode.text-based-dylib-definition"; name = libz.tbd; path = usr/lib/libz.tbd; sourceTree = SDKROOT; };
- 13B07F961A680F5B00A75B9A /* RocketChatRN.app */ = {isa = PBXFileReference; explicitFileType = wrapper.application; includeInIndex = 0; path = RocketChatRN.app; sourceTree = BUILT_PRODUCTS_DIR; };
+ 13B07F961A680F5B00A75B9A /* Rocket.Chat Experimental.app */ = {isa = PBXFileReference; explicitFileType = wrapper.application; includeInIndex = 0; path = "Rocket.Chat Experimental.app"; sourceTree = BUILT_PRODUCTS_DIR; };
13B07FAF1A68108700A75B9A /* AppDelegate.h */ = {isa = PBXFileReference; fileEncoding = 4; lastKnownFileType = sourcecode.c.h; name = AppDelegate.h; path = RocketChatRN/AppDelegate.h; sourceTree = ""; };
13B07FB01A68108700A75B9A /* AppDelegate.m */ = {isa = PBXFileReference; fileEncoding = 4; lastKnownFileType = sourcecode.c.objc; name = AppDelegate.m; path = RocketChatRN/AppDelegate.m; sourceTree = ""; };
13B07FB51A68108700A75B9A /* Images.xcassets */ = {isa = PBXFileReference; lastKnownFileType = folder.assetcatalog; name = Images.xcassets; path = RocketChatRN/Images.xcassets; sourceTree = ""; };
@@ -197,9 +271,11 @@
66D6B1D0567051BE541450C9 /* Pods-RocketChatRN.release.xcconfig */ = {isa = PBXFileReference; includeInIndex = 1; lastKnownFileType = text.xcconfig; name = "Pods-RocketChatRN.release.xcconfig"; path = "Pods/Target Support Files/Pods-RocketChatRN/Pods-RocketChatRN.release.xcconfig"; sourceTree = ""; };
7A006F13229C83B600803143 /* GoogleService-Info.plist */ = {isa = PBXFileReference; fileEncoding = 4; lastKnownFileType = text.plist.xml; path = "GoogleService-Info.plist"; sourceTree = ""; };
7A0D62D1242AB187006D5C06 /* LaunchScreen.storyboard */ = {isa = PBXFileReference; fileEncoding = 4; lastKnownFileType = file.storyboard; path = LaunchScreen.storyboard; sourceTree = ""; };
+ 7A14FCEC257FEB3A005BDCD4 /* Experimental.xcassets */ = {isa = PBXFileReference; lastKnownFileType = folder.assetcatalog; path = Experimental.xcassets; sourceTree = ""; };
+ 7A14FCF3257FEB59005BDCD4 /* Official.xcassets */ = {isa = PBXFileReference; lastKnownFileType = folder.assetcatalog; path = Official.xcassets; sourceTree = ""; };
7A3268F524F04FFE0050E241 /* custom.ttf */ = {isa = PBXFileReference; lastKnownFileType = file; path = custom.ttf; sourceTree = ""; };
7AAA749C23043B1D00F1ADE9 /* RocketChatRN-Bridging-Header.h */ = {isa = PBXFileReference; lastKnownFileType = sourcecode.c.h; path = "RocketChatRN-Bridging-Header.h"; sourceTree = ""; };
- 7AAA749D23043B1E00F1ADE9 /* Watermelon.swift */ = {isa = PBXFileReference; lastKnownFileType = sourcecode.swift; path = Watermelon.swift; sourceTree = ""; };
+ 7AAB3E52257E6A6E00707CF6 /* Rocket.Chat.app */ = {isa = PBXFileReference; explicitFileType = wrapper.application; includeInIndex = 0; path = Rocket.Chat.app; sourceTree = BUILT_PRODUCTS_DIR; };
7ACD4853222860DE00442C55 /* JavaScriptCore.framework */ = {isa = PBXFileReference; lastKnownFileType = wrapper.framework; name = JavaScriptCore.framework; path = System/Library/Frameworks/JavaScriptCore.framework; sourceTree = SDKROOT; };
81411D280138EF5344596C2F /* libPods-NotificationService.a */ = {isa = PBXFileReference; explicitFileType = archive.ar; includeInIndex = 0; path = "libPods-NotificationService.a"; sourceTree = BUILT_PRODUCTS_DIR; };
9730F55A254AC78BC5361659 /* Pods-NotificationService.release.xcconfig */ = {isa = PBXFileReference; includeInIndex = 1; lastKnownFileType = text.xcconfig; name = "Pods-NotificationService.release.xcconfig"; path = "Pods/Target Support Files/Pods-NotificationService/Pods-NotificationService.release.xcconfig"; sourceTree = ""; };
@@ -251,6 +327,27 @@
);
runOnlyForDeploymentPostprocessing = 0;
};
+ 7AAB3E32257E6A6E00707CF6 /* Frameworks */ = {
+ isa = PBXFrameworksBuildPhase;
+ buildActionMask = 2147483647;
+ files = (
+ 7AAB3E33257E6A6E00707CF6 /* libc++.tbd in Frameworks */,
+ 7AAB3E34257E6A6E00707CF6 /* libsqlite3.tbd in Frameworks */,
+ 7AAB3E35257E6A6E00707CF6 /* libc.tbd in Frameworks */,
+ 7AAB3E36257E6A6E00707CF6 /* VideoToolbox.framework in Frameworks */,
+ 7AAB3E37257E6A6E00707CF6 /* CoreVideo.framework in Frameworks */,
+ 7AAB3E38257E6A6E00707CF6 /* CoreAudio.framework in Frameworks */,
+ 7AAB3E39257E6A6E00707CF6 /* GLKit.framework in Frameworks */,
+ 7AAB3E3A257E6A6E00707CF6 /* CoreGraphics.framework in Frameworks */,
+ 7AAB3E3B257E6A6E00707CF6 /* AudioToolbox.framework in Frameworks */,
+ 7AAB3E3C257E6A6E00707CF6 /* AVFoundation.framework in Frameworks */,
+ 7AAB3E3D257E6A6E00707CF6 /* JavaScriptCore.framework in Frameworks */,
+ 7AAB3E3E257E6A6E00707CF6 /* libz.tbd in Frameworks */,
+ 7AAB3E3F257E6A6E00707CF6 /* libWatermelonDB.a in Frameworks */,
+ 7AAB3E40257E6A6E00707CF6 /* libPods-RocketChatRN.a in Frameworks */,
+ );
+ runOnlyForDeploymentPostprocessing = 0;
+ };
/* End PBXFrameworksBuildPhase section */
/* Begin PBXGroup section */
@@ -263,9 +360,10 @@
13B07FAF1A68108700A75B9A /* AppDelegate.h */,
13B07FB01A68108700A75B9A /* AppDelegate.m */,
13B07FB51A68108700A75B9A /* Images.xcassets */,
+ 7A14FCEC257FEB3A005BDCD4 /* Experimental.xcassets */,
+ 7A14FCF3257FEB59005BDCD4 /* Official.xcassets */,
13B07FB61A68108700A75B9A /* Info.plist */,
13B07FB71A68108700A75B9A /* main.m */,
- 7AAA749D23043B1E00F1ADE9 /* Watermelon.swift */,
7AAA749C23043B1D00F1ADE9 /* RocketChatRN-Bridging-Header.h */,
7A0D62D1242AB187006D5C06 /* LaunchScreen.storyboard */,
1ED00BB02513E04400A1331F /* ReplyNotification.swift */,
@@ -426,9 +524,10 @@
83CBBA001A601CBA00E9B192 /* Products */ = {
isa = PBXGroup;
children = (
- 13B07F961A680F5B00A75B9A /* RocketChatRN.app */,
+ 13B07F961A680F5B00A75B9A /* Rocket.Chat Experimental.app */,
1EC6ACB022CB9FC300A41C61 /* ShareRocketChatRN.appex */,
1EFEB5952493B6640072EDC0 /* NotificationService.appex */,
+ 7AAB3E52257E6A6E00707CF6 /* Rocket.Chat.app */,
);
name = Products;
sourceTree = "";
@@ -499,7 +598,7 @@
);
name = RocketChatRN;
productName = "Hello World";
- productReference = 13B07F961A680F5B00A75B9A /* RocketChatRN.app */;
+ productReference = 13B07F961A680F5B00A75B9A /* Rocket.Chat Experimental.app */;
productType = "com.apple.product-type.application";
};
1EC6ACAF22CB9FC300A41C61 /* ShareRocketChatRN */ = {
@@ -545,6 +644,34 @@
productReference = 1EFEB5952493B6640072EDC0 /* NotificationService.appex */;
productType = "com.apple.product-type.app-extension";
};
+ 7AAB3E0D257E6A6E00707CF6 /* Rocket.Chat */ = {
+ isa = PBXNativeTarget;
+ buildConfigurationList = 7AAB3E4F257E6A6E00707CF6 /* Build configuration list for PBXNativeTarget "Rocket.Chat" */;
+ buildPhases = (
+ 7AAB3E12257E6A6E00707CF6 /* [CP] Check Pods Manifest.lock */,
+ 7AAB3E13257E6A6E00707CF6 /* Start Packager */,
+ 7AAB3E14257E6A6E00707CF6 /* Sources */,
+ 7AAB3E32257E6A6E00707CF6 /* Frameworks */,
+ 7AAB3E41257E6A6E00707CF6 /* Resources */,
+ 7AAB3E46257E6A6E00707CF6 /* Bundle React Native code and images */,
+ 7AAB3E47257E6A6E00707CF6 /* [CP] Copy Pods Resources */,
+ 7AAB3E48257E6A6E00707CF6 /* Embed App Extensions */,
+ 7AAB3E4B257E6A6E00707CF6 /* ShellScript */,
+ 7AAB3E4C257E6A6E00707CF6 /* [CP] Embed Pods Frameworks */,
+ 7AAB3E4D257E6A6E00707CF6 /* [CP-User] [RNFB] Core Configuration */,
+ 7AAB3E4E257E6A6E00707CF6 /* [CP-User] [RNFB] Crashlytics Configuration */,
+ );
+ buildRules = (
+ );
+ dependencies = (
+ 7AAB3E0E257E6A6E00707CF6 /* PBXTargetDependency */,
+ 7AAB3E10257E6A6E00707CF6 /* PBXTargetDependency */,
+ );
+ name = Rocket.Chat;
+ productName = "Hello World";
+ productReference = 7AAB3E52257E6A6E00707CF6 /* Rocket.Chat.app */;
+ productType = "com.apple.product-type.application";
+ };
/* End PBXNativeTarget section */
/* Begin PBXProject section */
@@ -590,6 +717,10 @@
DevelopmentTeam = S6UPZG7ZR3;
ProvisioningStyle = Manual;
};
+ 7AAB3E0D257E6A6E00707CF6 = {
+ DevelopmentTeam = S6UPZG7ZR3;
+ ProvisioningStyle = Manual;
+ };
};
};
buildConfigurationList = 83CBB9FA1A601CBA00E9B192 /* Build configuration list for PBXProject "RocketChatRN" */;
@@ -615,6 +746,7 @@
13B07F861A680F5B00A75B9A /* RocketChatRN */,
1EC6ACAF22CB9FC300A41C61 /* ShareRocketChatRN */,
1EFEB5942493B6640072EDC0 /* NotificationService */,
+ 7AAB3E0D257E6A6E00707CF6 /* Rocket.Chat */,
);
};
/* End PBXProject section */
@@ -636,6 +768,7 @@
files = (
13B07FBF1A68108700A75B9A /* Images.xcassets in Resources */,
7A3268F624F04FFE0050E241 /* custom.ttf in Resources */,
+ 7A14FCED257FEB3A005BDCD4 /* Experimental.xcassets in Resources */,
7A006F14229C83B600803143 /* GoogleService-Info.plist in Resources */,
7A0D62D2242AB187006D5C06 /* LaunchScreen.storyboard in Resources */,
);
@@ -659,6 +792,18 @@
);
runOnlyForDeploymentPostprocessing = 0;
};
+ 7AAB3E41257E6A6E00707CF6 /* Resources */ = {
+ isa = PBXResourcesBuildPhase;
+ buildActionMask = 2147483647;
+ files = (
+ 7A14FCF4257FEB59005BDCD4 /* Official.xcassets in Resources */,
+ 7AAB3E42257E6A6E00707CF6 /* Images.xcassets in Resources */,
+ 7AAB3E43257E6A6E00707CF6 /* custom.ttf in Resources */,
+ 7AAB3E44257E6A6E00707CF6 /* GoogleService-Info.plist in Resources */,
+ 7AAB3E45257E6A6E00707CF6 /* LaunchScreen.storyboard in Resources */,
+ );
+ runOnlyForDeploymentPostprocessing = 0;
+ };
/* End PBXResourcesBuildPhase section */
/* Begin PBXShellScriptBuildPhase section */
@@ -868,6 +1013,167 @@
shellPath = /bin/sh;
shellScript = "export RCT_METRO_PORT=\"${RCT_METRO_PORT:=8081}\"\necho \"export RCT_METRO_PORT=${RCT_METRO_PORT}\" > \"${SRCROOT}/../node_modules/react-native/scripts/.packager.env\"\nif [ -z \"${RCT_NO_LAUNCH_PACKAGER+xxx}\" ] ; then\n if nc -w 5 -z localhost ${RCT_METRO_PORT} ; then\n if ! curl -s \"http://localhost:${RCT_METRO_PORT}/status\" | grep -q \"packager-status:running\" ; then\n echo \"Port ${RCT_METRO_PORT} already in use, packager is either not running or not running correctly\"\n exit 2\n fi\n else\n open \"$SRCROOT/../node_modules/react-native/scripts/launchPackager.command\" || echo \"Can't start packager automatically\"\n fi\nfi\n";
};
+ 7AAB3E12257E6A6E00707CF6 /* [CP] Check Pods Manifest.lock */ = {
+ isa = PBXShellScriptBuildPhase;
+ buildActionMask = 2147483647;
+ files = (
+ );
+ inputPaths = (
+ "${PODS_PODFILE_DIR_PATH}/Podfile.lock",
+ "${PODS_ROOT}/Manifest.lock",
+ );
+ name = "[CP] Check Pods Manifest.lock";
+ outputPaths = (
+ "$(DERIVED_FILE_DIR)/Pods-RocketChatRN-checkManifestLockResult.txt",
+ );
+ runOnlyForDeploymentPostprocessing = 0;
+ shellPath = /bin/sh;
+ shellScript = "diff \"${PODS_PODFILE_DIR_PATH}/Podfile.lock\" \"${PODS_ROOT}/Manifest.lock\" > /dev/null\nif [ $? != 0 ] ; then\n # print error to STDERR\n echo \"error: The sandbox is not in sync with the Podfile.lock. Run 'pod install' or update your CocoaPods installation.\" >&2\n exit 1\nfi\n# This output is used by Xcode 'outputs' to avoid re-running this script phase.\necho \"SUCCESS\" > \"${SCRIPT_OUTPUT_FILE_0}\"\n";
+ showEnvVarsInLog = 0;
+ };
+ 7AAB3E13257E6A6E00707CF6 /* Start Packager */ = {
+ isa = PBXShellScriptBuildPhase;
+ buildActionMask = 2147483647;
+ files = (
+ );
+ inputFileListPaths = (
+ );
+ inputPaths = (
+ );
+ name = "Start Packager";
+ outputFileListPaths = (
+ );
+ outputPaths = (
+ );
+ runOnlyForDeploymentPostprocessing = 0;
+ shellPath = /bin/sh;
+ shellScript = "export RCT_METRO_PORT=\"${RCT_METRO_PORT:=8081}\"\necho \"export RCT_METRO_PORT=${RCT_METRO_PORT}\" > \"${SRCROOT}/../node_modules/react-native/scripts/.packager.env\"\nif [ -z \"${RCT_NO_LAUNCH_PACKAGER+xxx}\" ] ; then\n if nc -w 5 -z localhost ${RCT_METRO_PORT} ; then\n if ! curl -s \"http://localhost:${RCT_METRO_PORT}/status\" | grep -q \"packager-status:running\" ; then\n echo \"Port ${RCT_METRO_PORT} already in use, packager is either not running or not running correctly\"\n exit 2\n fi\n else\n open \"$SRCROOT/../node_modules/react-native/scripts/launchPackager.command\" || echo \"Can't start packager automatically\"\n fi\nfi\n";
+ };
+ 7AAB3E46257E6A6E00707CF6 /* Bundle React Native code and images */ = {
+ isa = PBXShellScriptBuildPhase;
+ buildActionMask = 12;
+ files = (
+ );
+ inputPaths = (
+ );
+ name = "Bundle React Native code and images";
+ outputPaths = (
+ );
+ runOnlyForDeploymentPostprocessing = 0;
+ shellPath = /bin/sh;
+ shellScript = "export NODE_BINARY=node\n../node_modules/react-native/scripts/react-native-xcode.sh\n";
+ };
+ 7AAB3E47257E6A6E00707CF6 /* [CP] Copy Pods Resources */ = {
+ isa = PBXShellScriptBuildPhase;
+ buildActionMask = 2147483647;
+ files = (
+ );
+ inputPaths = (
+ "${PODS_ROOT}/Target Support Files/Pods-RocketChatRN/Pods-RocketChatRN-resources.sh",
+ "${PODS_CONFIGURATION_BUILD_DIR}/RNImageCropPicker/QBImagePicker.bundle",
+ "${PODS_ROOT}/../../node_modules/react-native-vector-icons/Fonts/AntDesign.ttf",
+ "${PODS_ROOT}/../../node_modules/react-native-vector-icons/Fonts/Entypo.ttf",
+ "${PODS_ROOT}/../../node_modules/react-native-vector-icons/Fonts/EvilIcons.ttf",
+ "${PODS_ROOT}/../../node_modules/react-native-vector-icons/Fonts/Feather.ttf",
+ "${PODS_ROOT}/../../node_modules/react-native-vector-icons/Fonts/FontAwesome.ttf",
+ "${PODS_ROOT}/../../node_modules/react-native-vector-icons/Fonts/FontAwesome5_Brands.ttf",
+ "${PODS_ROOT}/../../node_modules/react-native-vector-icons/Fonts/FontAwesome5_Regular.ttf",
+ "${PODS_ROOT}/../../node_modules/react-native-vector-icons/Fonts/FontAwesome5_Solid.ttf",
+ "${PODS_ROOT}/../../node_modules/react-native-vector-icons/Fonts/Fontisto.ttf",
+ "${PODS_ROOT}/../../node_modules/react-native-vector-icons/Fonts/Foundation.ttf",
+ "${PODS_ROOT}/../../node_modules/react-native-vector-icons/Fonts/Ionicons.ttf",
+ "${PODS_ROOT}/../../node_modules/react-native-vector-icons/Fonts/MaterialCommunityIcons.ttf",
+ "${PODS_ROOT}/../../node_modules/react-native-vector-icons/Fonts/MaterialIcons.ttf",
+ "${PODS_ROOT}/../../node_modules/react-native-vector-icons/Fonts/Octicons.ttf",
+ "${PODS_ROOT}/../../node_modules/react-native-vector-icons/Fonts/SimpleLineIcons.ttf",
+ "${PODS_ROOT}/../../node_modules/react-native-vector-icons/Fonts/Zocial.ttf",
+ "${PODS_CONFIGURATION_BUILD_DIR}/React-Core/AccessibilityResources.bundle",
+ "${PODS_CONFIGURATION_BUILD_DIR}/TOCropViewController/TOCropViewControllerBundle.bundle",
+ );
+ name = "[CP] Copy Pods Resources";
+ outputPaths = (
+ "${TARGET_BUILD_DIR}/${UNLOCALIZED_RESOURCES_FOLDER_PATH}/QBImagePicker.bundle",
+ "${TARGET_BUILD_DIR}/${UNLOCALIZED_RESOURCES_FOLDER_PATH}/AntDesign.ttf",
+ "${TARGET_BUILD_DIR}/${UNLOCALIZED_RESOURCES_FOLDER_PATH}/Entypo.ttf",
+ "${TARGET_BUILD_DIR}/${UNLOCALIZED_RESOURCES_FOLDER_PATH}/EvilIcons.ttf",
+ "${TARGET_BUILD_DIR}/${UNLOCALIZED_RESOURCES_FOLDER_PATH}/Feather.ttf",
+ "${TARGET_BUILD_DIR}/${UNLOCALIZED_RESOURCES_FOLDER_PATH}/FontAwesome.ttf",
+ "${TARGET_BUILD_DIR}/${UNLOCALIZED_RESOURCES_FOLDER_PATH}/FontAwesome5_Brands.ttf",
+ "${TARGET_BUILD_DIR}/${UNLOCALIZED_RESOURCES_FOLDER_PATH}/FontAwesome5_Regular.ttf",
+ "${TARGET_BUILD_DIR}/${UNLOCALIZED_RESOURCES_FOLDER_PATH}/FontAwesome5_Solid.ttf",
+ "${TARGET_BUILD_DIR}/${UNLOCALIZED_RESOURCES_FOLDER_PATH}/Fontisto.ttf",
+ "${TARGET_BUILD_DIR}/${UNLOCALIZED_RESOURCES_FOLDER_PATH}/Foundation.ttf",
+ "${TARGET_BUILD_DIR}/${UNLOCALIZED_RESOURCES_FOLDER_PATH}/Ionicons.ttf",
+ "${TARGET_BUILD_DIR}/${UNLOCALIZED_RESOURCES_FOLDER_PATH}/MaterialCommunityIcons.ttf",
+ "${TARGET_BUILD_DIR}/${UNLOCALIZED_RESOURCES_FOLDER_PATH}/MaterialIcons.ttf",
+ "${TARGET_BUILD_DIR}/${UNLOCALIZED_RESOURCES_FOLDER_PATH}/Octicons.ttf",
+ "${TARGET_BUILD_DIR}/${UNLOCALIZED_RESOURCES_FOLDER_PATH}/SimpleLineIcons.ttf",
+ "${TARGET_BUILD_DIR}/${UNLOCALIZED_RESOURCES_FOLDER_PATH}/Zocial.ttf",
+ "${TARGET_BUILD_DIR}/${UNLOCALIZED_RESOURCES_FOLDER_PATH}/AccessibilityResources.bundle",
+ "${TARGET_BUILD_DIR}/${UNLOCALIZED_RESOURCES_FOLDER_PATH}/TOCropViewControllerBundle.bundle",
+ );
+ runOnlyForDeploymentPostprocessing = 0;
+ shellPath = /bin/sh;
+ shellScript = "\"${PODS_ROOT}/Target Support Files/Pods-RocketChatRN/Pods-RocketChatRN-resources.sh\"\n";
+ showEnvVarsInLog = 0;
+ };
+ 7AAB3E4B257E6A6E00707CF6 /* ShellScript */ = {
+ isa = PBXShellScriptBuildPhase;
+ buildActionMask = 2147483647;
+ files = (
+ );
+ inputFileListPaths = (
+ );
+ inputPaths = (
+ );
+ outputFileListPaths = (
+ );
+ outputPaths = (
+ );
+ runOnlyForDeploymentPostprocessing = 0;
+ shellPath = /bin/sh;
+ shellScript = "echo \"Target architectures: $ARCHS\"\n\nAPP_PATH=\"${TARGET_BUILD_DIR}/${WRAPPER_NAME}\"\n\nfind \"$APP_PATH\" -name '*.framework' -type d | while read -r FRAMEWORK\ndo\nFRAMEWORK_EXECUTABLE_NAME=$(defaults read \"$FRAMEWORK/Info.plist\" CFBundleExecutable)\nFRAMEWORK_EXECUTABLE_PATH=\"$FRAMEWORK/$FRAMEWORK_EXECUTABLE_NAME\"\necho \"Executable is $FRAMEWORK_EXECUTABLE_PATH\"\necho $(lipo -info \"$FRAMEWORK_EXECUTABLE_PATH\")\n\nFRAMEWORK_TMP_PATH=\"$FRAMEWORK_EXECUTABLE_PATH-tmp\"\n\n# remove simulator's archs if location is not simulator's directory\ncase \"${TARGET_BUILD_DIR}\" in\n*\"iphonesimulator\")\necho \"No need to remove archs\"\n;;\n*)\nif $(lipo \"$FRAMEWORK_EXECUTABLE_PATH\" -verify_arch \"i386\") ; then\nlipo -output \"$FRAMEWORK_TMP_PATH\" -remove \"i386\" \"$FRAMEWORK_EXECUTABLE_PATH\"\necho \"i386 architecture removed\"\nrm \"$FRAMEWORK_EXECUTABLE_PATH\"\nmv \"$FRAMEWORK_TMP_PATH\" \"$FRAMEWORK_EXECUTABLE_PATH\"\nfi\nif $(lipo \"$FRAMEWORK_EXECUTABLE_PATH\" -verify_arch \"x86_64\") ; then\nlipo -output \"$FRAMEWORK_TMP_PATH\" -remove \"x86_64\" \"$FRAMEWORK_EXECUTABLE_PATH\"\necho \"x86_64 architecture removed\"\nrm \"$FRAMEWORK_EXECUTABLE_PATH\"\nmv \"$FRAMEWORK_TMP_PATH\" \"$FRAMEWORK_EXECUTABLE_PATH\"\nfi\n;;\nesac\n\necho \"Completed for executable $FRAMEWORK_EXECUTABLE_PATH\"\necho $\n\ndone\n";
+ };
+ 7AAB3E4C257E6A6E00707CF6 /* [CP] Embed Pods Frameworks */ = {
+ isa = PBXShellScriptBuildPhase;
+ buildActionMask = 2147483647;
+ files = (
+ );
+ inputPaths = (
+ "${PODS_ROOT}/Target Support Files/Pods-RocketChatRN/Pods-RocketChatRN-frameworks.sh",
+ "${PODS_ROOT}/JitsiMeetSDK/Frameworks/JitsiMeet.framework",
+ "${PODS_ROOT}/JitsiMeetSDK/Frameworks/WebRTC.framework",
+ );
+ name = "[CP] Embed Pods Frameworks";
+ outputPaths = (
+ "${TARGET_BUILD_DIR}/${FRAMEWORKS_FOLDER_PATH}/JitsiMeet.framework",
+ "${TARGET_BUILD_DIR}/${FRAMEWORKS_FOLDER_PATH}/WebRTC.framework",
+ );
+ runOnlyForDeploymentPostprocessing = 0;
+ shellPath = /bin/sh;
+ shellScript = "\"${PODS_ROOT}/Target Support Files/Pods-RocketChatRN/Pods-RocketChatRN-frameworks.sh\"\n";
+ showEnvVarsInLog = 0;
+ };
+ 7AAB3E4D257E6A6E00707CF6 /* [CP-User] [RNFB] Core Configuration */ = {
+ isa = PBXShellScriptBuildPhase;
+ buildActionMask = 2147483647;
+ files = (
+ );
+ name = "[CP-User] [RNFB] Core Configuration";
+ runOnlyForDeploymentPostprocessing = 0;
+ shellPath = /bin/sh;
+ shellScript = "#!/usr/bin/env bash\n#\n# Copyright (c) 2016-present Invertase Limited & Contributors\n#\n# Licensed under the Apache License, Version 2.0 (the \"License\");\n# you may not use this library except in compliance with the License.\n# You may obtain a copy of the License at\n#\n# http://www.apache.org/licenses/LICENSE-2.0\n#\n# Unless required by applicable law or agreed to in writing, software\n# distributed under the License is distributed on an \"AS IS\" BASIS,\n# WITHOUT WARRANTIES OR CONDITIONS OF ANY KIND, either express or implied.\n# See the License for the specific language governing permissions and\n# limitations under the License.\n#\nset -e\n\n_MAX_LOOKUPS=2;\n_SEARCH_RESULT=''\n_RN_ROOT_EXISTS=''\n_CURRENT_LOOKUPS=1\n_JSON_ROOT=\"'react-native'\"\n_JSON_FILE_NAME='firebase.json'\n_JSON_OUTPUT_BASE64='e30=' # { }\n_CURRENT_SEARCH_DIR=${PROJECT_DIR}\n_PLIST_BUDDY=/usr/libexec/PlistBuddy\n_TARGET_PLIST=\"${BUILT_PRODUCTS_DIR}/${INFOPLIST_PATH}\"\n_DSYM_PLIST=\"${DWARF_DSYM_FOLDER_PATH}/${DWARF_DSYM_FILE_NAME}/Contents/Info.plist\"\n\n# plist arrays\n_PLIST_ENTRY_KEYS=()\n_PLIST_ENTRY_TYPES=()\n_PLIST_ENTRY_VALUES=()\n\nfunction setPlistValue {\n echo \"info: setting plist entry '$1' of type '$2' in file '$4'\"\n ${_PLIST_BUDDY} -c \"Add :$1 $2 '$3'\" $4 || echo \"info: '$1' already exists\"\n}\n\nfunction getFirebaseJsonKeyValue () {\n if [[ ${_RN_ROOT_EXISTS} ]]; then\n ruby -e \"require 'rubygems';require 'json'; output=JSON.parse('$1'); puts output[$_JSON_ROOT]['$2']\"\n else\n echo \"\"\n fi;\n}\n\nfunction jsonBoolToYesNo () {\n if [[ $1 == \"false\" ]]; then\n echo \"NO\"\n elif [[ $1 == \"true\" ]]; then\n echo \"YES\"\n else echo \"NO\"\n fi\n}\n\necho \"info: -> RNFB build script started\"\necho \"info: 1) Locating ${_JSON_FILE_NAME} file:\"\n\nif [[ -z ${_CURRENT_SEARCH_DIR} ]]; then\n _CURRENT_SEARCH_DIR=$(pwd)\nfi;\n\nwhile true; do\n _CURRENT_SEARCH_DIR=$(dirname \"$_CURRENT_SEARCH_DIR\")\n if [[ \"$_CURRENT_SEARCH_DIR\" == \"/\" ]] || [[ ${_CURRENT_LOOKUPS} -gt ${_MAX_LOOKUPS} ]]; then break; fi;\n echo \"info: ($_CURRENT_LOOKUPS of $_MAX_LOOKUPS) Searching in '$_CURRENT_SEARCH_DIR' for a ${_JSON_FILE_NAME} file.\"\n _SEARCH_RESULT=$(find \"$_CURRENT_SEARCH_DIR\" -maxdepth 2 -name ${_JSON_FILE_NAME} -print | head -n 1)\n if [[ ${_SEARCH_RESULT} ]]; then\n echo \"info: ${_JSON_FILE_NAME} found at $_SEARCH_RESULT\"\n break;\n fi;\n _CURRENT_LOOKUPS=$((_CURRENT_LOOKUPS+1))\ndone\n\nif [[ ${_SEARCH_RESULT} ]]; then\n _JSON_OUTPUT_RAW=$(cat \"${_SEARCH_RESULT}\")\n _RN_ROOT_EXISTS=$(ruby -e \"require 'rubygems';require 'json'; output=JSON.parse('$_JSON_OUTPUT_RAW'); puts output[$_JSON_ROOT]\" || echo '')\n\n if [[ ${_RN_ROOT_EXISTS} ]]; then\n _JSON_OUTPUT_BASE64=$(python -c 'import json,sys,base64;print(base64.b64encode(json.dumps(json.loads(open('\"'${_SEARCH_RESULT}'\"').read())['${_JSON_ROOT}'])))' || echo \"e30=\")\n fi\n\n _PLIST_ENTRY_KEYS+=(\"firebase_json_raw\")\n _PLIST_ENTRY_TYPES+=(\"string\")\n _PLIST_ENTRY_VALUES+=(\"$_JSON_OUTPUT_BASE64\")\n\n # config.messaging_auto_init_enabled\n _MESSAGING_AUTO_INIT=$(getFirebaseJsonKeyValue \"$_JSON_OUTPUT_RAW\" \"messaging_auto_init_enabled\")\n if [[ $_MESSAGING_AUTO_INIT ]]; then\n _PLIST_ENTRY_KEYS+=(\"FirebaseMessagingAutoInitEnabled\")\n _PLIST_ENTRY_TYPES+=(\"bool\")\n _PLIST_ENTRY_VALUES+=(\"$(jsonBoolToYesNo \"$_MESSAGING_AUTO_INIT\")\")\n fi\n\n # config.crashlytics_disable_auto_disabler - undocumented for now - mainly for debugging, document if becomes usful\n _CRASHLYTICS_AUTO_DISABLE_ENABLED=$(getFirebaseJsonKeyValue \"$_JSON_OUTPUT_RAW\" \"crashlytics_disable_auto_disabler\")\n if [[ $_CRASHLYTICS_AUTO_DISABLE_ENABLED == \"true\" ]]; then\n echo \"Disabled Crashlytics auto disabler.\" # do nothing\n else\n _PLIST_ENTRY_KEYS+=(\"FirebaseCrashlyticsCollectionEnabled\")\n _PLIST_ENTRY_TYPES+=(\"bool\")\n _PLIST_ENTRY_VALUES+=(\"NO\")\n fi\n\n # config.admob_delay_app_measurement_init\n _ADMOB_DELAY_APP_MEASUREMENT=$(getFirebaseJsonKeyValue \"$_JSON_OUTPUT_RAW\" \"admob_delay_app_measurement_init\")\n if [[ $_ADMOB_DELAY_APP_MEASUREMENT == \"true\" ]]; then\n _PLIST_ENTRY_KEYS+=(\"GADDelayAppMeasurementInit\")\n _PLIST_ENTRY_TYPES+=(\"bool\")\n _PLIST_ENTRY_VALUES+=(\"YES\")\n fi\n\n # config.admob_ios_app_id\n _ADMOB_IOS_APP_ID=$(getFirebaseJsonKeyValue \"$_JSON_OUTPUT_RAW\" \"admob_ios_app_id\")\n if [[ $_ADMOB_IOS_APP_ID ]]; then\n _PLIST_ENTRY_KEYS+=(\"GADApplicationIdentifier\")\n _PLIST_ENTRY_TYPES+=(\"string\")\n _PLIST_ENTRY_VALUES+=(\"$_ADMOB_IOS_APP_ID\")\n fi\nelse\n _PLIST_ENTRY_KEYS+=(\"firebase_json_raw\")\n _PLIST_ENTRY_TYPES+=(\"string\")\n _PLIST_ENTRY_VALUES+=(\"$_JSON_OUTPUT_BASE64\")\n echo \"warning: A firebase.json file was not found, whilst this file is optional it is recommended to include it to configure firebase services in React Native Firebase.\"\nfi;\n\necho \"info: 2) Injecting Info.plist entries: \"\n\n# Log out the keys we're adding\nfor i in \"${!_PLIST_ENTRY_KEYS[@]}\"; do\n echo \" -> $i) ${_PLIST_ENTRY_KEYS[$i]}\" \"${_PLIST_ENTRY_TYPES[$i]}\" \"${_PLIST_ENTRY_VALUES[$i]}\"\ndone\n\nfor plist in \"${_TARGET_PLIST}\" \"${_DSYM_PLIST}\" ; do\n if [[ -f \"${plist}\" ]]; then\n\n # paths with spaces break the call to setPlistValue. temporarily modify\n # the shell internal field separator variable (IFS), which normally \n # includes spaces, to consist only of line breaks\n oldifs=$IFS\n IFS=\"\n\"\n\n for i in \"${!_PLIST_ENTRY_KEYS[@]}\"; do\n setPlistValue \"${_PLIST_ENTRY_KEYS[$i]}\" \"${_PLIST_ENTRY_TYPES[$i]}\" \"${_PLIST_ENTRY_VALUES[$i]}\" \"${plist}\"\n done\n\n # restore the original internal field separator value\n IFS=$oldifs\n else\n echo \"warning: A Info.plist build output file was not found (${plist})\"\n fi\ndone\n\necho \"info: <- RNFB build script finished\"\n\n";
+ };
+ 7AAB3E4E257E6A6E00707CF6 /* [CP-User] [RNFB] Crashlytics Configuration */ = {
+ isa = PBXShellScriptBuildPhase;
+ buildActionMask = 2147483647;
+ files = (
+ );
+ name = "[CP-User] [RNFB] Crashlytics Configuration";
+ runOnlyForDeploymentPostprocessing = 0;
+ shellPath = /bin/sh;
+ shellScript = "#!/usr/bin/env bash\n#\n# Copyright (c) 2016-present Invertase Limited & Contributors\n#\n# Licensed under the Apache License, Version 2.0 (the \"License\");\n# you may not use this library except in compliance with the License.\n# You may obtain a copy of the License at\n#\n# http://www.apache.org/licenses/LICENSE-2.0\n#\n# Unless required by applicable law or agreed to in writing, software\n# distributed under the License is distributed on an \"AS IS\" BASIS,\n# WITHOUT WARRANTIES OR CONDITIONS OF ANY KIND, either express or implied.\n# See the License for the specific language governing permissions and\n# limitations under the License.\n#\nset -e\n\nif [[ ${PODS_ROOT} ]]; then\n echo \"info: Exec FirebaseCrashlytics Run from Pods\"\n \"${PODS_ROOT}/FirebaseCrashlytics/run\"\nelse\n echo \"info: Exec FirebaseCrashlytics Run from framework\"\n \"${PROJECT_DIR}/FirebaseCrashlytics.framework/run\"\nfi\n";
+ };
9558AC195A3506BB8472CE99 /* [CP] Embed Pods Frameworks */ = {
isa = PBXShellScriptBuildPhase;
buildActionMask = 2147483647;
@@ -1052,7 +1358,6 @@
1E76CBC825152C070067298C /* RocketChat.swift in Sources */,
1E76CBD725152C840067298C /* HTTPMethod.swift in Sources */,
1E76CBC725152BFF0067298C /* Payload.swift in Sources */,
- 7AAA749E23043B1E00F1ADE9 /* Watermelon.swift in Sources */,
1E76CBD225152C730067298C /* Data+Extensions.swift in Sources */,
1E76CBD125152C710067298C /* Date+Extensions.swift in Sources */,
1E76CBD425152C790067298C /* Database.swift in Sources */,
@@ -1077,7 +1382,6 @@
files = (
1EC6ACF622CBA01500A41C61 /* ShareRocketChatRN.m in Sources */,
1E068CFF24FD2DC700A0FFC1 /* AppGroup.swift in Sources */,
- 7AC99C1C2339361F0000A0CB /* Watermelon.swift in Sources */,
1E068D0224FD2E0500A0FFC1 /* AppGroup.m in Sources */,
);
runOnlyForDeploymentPostprocessing = 0;
@@ -1113,6 +1417,41 @@
);
runOnlyForDeploymentPostprocessing = 0;
};
+ 7AAB3E14257E6A6E00707CF6 /* Sources */ = {
+ isa = PBXSourcesBuildPhase;
+ buildActionMask = 2147483647;
+ files = (
+ 7AAB3E15257E6A6E00707CF6 /* Sender.swift in Sources */,
+ 7AAB3E16257E6A6E00707CF6 /* Request.swift in Sources */,
+ 7AAB3E17257E6A6E00707CF6 /* ReplyNotification.swift in Sources */,
+ 7AAB3E18257E6A6E00707CF6 /* Storage.swift in Sources */,
+ 7AAB3E19257E6A6E00707CF6 /* Push.swift in Sources */,
+ 7AAB3E1A257E6A6E00707CF6 /* RoomType.swift in Sources */,
+ 7AAB3E1B257E6A6E00707CF6 /* MessageType.swift in Sources */,
+ 7AAB3E1C257E6A6E00707CF6 /* PushResponse.swift in Sources */,
+ 7AAB3E1D257E6A6E00707CF6 /* AppDelegate.m in Sources */,
+ 7AAB3E1E257E6A6E00707CF6 /* Encryption.swift in Sources */,
+ 7AAB3E1F257E6A6E00707CF6 /* RocketChat.swift in Sources */,
+ 7AAB3E20257E6A6E00707CF6 /* HTTPMethod.swift in Sources */,
+ 7AAB3E21257E6A6E00707CF6 /* Payload.swift in Sources */,
+ 7AAB3E23257E6A6E00707CF6 /* Data+Extensions.swift in Sources */,
+ 7AAB3E24257E6A6E00707CF6 /* Date+Extensions.swift in Sources */,
+ 7AAB3E25257E6A6E00707CF6 /* Database.swift in Sources */,
+ 7AAB3E26257E6A6E00707CF6 /* String+Extensions.swift in Sources */,
+ 7AAB3E27257E6A6E00707CF6 /* Notification.swift in Sources */,
+ 7AAB3E28257E6A6E00707CF6 /* API.swift in Sources */,
+ 7AAB3E29257E6A6E00707CF6 /* Response.swift in Sources */,
+ 7AAB3E2A257E6A6E00707CF6 /* AppGroup.m in Sources */,
+ 7AAB3E2B257E6A6E00707CF6 /* main.m in Sources */,
+ 7AAB3E2C257E6A6E00707CF6 /* URL+Extensions.swift in Sources */,
+ 7AAB3E2D257E6A6E00707CF6 /* AppGroup.swift in Sources */,
+ 7AAB3E2E257E6A6E00707CF6 /* RoomKey.swift in Sources */,
+ 7AAB3E2F257E6A6E00707CF6 /* Message.swift in Sources */,
+ 7AAB3E30257E6A6E00707CF6 /* NotificationType.swift in Sources */,
+ 7AAB3E31257E6A6E00707CF6 /* SendMessage.swift in Sources */,
+ );
+ runOnlyForDeploymentPostprocessing = 0;
+ };
/* End PBXSourcesBuildPhase section */
/* Begin PBXTargetDependency section */
@@ -1126,6 +1465,16 @@
target = 1EFEB5942493B6640072EDC0 /* NotificationService */;
targetProxy = 1EFEB59A2493B6640072EDC0 /* PBXContainerItemProxy */;
};
+ 7AAB3E0E257E6A6E00707CF6 /* PBXTargetDependency */ = {
+ isa = PBXTargetDependency;
+ target = 1EC6ACAF22CB9FC300A41C61 /* ShareRocketChatRN */;
+ targetProxy = 7AAB3E0F257E6A6E00707CF6 /* PBXContainerItemProxy */;
+ };
+ 7AAB3E10257E6A6E00707CF6 /* PBXTargetDependency */ = {
+ isa = PBXTargetDependency;
+ target = 1EFEB5942493B6640072EDC0 /* NotificationService */;
+ targetProxy = 7AAB3E11257E6A6E00707CF6 /* PBXContainerItemProxy */;
+ };
/* End PBXTargetDependency section */
/* Begin PBXVariantGroup section */
@@ -1153,7 +1502,7 @@
CODE_SIGN_IDENTITY = "iPhone Developer";
"CODE_SIGN_IDENTITY[sdk=iphoneos*]" = "iPhone Developer";
CODE_SIGN_STYLE = Manual;
- CURRENT_PROJECT_VERSION = 100;
+ CURRENT_PROJECT_VERSION = 1;
DEAD_CODE_STRIPPING = NO;
DEVELOPMENT_TEAM = S6UPZG7ZR3;
ENABLE_BITCODE = NO;
@@ -1183,9 +1532,10 @@
"-lc++",
);
PRODUCT_BUNDLE_IDENTIFIER = chat.rocket.reactnative;
- PRODUCT_NAME = RocketChatRN;
- PROVISIONING_PROFILE_SPECIFIER = "chat.rocket.reactnative Development";
+ PRODUCT_NAME = "Rocket.Chat Experimental";
+ PROVISIONING_PROFILE_SPECIFIER = "match Development chat.rocket.reactnative";
SWIFT_OBJC_BRIDGING_HEADER = "RocketChatRN-Bridging-Header.h";
+ SWIFT_OBJC_INTERFACE_HEADER_NAME = "RocketChatRN-Swift.h";
SWIFT_OPTIMIZATION_LEVEL = "-Onone";
SWIFT_VERSION = 5.0;
TARGETED_DEVICE_FAMILY = "1,2";
@@ -1206,7 +1556,7 @@
CODE_SIGN_IDENTITY = "iPhone Distribution";
"CODE_SIGN_IDENTITY[sdk=iphoneos*]" = "iPhone Distribution";
CODE_SIGN_STYLE = Manual;
- CURRENT_PROJECT_VERSION = 100;
+ CURRENT_PROJECT_VERSION = 1;
DEAD_CODE_STRIPPING = NO;
DEVELOPMENT_TEAM = S6UPZG7ZR3;
ENABLE_BITCODE = NO;
@@ -1236,9 +1586,10 @@
"-lc++",
);
PRODUCT_BUNDLE_IDENTIFIER = chat.rocket.reactnative;
- PRODUCT_NAME = RocketChatRN;
+ PRODUCT_NAME = "Rocket.Chat Experimental";
PROVISIONING_PROFILE_SPECIFIER = "match AppStore chat.rocket.reactnative";
SWIFT_OBJC_BRIDGING_HEADER = "RocketChatRN-Bridging-Header.h";
+ SWIFT_OBJC_INTERFACE_HEADER_NAME = "RocketChatRN-Swift.h";
SWIFT_VERSION = 5.0;
TARGETED_DEVICE_FAMILY = "1,2";
VERSIONING_SYSTEM = "apple-generic";
@@ -1304,7 +1655,7 @@
);
PRODUCT_BUNDLE_IDENTIFIER = chat.rocket.reactnative.ShareExtension;
PRODUCT_NAME = "$(TARGET_NAME)";
- PROVISIONING_PROFILE_SPECIFIER = "chat.rocket.reactnative.ShareExtension Development";
+ PROVISIONING_PROFILE_SPECIFIER = "match Development chat.rocket.reactnative.ShareExtension";
SKIP_INSTALL = YES;
SWIFT_VERSION = 5.0;
TARGETED_DEVICE_FAMILY = "1,2";
@@ -1401,7 +1752,7 @@
MTL_FAST_MATH = YES;
PRODUCT_BUNDLE_IDENTIFIER = chat.rocket.reactnative.NotificationService;
PRODUCT_NAME = "$(TARGET_NAME)";
- PROVISIONING_PROFILE_SPECIFIER = "chat.rocket.reactnative.NotificationService Development";
+ PROVISIONING_PROFILE_SPECIFIER = "match Development chat.rocket.reactnative.NotificationService";
SKIP_INSTALL = YES;
SWIFT_ACTIVE_COMPILATION_CONDITIONS = DEBUG;
SWIFT_OBJC_BRIDGING_HEADER = "NotificationService/NotificationService-Bridging-Header.h";
@@ -1446,6 +1797,110 @@
};
name = Release;
};
+ 7AAB3E50257E6A6E00707CF6 /* Debug */ = {
+ isa = XCBuildConfiguration;
+ baseConfigurationReference = ACD75701AFD1CB848CAB0CB3 /* Pods-RocketChatRN.debug.xcconfig */;
+ buildSettings = {
+ ALWAYS_EMBED_SWIFT_STANDARD_LIBRARIES = YES;
+ APPLICATION_EXTENSION_API_ONLY = NO;
+ ASSETCATALOG_COMPILER_APPICON_NAME = AppIcon;
+ ASSETCATALOG_COMPILER_LAUNCHIMAGE_NAME = "";
+ CLANG_ENABLE_MODULES = YES;
+ CODE_SIGN_ENTITLEMENTS = RocketChatRN/RocketChatRN.entitlements;
+ CODE_SIGN_STYLE = Manual;
+ CURRENT_PROJECT_VERSION = 1;
+ DEAD_CODE_STRIPPING = NO;
+ DEVELOPMENT_TEAM = S6UPZG7ZR3;
+ ENABLE_BITCODE = NO;
+ FRAMEWORK_SEARCH_PATHS = (
+ "$(inherited)",
+ "$(PROJECT_DIR)",
+ );
+ HEADER_SEARCH_PATHS = (
+ "$(inherited)",
+ "$(SRCROOT)/../../../react-native/React/**",
+ "$(SRCROOT)/../node_modules/@nozbe/watermelondb/native/ios/WatermelonDB/SupportingFiles/**",
+ );
+ INFOPLIST_FILE = RocketChatRN/Info.plist;
+ IPHONEOS_DEPLOYMENT_TARGET = 11.0;
+ LD_RUNPATH_SEARCH_PATHS = "$(inherited) @executable_path/Frameworks";
+ LIBRARY_SEARCH_PATHS = (
+ "$(TOOLCHAIN_DIR)/usr/lib/swift/$(PLATFORM_NAME)",
+ "$(inherited)",
+ );
+ OTHER_CFLAGS = (
+ "$(inherited)",
+ "-DFB_SONARKIT_ENABLED=1",
+ );
+ OTHER_LDFLAGS = (
+ "$(inherited)",
+ "-ObjC",
+ "-lc++",
+ );
+ PRODUCT_BUNDLE_IDENTIFIER = chat.rocket.ios;
+ PRODUCT_NAME = "$(TARGET_NAME)";
+ PROVISIONING_PROFILE_SPECIFIER = "match Development chat.rocket.ios";
+ SWIFT_OBJC_BRIDGING_HEADER = "RocketChatRN-Bridging-Header.h";
+ SWIFT_OBJC_INTERFACE_HEADER_NAME = "RocketChatRN-Swift.h";
+ SWIFT_OPTIMIZATION_LEVEL = "-Onone";
+ SWIFT_VERSION = 5.0;
+ TARGETED_DEVICE_FAMILY = "1,2";
+ VERSIONING_SYSTEM = "apple-generic";
+ };
+ name = Debug;
+ };
+ 7AAB3E51257E6A6E00707CF6 /* Release */ = {
+ isa = XCBuildConfiguration;
+ baseConfigurationReference = 66D6B1D0567051BE541450C9 /* Pods-RocketChatRN.release.xcconfig */;
+ buildSettings = {
+ ALWAYS_EMBED_SWIFT_STANDARD_LIBRARIES = YES;
+ APPLICATION_EXTENSION_API_ONLY = NO;
+ ASSETCATALOG_COMPILER_APPICON_NAME = AppIcon;
+ ASSETCATALOG_COMPILER_LAUNCHIMAGE_NAME = "";
+ CLANG_ENABLE_MODULES = YES;
+ CODE_SIGN_ENTITLEMENTS = RocketChatRN/RocketChatRN.entitlements;
+ CODE_SIGN_IDENTITY = "Apple Distribution";
+ CODE_SIGN_STYLE = Manual;
+ CURRENT_PROJECT_VERSION = 1;
+ DEAD_CODE_STRIPPING = NO;
+ DEVELOPMENT_TEAM = S6UPZG7ZR3;
+ ENABLE_BITCODE = NO;
+ FRAMEWORK_SEARCH_PATHS = (
+ "$(inherited)",
+ "$(PROJECT_DIR)",
+ );
+ HEADER_SEARCH_PATHS = (
+ "$(inherited)",
+ "$(SRCROOT)/../../../react-native/React/**",
+ "$(SRCROOT)/../node_modules/@nozbe/watermelondb/native/ios/WatermelonDB/SupportingFiles/**",
+ );
+ INFOPLIST_FILE = RocketChatRN/Info.plist;
+ IPHONEOS_DEPLOYMENT_TARGET = 11.0;
+ LD_RUNPATH_SEARCH_PATHS = "$(inherited) @executable_path/Frameworks";
+ LIBRARY_SEARCH_PATHS = (
+ "$(TOOLCHAIN_DIR)/usr/lib/swift/$(PLATFORM_NAME)",
+ "$(inherited)",
+ );
+ OTHER_CFLAGS = (
+ "$(inherited)",
+ "-DFB_SONARKIT_ENABLED=1",
+ );
+ OTHER_LDFLAGS = (
+ "$(inherited)",
+ "-ObjC",
+ "-lc++",
+ );
+ PRODUCT_BUNDLE_IDENTIFIER = chat.rocket.ios;
+ PRODUCT_NAME = "$(TARGET_NAME)";
+ PROVISIONING_PROFILE_SPECIFIER = "match AppStore chat.rocket.ios";
+ SWIFT_OBJC_BRIDGING_HEADER = "RocketChatRN-Bridging-Header.h";
+ SWIFT_OBJC_INTERFACE_HEADER_NAME = "RocketChatRN-Swift.h";
+ SWIFT_VERSION = 5.0;
+ TARGETED_DEVICE_FAMILY = "1,2";
+ VERSIONING_SYSTEM = "apple-generic";
+ };
+ name = Release;
+ };
83CBBA201A601CBA00E9B192 /* Debug */ = {
isa = XCBuildConfiguration;
buildSettings = {
@@ -1578,6 +2033,15 @@
defaultConfigurationIsVisible = 0;
defaultConfigurationName = Release;
};
+ 7AAB3E4F257E6A6E00707CF6 /* Build configuration list for PBXNativeTarget "Rocket.Chat" */ = {
+ isa = XCConfigurationList;
+ buildConfigurations = (
+ 7AAB3E50257E6A6E00707CF6 /* Debug */,
+ 7AAB3E51257E6A6E00707CF6 /* Release */,
+ );
+ defaultConfigurationIsVisible = 0;
+ defaultConfigurationName = Release;
+ };
83CBB9FA1A601CBA00E9B192 /* Build configuration list for PBXProject "RocketChatRN" */ = {
isa = XCConfigurationList;
buildConfigurations = (
diff --git a/ios/RocketChatRN.xcodeproj/xcshareddata/xcschemes/NotificationService.xcscheme b/ios/RocketChatRN.xcodeproj/xcshareddata/xcschemes/NotificationService.xcscheme
index 3fd37eb6..0bd04dfd 100644
--- a/ios/RocketChatRN.xcodeproj/xcshareddata/xcschemes/NotificationService.xcscheme
+++ b/ios/RocketChatRN.xcodeproj/xcshareddata/xcschemes/NotificationService.xcscheme
@@ -30,7 +30,7 @@
@@ -66,7 +66,7 @@
@@ -84,7 +84,7 @@
diff --git a/ios/RocketChatRN.xcodeproj/xcshareddata/xcschemes/RocketChat.xcscheme b/ios/RocketChatRN.xcodeproj/xcshareddata/xcschemes/RocketChat.xcscheme
new file mode 100644
index 00000000..5f4de25a
--- /dev/null
+++ b/ios/RocketChatRN.xcodeproj/xcshareddata/xcschemes/RocketChat.xcscheme
@@ -0,0 +1,78 @@
+
+
+
+
+
+
+
+
+
+
+
+
+
+
+
+
+
+
+
+
+
+
+
+
+
+
+
+
+
+
+
diff --git a/ios/RocketChatRN.xcodeproj/xcshareddata/xcschemes/RocketChatRN.xcscheme b/ios/RocketChatRN.xcodeproj/xcshareddata/xcschemes/RocketChatRN.xcscheme
index a0a55dc1..dbff852e 100644
--- a/ios/RocketChatRN.xcodeproj/xcshareddata/xcschemes/RocketChatRN.xcscheme
+++ b/ios/RocketChatRN.xcodeproj/xcshareddata/xcschemes/RocketChatRN.xcscheme
@@ -29,7 +29,7 @@
@@ -59,7 +59,7 @@
@@ -92,7 +92,7 @@
@@ -126,7 +126,7 @@
diff --git a/ios/RocketChatRN.xcodeproj/xcshareddata/xcschemes/ShareRocketChatRN.xcscheme b/ios/RocketChatRN.xcodeproj/xcshareddata/xcschemes/ShareRocketChatRN.xcscheme
index 5771aad3..6db82c33 100644
--- a/ios/RocketChatRN.xcodeproj/xcshareddata/xcschemes/ShareRocketChatRN.xcscheme
+++ b/ios/RocketChatRN.xcodeproj/xcshareddata/xcschemes/ShareRocketChatRN.xcscheme
@@ -30,7 +30,7 @@
@@ -75,7 +75,7 @@
@@ -93,7 +93,7 @@
diff --git a/ios/RocketChatRN/Images.xcassets/Contents.json b/ios/RocketChatRN/Images.xcassets/Contents.json
index da4a164c..73c00596 100644
--- a/ios/RocketChatRN/Images.xcassets/Contents.json
+++ b/ios/RocketChatRN/Images.xcassets/Contents.json
@@ -1,6 +1,6 @@
{
"info" : {
- "version" : 1,
- "author" : "xcode"
+ "author" : "xcode",
+ "version" : 1
}
-}
\ No newline at end of file
+}
diff --git a/ios/RocketChatRN/Images.xcassets/Icons/Contents.json b/ios/RocketChatRN/Images.xcassets/Icons/Contents.json
deleted file mode 100644
index da4a164c..00000000
--- a/ios/RocketChatRN/Images.xcassets/Icons/Contents.json
+++ /dev/null
@@ -1,6 +0,0 @@
-{
- "info" : {
- "version" : 1,
- "author" : "xcode"
- }
-}
\ No newline at end of file
diff --git a/ios/RocketChatRN/Images.xcassets/Icons/message_empty_black.imageset/Contents.json b/ios/RocketChatRN/Images.xcassets/Icons/message_empty_black.imageset/Contents.json
deleted file mode 100644
index 85078270..00000000
--- a/ios/RocketChatRN/Images.xcassets/Icons/message_empty_black.imageset/Contents.json
+++ /dev/null
@@ -1,12 +0,0 @@
-{
- "images" : [
- {
- "idiom" : "universal",
- "filename" : "Message Empty Black Theme.pdf"
- }
- ],
- "info" : {
- "version" : 1,
- "author" : "xcode"
- }
-}
\ No newline at end of file
diff --git a/ios/RocketChatRN/Images.xcassets/Icons/message_empty_dark.imageset/Contents.json b/ios/RocketChatRN/Images.xcassets/Icons/message_empty_dark.imageset/Contents.json
deleted file mode 100644
index d414a4c1..00000000
--- a/ios/RocketChatRN/Images.xcassets/Icons/message_empty_dark.imageset/Contents.json
+++ /dev/null
@@ -1,12 +0,0 @@
-{
- "images" : [
- {
- "idiom" : "universal",
- "filename" : "Message Empty Dark Theme.pdf"
- }
- ],
- "info" : {
- "version" : 1,
- "author" : "xcode"
- }
-}
\ No newline at end of file
diff --git a/ios/RocketChatRN/Images.xcassets/Icons/message_empty_light.imageset/Contents.json b/ios/RocketChatRN/Images.xcassets/Icons/message_empty_light.imageset/Contents.json
deleted file mode 100644
index d1ff3f57..00000000
--- a/ios/RocketChatRN/Images.xcassets/Icons/message_empty_light.imageset/Contents.json
+++ /dev/null
@@ -1,12 +0,0 @@
-{
- "images" : [
- {
- "idiom" : "universal",
- "filename" : "Message Empty.pdf"
- }
- ],
- "info" : {
- "version" : 1,
- "author" : "xcode"
- }
-}
\ No newline at end of file
diff --git a/ios/RocketChatRN/Images.xcassets/Icons/audio_thumb.imageset/Contents.json b/ios/RocketChatRN/Images.xcassets/audio_thumb.imageset/Contents.json
similarity index 88%
rename from ios/RocketChatRN/Images.xcassets/Icons/audio_thumb.imageset/Contents.json
rename to ios/RocketChatRN/Images.xcassets/audio_thumb.imageset/Contents.json
index eed49b14..371d769f 100644
--- a/ios/RocketChatRN/Images.xcassets/Icons/audio_thumb.imageset/Contents.json
+++ b/ios/RocketChatRN/Images.xcassets/audio_thumb.imageset/Contents.json
@@ -1,23 +1,23 @@
{
"images" : [
{
- "idiom" : "universal",
"filename" : "audio_thumb.png",
+ "idiom" : "universal",
"scale" : "1x"
},
{
- "idiom" : "universal",
"filename" : "audio_thumb@2x.png",
+ "idiom" : "universal",
"scale" : "2x"
},
{
- "idiom" : "universal",
"filename" : "audio_thumb@3x.png",
+ "idiom" : "universal",
"scale" : "3x"
}
],
"info" : {
- "version" : 1,
- "author" : "xcode"
+ "author" : "xcode",
+ "version" : 1
}
-}
\ No newline at end of file
+}
diff --git a/ios/RocketChatRN/Images.xcassets/Icons/audio_thumb.imageset/audio_thumb.png b/ios/RocketChatRN/Images.xcassets/audio_thumb.imageset/audio_thumb.png
similarity index 100%
rename from ios/RocketChatRN/Images.xcassets/Icons/audio_thumb.imageset/audio_thumb.png
rename to ios/RocketChatRN/Images.xcassets/audio_thumb.imageset/audio_thumb.png
diff --git a/ios/RocketChatRN/Images.xcassets/Icons/audio_thumb.imageset/audio_thumb@2x.png b/ios/RocketChatRN/Images.xcassets/audio_thumb.imageset/audio_thumb@2x.png
similarity index 100%
rename from ios/RocketChatRN/Images.xcassets/Icons/audio_thumb.imageset/audio_thumb@2x.png
rename to ios/RocketChatRN/Images.xcassets/audio_thumb.imageset/audio_thumb@2x.png
diff --git a/ios/RocketChatRN/Images.xcassets/Icons/audio_thumb.imageset/audio_thumb@3x.png b/ios/RocketChatRN/Images.xcassets/audio_thumb.imageset/audio_thumb@3x.png
similarity index 100%
rename from ios/RocketChatRN/Images.xcassets/Icons/audio_thumb.imageset/audio_thumb@3x.png
rename to ios/RocketChatRN/Images.xcassets/audio_thumb.imageset/audio_thumb@3x.png
diff --git a/ios/RocketChatRN/Images.xcassets/Launch Screen Icon.imageset/Contents.json b/ios/RocketChatRN/Images.xcassets/logo.imageset/Contents.json
similarity index 100%
rename from ios/RocketChatRN/Images.xcassets/Launch Screen Icon.imageset/Contents.json
rename to ios/RocketChatRN/Images.xcassets/logo.imageset/Contents.json
diff --git a/ios/RocketChatRN/Images.xcassets/Icons/logo.imageset/icon.png b/ios/RocketChatRN/Images.xcassets/logo.imageset/icon.png
similarity index 100%
rename from ios/RocketChatRN/Images.xcassets/Icons/logo.imageset/icon.png
rename to ios/RocketChatRN/Images.xcassets/logo.imageset/icon.png
diff --git a/ios/RocketChatRN/Images.xcassets/Icons/logo.imageset/icon@2x.png b/ios/RocketChatRN/Images.xcassets/logo.imageset/icon@2x.png
similarity index 100%
rename from ios/RocketChatRN/Images.xcassets/Icons/logo.imageset/icon@2x.png
rename to ios/RocketChatRN/Images.xcassets/logo.imageset/icon@2x.png
diff --git a/ios/RocketChatRN/Images.xcassets/Icons/logo.imageset/icon@3x.png b/ios/RocketChatRN/Images.xcassets/logo.imageset/icon@3x.png
similarity index 100%
rename from ios/RocketChatRN/Images.xcassets/Icons/logo.imageset/icon@3x.png
rename to ios/RocketChatRN/Images.xcassets/logo.imageset/icon@3x.png
diff --git a/ios/RocketChatRN/Images.xcassets/message_empty_black.imageset/Contents.json b/ios/RocketChatRN/Images.xcassets/message_empty_black.imageset/Contents.json
new file mode 100644
index 00000000..dff142af
--- /dev/null
+++ b/ios/RocketChatRN/Images.xcassets/message_empty_black.imageset/Contents.json
@@ -0,0 +1,12 @@
+{
+ "images" : [
+ {
+ "filename" : "Message Empty Black Theme.pdf",
+ "idiom" : "universal"
+ }
+ ],
+ "info" : {
+ "author" : "xcode",
+ "version" : 1
+ }
+}
diff --git a/ios/RocketChatRN/Images.xcassets/Icons/message_empty_black.imageset/Message Empty Black Theme.pdf b/ios/RocketChatRN/Images.xcassets/message_empty_black.imageset/Message Empty Black Theme.pdf
similarity index 100%
rename from ios/RocketChatRN/Images.xcassets/Icons/message_empty_black.imageset/Message Empty Black Theme.pdf
rename to ios/RocketChatRN/Images.xcassets/message_empty_black.imageset/Message Empty Black Theme.pdf
diff --git a/ios/RocketChatRN/Images.xcassets/message_empty_dark.imageset/Contents.json b/ios/RocketChatRN/Images.xcassets/message_empty_dark.imageset/Contents.json
new file mode 100644
index 00000000..90d210a0
--- /dev/null
+++ b/ios/RocketChatRN/Images.xcassets/message_empty_dark.imageset/Contents.json
@@ -0,0 +1,12 @@
+{
+ "images" : [
+ {
+ "filename" : "Message Empty Dark Theme.pdf",
+ "idiom" : "universal"
+ }
+ ],
+ "info" : {
+ "author" : "xcode",
+ "version" : 1
+ }
+}
diff --git a/ios/RocketChatRN/Images.xcassets/Icons/message_empty_dark.imageset/Message Empty Dark Theme.pdf b/ios/RocketChatRN/Images.xcassets/message_empty_dark.imageset/Message Empty Dark Theme.pdf
similarity index 100%
rename from ios/RocketChatRN/Images.xcassets/Icons/message_empty_dark.imageset/Message Empty Dark Theme.pdf
rename to ios/RocketChatRN/Images.xcassets/message_empty_dark.imageset/Message Empty Dark Theme.pdf
diff --git a/ios/RocketChatRN/Images.xcassets/message_empty_light.imageset/Contents.json b/ios/RocketChatRN/Images.xcassets/message_empty_light.imageset/Contents.json
new file mode 100644
index 00000000..defdb34c
--- /dev/null
+++ b/ios/RocketChatRN/Images.xcassets/message_empty_light.imageset/Contents.json
@@ -0,0 +1,12 @@
+{
+ "images" : [
+ {
+ "filename" : "Message Empty.pdf",
+ "idiom" : "universal"
+ }
+ ],
+ "info" : {
+ "author" : "xcode",
+ "version" : 1
+ }
+}
diff --git a/ios/RocketChatRN/Images.xcassets/Icons/message_empty_light.imageset/Message Empty.pdf b/ios/RocketChatRN/Images.xcassets/message_empty_light.imageset/Message Empty.pdf
similarity index 100%
rename from ios/RocketChatRN/Images.xcassets/Icons/message_empty_light.imageset/Message Empty.pdf
rename to ios/RocketChatRN/Images.xcassets/message_empty_light.imageset/Message Empty.pdf
diff --git a/ios/RocketChatRN/Info.plist b/ios/RocketChatRN/Info.plist
index e0cf5571..5fd2e90d 100644
--- a/ios/RocketChatRN/Info.plist
+++ b/ios/RocketChatRN/Info.plist
@@ -2,14 +2,16 @@
- KeychainGroup
- $(AppIdentifierPrefix)chat.rocket.reactnative
+ IS_OFFICIAL
+
+ AppGroup
+ group.ios.chat.rocket
BugsnagAPIKey
CFBundleDevelopmentRegion
en
CFBundleDisplayName
- Rocket.Chat Experimental
+ $(PRODUCT_NAME)
CFBundleExecutable
$(EXECUTABLE_NAME)
CFBundleIdentifier
@@ -38,9 +40,18 @@
CFBundleVersion
- 100
+ $(CURRENT_PROJECT_VERSION)
ITSAppUsesNonExemptEncryption
+ KeychainGroup
+ $(AppIdentifierPrefix)chat.rocket.reactnative
+ LSApplicationQueriesSchemes
+
+ googlechrome
+ googlechromes
+ firefox
+ brave
+
LSRequiresIPhoneOS
NSAppTransportSecurity
@@ -60,6 +71,8 @@
Take photos to share with other users
NSContactsUsageDescription
Allow $(PRODUCT_NAME) to access your contacts
+ NSFaceIDUsageDescription
+ Unlock the app with FaceID
NSLocationAlwaysAndWhenInUseUsageDescription
This permission stems from a library we use and will never be called anyway. If you see this, deny access
NSLocationAlwaysUsageDescription
@@ -76,8 +89,6 @@
Upload photos to share with other users or to change your avatar
NSRemindersUsageDescription
Allow $(PRODUCT_NAME) to access your reminders
- NSFaceIDUsageDescription
- Unlock the app with FaceID
UIAppFonts
custom.ttf
@@ -107,14 +118,5 @@
UIViewControllerBasedStatusBarAppearance
- LSApplicationQueriesSchemes
-
- googlechrome
- googlechromes
- firefox
- brave
-
- AppGroup
- group.ios.chat.rocket
diff --git a/ios/ShareRocketChatRN/Info.plist b/ios/ShareRocketChatRN/Info.plist
index 60da51fe..35791ba3 100644
--- a/ios/ShareRocketChatRN/Info.plist
+++ b/ios/ShareRocketChatRN/Info.plist
@@ -2,8 +2,8 @@
- KeychainGroup
- $(AppIdentifierPrefix)chat.rocket.reactnative
+ AppGroup
+ group.ios.chat.rocket
CFBundleDevelopmentRegion
$(DEVELOPMENT_LANGUAGE)
CFBundleDisplayName
@@ -22,6 +22,8 @@
4.13.0
CFBundleVersion
1
+ KeychainGroup
+ $(AppIdentifierPrefix)chat.rocket.reactnative
NSAppTransportSecurity
NSAllowsArbitraryLoads
@@ -62,7 +64,5 @@
custom.ttf
- AppGroup
- group.ios.chat.rocket
diff --git a/ios/Shared/RocketChat/Database.swift b/ios/Shared/RocketChat/Database.swift
index 4dcf295d..7e792850 100644
--- a/ios/Shared/RocketChat/Database.swift
+++ b/ios/Shared/RocketChat/Database.swift
@@ -25,7 +25,8 @@ final class Database {
init(server: String) {
if let url = URL(string: server) {
if let domain = url.domain, let directory = directory {
- self.database = WatermelonDB.Database(path: "\(directory)/\(domain)-experimental.db")
+ let isOfficial = Bundle.main.object(forInfoDictionaryKey: "IS_OFFICIAL") as? Bool ?? false
+ self.database = WatermelonDB.Database(path: "\(directory)/\(domain)\(isOfficial ? "" : "-experimental").db")
}
}
}
diff --git a/ios/Watermelon.swift b/ios/Watermelon.swift
deleted file mode 100644
index 5008e236..00000000
--- a/ios/Watermelon.swift
+++ /dev/null
@@ -1,9 +0,0 @@
-//
-// Watermelon.swift
-// RocketChatRN
-//
-// Created by Diego Mello on 14/08/19.
-// Copyright © 2019 Facebook. All rights reserved.
-//
-
-import Foundation
diff --git a/ios/fastlane/Fastfile b/ios/fastlane/Fastfile
index 456a8a2c..6b6dd11c 100644
--- a/ios/fastlane/Fastfile
+++ b/ios/fastlane/Fastfile
@@ -25,13 +25,8 @@ platform :ios do
)
end
- desc "Runs all the tests"
- lane :test do
- scan
- end
-
desc "Submit a new Beta Build to Apple TestFlight"
- lane :beta do
+ lane :beta do |options|
api_key = app_store_connect_api_key(
key_id: "F296L2294Y",
issuer_id: "69a6de8e-75cf-47e3-e053-5b8c7c11a4d1",
@@ -39,12 +34,14 @@ platform :ios do
in_house: false
)
pilot(
- ipa: 'ios/RocketChatRN.ipa',
+ ipa: 'ios/Rocket.Chat.ipa',
+ app_identifier: options[:official] ? 'chat.rocket.ios' : 'chat.rocket.reactnative',
skip_waiting_for_build_processing: true
)
+ upload_symbols_to_crashlytics(dsym_path: "./ios/Rocket.Chat.app.dSYM.zip")
end
- desc "Build App for release"
+ desc "Build Experimental app"
lane :release do
api_key = app_store_connect_api_key(
key_id: "F296L2294Y",
@@ -56,7 +53,11 @@ platform :ios do
get_provisioning_profile(app_identifier: "chat.rocket.reactnative.ShareExtension")
get_provisioning_profile(app_identifier: "chat.rocket.reactnative.NotificationService")
# pem(api_key: api_key) # still uses Spaceship http://docs.fastlane.tools/actions/pem/#how-does-it-work
- gym(scheme: "RocketChatRN", workspace: "RocketChatRN.xcworkspace")
+ gym(
+ scheme: "RocketChatRN",
+ workspace: "RocketChatRN.xcworkspace",
+ output_name: "Rocket.Chat"
+ )
end
desc "Build fork app"
@@ -64,6 +65,41 @@ platform :ios do
gym(scheme: "RocketChatRN", workspace: "RocketChatRN.xcworkspace", skip_codesigning: true, skip_archive: true)
end
+ desc "Build Official app"
+ lane :build_official do
+ sh "../../scripts/prepare_ios_official.sh"
+
+ match(
+ type: "appstore",
+ app_identifier: ["chat.rocket.ios", "chat.rocket.ios.NotificationService", "chat.rocket.ios.Rocket-Chat-ShareExtension"],
+ readonly: true,
+ output_path: './'
+ )
+
+ update_project_provisioning(
+ xcodeproj: 'RocketChatRN.xcodeproj',
+ profile: "AppStore_chat.rocket.ios.NotificationService.mobileprovision",
+ target_filter: "NotificationService",
+ build_configuration: 'Release',
+ code_signing_identity: 'iPhone Distribution'
+ )
+
+ update_project_provisioning(
+ xcodeproj: 'RocketChatRN.xcodeproj',
+ profile: "AppStore_chat.rocket.ios.Rocket-Chat-ShareExtension.mobileprovision",
+ target_filter: "ShareRocketChatRN",
+ build_configuration: 'Release',
+ code_signing_identity: 'iPhone Distribution'
+ )
+
+ gym(
+ scheme: "RocketChat",
+ workspace: "RocketChatRN.xcworkspace",
+ xcargs: "-allowProvisioningUpdates",
+ output_name: "Rocket.Chat"
+ )
+ end
+
after_all do |lane|
delete_keychain(name: ENV["MATCH_KEYCHAIN_NAME"])
end
diff --git a/ios/fastlane/README.md b/ios/fastlane/README.md
index 82c024be..275f6ac1 100644
--- a/ios/fastlane/README.md
+++ b/ios/fastlane/README.md
@@ -16,11 +16,6 @@ or alternatively using `brew install fastlane`
# Available Actions
## iOS
-### ios test
-```
-fastlane ios test
-```
-Runs all the tests
### ios beta
```
fastlane ios beta
@@ -30,12 +25,17 @@ Submit a new Beta Build to Apple TestFlight
```
fastlane ios release
```
-Build App for release
-### ios build
+Build Experimental app
+### ios build_fork
```
-fastlane ios build
+fastlane ios build_fork
```
-Build App for development
+Build fork app
+### ios build_official
+```
+fastlane ios build_official
+```
+Build Official app
----
diff --git a/package.json b/package.json
index c8cafd9b..6fc1fed6 100644
--- a/package.json
+++ b/package.json
@@ -190,7 +190,7 @@
"specs": "e2e/tests",
"configurations": {
"ios.sim.debug": {
- "binaryPath": "ios/build/Build/Products/Debug-iphonesimulator/RocketChatRN.app",
+ "binaryPath": "ios/build/Build/Products/Debug-iphonesimulator/Rocket.Chat Experimental.app",
"build": "xcodebuild -workspace ios/RocketChatRN.xcworkspace -scheme RocketChatRN -configuration Debug -sdk iphonesimulator -derivedDataPath ios/build",
"type": "ios.simulator",
"device": {
@@ -198,7 +198,7 @@
}
},
"ios.sim.release": {
- "binaryPath": "ios/build/Build/Products/Release-iphonesimulator/RocketChatRN.app",
+ "binaryPath": "ios/build/Build/Products/Release-iphonesimulator/Rocket.Chat Experimental.app",
"build": "xcodebuild -workspace ios/RocketChatRN.xcworkspace -scheme RocketChatRN -configuration Release -sdk iphonesimulator -derivedDataPath ios/build",
"type": "ios.simulator",
"device": {
diff --git a/scripts/prepare_ios_official.sh b/scripts/prepare_ios_official.sh
new file mode 100755
index 00000000..8750c180
--- /dev/null
+++ b/scripts/prepare_ios_official.sh
@@ -0,0 +1,9 @@
+#!/usr/bin/env bash
+
+sed -i '' \
+ 's/PRODUCT_BUNDLE_IDENTIFIER = chat.rocket.reactnative.ShareExtension;/PRODUCT_BUNDLE_IDENTIFIER = chat.rocket.ios.Rocket-Chat-ShareExtension;/' \
+ ../RocketChatRN.xcodeproj/project.pbxproj
+
+sed -i '' \
+ 's/PRODUCT_BUNDLE_IDENTIFIER = chat.rocket.reactnative.NotificationService;/PRODUCT_BUNDLE_IDENTIFIER = chat.rocket.ios.NotificationService;/' \
+ ../RocketChatRN.xcodeproj/project.pbxproj
\ No newline at end of file