@appzung/react-native-code-push 11.0.0-rc1 → 11.0.0-rc10
This diff represents the content of publicly available package versions that have been released to one of the supported registries. The information contained in this diff is provided for informational purposes only and reflects changes between package versions as they appear in their respective public registries.
- package/CodePush.podspec +3 -5
- package/README.md +26 -24
- package/android/app/proguard-rules.pro +5 -0
- package/android/app/src/main/java/com/appzung/codepush/react/CodePush.java +4 -0
- package/android/app/src/main/java/com/appzung/codepush/react/CodePushConstants.java +2 -0
- package/android/app/src/main/java/com/appzung/codepush/react/CodePushNativeModule.java +86 -4
- package/android/app/src/main/java/com/appzung/codepush/react/ExpoUtils.java +22 -0
- package/ios/CodePush/CodePush.h +11 -6
- package/ios/CodePush/{CodePush.m → CodePush.mm} +132 -141
- package/ios/CodePush/CodePushConfig.m +54 -0
- package/ios/CodePush.xcodeproj/project.pbxproj +6 -6
- package/lib/commonjs/CodePush.js +11 -2
- package/lib/commonjs/CodePush.js.map +1 -1
- package/lib/commonjs/allowRestart.js +6 -2
- package/lib/commonjs/allowRestart.js.map +1 -1
- package/lib/commonjs/checkForUpdates.js +25 -26
- package/lib/commonjs/checkForUpdates.js.map +1 -1
- package/lib/commonjs/clearUpdates.js +6 -3
- package/lib/commonjs/clearUpdates.js.map +1 -1
- package/lib/commonjs/dataTransmission.js +28 -0
- package/lib/commonjs/dataTransmission.js.map +1 -0
- package/lib/commonjs/disallowRestart.js +6 -2
- package/lib/commonjs/disallowRestart.js.map +1 -1
- package/lib/commonjs/enums/CheckFrequency.enum.js +2 -2
- package/lib/commonjs/enums/InstallMode.enum.js +7 -3
- package/lib/commonjs/enums/InstallMode.enum.js.map +1 -1
- package/lib/commonjs/enums/LogLevel.enum.js +17 -0
- package/lib/commonjs/enums/LogLevel.enum.js.map +1 -0
- package/lib/commonjs/enums/SyncStatus.enum.js +7 -7
- package/lib/commonjs/enums/UpdateState.enum.js +7 -6
- package/lib/commonjs/enums/UpdateState.enum.js.map +1 -1
- package/lib/commonjs/getClientUniqueId.js +16 -0
- package/lib/commonjs/getClientUniqueId.js.map +1 -0
- package/lib/commonjs/index.js +90 -9
- package/lib/commonjs/index.js.map +1 -1
- package/lib/commonjs/internals/CodePushApiSdk.errors.js +26 -0
- package/lib/commonjs/internals/CodePushApiSdk.errors.js.map +1 -0
- package/lib/commonjs/internals/CodePushApiSdk.js +122 -0
- package/lib/commonjs/internals/CodePushApiSdk.js.map +1 -0
- package/lib/commonjs/{enums/DeploymentStatus.enum.js → internals/CodePushApiSdk.types.js} +3 -2
- package/lib/commonjs/internals/CodePushApiSdk.types.js.map +1 -0
- package/lib/commonjs/internals/CodePushEventEmitter.js +10 -0
- package/lib/commonjs/internals/CodePushEventEmitter.js.map +1 -0
- package/lib/commonjs/internals/RemotePackageImplementation.js +9 -8
- package/lib/commonjs/internals/RemotePackageImplementation.js.map +1 -1
- package/lib/commonjs/internals/getConfiguration.js +4 -0
- package/lib/commonjs/internals/getConfiguration.js.map +1 -1
- package/lib/commonjs/internals/logger.js +51 -0
- package/lib/commonjs/internals/logger.js.map +1 -0
- package/lib/commonjs/internals/shouldUpdateBeIgnored.js +6 -5
- package/lib/commonjs/internals/shouldUpdateBeIgnored.js.map +1 -1
- package/lib/commonjs/internals/utils/fetchRetry.js +59 -0
- package/lib/commonjs/internals/utils/fetchRetry.js.map +1 -0
- package/lib/commonjs/internals/utils/log.js +10 -3
- package/lib/commonjs/internals/utils/log.js.map +1 -1
- package/lib/commonjs/internals/utils/queryStringify.js +25 -0
- package/lib/commonjs/internals/utils/queryStringify.js.map +1 -0
- package/lib/commonjs/internals/utils/requestFetchAdapter.js +38 -0
- package/lib/commonjs/internals/utils/requestFetchAdapter.js.map +1 -0
- package/lib/commonjs/internals/version.js +1 -1
- package/lib/commonjs/internals/version.js.map +1 -1
- package/lib/commonjs/logLevel.js +15 -0
- package/lib/commonjs/logLevel.js.map +1 -0
- package/lib/commonjs/logger.js +19 -0
- package/lib/commonjs/logger.js.map +1 -0
- package/lib/commonjs/notifyAppReady.js +26 -15
- package/lib/commonjs/notifyAppReady.js.map +1 -1
- package/lib/commonjs/resetClientUniqueId.js +18 -0
- package/lib/commonjs/resetClientUniqueId.js.map +1 -0
- package/lib/commonjs/restartApp.js +4 -2
- package/lib/commonjs/restartApp.js.map +1 -1
- package/lib/commonjs/sync.js +35 -28
- package/lib/commonjs/sync.js.map +1 -1
- package/lib/commonjs/telemetry.js +28 -0
- package/lib/commonjs/telemetry.js.map +1 -0
- package/lib/module/CodePush.js +11 -2
- package/lib/module/CodePush.js.map +1 -1
- package/lib/module/allowRestart.js +5 -1
- package/lib/module/allowRestart.js.map +1 -1
- package/lib/module/checkForUpdates.js +25 -26
- package/lib/module/checkForUpdates.js.map +1 -1
- package/lib/module/clearUpdates.js +5 -2
- package/lib/module/clearUpdates.js.map +1 -1
- package/lib/module/dataTransmission.js +24 -0
- package/lib/module/dataTransmission.js.map +1 -0
- package/lib/module/disallowRestart.js +5 -1
- package/lib/module/disallowRestart.js.map +1 -1
- package/lib/module/enums/CheckFrequency.enum.js +2 -2
- package/lib/module/enums/InstallMode.enum.js +7 -3
- package/lib/module/enums/InstallMode.enum.js.map +1 -1
- package/lib/module/enums/LogLevel.enum.js +13 -0
- package/lib/module/enums/LogLevel.enum.js.map +1 -0
- package/lib/module/enums/SyncStatus.enum.js +7 -7
- package/lib/module/enums/UpdateState.enum.js +7 -6
- package/lib/module/enums/UpdateState.enum.js.map +1 -1
- package/lib/module/getClientUniqueId.js +12 -0
- package/lib/module/getClientUniqueId.js.map +1 -0
- package/lib/module/index.js +8 -1
- package/lib/module/index.js.map +1 -1
- package/lib/module/internals/CodePushApiSdk.errors.js +20 -0
- package/lib/module/internals/CodePushApiSdk.errors.js.map +1 -0
- package/lib/module/internals/CodePushApiSdk.js +118 -0
- package/lib/module/internals/CodePushApiSdk.js.map +1 -0
- package/lib/module/{enums/DeploymentStatus.enum.js → internals/CodePushApiSdk.types.js} +2 -1
- package/lib/module/internals/CodePushApiSdk.types.js.map +1 -0
- package/lib/module/internals/CodePushEventEmitter.js +6 -0
- package/lib/module/internals/CodePushEventEmitter.js.map +1 -0
- package/lib/module/internals/RemotePackageImplementation.js +9 -8
- package/lib/module/internals/RemotePackageImplementation.js.map +1 -1
- package/lib/module/internals/getConfiguration.js +3 -0
- package/lib/module/internals/getConfiguration.js.map +1 -1
- package/lib/module/internals/logger.js +44 -0
- package/lib/module/internals/logger.js.map +1 -0
- package/lib/module/internals/shouldUpdateBeIgnored.js +6 -5
- package/lib/module/internals/shouldUpdateBeIgnored.js.map +1 -1
- package/lib/module/internals/utils/fetchRetry.js +55 -0
- package/lib/module/internals/utils/fetchRetry.js.map +1 -0
- package/lib/module/internals/utils/log.js +11 -3
- package/lib/module/internals/utils/log.js.map +1 -1
- package/lib/module/internals/utils/queryStringify.js +21 -0
- package/lib/module/internals/utils/queryStringify.js.map +1 -0
- package/lib/module/internals/utils/requestFetchAdapter.js +34 -0
- package/lib/module/internals/utils/requestFetchAdapter.js.map +1 -0
- package/lib/module/internals/version.js +1 -1
- package/lib/module/internals/version.js.map +1 -1
- package/lib/module/logLevel.js +9 -0
- package/lib/module/logLevel.js.map +1 -0
- package/lib/module/logger.js +4 -0
- package/lib/module/logger.js.map +1 -0
- package/lib/module/notifyAppReady.js +26 -15
- package/lib/module/notifyAppReady.js.map +1 -1
- package/lib/module/resetClientUniqueId.js +14 -0
- package/lib/module/resetClientUniqueId.js.map +1 -0
- package/lib/module/restartApp.js +4 -2
- package/lib/module/restartApp.js.map +1 -1
- package/lib/module/sync.js +35 -28
- package/lib/module/sync.js.map +1 -1
- package/lib/module/telemetry.js +24 -0
- package/lib/module/telemetry.js.map +1 -0
- package/lib/typescript/commonjs/src/CodePush.d.ts +10 -5
- package/lib/typescript/commonjs/src/CodePush.d.ts.map +1 -1
- package/lib/typescript/commonjs/src/allowRestart.d.ts +3 -1
- package/lib/typescript/commonjs/src/allowRestart.d.ts.map +1 -1
- package/lib/typescript/commonjs/src/checkForUpdates.d.ts.map +1 -1
- package/lib/typescript/commonjs/src/clearUpdates.d.ts +3 -2
- package/lib/typescript/commonjs/src/clearUpdates.d.ts.map +1 -1
- package/lib/typescript/commonjs/src/dataTransmission.d.ts +13 -0
- package/lib/typescript/commonjs/src/dataTransmission.d.ts.map +1 -0
- package/lib/typescript/commonjs/src/disallowRestart.d.ts +3 -1
- package/lib/typescript/commonjs/src/disallowRestart.d.ts.map +1 -1
- package/lib/typescript/commonjs/src/enums/CheckFrequency.enum.d.ts +2 -2
- package/lib/typescript/commonjs/src/enums/InstallMode.enum.d.ts +7 -3
- package/lib/typescript/commonjs/src/enums/InstallMode.enum.d.ts.map +1 -1
- package/lib/typescript/commonjs/src/enums/LogLevel.enum.d.ts +10 -0
- package/lib/typescript/commonjs/src/enums/LogLevel.enum.d.ts.map +1 -0
- package/lib/typescript/commonjs/src/enums/SyncStatus.enum.d.ts +7 -7
- package/lib/typescript/commonjs/src/enums/UpdateState.enum.d.ts +7 -6
- package/lib/typescript/commonjs/src/enums/UpdateState.enum.d.ts.map +1 -1
- package/lib/typescript/commonjs/src/getClientUniqueId.d.ts +5 -0
- package/lib/typescript/commonjs/src/getClientUniqueId.d.ts.map +1 -0
- package/lib/typescript/commonjs/src/index.d.ts +8 -1
- package/lib/typescript/commonjs/src/index.d.ts.map +1 -1
- package/lib/typescript/commonjs/src/internals/CodePushApiSdk.d.ts +15 -0
- package/lib/typescript/commonjs/src/internals/CodePushApiSdk.d.ts.map +1 -0
- package/lib/typescript/commonjs/src/internals/CodePushApiSdk.errors.d.ts +9 -0
- package/lib/typescript/commonjs/src/internals/CodePushApiSdk.errors.d.ts.map +1 -0
- package/lib/typescript/commonjs/src/internals/CodePushApiSdk.types.d.ts +103 -0
- package/lib/typescript/commonjs/src/internals/CodePushApiSdk.types.d.ts.map +1 -0
- package/lib/typescript/commonjs/src/internals/CodePushEventEmitter.d.ts +3 -0
- package/lib/typescript/commonjs/src/internals/CodePushEventEmitter.d.ts.map +1 -0
- package/lib/typescript/commonjs/src/internals/RNAppZungCodePushModuleSpec.d.ts +5 -0
- package/lib/typescript/commonjs/src/internals/RNAppZungCodePushModuleSpec.d.ts.map +1 -1
- package/lib/typescript/commonjs/src/internals/RemotePackageImplementation.d.ts +2 -2
- package/lib/typescript/commonjs/src/internals/RemotePackageImplementation.d.ts.map +1 -1
- package/lib/typescript/commonjs/src/internals/getConfiguration.d.ts +1 -0
- package/lib/typescript/commonjs/src/internals/getConfiguration.d.ts.map +1 -1
- package/lib/typescript/commonjs/src/internals/logger.d.ts +33 -0
- package/lib/typescript/commonjs/src/internals/logger.d.ts.map +1 -0
- package/lib/typescript/commonjs/src/internals/shouldUpdateBeIgnored.d.ts.map +1 -1
- package/lib/typescript/commonjs/src/internals/types.d.ts +2 -2
- package/lib/typescript/commonjs/src/internals/types.d.ts.map +1 -1
- package/lib/typescript/commonjs/src/internals/utils/fetchRetry.d.ts +9 -0
- package/lib/typescript/commonjs/src/internals/utils/fetchRetry.d.ts.map +1 -0
- package/lib/typescript/commonjs/src/internals/utils/log.d.ts +2 -1
- package/lib/typescript/commonjs/src/internals/utils/log.d.ts.map +1 -1
- package/lib/typescript/commonjs/src/internals/utils/queryStringify.d.ts +4 -0
- package/lib/typescript/commonjs/src/internals/utils/queryStringify.d.ts.map +1 -0
- package/lib/typescript/commonjs/src/internals/utils/requestFetchAdapter.d.ts +3 -0
- package/lib/typescript/commonjs/src/internals/utils/requestFetchAdapter.d.ts.map +1 -0
- package/lib/typescript/commonjs/src/internals/version.d.ts +1 -1
- package/lib/typescript/commonjs/src/internals/version.d.ts.map +1 -1
- package/lib/typescript/commonjs/src/logLevel.d.ts +4 -0
- package/lib/typescript/commonjs/src/logLevel.d.ts.map +1 -0
- package/lib/typescript/commonjs/src/logger.d.ts +3 -0
- package/lib/typescript/commonjs/src/logger.d.ts.map +1 -0
- package/lib/typescript/commonjs/src/notifyAppReady.d.ts +4 -0
- package/lib/typescript/commonjs/src/notifyAppReady.d.ts.map +1 -1
- package/lib/typescript/commonjs/src/resetClientUniqueId.d.ts +5 -0
- package/lib/typescript/commonjs/src/resetClientUniqueId.d.ts.map +1 -0
- package/lib/typescript/commonjs/src/restartApp.d.ts +2 -0
- package/lib/typescript/commonjs/src/restartApp.d.ts.map +1 -1
- package/lib/typescript/commonjs/src/sync.d.ts +5 -1
- package/lib/typescript/commonjs/src/sync.d.ts.map +1 -1
- package/lib/typescript/commonjs/src/telemetry.d.ts +13 -0
- package/lib/typescript/commonjs/src/telemetry.d.ts.map +1 -0
- package/lib/typescript/commonjs/src/types.d.ts +72 -29
- package/lib/typescript/commonjs/src/types.d.ts.map +1 -1
- package/lib/typescript/module/src/CodePush.d.ts +10 -5
- package/lib/typescript/module/src/CodePush.d.ts.map +1 -1
- package/lib/typescript/module/src/allowRestart.d.ts +3 -1
- package/lib/typescript/module/src/allowRestart.d.ts.map +1 -1
- package/lib/typescript/module/src/checkForUpdates.d.ts.map +1 -1
- package/lib/typescript/module/src/clearUpdates.d.ts +3 -2
- package/lib/typescript/module/src/clearUpdates.d.ts.map +1 -1
- package/lib/typescript/module/src/dataTransmission.d.ts +13 -0
- package/lib/typescript/module/src/dataTransmission.d.ts.map +1 -0
- package/lib/typescript/module/src/disallowRestart.d.ts +3 -1
- package/lib/typescript/module/src/disallowRestart.d.ts.map +1 -1
- package/lib/typescript/module/src/enums/CheckFrequency.enum.d.ts +2 -2
- package/lib/typescript/module/src/enums/InstallMode.enum.d.ts +7 -3
- package/lib/typescript/module/src/enums/InstallMode.enum.d.ts.map +1 -1
- package/lib/typescript/module/src/enums/LogLevel.enum.d.ts +10 -0
- package/lib/typescript/module/src/enums/LogLevel.enum.d.ts.map +1 -0
- package/lib/typescript/module/src/enums/SyncStatus.enum.d.ts +7 -7
- package/lib/typescript/module/src/enums/UpdateState.enum.d.ts +7 -6
- package/lib/typescript/module/src/enums/UpdateState.enum.d.ts.map +1 -1
- package/lib/typescript/module/src/getClientUniqueId.d.ts +5 -0
- package/lib/typescript/module/src/getClientUniqueId.d.ts.map +1 -0
- package/lib/typescript/module/src/index.d.ts +8 -1
- package/lib/typescript/module/src/index.d.ts.map +1 -1
- package/lib/typescript/module/src/internals/CodePushApiSdk.d.ts +15 -0
- package/lib/typescript/module/src/internals/CodePushApiSdk.d.ts.map +1 -0
- package/lib/typescript/module/src/internals/CodePushApiSdk.errors.d.ts +9 -0
- package/lib/typescript/module/src/internals/CodePushApiSdk.errors.d.ts.map +1 -0
- package/lib/typescript/module/src/internals/CodePushApiSdk.types.d.ts +103 -0
- package/lib/typescript/module/src/internals/CodePushApiSdk.types.d.ts.map +1 -0
- package/lib/typescript/module/src/internals/CodePushEventEmitter.d.ts +3 -0
- package/lib/typescript/module/src/internals/CodePushEventEmitter.d.ts.map +1 -0
- package/lib/typescript/module/src/internals/RNAppZungCodePushModuleSpec.d.ts +5 -0
- package/lib/typescript/module/src/internals/RNAppZungCodePushModuleSpec.d.ts.map +1 -1
- package/lib/typescript/module/src/internals/RemotePackageImplementation.d.ts +2 -2
- package/lib/typescript/module/src/internals/RemotePackageImplementation.d.ts.map +1 -1
- package/lib/typescript/module/src/internals/getConfiguration.d.ts +1 -0
- package/lib/typescript/module/src/internals/getConfiguration.d.ts.map +1 -1
- package/lib/typescript/module/src/internals/logger.d.ts +33 -0
- package/lib/typescript/module/src/internals/logger.d.ts.map +1 -0
- package/lib/typescript/module/src/internals/shouldUpdateBeIgnored.d.ts.map +1 -1
- package/lib/typescript/module/src/internals/types.d.ts +2 -2
- package/lib/typescript/module/src/internals/types.d.ts.map +1 -1
- package/lib/typescript/module/src/internals/utils/fetchRetry.d.ts +9 -0
- package/lib/typescript/module/src/internals/utils/fetchRetry.d.ts.map +1 -0
- package/lib/typescript/module/src/internals/utils/log.d.ts +2 -1
- package/lib/typescript/module/src/internals/utils/log.d.ts.map +1 -1
- package/lib/typescript/module/src/internals/utils/queryStringify.d.ts +4 -0
- package/lib/typescript/module/src/internals/utils/queryStringify.d.ts.map +1 -0
- package/lib/typescript/module/src/internals/utils/requestFetchAdapter.d.ts +3 -0
- package/lib/typescript/module/src/internals/utils/requestFetchAdapter.d.ts.map +1 -0
- package/lib/typescript/module/src/internals/version.d.ts +1 -1
- package/lib/typescript/module/src/internals/version.d.ts.map +1 -1
- package/lib/typescript/module/src/logLevel.d.ts +4 -0
- package/lib/typescript/module/src/logLevel.d.ts.map +1 -0
- package/lib/typescript/module/src/logger.d.ts +3 -0
- package/lib/typescript/module/src/logger.d.ts.map +1 -0
- package/lib/typescript/module/src/notifyAppReady.d.ts +4 -0
- package/lib/typescript/module/src/notifyAppReady.d.ts.map +1 -1
- package/lib/typescript/module/src/resetClientUniqueId.d.ts +5 -0
- package/lib/typescript/module/src/resetClientUniqueId.d.ts.map +1 -0
- package/lib/typescript/module/src/restartApp.d.ts +2 -0
- package/lib/typescript/module/src/restartApp.d.ts.map +1 -1
- package/lib/typescript/module/src/sync.d.ts +5 -1
- package/lib/typescript/module/src/sync.d.ts.map +1 -1
- package/lib/typescript/module/src/telemetry.d.ts +13 -0
- package/lib/typescript/module/src/telemetry.d.ts.map +1 -0
- package/lib/typescript/module/src/types.d.ts +72 -29
- package/lib/typescript/module/src/types.d.ts.map +1 -1
- package/package.json +24 -13
- package/scripts/generateBundledResourcesHash.js +73 -68
- package/scripts/getFilesInFolder.js +12 -12
- package/scripts/recordFilesBeforeBundleCommand.js +19 -20
- package/src/CodePush.tsx +20 -5
- package/src/allowRestart.ts +5 -1
- package/src/checkForUpdates.ts +26 -24
- package/src/clearUpdates.ts +5 -2
- package/src/dataTransmission.ts +21 -0
- package/src/disallowRestart.ts +5 -1
- package/src/enums/CheckFrequency.enum.ts +2 -2
- package/src/enums/InstallMode.enum.ts +7 -3
- package/src/enums/LogLevel.enum.ts +9 -0
- package/src/enums/SyncStatus.enum.ts +7 -7
- package/src/enums/UpdateState.enum.ts +7 -6
- package/src/getClientUniqueId.ts +9 -0
- package/src/index.ts +8 -1
- package/src/internals/CodePushApiSdk.errors.ts +22 -0
- package/src/internals/CodePushApiSdk.ts +160 -0
- package/src/internals/CodePushApiSdk.types.ts +117 -0
- package/src/internals/CodePushEventEmitter.ts +4 -0
- package/src/internals/RNAppZungCodePushModuleSpec.ts +7 -0
- package/src/internals/RemotePackageImplementation.ts +11 -10
- package/src/internals/getConfiguration.ts +4 -0
- package/src/internals/logger.ts +46 -0
- package/src/internals/shouldUpdateBeIgnored.ts +6 -5
- package/src/internals/types.ts +2 -2
- package/src/internals/utils/fetchRetry.ts +72 -0
- package/src/internals/utils/log.ts +13 -3
- package/src/internals/utils/queryStringify.ts +22 -0
- package/src/internals/utils/requestFetchAdapter.ts +36 -0
- package/src/internals/version.ts +1 -1
- package/src/logLevel.ts +9 -0
- package/src/logger.ts +2 -0
- package/src/notifyAppReady.ts +29 -18
- package/src/resetClientUniqueId.ts +11 -0
- package/src/restartApp.ts +4 -2
- package/src/sync.ts +41 -27
- package/src/telemetry.ts +21 -0
- package/src/types.ts +72 -29
- package/android/app/.gradle/config.properties +0 -2
- package/android/app/local.properties +0 -8
- package/docs/advanced-usage.md +0 -56
- package/docs/api-android.md +0 -22
- package/docs/api-ios.md +0 -19
- package/docs/api-js.md +0 -557
- package/docs/code-signing.md +0 -62
- package/docs/migrating-to-v10.md +0 -31
- package/docs/setup-android.md +0 -81
- package/docs/setup-ios.md +0 -108
- package/docs/setup-windows.md +0 -55
- package/lib/commonjs/enums/DeploymentStatus.enum.js.map +0 -1
- package/lib/commonjs/internals/AcquisitionSdk.js +0 -9
- package/lib/commonjs/internals/AcquisitionSdk.js.map +0 -1
- package/lib/commonjs/internals/getPromisifiedSdk.js +0 -49
- package/lib/commonjs/internals/getPromisifiedSdk.js.map +0 -1
- package/lib/commonjs/internals/utils/request-fetch-adapter.js +0 -50
- package/lib/commonjs/internals/utils/request-fetch-adapter.js.map +0 -1
- package/lib/module/enums/DeploymentStatus.enum.js.map +0 -1
- package/lib/module/internals/AcquisitionSdk.js +0 -5
- package/lib/module/internals/AcquisitionSdk.js.map +0 -1
- package/lib/module/internals/getPromisifiedSdk.js +0 -45
- package/lib/module/internals/getPromisifiedSdk.js.map +0 -1
- package/lib/module/internals/utils/request-fetch-adapter.js +0 -46
- package/lib/module/internals/utils/request-fetch-adapter.js.map +0 -1
- package/lib/typescript/commonjs/src/enums/DeploymentStatus.enum.d.ts +0 -14
- package/lib/typescript/commonjs/src/enums/DeploymentStatus.enum.d.ts.map +0 -1
- package/lib/typescript/commonjs/src/internals/AcquisitionSdk.d.ts +0 -3
- package/lib/typescript/commonjs/src/internals/AcquisitionSdk.d.ts.map +0 -1
- package/lib/typescript/commonjs/src/internals/getPromisifiedSdk.d.ts +0 -13
- package/lib/typescript/commonjs/src/internals/getPromisifiedSdk.d.ts.map +0 -1
- package/lib/typescript/commonjs/src/internals/utils/request-fetch-adapter.d.ts +0 -3
- package/lib/typescript/commonjs/src/internals/utils/request-fetch-adapter.d.ts.map +0 -1
- package/lib/typescript/module/src/enums/DeploymentStatus.enum.d.ts +0 -14
- package/lib/typescript/module/src/enums/DeploymentStatus.enum.d.ts.map +0 -1
- package/lib/typescript/module/src/internals/AcquisitionSdk.d.ts +0 -3
- package/lib/typescript/module/src/internals/AcquisitionSdk.d.ts.map +0 -1
- package/lib/typescript/module/src/internals/getPromisifiedSdk.d.ts +0 -13
- package/lib/typescript/module/src/internals/getPromisifiedSdk.d.ts.map +0 -1
- package/lib/typescript/module/src/internals/utils/request-fetch-adapter.d.ts +0 -3
- package/lib/typescript/module/src/internals/utils/request-fetch-adapter.d.ts.map +0 -1
- package/src/enums/DeploymentStatus.enum.ts +0 -14
- package/src/internals/AcquisitionSdk.ts +0 -3
- package/src/internals/getPromisifiedSdk.ts +0 -72
- package/src/internals/utils/request-fetch-adapter.ts +0 -58
|
@@ -1,4 +1,3 @@
|
|
|
1
|
-
#if __has_include(<React/RCTAssert.h>)
|
|
2
1
|
#import <React/RCTAssert.h>
|
|
3
2
|
#import <React/RCTBridgeModule.h>
|
|
4
3
|
#import <React/RCTConvert.h>
|
|
@@ -6,18 +5,10 @@
|
|
|
6
5
|
#import <React/RCTRootView.h>
|
|
7
6
|
#import <React/RCTUtils.h>
|
|
8
7
|
#import <React/RCTReloadCommand.h>
|
|
9
|
-
#else // back compatibility for RN version < 0.40
|
|
10
|
-
#import "RCTAssert.h"
|
|
11
|
-
#import "RCTBridgeModule.h"
|
|
12
|
-
#import "RCTConvert.h"
|
|
13
|
-
#import "RCTEventDispatcher.h"
|
|
14
|
-
#import "RCTRootView.h"
|
|
15
|
-
#import "RCTUtils.h"
|
|
16
|
-
#endif
|
|
17
8
|
|
|
18
9
|
#import "CodePush.h"
|
|
19
10
|
|
|
20
|
-
@interface CodePush () <RCTBridgeModule
|
|
11
|
+
@interface CodePush () <RCTBridgeModule>
|
|
21
12
|
@end
|
|
22
13
|
|
|
23
14
|
@implementation CodePush {
|
|
@@ -30,8 +21,8 @@
|
|
|
30
21
|
|
|
31
22
|
// Used to coordinate the dispatching of download progress events to JS.
|
|
32
23
|
long long _latestExpectedContentLength;
|
|
33
|
-
long long
|
|
34
|
-
|
|
24
|
+
long long _latestReceivedContentLength;
|
|
25
|
+
NSTimeInterval _lastProgressEmitTimestamp;
|
|
35
26
|
|
|
36
27
|
BOOL _allowed;
|
|
37
28
|
BOOL _restartInProgress;
|
|
@@ -255,18 +246,6 @@ static NSString *const LatestRollbackCountKey = @"count";
|
|
|
255
246
|
#pragma mark - Private API methods
|
|
256
247
|
|
|
257
248
|
@synthesize methodQueue = _methodQueue;
|
|
258
|
-
@synthesize pauseCallback = _pauseCallback;
|
|
259
|
-
@synthesize paused = _paused;
|
|
260
|
-
|
|
261
|
-
- (void)setPaused:(BOOL)paused
|
|
262
|
-
{
|
|
263
|
-
if (_paused != paused) {
|
|
264
|
-
_paused = paused;
|
|
265
|
-
if (_pauseCallback) {
|
|
266
|
-
_pauseCallback();
|
|
267
|
-
}
|
|
268
|
-
}
|
|
269
|
-
}
|
|
270
249
|
|
|
271
250
|
/*
|
|
272
251
|
* This method is used to clear updates that are installed
|
|
@@ -302,15 +281,15 @@ static NSString *const LatestRollbackCountKey = @"count";
|
|
|
302
281
|
// Export the values of the CodePushInstallMode and CodePushUpdateState
|
|
303
282
|
// enums so that the script-side can easily stay in sync
|
|
304
283
|
return @{
|
|
305
|
-
|
|
306
|
-
|
|
307
|
-
|
|
308
|
-
|
|
309
|
-
|
|
310
|
-
|
|
311
|
-
|
|
312
|
-
|
|
313
|
-
|
|
284
|
+
@"codePushInstallModeOnNextRestart":@(CodePushInstallModeOnNextRestart),
|
|
285
|
+
@"codePushInstallModeImmediate": @(CodePushInstallModeImmediate),
|
|
286
|
+
@"codePushInstallModeOnNextResume": @(CodePushInstallModeOnNextResume),
|
|
287
|
+
@"codePushInstallModeOnNextSuspend": @(CodePushInstallModeOnNextSuspend),
|
|
288
|
+
|
|
289
|
+
@"codePushUpdateStateRunning": @(CodePushUpdateStateRunning),
|
|
290
|
+
@"codePushUpdateStatePending": @(CodePushUpdateStatePending),
|
|
291
|
+
@"codePushUpdateStateLatest": @(CodePushUpdateStateLatest)
|
|
292
|
+
};
|
|
314
293
|
};
|
|
315
294
|
|
|
316
295
|
+ (BOOL)requiresMainQueueSetup
|
|
@@ -326,14 +305,14 @@ static NSString *const LatestRollbackCountKey = @"count";
|
|
|
326
305
|
}
|
|
327
306
|
|
|
328
307
|
- (void)dispatchDownloadProgressEvent {
|
|
329
|
-
|
|
330
|
-
|
|
331
|
-
|
|
332
|
-
|
|
333
|
-
|
|
334
|
-
|
|
335
|
-
|
|
336
|
-
|
|
308
|
+
// Notify the script-side about the progress
|
|
309
|
+
[self sendEventWithName:DownloadProgressEvent
|
|
310
|
+
body:@{
|
|
311
|
+
@"totalBytes" : [NSNumber
|
|
312
|
+
numberWithLongLong:_latestExpectedContentLength],
|
|
313
|
+
@"receivedBytes" : [NSNumber
|
|
314
|
+
numberWithLongLong:_latestReceivedContentLength]
|
|
315
|
+
}];
|
|
337
316
|
}
|
|
338
317
|
|
|
339
318
|
/*
|
|
@@ -345,28 +324,28 @@ static NSString *const LatestRollbackCountKey = @"count";
|
|
|
345
324
|
if (![self binaryBundleURL]) {
|
|
346
325
|
NSString *errorMessage;
|
|
347
326
|
|
|
348
|
-
|
|
349
|
-
|
|
350
|
-
|
|
351
|
-
|
|
352
|
-
|
|
327
|
+
#ifdef DEBUG
|
|
328
|
+
#if TARGET_IPHONE_SIMULATOR
|
|
329
|
+
errorMessage = @"React Native doesn't generate your app's JS bundle by default when deploying to the simulator. "
|
|
330
|
+
"If you'd like to test CodePush using the simulator, you can do one of the following depending on your "
|
|
331
|
+
"React Native version and/or preferred workflow:\n\n"
|
|
353
332
|
|
|
354
|
-
|
|
355
|
-
|
|
333
|
+
"1. Update your AppDelegate.m file to load the JS bundle from the packager instead of from CodePush. "
|
|
334
|
+
"You can still test your CodePush update experience using this workflow (Debug builds only).\n\n"
|
|
356
335
|
|
|
357
|
-
|
|
358
|
-
|
|
336
|
+
"2. Force the JS bundle to be generated in simulator builds by adding 'export FORCE_BUNDLING=true' to the script under "
|
|
337
|
+
"\"Build Phases\" > \"Bundle React Native code and images\" (React Native >=0.48 only).\n\n"
|
|
359
338
|
|
|
360
|
-
|
|
361
|
-
|
|
339
|
+
"3. Force the JS bundle to be generated in simulator builds by removing the if block that echoes "
|
|
340
|
+
"\"Skipping bundling for Simulator platform\" in the \"node_modules/react-native/packager/react-native-xcode.sh\" file (React Native <=0.47 only)\n\n"
|
|
362
341
|
|
|
363
|
-
|
|
364
|
-
|
|
365
|
-
|
|
366
|
-
|
|
367
|
-
|
|
342
|
+
"4. Deploy a Release build to the simulator, which unlike Debug builds, will generate the JS bundle (React Native >=0.22.0 only).";
|
|
343
|
+
#else
|
|
344
|
+
errorMessage = [NSString stringWithFormat:@"The specified JS bundle file wasn't found within the app's binary. Is \"%@\" the correct file name?", [bundleResourceName stringByAppendingPathExtension:bundleResourceExtension]];
|
|
345
|
+
#endif
|
|
346
|
+
#else
|
|
368
347
|
errorMessage = @"Something went wrong. Please verify if generated JS bundle is correct. ";
|
|
369
|
-
|
|
348
|
+
#endif
|
|
370
349
|
|
|
371
350
|
RCTFatal([CodePushErrorUtils errorWithMessage:errorMessage]);
|
|
372
351
|
}
|
|
@@ -396,7 +375,6 @@ static NSString *const LatestRollbackCountKey = @"count";
|
|
|
396
375
|
#ifdef DEBUG
|
|
397
376
|
[self clearDebugUpdates];
|
|
398
377
|
#endif
|
|
399
|
-
self.paused = YES;
|
|
400
378
|
NSUserDefaults *preferences = [NSUserDefaults standardUserDefaults];
|
|
401
379
|
NSDictionary *pendingUpdate = [preferences objectForKey:PendingUpdateKey];
|
|
402
380
|
if (pendingUpdate) {
|
|
@@ -517,8 +495,8 @@ static NSString *const LatestRollbackCountKey = @"count";
|
|
|
517
495
|
// If there is a pending update whose "state" isn't loading, then we consider it "pending".
|
|
518
496
|
// Additionally, if a specific hash was provided, we ensure it matches that of the pending update.
|
|
519
497
|
BOOL updateIsPending = pendingUpdate &&
|
|
520
|
-
|
|
521
|
-
|
|
498
|
+
[pendingUpdate[PendingUpdateIsLoadingKey] boolValue] == NO &&
|
|
499
|
+
(!packageHash || [pendingUpdate[PendingUpdateHashKey] isEqualToString:packageHash]);
|
|
522
500
|
|
|
523
501
|
return updateIsPending;
|
|
524
502
|
}
|
|
@@ -690,10 +668,10 @@ static NSString *const LatestRollbackCountKey = @"count";
|
|
|
690
668
|
|
|
691
669
|
if (_installMode == CodePushInstallModeOnNextSuspend && [[self class] isPendingUpdate:nil]) {
|
|
692
670
|
_appSuspendTimer = [NSTimer scheduledTimerWithTimeInterval:_minimumBackgroundDuration
|
|
693
|
-
|
|
694
|
-
|
|
695
|
-
|
|
696
|
-
|
|
671
|
+
target:self
|
|
672
|
+
selector:@selector(loadBundleOnTick:)
|
|
673
|
+
userInfo:nil
|
|
674
|
+
repeats:NO];
|
|
697
675
|
}
|
|
698
676
|
}
|
|
699
677
|
|
|
@@ -708,8 +686,8 @@ static NSString *const LatestRollbackCountKey = @"count";
|
|
|
708
686
|
*/
|
|
709
687
|
RCT_EXPORT_METHOD(downloadUpdate:(NSDictionary*)updatePackage
|
|
710
688
|
notifyProgress:(BOOL)notifyProgress
|
|
711
|
-
|
|
712
|
-
|
|
689
|
+
resolver:(RCTPromiseResolveBlock)resolve
|
|
690
|
+
rejecter:(RCTPromiseRejectBlock)reject)
|
|
713
691
|
{
|
|
714
692
|
NSDictionary *mutableUpdatePackage = [updatePackage mutableCopy];
|
|
715
693
|
NSURL *binaryBundleURL = [CodePush binaryBundleURL];
|
|
@@ -718,56 +696,46 @@ RCT_EXPORT_METHOD(downloadUpdate:(NSDictionary*)updatePackage
|
|
|
718
696
|
forKey:BinaryBundleDateKey];
|
|
719
697
|
}
|
|
720
698
|
|
|
721
|
-
if (notifyProgress) {
|
|
722
|
-
// Set up and unpause the frame observer so that it can emit
|
|
723
|
-
// progress events every frame if the progress is updated.
|
|
724
|
-
_didUpdateProgress = NO;
|
|
725
|
-
self.paused = NO;
|
|
726
|
-
}
|
|
727
|
-
|
|
728
699
|
NSString * publicKey = [[CodePushConfig current] publicKey];
|
|
729
700
|
|
|
730
701
|
[CodePushPackage
|
|
731
|
-
|
|
732
|
-
|
|
733
|
-
|
|
734
|
-
|
|
735
|
-
|
|
736
|
-
|
|
737
|
-
|
|
738
|
-
|
|
739
|
-
|
|
740
|
-
|
|
741
|
-
|
|
742
|
-
|
|
743
|
-
|
|
744
|
-
if (
|
|
745
|
-
|
|
746
|
-
self.paused = YES;
|
|
702
|
+
downloadPackage:mutableUpdatePackage
|
|
703
|
+
expectedBundleFileName:[bundleResourceName stringByAppendingPathExtension:bundleResourceExtension]
|
|
704
|
+
publicKey:publicKey
|
|
705
|
+
operationQueue:_methodQueue
|
|
706
|
+
// The download is progressing forward
|
|
707
|
+
progressCallback:^(long long expectedContentLength, long long receivedContentLength) {
|
|
708
|
+
self->_latestExpectedContentLength = expectedContentLength;
|
|
709
|
+
self->_latestReceivedContentLength = receivedContentLength;
|
|
710
|
+
|
|
711
|
+
if (expectedContentLength == receivedContentLength) {
|
|
712
|
+
[self dispatchDownloadProgressEvent];
|
|
713
|
+
} else if (notifyProgress) {
|
|
714
|
+
NSTimeInterval timestamp = [[NSDate date] timeIntervalSince1970];
|
|
715
|
+
if (timestamp - self->_lastProgressEmitTimestamp > 0.3) {
|
|
716
|
+
self->_lastProgressEmitTimestamp = timestamp;
|
|
747
717
|
[self dispatchDownloadProgressEvent];
|
|
748
718
|
}
|
|
749
719
|
}
|
|
750
|
-
|
|
751
|
-
|
|
752
|
-
|
|
753
|
-
|
|
720
|
+
}
|
|
721
|
+
// The download completed
|
|
722
|
+
doneCallback:^{
|
|
723
|
+
NSError *err;
|
|
724
|
+
NSDictionary *newPackage = [CodePushPackage getPackage:mutableUpdatePackage[PackageHashKey] error:&err];
|
|
754
725
|
|
|
755
|
-
|
|
756
|
-
|
|
757
|
-
|
|
758
|
-
|
|
726
|
+
if (err) {
|
|
727
|
+
return reject([NSString stringWithFormat: @"%lu", (long)err.code], err.localizedDescription, err);
|
|
728
|
+
}
|
|
729
|
+
resolve(newPackage);
|
|
730
|
+
}
|
|
731
|
+
// The download failed
|
|
732
|
+
failCallback:^(NSError *err) {
|
|
733
|
+
if ([CodePushErrorUtils isCodePushError:err]) {
|
|
734
|
+
[self saveFailedUpdate:mutableUpdatePackage];
|
|
759
735
|
}
|
|
760
|
-
// The download failed
|
|
761
|
-
failCallback:^(NSError *err) {
|
|
762
|
-
if ([CodePushErrorUtils isCodePushError:err]) {
|
|
763
|
-
[self saveFailedUpdate:mutableUpdatePackage];
|
|
764
|
-
}
|
|
765
736
|
|
|
766
|
-
|
|
767
|
-
|
|
768
|
-
self.paused = YES;
|
|
769
|
-
reject([NSString stringWithFormat: @"%lu", (long)err.code], err.localizedDescription, err);
|
|
770
|
-
}];
|
|
737
|
+
reject([NSString stringWithFormat: @"%lu", (long)err.code], err.localizedDescription, err);
|
|
738
|
+
}];
|
|
771
739
|
}
|
|
772
740
|
|
|
773
741
|
- (void)restartAppInternal:(BOOL)onlyIfUpdateIsPending
|
|
@@ -804,7 +772,7 @@ RCT_EXPORT_METHOD(downloadUpdate:(NSDictionary*)updatePackage
|
|
|
804
772
|
* app version, as well as the release channel public ID that was configured in the Info.plist file.
|
|
805
773
|
*/
|
|
806
774
|
RCT_EXPORT_METHOD(getConfiguration:(RCTPromiseResolveBlock)resolve
|
|
807
|
-
|
|
775
|
+
rejecter:(RCTPromiseRejectBlock)reject)
|
|
808
776
|
{
|
|
809
777
|
NSDictionary *configuration = [[CodePushConfig current] configuration];
|
|
810
778
|
NSError *error;
|
|
@@ -838,8 +806,8 @@ RCT_EXPORT_METHOD(getConfiguration:(RCTPromiseResolveBlock)resolve
|
|
|
838
806
|
* This method is the native side of the CodePush.getUpdateMetadata method.
|
|
839
807
|
*/
|
|
840
808
|
RCT_EXPORT_METHOD(getUpdateMetadata:(CodePushUpdateState)updateState
|
|
841
|
-
|
|
842
|
-
|
|
809
|
+
resolver:(RCTPromiseResolveBlock)resolve
|
|
810
|
+
rejecter:(RCTPromiseRejectBlock)reject)
|
|
843
811
|
{
|
|
844
812
|
NSError *error;
|
|
845
813
|
NSMutableDictionary *package = [[CodePushPackage getCurrentPackage:&error] mutableCopy];
|
|
@@ -886,10 +854,10 @@ RCT_EXPORT_METHOD(getUpdateMetadata:(CodePushUpdateState)updateState
|
|
|
886
854
|
* This method is the native side of the LocalPackage.install method.
|
|
887
855
|
*/
|
|
888
856
|
RCT_EXPORT_METHOD(installUpdate:(NSDictionary*)updatePackage
|
|
889
|
-
|
|
890
|
-
|
|
891
|
-
|
|
892
|
-
|
|
857
|
+
installMode:(CodePushInstallMode)installMode
|
|
858
|
+
minimumBackgroundDuration:(int)minimumBackgroundDuration
|
|
859
|
+
resolver:(RCTPromiseResolveBlock)resolve
|
|
860
|
+
rejecter:(RCTPromiseRejectBlock)reject)
|
|
893
861
|
{
|
|
894
862
|
NSError *error;
|
|
895
863
|
[CodePushPackage installPackage:updatePackage
|
|
@@ -939,8 +907,8 @@ RCT_EXPORT_METHOD(installUpdate:(NSDictionary*)updatePackage
|
|
|
939
907
|
* module, and is only used internally to populate the RemotePackage.failedInstall property.
|
|
940
908
|
*/
|
|
941
909
|
RCT_EXPORT_METHOD(isFailedUpdate:(NSString *)packageHash
|
|
942
|
-
|
|
943
|
-
|
|
910
|
+
resolve:(RCTPromiseResolveBlock)resolve
|
|
911
|
+
reject:(RCTPromiseRejectBlock)reject)
|
|
944
912
|
{
|
|
945
913
|
BOOL isFailedHash = [[self class] isFailedHash:packageHash];
|
|
946
914
|
resolve(@(isFailedHash));
|
|
@@ -967,14 +935,14 @@ RCT_EXPORT_METHOD(getLatestRollbackInfo:(RCTPromiseResolveBlock)resolve
|
|
|
967
935
|
* module, and is only used internally to populate the LocalPackage.isFirstRun property.
|
|
968
936
|
*/
|
|
969
937
|
RCT_EXPORT_METHOD(isFirstRun:(NSString *)packageHash
|
|
970
|
-
|
|
971
|
-
|
|
938
|
+
resolve:(RCTPromiseResolveBlock)resolve
|
|
939
|
+
rejecter:(RCTPromiseRejectBlock)reject)
|
|
972
940
|
{
|
|
973
941
|
NSError *error;
|
|
974
942
|
BOOL isFirstRun = _isFirstRunAfterUpdate
|
|
975
|
-
|
|
976
|
-
|
|
977
|
-
|
|
943
|
+
&& nil != packageHash
|
|
944
|
+
&& [packageHash length] > 0
|
|
945
|
+
&& [packageHash isEqualToString:[CodePushPackage getCurrentPackageHash:&error]];
|
|
978
946
|
|
|
979
947
|
resolve(@(isFirstRun));
|
|
980
948
|
}
|
|
@@ -983,14 +951,14 @@ RCT_EXPORT_METHOD(isFirstRun:(NSString *)packageHash
|
|
|
983
951
|
* This method is the native side of the CodePush.notifyApplicationReady() method.
|
|
984
952
|
*/
|
|
985
953
|
RCT_EXPORT_METHOD(notifyApplicationReady:(RCTPromiseResolveBlock)resolve
|
|
986
|
-
|
|
954
|
+
rejecter:(RCTPromiseRejectBlock)reject)
|
|
987
955
|
{
|
|
988
956
|
[CodePush removePendingUpdate];
|
|
989
957
|
resolve(nil);
|
|
990
958
|
}
|
|
991
959
|
|
|
992
960
|
RCT_EXPORT_METHOD(allow:(RCTPromiseResolveBlock)resolve
|
|
993
|
-
|
|
961
|
+
rejecter:(RCTPromiseRejectBlock)reject)
|
|
994
962
|
{
|
|
995
963
|
CPLog(@"Re-allowing restarts.");
|
|
996
964
|
_allowed = YES;
|
|
@@ -1006,14 +974,14 @@ RCT_EXPORT_METHOD(allow:(RCTPromiseResolveBlock)resolve
|
|
|
1006
974
|
}
|
|
1007
975
|
|
|
1008
976
|
RCT_EXPORT_METHOD(clearPendingRestart:(RCTPromiseResolveBlock)resolve
|
|
1009
|
-
|
|
977
|
+
rejecter:(RCTPromiseRejectBlock)reject)
|
|
1010
978
|
{
|
|
1011
979
|
[_restartQueue removeAllObjects];
|
|
1012
980
|
resolve(nil);
|
|
1013
981
|
}
|
|
1014
982
|
|
|
1015
983
|
RCT_EXPORT_METHOD(disallow:(RCTPromiseResolveBlock)resolve
|
|
1016
|
-
|
|
984
|
+
rejecter:(RCTPromiseRejectBlock)reject)
|
|
1017
985
|
{
|
|
1018
986
|
CPLog(@"Disallowing restarts.");
|
|
1019
987
|
_allowed = NO;
|
|
@@ -1024,8 +992,8 @@ RCT_EXPORT_METHOD(disallow:(RCTPromiseResolveBlock)resolve
|
|
|
1024
992
|
* This method is the native side of the CodePush.restartApp() method.
|
|
1025
993
|
*/
|
|
1026
994
|
RCT_EXPORT_METHOD(restartApp:(BOOL)onlyIfUpdateIsPending
|
|
1027
|
-
|
|
1028
|
-
|
|
995
|
+
resolve:(RCTPromiseResolveBlock)resolve
|
|
996
|
+
rejecter:(RCTPromiseRejectBlock)reject)
|
|
1029
997
|
{
|
|
1030
998
|
[self restartAppInternal:onlyIfUpdateIsPending];
|
|
1031
999
|
resolve(nil);
|
|
@@ -1042,6 +1010,41 @@ RCT_EXPORT_METHOD(clearUpdates) {
|
|
|
1042
1010
|
[CodePush clearUpdates];
|
|
1043
1011
|
}
|
|
1044
1012
|
|
|
1013
|
+
RCT_EXPORT_METHOD(resetClientUniqueId:(RCTPromiseResolveBlock)resolve
|
|
1014
|
+
rejecter:(RCTPromiseRejectBlock)reject)
|
|
1015
|
+
{
|
|
1016
|
+
CPLog(@"On iOS, resetting client device ID does nothing as it is the iOS IDFV.");
|
|
1017
|
+
resolve([[CodePushConfig current] clientUniqueId]);
|
|
1018
|
+
}
|
|
1019
|
+
|
|
1020
|
+
RCT_EXPORT_METHOD(setTelemetryEnabled:(BOOL)enabled
|
|
1021
|
+
resolver:(RCTPromiseResolveBlock)resolve
|
|
1022
|
+
rejecter:(RCTPromiseRejectBlock)reject)
|
|
1023
|
+
{
|
|
1024
|
+
[[CodePushConfig current] setTelemetryEnabled:enabled];
|
|
1025
|
+
resolve(nil);
|
|
1026
|
+
}
|
|
1027
|
+
|
|
1028
|
+
RCT_EXPORT_METHOD(getTelemetryEnabled:(RCTPromiseResolveBlock)resolve
|
|
1029
|
+
rejecter:(RCTPromiseRejectBlock)reject)
|
|
1030
|
+
{
|
|
1031
|
+
resolve(@([[CodePushConfig current] telemetryEnabled]));
|
|
1032
|
+
}
|
|
1033
|
+
|
|
1034
|
+
RCT_EXPORT_METHOD(setDataTransmissionEnabled:(BOOL)enabled
|
|
1035
|
+
resolver:(RCTPromiseResolveBlock)resolve
|
|
1036
|
+
rejecter:(RCTPromiseRejectBlock)reject)
|
|
1037
|
+
{
|
|
1038
|
+
[[CodePushConfig current] setDataTransmissionEnabled:enabled];
|
|
1039
|
+
resolve(nil);
|
|
1040
|
+
}
|
|
1041
|
+
|
|
1042
|
+
RCT_EXPORT_METHOD(getDataTransmissionEnabled:(RCTPromiseResolveBlock)resolve
|
|
1043
|
+
rejecter:(RCTPromiseRejectBlock)reject)
|
|
1044
|
+
{
|
|
1045
|
+
resolve(@([[CodePushConfig current] dataTransmissionEnabled]));
|
|
1046
|
+
}
|
|
1047
|
+
|
|
1045
1048
|
#pragma mark - JavaScript-exported module methods (Private)
|
|
1046
1049
|
|
|
1047
1050
|
/*
|
|
@@ -1062,7 +1065,7 @@ RCT_EXPORT_METHOD(downloadAndReplaceCurrentBundle:(NSString *)remoteBundleUrl)
|
|
|
1062
1065
|
* or an update failed) and return its details (version label, status).
|
|
1063
1066
|
*/
|
|
1064
1067
|
RCT_EXPORT_METHOD(getNewStatusReport:(RCTPromiseResolveBlock)resolve
|
|
1065
|
-
|
|
1068
|
+
rejecter:(RCTPromiseRejectBlock)reject)
|
|
1066
1069
|
{
|
|
1067
1070
|
if (needToReportRollback) {
|
|
1068
1071
|
needToReportRollback = NO;
|
|
@@ -1107,16 +1110,4 @@ RCT_EXPORT_METHOD(saveStatusReportForRetry:(NSDictionary *)statusReport)
|
|
|
1107
1110
|
[CodePushTelemetryManager saveStatusReportForRetry:statusReport];
|
|
1108
1111
|
}
|
|
1109
1112
|
|
|
1110
|
-
#pragma mark - RCTFrameUpdateObserver Methods
|
|
1111
|
-
|
|
1112
|
-
- (void)didUpdateFrame:(RCTFrameUpdate *)update
|
|
1113
|
-
{
|
|
1114
|
-
if (!_didUpdateProgress) {
|
|
1115
|
-
return;
|
|
1116
|
-
}
|
|
1117
|
-
|
|
1118
|
-
[self dispatchDownloadProgressEvent];
|
|
1119
|
-
_didUpdateProgress = NO;
|
|
1120
|
-
}
|
|
1121
|
-
|
|
1122
1113
|
@end
|
|
@@ -13,6 +13,8 @@ static NSString * const ClientUniqueIDConfigKey = @"clientUniqueId";
|
|
|
13
13
|
static NSString * const ReleaseChannelPublicIDConfigKey = @"releaseChannelPublicId";
|
|
14
14
|
static NSString * const ServerURLConfigKey = @"serverUrl";
|
|
15
15
|
static NSString * const PublicKeyKey = @"publicKey";
|
|
16
|
+
static NSString * const TelemetryEnabledKey = @"telemetryEnabled";
|
|
17
|
+
static NSString * const DataTransmissionEnabledKey = @"dataTransmissionEnabled";
|
|
16
18
|
|
|
17
19
|
+ (instancetype)current
|
|
18
20
|
{
|
|
@@ -35,6 +37,10 @@ static NSString * const PublicKeyKey = @"publicKey";
|
|
|
35
37
|
NSString *buildVersion = [infoDictionary objectForKey:(NSString *)kCFBundleVersionKey];
|
|
36
38
|
NSString *releaseChannelPublicId = [infoDictionary objectForKey:@"CodePushReleaseChannelPublicId"];
|
|
37
39
|
NSString *serverURL = [infoDictionary objectForKey:@"CodePushServerURL"];
|
|
40
|
+
if (!serverURL) {
|
|
41
|
+
serverURL = [infoDictionary objectForKey:@"CodePushServerUrl"];
|
|
42
|
+
}
|
|
43
|
+
|
|
38
44
|
NSString *publicKey = [infoDictionary objectForKey:@"CodePushSigningPublicKey"];
|
|
39
45
|
|
|
40
46
|
NSUserDefaults *userDefaults = [NSUserDefaults standardUserDefaults];
|
|
@@ -45,6 +51,26 @@ static NSString * const PublicKeyKey = @"publicKey";
|
|
|
45
51
|
[userDefaults synchronize];
|
|
46
52
|
}
|
|
47
53
|
|
|
54
|
+
NSNumber *defaultTelemetryEnabled = [infoDictionary objectForKey:@"CodePushDefaultTelemetryEnabled"];
|
|
55
|
+
BOOL telemetryEnabled;
|
|
56
|
+
if ([userDefaults objectForKey:TelemetryEnabledKey] != nil) {
|
|
57
|
+
telemetryEnabled = [userDefaults boolForKey:TelemetryEnabledKey];
|
|
58
|
+
} else if (defaultTelemetryEnabled != nil) {
|
|
59
|
+
telemetryEnabled = [defaultTelemetryEnabled boolValue];
|
|
60
|
+
} else {
|
|
61
|
+
telemetryEnabled = YES;
|
|
62
|
+
}
|
|
63
|
+
|
|
64
|
+
NSNumber *defaultDataTransmissionEnabled = [infoDictionary objectForKey:@"CodePushDefaultDataTransmissionEnabled"];
|
|
65
|
+
BOOL dataTransmissionEnabled;
|
|
66
|
+
if ([userDefaults objectForKey:DataTransmissionEnabledKey] != nil) {
|
|
67
|
+
dataTransmissionEnabled = [userDefaults boolForKey:DataTransmissionEnabledKey];
|
|
68
|
+
} else if (defaultDataTransmissionEnabled != nil) {
|
|
69
|
+
dataTransmissionEnabled = [defaultDataTransmissionEnabled boolValue];
|
|
70
|
+
} else {
|
|
71
|
+
dataTransmissionEnabled = YES;
|
|
72
|
+
}
|
|
73
|
+
|
|
48
74
|
if (!serverURL) {
|
|
49
75
|
serverURL = @"https://codepush.appzung.com/";
|
|
50
76
|
}
|
|
@@ -60,6 +86,8 @@ static NSString * const PublicKeyKey = @"publicKey";
|
|
|
60
86
|
CPLog(@"Executing CodePush with a signing public key.");
|
|
61
87
|
[_configDictionary setObject:publicKey forKey:PublicKeyKey];
|
|
62
88
|
}
|
|
89
|
+
[_configDictionary setObject:@(telemetryEnabled) forKey:TelemetryEnabledKey];
|
|
90
|
+
[_configDictionary setObject:@(dataTransmissionEnabled) forKey:DataTransmissionEnabledKey];
|
|
63
91
|
|
|
64
92
|
return self;
|
|
65
93
|
}
|
|
@@ -99,6 +127,32 @@ static NSString * const PublicKeyKey = @"publicKey";
|
|
|
99
127
|
return [_configDictionary objectForKey:PublicKeyKey];
|
|
100
128
|
}
|
|
101
129
|
|
|
130
|
+
- (BOOL)telemetryEnabled
|
|
131
|
+
{
|
|
132
|
+
return [[_configDictionary objectForKey:TelemetryEnabledKey] boolValue];
|
|
133
|
+
}
|
|
134
|
+
|
|
135
|
+
- (void)setTelemetryEnabled:(BOOL)telemetryEnabled
|
|
136
|
+
{
|
|
137
|
+
[_configDictionary setValue:@(telemetryEnabled) forKey:TelemetryEnabledKey];
|
|
138
|
+
NSUserDefaults *preferences = [NSUserDefaults standardUserDefaults];
|
|
139
|
+
[preferences setBool:telemetryEnabled forKey:TelemetryEnabledKey];
|
|
140
|
+
[preferences synchronize];
|
|
141
|
+
}
|
|
142
|
+
|
|
143
|
+
- (BOOL)dataTransmissionEnabled
|
|
144
|
+
{
|
|
145
|
+
return [[_configDictionary objectForKey:DataTransmissionEnabledKey] boolValue];
|
|
146
|
+
}
|
|
147
|
+
|
|
148
|
+
- (void)setDataTransmissionEnabled:(BOOL)dataTransmissionEnabled
|
|
149
|
+
{
|
|
150
|
+
[_configDictionary setValue:@(dataTransmissionEnabled) forKey:DataTransmissionEnabledKey];
|
|
151
|
+
NSUserDefaults *preferences = [NSUserDefaults standardUserDefaults];
|
|
152
|
+
[preferences setBool:dataTransmissionEnabled forKey:DataTransmissionEnabledKey];
|
|
153
|
+
[preferences synchronize];
|
|
154
|
+
}
|
|
155
|
+
|
|
102
156
|
- (void)setAppVersion:(NSString *)appVersion
|
|
103
157
|
{
|
|
104
158
|
[_configDictionary setValue:appVersion forKey:AppVersionConfigKey];
|
|
@@ -7,7 +7,7 @@
|
|
|
7
7
|
objects = {
|
|
8
8
|
|
|
9
9
|
/* Begin PBXBuildFile section */
|
|
10
|
-
13BE3DEE1AC21097009241FE /* CodePush.
|
|
10
|
+
13BE3DEE1AC21097009241FE /* CodePush.mm in Sources */ = {isa = PBXBuildFile; fileRef = 13BE3DED1AC21097009241FE /* CodePush.mm */; };
|
|
11
11
|
1B23B9141BF9267B000BB2F0 /* RCTConvert+CodePushInstallMode.m in Sources */ = {isa = PBXBuildFile; fileRef = 1B23B9131BF9267B000BB2F0 /* RCTConvert+CodePushInstallMode.m */; };
|
|
12
12
|
1B762E901C9A5E9A006EF800 /* CodePushErrorUtils.m in Sources */ = {isa = PBXBuildFile; fileRef = 1B762E8F1C9A5E9A006EF800 /* CodePushErrorUtils.m */; };
|
|
13
13
|
1BCC09A71CC19EB700DDC0DD /* RCTConvert+CodePushUpdateState.m in Sources */ = {isa = PBXBuildFile; fileRef = 1BCC09A61CC19EB700DDC0DD /* RCTConvert+CodePushUpdateState.m */; };
|
|
@@ -16,7 +16,7 @@
|
|
|
16
16
|
5498D8F61D21F14100B5EB43 /* CodePushUtils.m in Sources */ = {isa = PBXBuildFile; fileRef = 5498D8F51D21F14100B5EB43 /* CodePushUtils.m */; };
|
|
17
17
|
54FFEDE01BF550630061DD23 /* CodePushDownloadHandler.m in Sources */ = {isa = PBXBuildFile; fileRef = 54FFEDDF1BF550630061DD23 /* CodePushDownloadHandler.m */; };
|
|
18
18
|
6463C82D1EBA0CFB0095B8CD /* CodePushUtils.m in Sources */ = {isa = PBXBuildFile; fileRef = 5498D8F51D21F14100B5EB43 /* CodePushUtils.m */; };
|
|
19
|
-
6463C82E1EBA0CFB0095B8CD /* CodePush.
|
|
19
|
+
6463C82E1EBA0CFB0095B8CD /* CodePush.mm in Sources */ = {isa = PBXBuildFile; fileRef = 13BE3DED1AC21097009241FE /* CodePush.mm */; };
|
|
20
20
|
6463C82F1EBA0CFB0095B8CD /* CodePushConfig.m in Sources */ = {isa = PBXBuildFile; fileRef = 81D51F391B6181C2000DA084 /* CodePushConfig.m */; };
|
|
21
21
|
6463C8301EBA0CFB0095B8CD /* CodePushDownloadHandler.m in Sources */ = {isa = PBXBuildFile; fileRef = 54FFEDDF1BF550630061DD23 /* CodePushDownloadHandler.m */; };
|
|
22
22
|
6463C8311EBA0CFB0095B8CD /* CodePushErrorUtils.m in Sources */ = {isa = PBXBuildFile; fileRef = 1B762E8F1C9A5E9A006EF800 /* CodePushErrorUtils.m */; };
|
|
@@ -59,7 +59,7 @@
|
|
|
59
59
|
/* Begin PBXFileReference section */
|
|
60
60
|
134814201AA4EA6300B7C361 /* libCodePush.a */ = {isa = PBXFileReference; explicitFileType = archive.ar; includeInIndex = 0; path = libCodePush.a; sourceTree = BUILT_PRODUCTS_DIR; };
|
|
61
61
|
13BE3DEC1AC21097009241FE /* CodePush.h */ = {isa = PBXFileReference; fileEncoding = 4; lastKnownFileType = sourcecode.c.h; name = CodePush.h; path = CodePush/CodePush.h; sourceTree = "<group>"; };
|
|
62
|
-
13BE3DED1AC21097009241FE /* CodePush.
|
|
62
|
+
13BE3DED1AC21097009241FE /* CodePush.mm */ = {isa = PBXFileReference; fileEncoding = 4; lastKnownFileType = sourcecode.cpp.objcpp; name = CodePush.mm; path = CodePush/CodePush.mm; sourceTree = "<group>"; };
|
|
63
63
|
1B23B9131BF9267B000BB2F0 /* RCTConvert+CodePushInstallMode.m */ = {isa = PBXFileReference; fileEncoding = 4; lastKnownFileType = sourcecode.c.objc; name = "RCTConvert+CodePushInstallMode.m"; path = "CodePush/RCTConvert+CodePushInstallMode.m"; sourceTree = "<group>"; };
|
|
64
64
|
1B762E8F1C9A5E9A006EF800 /* CodePushErrorUtils.m */ = {isa = PBXFileReference; fileEncoding = 4; lastKnownFileType = sourcecode.c.objc; name = CodePushErrorUtils.m; path = CodePush/CodePushErrorUtils.m; sourceTree = "<group>"; };
|
|
65
65
|
1BCC09A61CC19EB700DDC0DD /* RCTConvert+CodePushUpdateState.m */ = {isa = PBXFileReference; fileEncoding = 4; lastKnownFileType = sourcecode.c.objc; name = "RCTConvert+CodePushUpdateState.m"; path = "CodePush/RCTConvert+CodePushUpdateState.m"; sourceTree = "<group>"; };
|
|
@@ -105,7 +105,7 @@
|
|
|
105
105
|
FF90DEF92C5A808600CA8692 /* PrivacyInfo.xcprivacy */,
|
|
106
106
|
5498D8F51D21F14100B5EB43 /* CodePushUtils.m */,
|
|
107
107
|
13BE3DEC1AC21097009241FE /* CodePush.h */,
|
|
108
|
-
13BE3DED1AC21097009241FE /* CodePush.
|
|
108
|
+
13BE3DED1AC21097009241FE /* CodePush.mm */,
|
|
109
109
|
81D51F391B6181C2000DA084 /* CodePushConfig.m */,
|
|
110
110
|
54FFEDDF1BF550630061DD23 /* CodePushDownloadHandler.m */,
|
|
111
111
|
1B762E8F1C9A5E9A006EF800 /* CodePushErrorUtils.m */,
|
|
@@ -233,7 +233,7 @@
|
|
|
233
233
|
81D51F3A1B6181C2000DA084 /* CodePushConfig.m in Sources */,
|
|
234
234
|
54FFEDE01BF550630061DD23 /* CodePushDownloadHandler.m in Sources */,
|
|
235
235
|
5421FE311C58AD5A00986A55 /* CodePushTelemetryManager.m in Sources */,
|
|
236
|
-
13BE3DEE1AC21097009241FE /* CodePush.
|
|
236
|
+
13BE3DEE1AC21097009241FE /* CodePush.mm in Sources */,
|
|
237
237
|
1B762E901C9A5E9A006EF800 /* CodePushErrorUtils.m in Sources */,
|
|
238
238
|
5498D8F61D21F14100B5EB43 /* CodePushUtils.m in Sources */,
|
|
239
239
|
810D4E6D1B96935000B397E9 /* CodePushPackage.m in Sources */,
|
|
@@ -245,7 +245,7 @@
|
|
|
245
245
|
buildActionMask = 2147483647;
|
|
246
246
|
files = (
|
|
247
247
|
6463C82D1EBA0CFB0095B8CD /* CodePushUtils.m in Sources */,
|
|
248
|
-
6463C82E1EBA0CFB0095B8CD /* CodePush.
|
|
248
|
+
6463C82E1EBA0CFB0095B8CD /* CodePush.mm in Sources */,
|
|
249
249
|
6463C82F1EBA0CFB0095B8CD /* CodePushConfig.m in Sources */,
|
|
250
250
|
6463C8301EBA0CFB0095B8CD /* CodePushDownloadHandler.m in Sources */,
|
|
251
251
|
6463C8311EBA0CFB0095B8CD /* CodePushErrorUtils.m in Sources */,
|
package/lib/commonjs/CodePush.js
CHANGED
|
@@ -9,19 +9,25 @@ var _hoistNonReactStatics = _interopRequireDefault(require("hoist-non-react-stat
|
|
|
9
9
|
var _react = _interopRequireDefault(require("react"));
|
|
10
10
|
var _reactNative = require("react-native");
|
|
11
11
|
var _CheckFrequencyEnum = require("./enums/CheckFrequency.enum.js");
|
|
12
|
+
var _LogLevelEnum = require("./enums/LogLevel.enum.js");
|
|
13
|
+
var _log = require("./internals/utils/log.js");
|
|
12
14
|
var _notifyAppReady = require("./notifyAppReady.js");
|
|
13
15
|
var _sync = require("./sync.js");
|
|
14
16
|
var _jsxRuntime = require("react/jsx-runtime");
|
|
15
17
|
function _interopRequireDefault(e) { return e && e.__esModule ? e : { default: e }; }
|
|
16
18
|
/**
|
|
17
|
-
*
|
|
19
|
+
* Wraps a React component inside a "higher order" React component that knows how to synchronize your app's JavaScript bundle and image assets when it is mounted.
|
|
20
|
+
*
|
|
21
|
+
* Internally, the higher-order component calls `sync` inside its `componentDidMount` lifecycle handle, which in turns performs an update check, downloads the update if it exists and installs the update for you.
|
|
18
22
|
*
|
|
19
23
|
* @param component the React Component that will be decorated
|
|
20
24
|
*/
|
|
21
25
|
// @ts-ignore
|
|
22
26
|
|
|
23
27
|
/**
|
|
24
|
-
*
|
|
28
|
+
* Wraps a React component inside a "higher order" React component that knows how to synchronize your app's JavaScript bundle and image assets when it is mounted.
|
|
29
|
+
*
|
|
30
|
+
* Internally, the higher-order component calls `sync` inside its `componentDidMount` lifecycle handle, which in turns performs an update check, downloads the update if it exists and installs the update for you.
|
|
25
31
|
*
|
|
26
32
|
* @param options Options used to configure the end-user sync and update experience (e.g. when to check for updates?, show a prompt?, install the update immediately?).
|
|
27
33
|
*/
|
|
@@ -35,6 +41,7 @@ function withCodePush(optionsOrComponent) {
|
|
|
35
41
|
this.rootComponentRef = /*#__PURE__*/_react.default.createRef();
|
|
36
42
|
}
|
|
37
43
|
componentDidMount() {
|
|
44
|
+
(0, _log.log)(_LogLevelEnum.LogLevel.DEBUG, `withCodePush ${JSON.stringify(options)}`);
|
|
38
45
|
if (options.checkFrequency === _CheckFrequencyEnum.CheckFrequency.MANUAL) {
|
|
39
46
|
(0, _notifyAppReady.notifyAppReady)();
|
|
40
47
|
} else {
|
|
@@ -51,10 +58,12 @@ function withCodePush(optionsOrComponent) {
|
|
|
51
58
|
if (rootComponentInstance && rootComponentInstance.codePushOnBinaryVersionMismatch) {
|
|
52
59
|
handleBinaryVersionMismatchCallback = rootComponentInstance.codePushOnBinaryVersionMismatch.bind(rootComponentInstance);
|
|
53
60
|
}
|
|
61
|
+
(0, _log.log)(_LogLevelEnum.LogLevel.DEBUG, `sync on mount`);
|
|
54
62
|
(0, _sync.sync)(options, syncStatusCallback, downloadProgressCallback, handleBinaryVersionMismatchCallback);
|
|
55
63
|
if (options.checkFrequency === _CheckFrequencyEnum.CheckFrequency.ON_APP_RESUME) {
|
|
56
64
|
_reactNative.AppState.addEventListener('change', newState => {
|
|
57
65
|
if (newState === 'active') {
|
|
66
|
+
(0, _log.log)(_LogLevelEnum.LogLevel.DEBUG, `sync on active appState`);
|
|
58
67
|
(0, _sync.sync)(options, syncStatusCallback, downloadProgressCallback);
|
|
59
68
|
}
|
|
60
69
|
});
|