diff options
author | Fabrice Di Meglio <fdimeglio@google.com> | 2014-11-19 17:12:32 -0800 |
---|---|---|
committer | Fabrice Di Meglio <fdimeglio@google.com> | 2015-03-30 10:58:35 -0700 |
commit | 1c1b47125da018b44240739db75f8898e064a948 (patch) | |
tree | c2c4b241798ae9e5d61fd09955b8c0d2704bb133 /test-runner/src | |
parent | 523fe91af4baf26cd26e46c1418a072574959b73 (diff) | |
download | frameworks_base-1c1b47125da018b44240739db75f8898e064a948.zip frameworks_base-1c1b47125da018b44240739db75f8898e064a948.tar.gz frameworks_base-1c1b47125da018b44240739db75f8898e064a948.tar.bz2 |
Add IntentFilter auto verification
The purpose of this feature is to prompt the Disambiguation dialog
to Users as less as possible.
- add the new "autoVerify" property to the IntentFilter class
- add new APIs to PackageManager:
verifyIntentFilter(int, int, List<String>),
getIntentVerificationStatus(String, int),
updateIntentVerificationStatus(String, int, int),
getIntentFilterVerifications(String)
for supporting IntentFilter verification
- add support for multi-user
- update PackageManager for IntentFilter verification:
basically when we are installing a new package, ask for verification
of all domains from the IntentFilters that have the "autoVerify" to true.
This means that the PackageManager will send a well defined protected
broadcast (with a new INTENT_FILTER_NEEDS_VERIFICATION action) to
an IntentFilter verifier to do the real job of verification.
We are passing in the broadcast Intent all the necessary data for
doing the verification. The PackageManager will receive as response
the result code of the domain verifications and, if needed, the list
of domains that have failed the verification.
- add a new INTENT_FILTER_VERIFICATION_AGENT permission that needs to
be set by an intent filter verifier to be considered as a trustable
party by the PackageManager.
- add also a new BIND_INTENT_FILTER_VERIFIER permission for securing
the binding between the PackageManager and a service doing the
intent filter verifications.
- add ResolveInfo filterNeedsVerification which is a boolean
to knows if the IntentFilter is of a type that needs a verification
(action VIEW, category BROWABLE, HTTP/HTTPS data URI)
- add new "domain-preferred-apps" / "d" dump command for listing the
prefered Apps for all domains
- add new "intent-filter-verifiers" / "ivf" command for listing the
IntentFilterVerifier used
- introduce the IntentVerificationService which is a basic service
for verifying IntentFilters. This service will send HTTPS requests
to the domain declared in the IntentFilter(s) for doing the
verification. This service has a low priority level so that it
can be replaced by a more sophisticated one if needed. This service
is updating the PackageManager intent verification states thru
the updateIntentVerificationStatus(...) API.
- update MockPackageManager
Change-Id: I0bfed193d0bf1f7c7ac79f6c1b160b7ab93b5fb5
Diffstat (limited to 'test-runner/src')
-rw-r--r-- | test-runner/src/android/test/mock/MockPackageManager.java | 33 |
1 files changed, 33 insertions, 0 deletions
diff --git a/test-runner/src/android/test/mock/MockPackageManager.java b/test-runner/src/android/test/mock/MockPackageManager.java index 67a8c2b..a204376 100644 --- a/test-runner/src/android/test/mock/MockPackageManager.java +++ b/test-runner/src/android/test/mock/MockPackageManager.java @@ -31,6 +31,7 @@ import android.content.pm.IPackageInstallObserver; import android.content.pm.IPackageMoveObserver; import android.content.pm.IPackageStatsObserver; import android.content.pm.InstrumentationInfo; +import android.content.pm.IntentFilterVerificationInfo; import android.content.pm.KeySet; import android.content.pm.ManifestDigest; import android.content.pm.PackageInfo; @@ -725,6 +726,38 @@ public class MockPackageManager extends PackageManager { * @hide */ @Override + public void verifyIntentFilter(int id, int verificationCode, List<String> outFailedDomains) { + throw new UnsupportedOperationException(); + } + + /** + * @hide + */ + @Override + public int getIntentVerificationStatus(String packageName, int userId) { + throw new UnsupportedOperationException(); + } + + /** + * @hide + */ + @Override + public boolean updateIntentVerificationStatus(String packageName, int status, int userId) { + throw new UnsupportedOperationException(); + } + + /** + * @hide + */ + @Override + public List<IntentFilterVerificationInfo> getIntentFilterVerifications(String packageName) { + throw new UnsupportedOperationException(); + } + + /** + * @hide + */ + @Override public VerifierDeviceIdentity getVerifierDeviceIdentity() { throw new UnsupportedOperationException(); } |