All Downloads are FREE. Search and download functionalities are using the official Maven repository.

src.android.service.carrier.CarrierMessagingClientService Maven / Gradle / Ivy

/*
 * 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.NonNull;
import android.annotation.Nullable;
import android.app.Service;
import android.content.ComponentName;
import android.content.Intent;
import android.os.IBinder;

/**
 * If the default SMS app has a service that extends this class, the system always tries to bind
 * it so that the process is always running, which allows the app to have a persistent connection
 * to the server.
 *
 * 

The service must have an * {@link android.telephony.TelephonyManager#ACTION_CARRIER_MESSAGING_CLIENT_SERVICE} * action in the intent handler, and be protected with * {@link android.Manifest.permission#BIND_CARRIER_MESSAGING_CLIENT_SERVICE}. * However the service does not have to be exported. * *

The service must be associated with a non-main process, meaning it must have an * {@code android:process} tag in its manifest entry. * *

An app can use * {@link android.content.pm.PackageManager#setComponentEnabledSetting(ComponentName, int, int)} * to disable or enable the service. An app should use it to disable the service when it no longer * needs to be running. * *

When the owner process crashes, the service will be re-bound automatically after a * back-off. * *

Note the process may still be killed if the system is under heavy memory pressure, in which * case the process will be re-started later. * *

Example: First, define a subclass in the application: *

 * public class MyCarrierMessagingClientService extends CarrierMessagingClientService {
 * }
 * 
* Then, declare it in its {@code AndroidManifest.xml}: *
 * <service
 *    android:name=".MyCarrierMessagingClientService"
 *    android:exported="false"
 *    android:process=":persistent"
 *    android:permission="android.permission.BIND_CARRIER_MESSAGING_CLIENT_SERVICE">
 *    <intent-filter>
 *        <action android:name="android.telephony.action.CARRIER_MESSAGING_CLIENT_SERVICE" />
 *    </intent-filter>
 * </service>
 * 
*/ public class CarrierMessagingClientService extends Service { private final ICarrierMessagingClientServiceImpl mImpl; public CarrierMessagingClientService() { mImpl = new ICarrierMessagingClientServiceImpl(); } @Override @NonNull public final IBinder onBind(@Nullable Intent intent) { return mImpl.asBinder(); } private class ICarrierMessagingClientServiceImpl extends ICarrierMessagingClientService.Stub { } }




© 2015 - 2025 Weber Informatics LLC | Privacy Policy