diff options
| author | 2018-11-26 22:47:52 +0000 | |
|---|---|---|
| committer | 2018-11-26 22:47:52 +0000 | |
| commit | 0e706db965638f47b58e5612a0c566be14f900d1 (patch) | |
| tree | 66db5ad190a26a71ddd19b04182a936c9c3c7d5f | |
| parent | 4d73d87d83211f14f46f5d62d6241755b9e45a8c (diff) | |
| parent | 2f2dd0a6e19be61b10135400a068911cc95022e6 (diff) | |
Merge "Expose ApnService as a SystemApi and use subId arg"
| -rw-r--r-- | api/system-current.txt | 10 | ||||
| -rw-r--r-- | core/java/android/service/carrier/ApnService.java | 77 | ||||
| -rw-r--r-- | telephony/java/com/android/internal/telephony/IApnSourceService.aidl | 2 |
3 files changed, 88 insertions, 1 deletions
diff --git a/api/system-current.txt b/api/system-current.txt index b1f0bed327ac..8729354fd1bc 100644 --- a/api/system-current.txt +++ b/api/system-current.txt @@ -4462,6 +4462,16 @@ package android.service.autofill { } +package android.service.carrier { + + public abstract class ApnService extends android.app.Service { + ctor public ApnService(); + method public abstract java.util.List<android.content.ContentValues> onRestoreApns(int); + method public android.os.IBinder onBind(android.content.Intent); + } + +} + package android.service.euicc { public final class EuiccProfileInfo implements android.os.Parcelable { diff --git a/core/java/android/service/carrier/ApnService.java b/core/java/android/service/carrier/ApnService.java new file mode 100644 index 000000000000..d53eb37ca786 --- /dev/null +++ b/core/java/android/service/carrier/ApnService.java @@ -0,0 +1,77 @@ +/* + * Copyright (C) 2018 The Android Open Source Project + * + * Licensed under the Apache License, Version 2.0 (the "License"); + * you may not use this file except in compliance with the License. + * You may obtain a copy of the License at + * + * http://www.apache.org/licenses/LICENSE-2.0 + * + * Unless required by applicable law or agreed to in writing, software + * distributed under the License is distributed on an "AS IS" BASIS, + * WITHOUT WARRANTIES OR CONDITIONS OF ANY KIND, either express or implied. + * See the License for the specific language governing permissions and + * limitations under the License. + */ + +package android.service.carrier; + +import android.annotation.SystemApi; +import android.annotation.WorkerThread; +import android.app.Service; +import android.content.ContentValues; +import android.content.Intent; +import android.os.IBinder; +import android.util.Log; + +import com.android.internal.telephony.IApnSourceService; + +import java.util.List; + +/** + * A service that the system can call to restore default APNs. + * <p> + * To extend this class, specify the full name of your implementation in the resource file + * {@code packages/providers/TelephonyProvider/res/values/config.xml} as the + * {@code apn_source_service}. + * </p> + * + * @hide + */ +@SystemApi +public abstract class ApnService extends Service { + + private static final String LOG_TAG = "ApnService"; + + private final IApnSourceService.Stub mBinder = new IApnSourceService.Stub() { + /** + * Retreive APNs for the default slot index. + */ + @Override + public ContentValues[] getApns(int subId) { + try { + List<ContentValues> apns = ApnService.this.onRestoreApns(subId); + return apns.toArray(new ContentValues[apns.size()]); + } catch (Exception e) { + Log.e(LOG_TAG, "Error in getApns for subId=" + subId + ": " + e.getMessage(), e); + return null; + } + } + }; + + @Override + public IBinder onBind(Intent intent) { + return mBinder; + } + + /** + * Override this method to restore default user APNs with a carrier service instead of the + * built in platform xml APNs list. + * <p> + * This method is called by the TelephonyProvider when the user requests restoring the default + * APNs. It should return a list of ContentValues representing the default APNs for the given + * subId. + */ + @WorkerThread + public abstract List<ContentValues> onRestoreApns(int subId); +} diff --git a/telephony/java/com/android/internal/telephony/IApnSourceService.aidl b/telephony/java/com/android/internal/telephony/IApnSourceService.aidl index 07bb18b6cd1b..34c9067c3f2f 100644 --- a/telephony/java/com/android/internal/telephony/IApnSourceService.aidl +++ b/telephony/java/com/android/internal/telephony/IApnSourceService.aidl @@ -20,5 +20,5 @@ import android.content.ContentValues; interface IApnSourceService { /** Retreive APNs. */ - ContentValues[] getApns(); + ContentValues[] getApns(int subId); } |