blob: b893b45611fb04f37ca720d2e025d2443598df2e [file] [log] [blame]
Amit Mahajan24c01a22019-09-20 11:13:05 -07001/*
2 * Copyright (C) 2019 The Android Open Source Project
3 *
4 * Licensed under the Apache License, Version 2.0 (the "License");
5 * you may not use this file except in compliance with the License.
6 * You may obtain a copy of the License at
7 *
8 * http://www.apache.org/licenses/LICENSE-2.0
9 *
10 * Unless required by applicable law or agreed to in writing, software
11 * distributed under the License is distributed on an "AS IS" BASIS,
12 * WITHOUT WARRANTIES OR CONDITIONS OF ANY KIND, either express or implied.
13 * See the License for the specific language governing permissions and
14 * limitations under the License.
15 */
16
17package android.telephony;
18
Sarah Chin4affb512020-01-10 16:09:11 -080019import android.annotation.NonNull;
20import android.annotation.Nullable;
21import android.annotation.SystemService;
Amit Mahajan24c01a22019-09-20 11:13:05 -070022import android.app.ActivityThread;
23import android.app.PendingIntent;
Sarah Chin4affb512020-01-10 16:09:11 -080024import android.content.Context;
Amit Mahajan24c01a22019-09-20 11:13:05 -070025import android.net.Uri;
26import android.os.Bundle;
27import android.os.RemoteException;
28import android.os.ServiceManager;
29
30import com.android.internal.telephony.IMms;
31
32/**
33 * Manages MMS operations such as sending multimedia messages.
Sarah Chin4affb512020-01-10 16:09:11 -080034 * Get this object by calling Context#getSystemService(Context#MMS_SERVICE).
Sarah Chin8ac7ce52020-03-18 13:57:18 -070035 * @hide
Amit Mahajan24c01a22019-09-20 11:13:05 -070036 */
Sarah Chin4affb512020-01-10 16:09:11 -080037@SystemService(Context.MMS_SERVICE)
Sarah Chinee13f122020-01-10 19:23:33 +000038public class MmsManager {
Amit Mahajan24c01a22019-09-20 11:13:05 -070039 private static final String TAG = "MmsManager";
Sarah Chin4affb512020-01-10 16:09:11 -080040 private final Context mContext;
Amit Mahajan24c01a22019-09-20 11:13:05 -070041
42 /**
Sarah Chin4affb512020-01-10 16:09:11 -080043 * @hide
Amit Mahajan24c01a22019-09-20 11:13:05 -070044 */
Sarah Chin4affb512020-01-10 16:09:11 -080045 public MmsManager(@NonNull Context context) {
46 mContext = context;
Amit Mahajan24c01a22019-09-20 11:13:05 -070047 }
48
49 /**
50 * Send an MMS message
51 *
52 * @param subId the subscription id
53 * @param contentUri the content Uri from which the message pdu will be read
54 * @param locationUrl the optional location url where message should be sent to
55 * @param configOverrides the carrier-specific messaging configuration values to override for
56 * sending the message.
57 * @param sentIntent if not NULL this <code>PendingIntent</code> is broadcast when the message
58 * is successfully sent, or failed
Tom Taylor03079ec2020-01-24 10:21:50 -080059 * @param messageId an id that uniquely identifies the message requested to be sent.
Tom Taylorc03117f2020-02-19 16:13:13 -080060 * Used for logging and diagnostics purposes. The id may be 0. The messageId
61 * can be found in radio logs from logcat.
Amit Mahajan24c01a22019-09-20 11:13:05 -070062 */
Sarah Chin4affb512020-01-10 16:09:11 -080063 public void sendMultimediaMessage(int subId, @NonNull Uri contentUri,
64 @Nullable String locationUrl, @Nullable Bundle configOverrides,
Tom Taylor03079ec2020-01-24 10:21:50 -080065 @Nullable PendingIntent sentIntent, long messageId) {
Amit Mahajan24c01a22019-09-20 11:13:05 -070066 try {
67 final IMms iMms = IMms.Stub.asInterface(ServiceManager.getService("imms"));
68 if (iMms == null) {
69 return;
70 }
71
72 iMms.sendMessage(subId, ActivityThread.currentPackageName(), contentUri,
Nan Wu98c48742022-03-17 21:25:41 +000073 locationUrl, configOverrides, sentIntent, messageId,
74 mContext.getAttributionTag());
Amit Mahajan24c01a22019-09-20 11:13:05 -070075 } catch (RemoteException e) {
76 // Ignore it
77 }
78 }
79
80 /**
81 * Download an MMS message from carrier by a given location URL
82 *
83 * @param subId the subscription id
84 * @param locationUrl the location URL of the MMS message to be downloaded, usually obtained
85 * from the MMS WAP push notification
86 * @param contentUri the content uri to which the downloaded pdu will be written
87 * @param configOverrides the carrier-specific messaging configuration values to override for
88 * downloading the message.
89 * @param downloadedIntent if not NULL this <code>PendingIntent</code> is
90 * broadcast when the message is downloaded, or the download is failed
Tom Taylor03079ec2020-01-24 10:21:50 -080091 * @param messageId an id that uniquely identifies the message requested to be downloaded.
Tom Taylorc03117f2020-02-19 16:13:13 -080092 * Used for logging and diagnostics purposes. The id may be 0. The messageId
93 * can be found in radio logs from logcat.
Amit Mahajan24c01a22019-09-20 11:13:05 -070094 * @throws IllegalArgumentException if locationUrl or contentUri is empty
95 */
Sarah Chin4affb512020-01-10 16:09:11 -080096 public void downloadMultimediaMessage(int subId, @NonNull String locationUrl,
97 @NonNull Uri contentUri, @Nullable Bundle configOverrides,
Tom Taylor03079ec2020-01-24 10:21:50 -080098 @Nullable PendingIntent downloadedIntent, long messageId) {
Amit Mahajan24c01a22019-09-20 11:13:05 -070099 try {
100 final IMms iMms = IMms.Stub.asInterface(ServiceManager.getService("imms"));
101 if (iMms == null) {
102 return;
103 }
104 iMms.downloadMessage(subId, ActivityThread.currentPackageName(),
Tom Taylor03079ec2020-01-24 10:21:50 -0800105 locationUrl, contentUri, configOverrides, downloadedIntent,
Nan Wu98c48742022-03-17 21:25:41 +0000106 messageId, mContext.getAttributionTag());
Amit Mahajan24c01a22019-09-20 11:13:05 -0700107 } catch (RemoteException e) {
108 // Ignore it
109 }
110 }
Amit Mahajan24c01a22019-09-20 11:13:05 -0700111}