In addition, modified VoicemailProviderHelpers to use "source_package" uri parameter instead of deprecated /source/ path for source specific uri and stop using other deprecated fields. Change-Id: Ia9570de2d9823ea27d57f7d602348d2a2826f2e8
272 lines
12 KiB
Java
272 lines
12 KiB
Java
/*
|
|
* Copyright (C) 2011 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 com.example.android.provider;
|
|
|
|
// This is a COPY of the voicemail provider contract file checked in at
|
|
// framework/base/core/java/android/provider. The API is currently hidden so
|
|
// it is not available through the SDK and hence is not available to the sample
|
|
// code.
|
|
// TODO: get rid of this copy once the voicemail provider API is opened ups.
|
|
|
|
import android.content.Intent;
|
|
import android.database.ContentObserver;
|
|
import android.net.Uri;
|
|
import android.provider.BaseColumns;
|
|
import android.provider.CallLog.Calls;
|
|
|
|
/**
|
|
* The contract between the voicemail provider and applications. Contains
|
|
* definitions for the supported URIs and columns.
|
|
*
|
|
* <P>Voicemails are inserted by what is called as a "voicemail source"
|
|
* application, which is responsible for syncing voicemail data between a remote
|
|
* server and the local voicemail content provider. "voicemail source"
|
|
* application should use the source specific {@link #CONTENT_URI_SOURCE} URI
|
|
* to insert and retrieve voicemails.
|
|
*
|
|
* <P>In addition to the {@link ContentObserver} notifications the voicemail
|
|
* provider also generates broadcast intents to notify change for applications
|
|
* that are not active and therefore cannot listen to ContentObserver
|
|
* notifications. Broadcast intents with following actions are generated:
|
|
* <ul>
|
|
* <li> {@link #ACTION_NEW_VOICEMAIL} is generated for each new voicemail
|
|
* inserted.
|
|
* </li>
|
|
* <li> {@link Intent#ACTION_PROVIDER_CHANGED} is generated for any change
|
|
* made into the database, including new voicemail.
|
|
* </li>
|
|
* </ul>
|
|
* @hide
|
|
*/
|
|
// TODO: unhide when the API is approved by android-api-council
|
|
public class VoicemailContract {
|
|
/** Not instantiable. */
|
|
private VoicemailContract() {
|
|
}
|
|
|
|
/** The authority used by the voicemail provider. */
|
|
public static final String AUTHORITY = "com.android.voicemail";
|
|
/**
|
|
* URI to insert/retrieve all voicemails.
|
|
* @deprecated
|
|
*/
|
|
public static final Uri CONTENT_URI =
|
|
Uri.parse("content://" + AUTHORITY + "/voicemail");
|
|
/**
|
|
* URI to insert/retrieve voicemails by a given voicemail source.
|
|
* @deprecated
|
|
*/
|
|
public static final Uri CONTENT_URI_SOURCE =
|
|
Uri.parse("content://" + AUTHORITY + "/voicemail/source/");
|
|
/**
|
|
* Parameter key used in the URI to specify the voicemail source package name.
|
|
* <p> This field must be set in all requests that originate from a voicemail source.
|
|
*/
|
|
public static final String PARAM_KEY_SOURCE_PACKAGE = "source_package";
|
|
|
|
// TODO: Move ACTION_NEW_VOICEMAIL to the Intent class.
|
|
/** Broadcast intent when a new voicemail record is inserted. */
|
|
public static final String ACTION_NEW_VOICEMAIL = "android.intent.action.NEW_VOICEMAIL";
|
|
/**
|
|
* Extra included in {@value Intent#ACTION_PROVIDER_CHANGED} and
|
|
* {@value #ACTION_NEW_VOICEMAIL} broadcast intents to indicate if the receiving
|
|
* package made this change.
|
|
*/
|
|
public static final String EXTRA_SELF_CHANGE = "com.android.voicemail.extra.SELF_CHANGE";
|
|
|
|
/**
|
|
* The mime type for a collection of voicemails.
|
|
* @deprecated */
|
|
public static final String DIR_TYPE = "vnd.android.cursor.dir/voicemails";
|
|
|
|
/** Defines fields exposed through the /voicemail path of this content provider. */
|
|
public static final class Voicemails implements BaseColumns {
|
|
/** Not instantiable. */
|
|
private Voicemails() {
|
|
}
|
|
|
|
/** URI to insert/retrieve voicemails by a given voicemail source. */
|
|
public static final Uri CONTENT_URI =
|
|
Uri.parse("content://" + AUTHORITY + "/voicemail");
|
|
/** URI to insert/retrieve voicemails by a given voicemail source. */
|
|
public static final Uri CONTENT_URI_SOURCE =
|
|
Uri.parse("content://" + AUTHORITY + "/voicemail/source/");
|
|
|
|
/** The mime type for a collection of voicemails. */
|
|
public static final String DIR_TYPE = "vnd.android.cursor.dir/voicemails";
|
|
|
|
/**
|
|
* Phone number of the voicemail sender.
|
|
* <P>Type: TEXT</P>
|
|
*/
|
|
public static final String NUMBER = Calls.NUMBER;
|
|
/**
|
|
* The date the voicemail was sent, in milliseconds since the epoch
|
|
* <P>Type: INTEGER (long)</P>
|
|
*/
|
|
public static final String DATE = Calls.DATE;
|
|
/**
|
|
* The duration of the voicemail in seconds.
|
|
* <P>Type: INTEGER (long)</P>
|
|
*/
|
|
public static final String DURATION = Calls.DURATION;
|
|
/**
|
|
* Whether this is a new voicemail (i.e. has not been heard).
|
|
* <P>Type: INTEGER (boolean)</P>
|
|
*/
|
|
public static final String NEW = Calls.NEW;
|
|
/**
|
|
* The mail box state of the voicemail.
|
|
* <P> Possible values: {@link #STATE_INBOX}, {@link #STATE_DELETED},
|
|
* {@link #STATE_UNDELETED}.
|
|
* <P>Type: INTEGER</P>
|
|
*/
|
|
public static final String STATE = "state";
|
|
/** Value of {@link #STATE} when the voicemail is in inbox. */
|
|
public static int STATE_INBOX = 0;
|
|
/** Value of {@link #STATE} when the voicemail has been marked as deleted. */
|
|
public static int STATE_DELETED = 1;
|
|
/** Value of {@link #STATE} when the voicemail has marked as undeleted. */
|
|
public static int STATE_UNDELETED = 2;
|
|
/**
|
|
* Package name of the source application that inserted the voicemail.
|
|
* <P>Type: TEXT</P>
|
|
*/
|
|
public static final String SOURCE_PACKAGE = "source_package";
|
|
/**
|
|
* Application-specific data available to the source application that
|
|
* inserted the voicemail. This is typically used to store the source
|
|
* specific message id to identify this voicemail on the remote
|
|
* voicemail server.
|
|
* <P>Type: TEXT</P>
|
|
* <P> Note that this is NOT the voicemail media content data.
|
|
*/
|
|
public static final String SOURCE_DATA = "source_data";
|
|
/**
|
|
* Whether the media content for this voicemail is available for
|
|
* consumption.
|
|
* <P>Type: INTEGER (boolean)</P>
|
|
*/
|
|
public static final String HAS_CONTENT = "has_content";
|
|
/**
|
|
* MIME type of the media content for the voicemail.
|
|
* <P>Type: TEXT</P>
|
|
*/
|
|
public static final String MIME_TYPE = "mime_type";
|
|
/**
|
|
* Path to the media content file. Internal only field.
|
|
* @hide
|
|
*/
|
|
public static final String _DATA = "_data";
|
|
|
|
/**
|
|
* A convenience method to build voicemail URI specific to a source package by appending
|
|
* {@link VoicemailContract#PARAM_KEY_SOURCE_PACKAGE} param to the base URI.
|
|
*/
|
|
public static Uri buildSourceUri(String packageName) {
|
|
return Voicemails.CONTENT_URI.buildUpon()
|
|
.appendQueryParameter(PARAM_KEY_SOURCE_PACKAGE, packageName).build();
|
|
}
|
|
}
|
|
|
|
/** Defines fields exposed through the /status path of this content provider. */
|
|
public static final class Status implements BaseColumns {
|
|
/** URI to insert/retrieve status of voicemail source. */
|
|
public static final Uri CONTENT_URI = Uri.parse("content://" + AUTHORITY + "/status");
|
|
/** The mime type for a collection of voicemail source statuses. */
|
|
public static final String DIR_TYPE = "vnd.android.cursor.dir/voicemail.source.status";
|
|
/** The mime type for a collection of voicemails. */
|
|
public static final String ITEM_TYPE = "vnd.android.cursor.item/voicemail.source.status";
|
|
|
|
/** Not instantiable. */
|
|
private Status() {
|
|
}
|
|
/**
|
|
* The package name of the voicemail source. There can only be a one entry per source.
|
|
* <P>Type: TEXT</P>
|
|
*/
|
|
public static final String SOURCE_PACKAGE = "source_package";
|
|
/**
|
|
* The URI to call to invoke source specific voicemail settings screen. On a user request
|
|
* to setup voicemail an intent with action VIEW with this URI will be fired by the system.
|
|
* <P>Type: TEXT</P>
|
|
*/
|
|
public static final String SETTINGS_URI = "settings_uri";
|
|
/**
|
|
* The URI to call when the user requests to directly access the voicemail from the remote
|
|
* server. In case of an IVR voicemail system this is typically set to the the voicemail
|
|
* number specified using a tel:/ URI.
|
|
* <P>Type: TEXT</P>
|
|
*/
|
|
public static final String VOICEMAIL_ACCESS_URI = "voicemail_access_uri";
|
|
/**
|
|
* The configuration state of the voicemail source.
|
|
* <P> Possible values:
|
|
* {@link #CONFIGURATION_STATE_OK},
|
|
* {@link #CONFIGURATION_STATE_NOT_CONFIGURED},
|
|
* {@link #CONFIGURATION_STATE_CAN_BE_CONFIGURED}
|
|
* <P>Type: INTEGER</P>
|
|
*/
|
|
public static final String CONFIGURATION_STATE = "configuration_state";
|
|
public static final int CONFIGURATION_STATE_OK = 0;
|
|
public static final int CONFIGURATION_STATE_NOT_CONFIGURED = 1;
|
|
/**
|
|
* This state must be used when the source has verified that the current user can be
|
|
* upgraded to visual voicemail and would like to show a set up invitation message.
|
|
*/
|
|
public static final int CONFIGURATION_STATE_CAN_BE_CONFIGURED = 2;
|
|
/**
|
|
* The data channel state of the voicemail source. This the channel through which the source
|
|
* pulls voicemail data from a remote server.
|
|
* <P> Possible values:
|
|
* {@link #DATA_CHANNEL_STATE_OK},
|
|
* {@link #DATA_CHANNEL_STATE_NO_CONNECTION}
|
|
* </P>
|
|
* <P>Type: INTEGER</P>
|
|
*/
|
|
public static final String DATA_CHANNEL_STATE = "data_channel_state";
|
|
public static final int DATA_CHANNEL_STATE_OK = 0;
|
|
public static final int DATA_CHANNEL_STATE_NO_CONNECTION = 1;
|
|
/**
|
|
* The notification channel state of the voicemail source. This is the channel through which
|
|
* the source gets notified of new voicemails on the remote server.
|
|
* <P> Possible values:
|
|
* {@link #NOTIFICATION_CHANNEL_STATE_OK},
|
|
* {@link #NOTIFICATION_CHANNEL_STATE_NO_CONNECTION},
|
|
* {@link #NOTIFICATION_CHANNEL_STATE_MESSAGE_WAITING}
|
|
* </P>
|
|
* <P>Type: INTEGER</P>
|
|
*/
|
|
public static final String NOTIFICATION_CHANNEL_STATE = "notification_channel_state";
|
|
public static final int NOTIFICATION_CHANNEL_STATE_OK = 0;
|
|
public static final int NOTIFICATION_CHANNEL_STATE_NO_CONNECTION = 1;
|
|
/**
|
|
* Use this state when the notification can only tell that there are pending messages on
|
|
* the server but no details of the sender/time etc are known.
|
|
*/
|
|
public static final int NOTIFICATION_CHANNEL_STATE_MESSAGE_WAITING = 2;
|
|
|
|
/**
|
|
* A convenience method to build status URI specific to a source package by appending
|
|
* {@link VoicemailContract#PARAM_KEY_SOURCE_PACKAGE} param to the base URI.
|
|
*/
|
|
public static Uri buildSourceUri(String packageName) {
|
|
return Status.CONTENT_URI.buildUpon()
|
|
.appendQueryParameter(PARAM_KEY_SOURCE_PACKAGE, packageName).build();
|
|
}
|
|
}
|
|
}
|