1088b2918423ef79b92c0b0433f2f59a1fd0f7c1bEvan Millar/* 2088b2918423ef79b92c0b0433f2f59a1fd0f7c1bEvan Millar * Copyright (C) 2009 The Android Open Source Project 3088b2918423ef79b92c0b0433f2f59a1fd0f7c1bEvan Millar * 4088b2918423ef79b92c0b0433f2f59a1fd0f7c1bEvan Millar * Licensed under the Apache License, Version 2.0 (the "License"); 5088b2918423ef79b92c0b0433f2f59a1fd0f7c1bEvan Millar * you may not use this file except in compliance with the License. 6088b2918423ef79b92c0b0433f2f59a1fd0f7c1bEvan Millar * You may obtain a copy of the License at 7088b2918423ef79b92c0b0433f2f59a1fd0f7c1bEvan Millar * 8088b2918423ef79b92c0b0433f2f59a1fd0f7c1bEvan Millar * http://www.apache.org/licenses/LICENSE-2.0 9088b2918423ef79b92c0b0433f2f59a1fd0f7c1bEvan Millar * 10088b2918423ef79b92c0b0433f2f59a1fd0f7c1bEvan Millar * Unless required by applicable law or agreed to in writing, software 11088b2918423ef79b92c0b0433f2f59a1fd0f7c1bEvan Millar * distributed under the License is distributed on an "AS IS" BASIS, 12088b2918423ef79b92c0b0433f2f59a1fd0f7c1bEvan Millar * WITHOUT WARRANTIES OR CONDITIONS OF ANY KIND, either express or implied. 13088b2918423ef79b92c0b0433f2f59a1fd0f7c1bEvan Millar * See the License for the specific language governing permissions and 14088b2918423ef79b92c0b0433f2f59a1fd0f7c1bEvan Millar * limitations under the License 15088b2918423ef79b92c0b0433f2f59a1fd0f7c1bEvan Millar */ 16088b2918423ef79b92c0b0433f2f59a1fd0f7c1bEvan Millar 17088b2918423ef79b92c0b0433f2f59a1fd0f7c1bEvan Millarpackage android.provider; 18088b2918423ef79b92c0b0433f2f59a1fd0f7c1bEvan Millar 198a0193e4ca1522b9a817ebd399812b6e2f1b0cdcJeff Sharkeyimport android.content.res.Resources; 20088b2918423ef79b92c0b0433f2f59a1fd0f7c1bEvan Millarimport android.graphics.BitmapFactory; 21088b2918423ef79b92c0b0433f2f59a1fd0f7c1bEvan Millarimport android.net.Uri; 227cca5f83638b019cc68acfaedd533602a97486b0Dmitri Plotnikovimport android.provider.ContactsContract.Contacts; 23d530b3ce850cfa3d61b79eba1aee6f67b04dba15Jeff Sharkeyimport android.provider.ContactsContract.Data; 24088b2918423ef79b92c0b0433f2f59a1fd0f7c1bEvan Millar 25088b2918423ef79b92c0b0433f2f59a1fd0f7c1bEvan Millar/** 26088b2918423ef79b92c0b0433f2f59a1fd0f7c1bEvan Millar * The contract between the social provider and applications. Contains 27088b2918423ef79b92c0b0433f2f59a1fd0f7c1bEvan Millar * definitions for the supported URIs and columns. 285f123bdcde61b9fdcd58952882c621c34a727e10Dmitri Plotnikov * 295f123bdcde61b9fdcd58952882c621c34a727e10Dmitri Plotnikov * @hide 30088b2918423ef79b92c0b0433f2f59a1fd0f7c1bEvan Millar */ 31088b2918423ef79b92c0b0433f2f59a1fd0f7c1bEvan Millarpublic class SocialContract { 32088b2918423ef79b92c0b0433f2f59a1fd0f7c1bEvan Millar /** The authority for the social provider */ 33088b2918423ef79b92c0b0433f2f59a1fd0f7c1bEvan Millar public static final String AUTHORITY = "com.android.social"; 34088b2918423ef79b92c0b0433f2f59a1fd0f7c1bEvan Millar 35088b2918423ef79b92c0b0433f2f59a1fd0f7c1bEvan Millar /** A content:// style uri to the authority for the contacts provider */ 36088b2918423ef79b92c0b0433f2f59a1fd0f7c1bEvan Millar public static final Uri AUTHORITY_URI = Uri.parse("content://" + AUTHORITY); 37088b2918423ef79b92c0b0433f2f59a1fd0f7c1bEvan Millar 38088b2918423ef79b92c0b0433f2f59a1fd0f7c1bEvan Millar private interface ActivitiesColumns { 39088b2918423ef79b92c0b0433f2f59a1fd0f7c1bEvan Millar /** 408a0193e4ca1522b9a817ebd399812b6e2f1b0cdcJeff Sharkey * The package name to use when creating {@link Resources} objects for 418a0193e4ca1522b9a817ebd399812b6e2f1b0cdcJeff Sharkey * this data row. This value is only designed for use when building user 428a0193e4ca1522b9a817ebd399812b6e2f1b0cdcJeff Sharkey * interfaces, and should not be used to infer the owner. 43088b2918423ef79b92c0b0433f2f59a1fd0f7c1bEvan Millar * <p> 44088b2918423ef79b92c0b0433f2f59a1fd0f7c1bEvan Millar * Type: TEXT 45088b2918423ef79b92c0b0433f2f59a1fd0f7c1bEvan Millar */ 468a0193e4ca1522b9a817ebd399812b6e2f1b0cdcJeff Sharkey public static final String RES_PACKAGE = "res_package"; 47088b2918423ef79b92c0b0433f2f59a1fd0f7c1bEvan Millar 48088b2918423ef79b92c0b0433f2f59a1fd0f7c1bEvan Millar /** 49088b2918423ef79b92c0b0433f2f59a1fd0f7c1bEvan Millar * The mime-type of this social activity. 50088b2918423ef79b92c0b0433f2f59a1fd0f7c1bEvan Millar * <p> 51088b2918423ef79b92c0b0433f2f59a1fd0f7c1bEvan Millar * Type: TEXT 52088b2918423ef79b92c0b0433f2f59a1fd0f7c1bEvan Millar */ 53088b2918423ef79b92c0b0433f2f59a1fd0f7c1bEvan Millar public static final String MIMETYPE = "mimetype"; 54088b2918423ef79b92c0b0433f2f59a1fd0f7c1bEvan Millar 55088b2918423ef79b92c0b0433f2f59a1fd0f7c1bEvan Millar /** 56088b2918423ef79b92c0b0433f2f59a1fd0f7c1bEvan Millar * Internal raw identifier for this social activity. This field is 57088b2918423ef79b92c0b0433f2f59a1fd0f7c1bEvan Millar * analogous to the <code>atom:id</code> element defined in RFC 4287. 58088b2918423ef79b92c0b0433f2f59a1fd0f7c1bEvan Millar * <p> 59088b2918423ef79b92c0b0433f2f59a1fd0f7c1bEvan Millar * Type: TEXT 60088b2918423ef79b92c0b0433f2f59a1fd0f7c1bEvan Millar */ 61088b2918423ef79b92c0b0433f2f59a1fd0f7c1bEvan Millar public static final String RAW_ID = "raw_id"; 62088b2918423ef79b92c0b0433f2f59a1fd0f7c1bEvan Millar 63088b2918423ef79b92c0b0433f2f59a1fd0f7c1bEvan Millar /** 64088b2918423ef79b92c0b0433f2f59a1fd0f7c1bEvan Millar * Reference to another {@link Activities#RAW_ID} that this social activity 65088b2918423ef79b92c0b0433f2f59a1fd0f7c1bEvan Millar * is replying to. This field is analogous to the 66088b2918423ef79b92c0b0433f2f59a1fd0f7c1bEvan Millar * <code>thr:in-reply-to</code> element defined in RFC 4685. 67088b2918423ef79b92c0b0433f2f59a1fd0f7c1bEvan Millar * <p> 68088b2918423ef79b92c0b0433f2f59a1fd0f7c1bEvan Millar * Type: TEXT 69088b2918423ef79b92c0b0433f2f59a1fd0f7c1bEvan Millar */ 70088b2918423ef79b92c0b0433f2f59a1fd0f7c1bEvan Millar public static final String IN_REPLY_TO = "in_reply_to"; 71088b2918423ef79b92c0b0433f2f59a1fd0f7c1bEvan Millar 72088b2918423ef79b92c0b0433f2f59a1fd0f7c1bEvan Millar /** 73569277732b4180c07c9f917ff8c3fc3111b10338Dmitri Plotnikov * Reference to the {@link android.provider.ContactsContract.Contacts#_ID} that authored 74569277732b4180c07c9f917ff8c3fc3111b10338Dmitri Plotnikov * this social activity. This field is analogous to the <code>atom:author</code> 75088b2918423ef79b92c0b0433f2f59a1fd0f7c1bEvan Millar * element defined in RFC 4287. 76088b2918423ef79b92c0b0433f2f59a1fd0f7c1bEvan Millar * <p> 77088b2918423ef79b92c0b0433f2f59a1fd0f7c1bEvan Millar * Type: INTEGER 78088b2918423ef79b92c0b0433f2f59a1fd0f7c1bEvan Millar */ 79088b2918423ef79b92c0b0433f2f59a1fd0f7c1bEvan Millar public static final String AUTHOR_CONTACT_ID = "author_contact_id"; 80088b2918423ef79b92c0b0433f2f59a1fd0f7c1bEvan Millar 81088b2918423ef79b92c0b0433f2f59a1fd0f7c1bEvan Millar /** 82569277732b4180c07c9f917ff8c3fc3111b10338Dmitri Plotnikov * Optional reference to the {@link android.provider.ContactsContract.Contacts#_ID} this 83569277732b4180c07c9f917ff8c3fc3111b10338Dmitri Plotnikov * social activity is targeted towards. If more than one direct target, this field may 84088b2918423ef79b92c0b0433f2f59a1fd0f7c1bEvan Millar * be left undefined. This field is analogous to the 85088b2918423ef79b92c0b0433f2f59a1fd0f7c1bEvan Millar * <code>activity:target</code> element defined in the Atom Activity 86088b2918423ef79b92c0b0433f2f59a1fd0f7c1bEvan Millar * Extensions Internet-Draft. 87088b2918423ef79b92c0b0433f2f59a1fd0f7c1bEvan Millar * <p> 88088b2918423ef79b92c0b0433f2f59a1fd0f7c1bEvan Millar * Type: INTEGER 89088b2918423ef79b92c0b0433f2f59a1fd0f7c1bEvan Millar */ 90088b2918423ef79b92c0b0433f2f59a1fd0f7c1bEvan Millar public static final String TARGET_CONTACT_ID = "target_contact_id"; 91088b2918423ef79b92c0b0433f2f59a1fd0f7c1bEvan Millar 92088b2918423ef79b92c0b0433f2f59a1fd0f7c1bEvan Millar /** 93088b2918423ef79b92c0b0433f2f59a1fd0f7c1bEvan Millar * Timestamp when this social activity was published, in a 94088b2918423ef79b92c0b0433f2f59a1fd0f7c1bEvan Millar * {@link System#currentTimeMillis()} time base. This field is analogous 95088b2918423ef79b92c0b0433f2f59a1fd0f7c1bEvan Millar * to the <code>atom:published</code> element defined in RFC 4287. 96088b2918423ef79b92c0b0433f2f59a1fd0f7c1bEvan Millar * <p> 97088b2918423ef79b92c0b0433f2f59a1fd0f7c1bEvan Millar * Type: INTEGER 98088b2918423ef79b92c0b0433f2f59a1fd0f7c1bEvan Millar */ 99088b2918423ef79b92c0b0433f2f59a1fd0f7c1bEvan Millar public static final String PUBLISHED = "published"; 100088b2918423ef79b92c0b0433f2f59a1fd0f7c1bEvan Millar 101088b2918423ef79b92c0b0433f2f59a1fd0f7c1bEvan Millar /** 102088b2918423ef79b92c0b0433f2f59a1fd0f7c1bEvan Millar * Timestamp when the original social activity in a thread was 103088b2918423ef79b92c0b0433f2f59a1fd0f7c1bEvan Millar * published. For activities that have an in-reply-to field specified, the 104088b2918423ef79b92c0b0433f2f59a1fd0f7c1bEvan Millar * content provider will automatically populate this field with the 105088b2918423ef79b92c0b0433f2f59a1fd0f7c1bEvan Millar * timestamp of the original activity. 106088b2918423ef79b92c0b0433f2f59a1fd0f7c1bEvan Millar * <p> 107088b2918423ef79b92c0b0433f2f59a1fd0f7c1bEvan Millar * This field is useful for sorting order of activities that keeps together all 108088b2918423ef79b92c0b0433f2f59a1fd0f7c1bEvan Millar * messages in each thread. 109088b2918423ef79b92c0b0433f2f59a1fd0f7c1bEvan Millar * <p> 110088b2918423ef79b92c0b0433f2f59a1fd0f7c1bEvan Millar * Type: INTEGER 111088b2918423ef79b92c0b0433f2f59a1fd0f7c1bEvan Millar */ 112088b2918423ef79b92c0b0433f2f59a1fd0f7c1bEvan Millar public static final String THREAD_PUBLISHED = "thread_published"; 113088b2918423ef79b92c0b0433f2f59a1fd0f7c1bEvan Millar 114088b2918423ef79b92c0b0433f2f59a1fd0f7c1bEvan Millar /** 115088b2918423ef79b92c0b0433f2f59a1fd0f7c1bEvan Millar * Title of this social activity. This field is analogous to the 116088b2918423ef79b92c0b0433f2f59a1fd0f7c1bEvan Millar * <code>atom:title</code> element defined in RFC 4287. 117088b2918423ef79b92c0b0433f2f59a1fd0f7c1bEvan Millar * <p> 118088b2918423ef79b92c0b0433f2f59a1fd0f7c1bEvan Millar * Type: TEXT 119088b2918423ef79b92c0b0433f2f59a1fd0f7c1bEvan Millar */ 120088b2918423ef79b92c0b0433f2f59a1fd0f7c1bEvan Millar public static final String TITLE = "title"; 121088b2918423ef79b92c0b0433f2f59a1fd0f7c1bEvan Millar 122088b2918423ef79b92c0b0433f2f59a1fd0f7c1bEvan Millar /** 123088b2918423ef79b92c0b0433f2f59a1fd0f7c1bEvan Millar * Summary of this social activity. This field is analogous to the 124088b2918423ef79b92c0b0433f2f59a1fd0f7c1bEvan Millar * <code>atom:summary</code> element defined in RFC 4287. 125088b2918423ef79b92c0b0433f2f59a1fd0f7c1bEvan Millar * <p> 126088b2918423ef79b92c0b0433f2f59a1fd0f7c1bEvan Millar * Type: TEXT 127088b2918423ef79b92c0b0433f2f59a1fd0f7c1bEvan Millar */ 128088b2918423ef79b92c0b0433f2f59a1fd0f7c1bEvan Millar public static final String SUMMARY = "summary"; 129088b2918423ef79b92c0b0433f2f59a1fd0f7c1bEvan Millar 130088b2918423ef79b92c0b0433f2f59a1fd0f7c1bEvan Millar /** 131088b2918423ef79b92c0b0433f2f59a1fd0f7c1bEvan Millar * A URI associated this social activity. This field is analogous to the 132088b2918423ef79b92c0b0433f2f59a1fd0f7c1bEvan Millar * <code>atom:link rel="alternate"</code> element defined in RFC 4287. 133088b2918423ef79b92c0b0433f2f59a1fd0f7c1bEvan Millar * <p> 134088b2918423ef79b92c0b0433f2f59a1fd0f7c1bEvan Millar * Type: TEXT 135088b2918423ef79b92c0b0433f2f59a1fd0f7c1bEvan Millar */ 136088b2918423ef79b92c0b0433f2f59a1fd0f7c1bEvan Millar public static final String LINK = "link"; 137088b2918423ef79b92c0b0433f2f59a1fd0f7c1bEvan Millar 138088b2918423ef79b92c0b0433f2f59a1fd0f7c1bEvan Millar /** 139088b2918423ef79b92c0b0433f2f59a1fd0f7c1bEvan Millar * Optional thumbnail specific to this social activity. This is the raw 140088b2918423ef79b92c0b0433f2f59a1fd0f7c1bEvan Millar * bytes of an image that could be inflated using {@link BitmapFactory}. 141088b2918423ef79b92c0b0433f2f59a1fd0f7c1bEvan Millar * <p> 142088b2918423ef79b92c0b0433f2f59a1fd0f7c1bEvan Millar * Type: BLOB 143088b2918423ef79b92c0b0433f2f59a1fd0f7c1bEvan Millar */ 144088b2918423ef79b92c0b0433f2f59a1fd0f7c1bEvan Millar public static final String THUMBNAIL = "thumbnail"; 145088b2918423ef79b92c0b0433f2f59a1fd0f7c1bEvan Millar } 146088b2918423ef79b92c0b0433f2f59a1fd0f7c1bEvan Millar 147088b2918423ef79b92c0b0433f2f59a1fd0f7c1bEvan Millar public static final class Activities implements BaseColumns, ActivitiesColumns { 148088b2918423ef79b92c0b0433f2f59a1fd0f7c1bEvan Millar /** 149088b2918423ef79b92c0b0433f2f59a1fd0f7c1bEvan Millar * This utility class cannot be instantiated 150088b2918423ef79b92c0b0433f2f59a1fd0f7c1bEvan Millar */ 151088b2918423ef79b92c0b0433f2f59a1fd0f7c1bEvan Millar private Activities() { 152088b2918423ef79b92c0b0433f2f59a1fd0f7c1bEvan Millar } 153088b2918423ef79b92c0b0433f2f59a1fd0f7c1bEvan Millar 154088b2918423ef79b92c0b0433f2f59a1fd0f7c1bEvan Millar /** 155088b2918423ef79b92c0b0433f2f59a1fd0f7c1bEvan Millar * The content:// style URI for this table 156088b2918423ef79b92c0b0433f2f59a1fd0f7c1bEvan Millar */ 157088b2918423ef79b92c0b0433f2f59a1fd0f7c1bEvan Millar public static final Uri CONTENT_URI = Uri.withAppendedPath(AUTHORITY_URI, "activities"); 158088b2918423ef79b92c0b0433f2f59a1fd0f7c1bEvan Millar 159088b2918423ef79b92c0b0433f2f59a1fd0f7c1bEvan Millar /** 160d530b3ce850cfa3d61b79eba1aee6f67b04dba15Jeff Sharkey * The content:// URI for this table filtered to the set of social activities 161569277732b4180c07c9f917ff8c3fc3111b10338Dmitri Plotnikov * authored by a specific {@link android.provider.ContactsContract.Contacts#_ID}. 162088b2918423ef79b92c0b0433f2f59a1fd0f7c1bEvan Millar */ 163088b2918423ef79b92c0b0433f2f59a1fd0f7c1bEvan Millar public static final Uri CONTENT_AUTHORED_BY_URI = 164088b2918423ef79b92c0b0433f2f59a1fd0f7c1bEvan Millar Uri.withAppendedPath(CONTENT_URI, "authored_by"); 165088b2918423ef79b92c0b0433f2f59a1fd0f7c1bEvan Millar 166088b2918423ef79b92c0b0433f2f59a1fd0f7c1bEvan Millar /** 167d530b3ce850cfa3d61b79eba1aee6f67b04dba15Jeff Sharkey * The {@link Uri} for the latest social activity performed by any 168ac39b26b5195d08a9f8e8c3a1bb612a2e2a608a2Evan Millar * raw contact aggregated under the specified {@link Contacts#_ID}. Will 169d530b3ce850cfa3d61b79eba1aee6f67b04dba15Jeff Sharkey * also join with most-present {@link Presence} for this aggregate. 170d530b3ce850cfa3d61b79eba1aee6f67b04dba15Jeff Sharkey */ 171ac39b26b5195d08a9f8e8c3a1bb612a2e2a608a2Evan Millar public static final Uri CONTENT_CONTACT_STATUS_URI = 172ac39b26b5195d08a9f8e8c3a1bb612a2e2a608a2Evan Millar Uri.withAppendedPath(AUTHORITY_URI, "contact_status"); 173d530b3ce850cfa3d61b79eba1aee6f67b04dba15Jeff Sharkey 174d530b3ce850cfa3d61b79eba1aee6f67b04dba15Jeff Sharkey /** 175088b2918423ef79b92c0b0433f2f59a1fd0f7c1bEvan Millar * The MIME type of {@link #CONTENT_URI} providing a directory of social 176088b2918423ef79b92c0b0433f2f59a1fd0f7c1bEvan Millar * activities. 177088b2918423ef79b92c0b0433f2f59a1fd0f7c1bEvan Millar */ 178088b2918423ef79b92c0b0433f2f59a1fd0f7c1bEvan Millar public static final String CONTENT_TYPE = "vnd.android.cursor.dir/activity"; 179088b2918423ef79b92c0b0433f2f59a1fd0f7c1bEvan Millar 180088b2918423ef79b92c0b0433f2f59a1fd0f7c1bEvan Millar /** 181088b2918423ef79b92c0b0433f2f59a1fd0f7c1bEvan Millar * The MIME type of a {@link #CONTENT_URI} subdirectory of a single 182088b2918423ef79b92c0b0433f2f59a1fd0f7c1bEvan Millar * social activity. 183088b2918423ef79b92c0b0433f2f59a1fd0f7c1bEvan Millar */ 184088b2918423ef79b92c0b0433f2f59a1fd0f7c1bEvan Millar public static final String CONTENT_ITEM_TYPE = "vnd.android.cursor.item/activity"; 185088b2918423ef79b92c0b0433f2f59a1fd0f7c1bEvan Millar } 186088b2918423ef79b92c0b0433f2f59a1fd0f7c1bEvan Millar 187088b2918423ef79b92c0b0433f2f59a1fd0f7c1bEvan Millar} 188