PackageInstaller.SessionParams.SetRequireUserAction(Int32) Method
Definition
Important
Some information relates to prerelease product that may be substantially modified before it’s released. Microsoft makes no warranties, express or implied, with respect to the information provided here.
Optionally indicate whether user action should be required when the session is committed.
[Android.Runtime.Register("setRequireUserAction", "(I)V", "GetSetRequireUserAction_IHandler", ApiSince=31)]
public virtual void SetRequireUserAction (int requireUserAction);
[<Android.Runtime.Register("setRequireUserAction", "(I)V", "GetSetRequireUserAction_IHandler", ApiSince=31)>]
abstract member SetRequireUserAction : int -> unit
override this.SetRequireUserAction : int -> unit
Parameters
- requireUserAction
- Int32
whether user action should be required.
- Attributes
Remarks
Optionally indicate whether user action should be required when the session is committed.
Defaults to #USER_ACTION_UNSPECIFIED
unless otherwise set. When unspecified for installers using the android.Manifest.permission#REQUEST_INSTALL_PACKAGES REQUEST_INSTALL_PACKAGES
permission will behave as if set to #USER_ACTION_REQUIRED
, and #USER_ACTION_NOT_REQUIRED
otherwise. When requireUserAction
is set to #USER_ACTION_REQUIRED
, installers will receive a #STATUS_PENDING_USER_ACTION
callback once the session is committed, indicating that user action is required for the install to proceed.
For installers that have been granted the android.Manifest.permission#REQUEST_INSTALL_PACKAGES REQUEST_INSTALL_PACKAGES
permission, user action will not be required when all of the following conditions are met:
<ul> <li>requireUserAction
is set to #USER_ACTION_NOT_REQUIRED
.</li> <li>The app being installed targets: <ul> <li>android.os.Build.VERSION_CODES#Q API 29
or higher on Android S (android.os.Build.VERSION_CODES#S API 31
)</li> <li>android.os.Build.VERSION_CODES#R API 30
or higher on Android T (android.os.Build.VERSION_CODES#TIRAMISU API 33
)</li> <li>android.os.Build.VERSION_CODES#S API 31
or higher <b>after</b> Android T (android.os.Build.VERSION_CODES#TIRAMISU API 33
)</li> </ul> </li> <li>The installer is: <ul> <li>The InstallSourceInfo#getUpdateOwnerPackageName() update owner
of an existing version of the app (in other words, this install session is an app update) if the update ownership enforcement is enabled.</li> <li>The InstallSourceInfo#getInstallingPackageName() installer of record
of an existing version of the app (in other words, this install session is an app update) if the update ownership enforcement isn't enabled.</li> <li>Updating itself.</li> </ul> </li> <li>The installer declares the android.Manifest.permission#UPDATE_PACKAGES_WITHOUT_USER_ACTION UPDATE_PACKAGES_WITHOUT_USER_ACTION
permission.</li> </ul>
Note: The target API level requirement will advance in future Android versions. Session owners should always be prepared to handle #STATUS_PENDING_USER_ACTION
.
Java documentation for android.content.pm.PackageInstaller.SessionParams.setRequireUserAction(int)
.
Portions of this page are modifications based on work created and shared by the Android Open Source Project and used according to terms described in the Creative Commons 2.5 Attribution License.