Skip to content

Commit 1d2083e

Browse files
committed
Merge pull request #350 from Microsoft/doc_updates
Adding docs for dis/allowRestart
2 parents 006224a + 61906b9 commit 1d2083e

File tree

1 file changed

+75
-3
lines changed

1 file changed

+75
-3
lines changed

README.md

+75-3
Original file line numberDiff line numberDiff line change
@@ -124,7 +124,8 @@ We hope to eventually remove the need for steps #2-4, but in the meantime, RNPM
124124
pod 'CodePush', :path => './node_modules/react-native-code-push', :subspecs => ['NoZip']
125125
```
126126

127-
*NOTE: The above paths needs to be relative to your app's `Podfile`, so adjust it as neccessary.*
127+
*NOTE: The above paths needs to be relative to your app's `Podfile`, so adjust it as nec
128+
cessary.*
128129
129130
2. Run `pod install`
130131
@@ -409,7 +410,7 @@ code-push release-react MyApp ios
409410
code-push release-react MyApp-Android android
410411
```
411412
412-
The `release-react` command enables such a simple workflow because it provides many sensible defaults (e.g. generating a release bundle, assuming your app's entry file on iOS is either `index.ios.js` or `index.js`). However, all of these defaults can be customized to allow incremental flexibility as neccessary, which makes it a good fit for most scenarios.
413+
The `release-react` command enables such a simple workflow because it provides many sensible defaults (e.g. generating a release bundle, assuming your app's entry file on iOS is either `index.ios.js` or `index.js`). However, all of these defaults can be customized to allow incremental flexibility as necessary, which makes it a good fit for most scenarios.
413414

414415
```shell
415416
# Release a mandatory update with a changelog
@@ -450,8 +451,12 @@ The following sections describe the shape and behavior of these APIs in detail:
450451

451452
When you require `react-native-code-push`, the module object provides the following top-level methods:
452453

454+
* [allowRestart](#codepushallowrestart): Re-allows programmatic restarts to occur as a result of an update being installed, and optionally, immediately restarts the app if a pending update had attempted to restart the app while restarts were disallowed. This is an advanced API and is only necessary if your app explicitly disallowed restarts via the `disallowRestart` method.
455+
453456
* [checkForUpdate](#codepushcheckforupdate): Asks the CodePush service whether the configured app deployment has an update available.
454457

458+
* [disallowRestart](#codepushdisallowrestart): Temporarily disallows any programmatic restarts to occur as a result of a CodePush update being installed. This is an advanced API, and is useful when a component within your app (e.g. an onboarding process) needs to ensure that no end-user interruptions can occur during its lifetime.
459+
455460
* [getCurrentPackage](#codepushgetcurrentpackage): Retrieves the metadata about the currently installed update (e.g. description, installation time, size). *NOTE: As of `v1.10.3-beta` of the CodePush module, this method is deprecated in favor of [`getUpdateMetadata`](#codepushgetupdatemetadata)*.
456461

457462
* [getUpdateMetadata](#codepushgetupdatemetadata): Retrieves the metadata for an installed update (e.g. description, mandatory).
@@ -462,6 +467,30 @@ When you require `react-native-code-push`, the module object provides the follow
462467

463468
* [sync](#codepushsync): Allows checking for an update, downloading it and installing it, all with a single call. Unless you need custom UI and/or behavior, we recommend most developers to use this method when integrating CodePush into their apps
464469

470+
#### codePush.allowRestart
471+
472+
```javascript
473+
codePush.allowRestart(): void;
474+
```
475+
476+
Re-allows programmatic restarts to occur, that would have otherwise been rejected due to a previous call to `disallowRestart`. If `disallowRestart` was never called in the first place, then calling this method will simply result in a no-op.
477+
478+
If a CodePush update is currently pending, which attempted to restart the app (e.g. it used `InstallMode.IMMEDIATE`), but was blocked due to `disallowRestart` having been called, then calling `allowRestart` will result in an immediate restart. This allows the update to be applied as soon as possible, without interrupting the end user during critical workflows (e.g. an onboarding process).
479+
480+
For example, calling `allowRestart` would trigger an immediate restart if either of the three scenarios mentioned in the [`disallowRestart` docs](#codepushdisallowrestart) occured after `disallowRestart` was called. However, calling `allowRestart` wouldn't trigger a restart if the following were true:
481+
482+
1. No CodePush updates were installed since the last time `disallowRestart` was called, and therefore, there isn't any need to restart anyways.
483+
484+
2. There is currently a pending CodePush update, but it was installed via `InstallMode.ON_NEXT_RESTART`, and therefore, doesn't require a programmatic restart.
485+
486+
3. There is currently a pending CodePush update, but it was installed via `InstallMode.ON_NEXT_RESUME` and the app hasn't been put into the background yet, and therefore, there isn't a need to programmatically restart yet.
487+
488+
4. No calls to `restartApp` were made since the last time `disallowRestart` was called.
489+
490+
This behavior ensures that no restarts will be triggered as a result of calling `allowRestart` unless one was explictly requested during the disallowed period. In this way, `allowRestart` is somewhat similar to calling `restartApp(true)`, except the former will only trigger a restart if the currently pending update wanted to restart, whereas the later would restart as long as an update is pending.
491+
492+
See [disallowRestart](#codepushdisallowrestart) for an example of how this method can be used.
493+
465494
#### codePush.checkForUpdate
466495
467496
```javascript
@@ -493,6 +522,49 @@ codePush.checkForUpdate()
493522
});
494523
```
495524

525+
#### codePush.disallowRestart
526+
527+
```javascript
528+
codePush.disallowRestart(): void;
529+
```
530+
531+
Temporarily disallows programmatic restarts to occur as a result of either of following scenarios:
532+
533+
1. A CodePush update is installed using `InstallMode.IMMEDIATE`
534+
2. A CodePush update is installed using `InstallMode.ON_NEXT_RESUME` and the app is resumed from the background (optionally being throttled by the `minimumBackgroundDuration` property)
535+
3. The `restartApp` method was called
536+
537+
*NOTE: #1 and #2 effectively work by calling `restartApp` for you, so you can think of `disallowRestart` as blocking any call to `restartApp`, regardless if your app calls it directly or indirectly.*
538+
539+
After calling this method, any calls to `sync` would still be allowed to check for an update, download it and install it, but an attempt to restart the app would be queued until `allowRestart` is called. This way, the restart request is captured and can be "flushed" whenever you want to allow it to occur.
540+
541+
This is an advanced API, and is primarily useful when individual components within your app (e.g. an onboarding process) need to ensure that no end-user interruptions can occur during their lifetime, while continuing to allow the app to keep syncing with the CodePush server at its own pace and using whatever install modes are appropriate. This has the benefit of allowing the app to discover and download available updates as soon as possible, while also preventing any disruptions during key end-user experiences.
542+
543+
As an alternative, you could also choose to simply use `InstallMode.ON_NEXT_RESTART` whenever calling `sync` (which will never attempt to programmatically restart the app), and then explicity calling `restartApp` at points in your app that you know it is "safe" to do so. `disallowRestart` provides an alternative approach to this when the code that synchronizes with the CodePush server is separate from the code/components that want to enforce a no-restart policy.
544+
545+
Example Usage:
546+
547+
```javascript
548+
class OnboardingProcess extends Component {
549+
...
550+
551+
componentWillMount() {
552+
// Ensure that any CodePush updates which are
553+
// synchronized in the background can't trigger
554+
// a restart while this component is mounted.
555+
codePush.disallowRestart();
556+
}
557+
558+
componentWillUnmount() {
559+
// Reallow restarts, and optionally trigger
560+
// a restart if one was currently pending.
561+
codePush.allowRestart();
562+
}
563+
564+
...
565+
}
566+
```
567+
496568
#### codePush.getCurrentPackage
497569

498570
*NOTE: This method is considered deprecated as of `v1.10.3-beta` of the CodePush module. If you're running this version (or newer), we would recommend using the [`codePush.getUpdateMetadata`](#codepushgetupdatemetadata) instead, since it has more predictable behavior.*
@@ -828,7 +900,7 @@ The `CodePush` class' methods can be thought of as composite resolvers which alw
828900
829901
4. Repeat #2 and #3 as the CodePush releases and app store releases continue on into infinity (and beyond?)
830902
831-
Because of this behavior, you can safely deploy updates to both the app store(s) and CodePush as neccesary, and rest assured that your end-users will always get the most recent version.
903+
Because of this behavior, you can safely deploy updates to both the app store(s) and CodePush as necesary, and rest assured that your end-users will always get the most recent version.
832904
833905
##### Methods
834906

0 commit comments

Comments
 (0)