83f8bc81be65cb09720c6d8dac7717d4652cd931 |
|
15-May-2017 |
Jeff Davidson <jpd@google.com> |
eUICC API error code cleanup. -Remove result classes in cases that a simple int will do. Split the int error code space (now shared across all calls) into two parts - predefined errors (0 or negative) and custom errors (positive). -Replace "generic error" with "error" in naming. -Remove detailed code from any result returned by the LPA. There is still a detailed code in the platform API, which is equal to the result code returned by the LPA. Fixes: 38206601 Test: TreeHugger Change-Id: I304081db2127a22d6dd67b6494b4f3279614d19c
/frameworks/base/core/java/android/service/euicc/GetDownloadableSubscriptionMetadataResult.java
|
91c3d07fd9c75258a47fb25c59bc0cd5d2b638a4 |
|
12-Apr-2017 |
Jeff Davidson <jpd@google.com> |
Implement remaining core eUICC APIs. Includes: -getDefaultDownloadableSubscriptionList, which returns a list of default subscriptions available for the device. -getEuiccInfo, which returns an EuiccInfo object containing non-sensitive information about the eUICC device. -deleteSubscription, to delete a subscription. -switchToSubscription, to switch to (or away from) a subscription. -updateSubscriptionNickname, to update the nickname of a subscription which is saved to the eUICC. -eraseSubscriptions, to factory reset the eUICC. -Settings.Global#DEFAULT_SM_DP_PLUS, a default SM-DP+ server which is used to query for default subscriptions in getDefaultDownloadableSubscriptionList. These APIs follow the template of the APIs which have already been implemented. This completes the baseline implementation as designed; any additional APIs or tweaks to the APIs will be tracked as separate bugs. Fixes: 33075886 Test: Build/boot Change-Id: I8057757c874f94e0c816af1ca071d656c8f145b9
/frameworks/base/core/java/android/service/euicc/GetDownloadableSubscriptionMetadataResult.java
|
cfa70fa0abe90d91bd7997ef23432e5631b40d2a |
|
07-Apr-2017 |
Jeff Davidson <jpd@google.com> |
EUICC API changes to support error resolution. -Implement EuiccManager#startResolutionActivity. This is just a pass-through to start the LUI dispatcher. -Add and implement EuiccManager#continueOperation. The LUI calls this method upon completion of a resolution action to continue the original operation. -Remove the "consentGranted" bit from DownloadableSubscription. This was originally to be used by the LUI to communicate user consent, but it is impossible to allow the LUI to modify the given DownloadableSubscription while also preventing it from tampering by the untrusted app. It's also unclear what kind of "consent" was granted - it could be to disable the physical SIM, or to grant an unprivileged app permissions to switch. Instead, this bit is passed by the LUI to continueOperation() as an extra and propagated down as an explicit parameter to the LPA. Bug: 33075886 Test: Manual verification using test LPA Change-Id: I17d8028e0ecea365ca5a2cc17424fc9645f5a489
/frameworks/base/core/java/android/service/euicc/GetDownloadableSubscriptionMetadataResult.java
|
e397bf3f22558756147f9ee5b49cb2d70f08ee66 |
|
06-Apr-2017 |
Jeff Davidson <jpd@google.com> |
Fix NPE when parceling getMetadata result. Bug: 33075886 Test: None (trivial change) Change-Id: Ie0bb576e7162d405a05a2b8a5798d9480cb3239c
/frameworks/base/core/java/android/service/euicc/GetDownloadableSubscriptionMetadataResult.java
|
35cda39422acdeb3fa47ca60f131678e52dbfcb3 |
|
27-Feb-2017 |
Jeff Davidson <jpd@google.com> |
Squashed merge of master-sim into master. Includes the following commits: == New system feature: eUICC. Presence of this feature implies that eUICC-related APIs are expected to function as long as an eUICC is present in the device. Note that an eUICC may be embedded in the device but may also be removable. == Add empty EuiccManager API and plumbing. == Add stub EuiccService. EuiccService is the class that the LPA app must implement; for now, just define the action and priority so that the implementation can be found. Actual methods will come later. Also declare two relevant permissions: BIND_EUICC_SERVICE, which the implementation must require (so that nobody else can bind to the service directly), and WRITE_EMBEDDED_SUBSCRIPTIONS, which permits signature|privileged apps and CTS (via development) to access EuiccManager APIs. == Add UiccAccessRule based off UiccCarrierPrivilegeRules#AccessRule. This class can be used to transfer access rules between an EuiccService implementation and the platform. We also add a simple encoding/decoding of a list of rules so that they may be stored in the subscription info table. == Add getEid() to EuiccManager/EuiccService. getEid() fetches the EID. It requires either a privileged permission (READ_PRIVILEGED_PHONE_STATE) or carrier privileges on the currently-active profile. Until there is a use case that requires opening this up to apps with only READ_PHONE_STATE, we shouldn't do so. To avoid churn in the future, the API signatures for EuiccService include a slot ID to identify which SIM slot is being used. However, this parameter is currently not populated correctly (nor is it usable, as no Telephony APIs accept a slot ID to address commands). There is no need to expose it yet in the EuiccManager APIs as we expect to follow the TelephonyManager pattern of allowing per-slot instances of EuiccManager in the future while keeping other method signatures the same. == Define Euicc UI actions in EuiccManager/EuiccService. The EuiccManager actions are to be implemented by the platform (and only the platform), which forwards the actions to the active implementation. Also, remove our explicit priority meta-data tag as we can just rely on android:priority in the corresponding intent-filter. == APIs for downloading embedded subscriptions. Includes: -getDownloadableSubscriptionMetadata, used by the platform and LUI to fetch metadata about a downloadable subscription. The platform will use this to perform the necessary permission checks (only allowing otherwise-unprivileged apps to download profiles that are permitted per the subscription metadata), and the LUI can use this to present the name of the profile. -downloadSubscription, to actually perform a profile download. The stub for startResolutionActivity is included but not implemented; resolution activities will be handled in a follow-up change. == Test: TreeHugger Change-Id: I47b1da5a69f0736012cb137e02cd6c4e07fdaace
/frameworks/base/core/java/android/service/euicc/GetDownloadableSubscriptionMetadataResult.java
|