SocialContract.java revision 5f123bdcde61b9fdcd58952882c621c34a727e10
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 19088b2918423ef79b92c0b0433f2f59a1fd0f7c1bEvan Millarimport android.graphics.BitmapFactory; 20088b2918423ef79b92c0b0433f2f59a1fd0f7c1bEvan Millarimport android.net.Uri; 21088b2918423ef79b92c0b0433f2f59a1fd0f7c1bEvan Millar 22088b2918423ef79b92c0b0433f2f59a1fd0f7c1bEvan Millar/** 23088b2918423ef79b92c0b0433f2f59a1fd0f7c1bEvan Millar * The contract between the social provider and applications. Contains 24088b2918423ef79b92c0b0433f2f59a1fd0f7c1bEvan Millar * definitions for the supported URIs and columns. 255f123bdcde61b9fdcd58952882c621c34a727e10Dmitri Plotnikov * 265f123bdcde61b9fdcd58952882c621c34a727e10Dmitri Plotnikov * @hide 27088b2918423ef79b92c0b0433f2f59a1fd0f7c1bEvan Millar */ 28088b2918423ef79b92c0b0433f2f59a1fd0f7c1bEvan Millarpublic class SocialContract { 29088b2918423ef79b92c0b0433f2f59a1fd0f7c1bEvan Millar /** The authority for the social provider */ 30088b2918423ef79b92c0b0433f2f59a1fd0f7c1bEvan Millar public static final String AUTHORITY = "com.android.social"; 31088b2918423ef79b92c0b0433f2f59a1fd0f7c1bEvan Millar 32088b2918423ef79b92c0b0433f2f59a1fd0f7c1bEvan Millar /** A content:// style uri to the authority for the contacts provider */ 33088b2918423ef79b92c0b0433f2f59a1fd0f7c1bEvan Millar public static final Uri AUTHORITY_URI = Uri.parse("content://" + AUTHORITY); 34088b2918423ef79b92c0b0433f2f59a1fd0f7c1bEvan Millar 35088b2918423ef79b92c0b0433f2f59a1fd0f7c1bEvan Millar private interface ActivitiesColumns { 36088b2918423ef79b92c0b0433f2f59a1fd0f7c1bEvan Millar /** 37088b2918423ef79b92c0b0433f2f59a1fd0f7c1bEvan Millar * The package name that owns this social activity. 38088b2918423ef79b92c0b0433f2f59a1fd0f7c1bEvan Millar * <p> 39088b2918423ef79b92c0b0433f2f59a1fd0f7c1bEvan Millar * Type: TEXT 40088b2918423ef79b92c0b0433f2f59a1fd0f7c1bEvan Millar */ 41088b2918423ef79b92c0b0433f2f59a1fd0f7c1bEvan Millar public static final String PACKAGE = "package"; 42088b2918423ef79b92c0b0433f2f59a1fd0f7c1bEvan Millar 43088b2918423ef79b92c0b0433f2f59a1fd0f7c1bEvan Millar /** 44088b2918423ef79b92c0b0433f2f59a1fd0f7c1bEvan Millar * The mime-type of this social activity. 45088b2918423ef79b92c0b0433f2f59a1fd0f7c1bEvan Millar * <p> 46088b2918423ef79b92c0b0433f2f59a1fd0f7c1bEvan Millar * Type: TEXT 47088b2918423ef79b92c0b0433f2f59a1fd0f7c1bEvan Millar */ 48088b2918423ef79b92c0b0433f2f59a1fd0f7c1bEvan Millar public static final String MIMETYPE = "mimetype"; 49088b2918423ef79b92c0b0433f2f59a1fd0f7c1bEvan Millar 50088b2918423ef79b92c0b0433f2f59a1fd0f7c1bEvan Millar /** 51088b2918423ef79b92c0b0433f2f59a1fd0f7c1bEvan Millar * Internal raw identifier for this social activity. This field is 52088b2918423ef79b92c0b0433f2f59a1fd0f7c1bEvan Millar * analogous to the <code>atom:id</code> element defined in RFC 4287. 53088b2918423ef79b92c0b0433f2f59a1fd0f7c1bEvan Millar * <p> 54088b2918423ef79b92c0b0433f2f59a1fd0f7c1bEvan Millar * Type: TEXT 55088b2918423ef79b92c0b0433f2f59a1fd0f7c1bEvan Millar */ 56088b2918423ef79b92c0b0433f2f59a1fd0f7c1bEvan Millar public static final String RAW_ID = "raw_id"; 57088b2918423ef79b92c0b0433f2f59a1fd0f7c1bEvan Millar 58088b2918423ef79b92c0b0433f2f59a1fd0f7c1bEvan Millar /** 59088b2918423ef79b92c0b0433f2f59a1fd0f7c1bEvan Millar * Reference to another {@link Activities#RAW_ID} that this social activity 60088b2918423ef79b92c0b0433f2f59a1fd0f7c1bEvan Millar * is replying to. This field is analogous to the 61088b2918423ef79b92c0b0433f2f59a1fd0f7c1bEvan Millar * <code>thr:in-reply-to</code> element defined in RFC 4685. 62088b2918423ef79b92c0b0433f2f59a1fd0f7c1bEvan Millar * <p> 63088b2918423ef79b92c0b0433f2f59a1fd0f7c1bEvan Millar * Type: TEXT 64088b2918423ef79b92c0b0433f2f59a1fd0f7c1bEvan Millar */ 65088b2918423ef79b92c0b0433f2f59a1fd0f7c1bEvan Millar public static final String IN_REPLY_TO = "in_reply_to"; 66088b2918423ef79b92c0b0433f2f59a1fd0f7c1bEvan Millar 67088b2918423ef79b92c0b0433f2f59a1fd0f7c1bEvan Millar /** 68569277732b4180c07c9f917ff8c3fc3111b10338Dmitri Plotnikov * Reference to the {@link android.provider.ContactsContract.Contacts#_ID} that authored 69569277732b4180c07c9f917ff8c3fc3111b10338Dmitri Plotnikov * this social activity. This field is analogous to the <code>atom:author</code> 70088b2918423ef79b92c0b0433f2f59a1fd0f7c1bEvan Millar * element defined in RFC 4287. 71088b2918423ef79b92c0b0433f2f59a1fd0f7c1bEvan Millar * <p> 72088b2918423ef79b92c0b0433f2f59a1fd0f7c1bEvan Millar * Type: INTEGER 73088b2918423ef79b92c0b0433f2f59a1fd0f7c1bEvan Millar */ 74088b2918423ef79b92c0b0433f2f59a1fd0f7c1bEvan Millar public static final String AUTHOR_CONTACT_ID = "author_contact_id"; 75088b2918423ef79b92c0b0433f2f59a1fd0f7c1bEvan Millar 76088b2918423ef79b92c0b0433f2f59a1fd0f7c1bEvan Millar /** 77569277732b4180c07c9f917ff8c3fc3111b10338Dmitri Plotnikov * Optional reference to the {@link android.provider.ContactsContract.Contacts#_ID} this 78569277732b4180c07c9f917ff8c3fc3111b10338Dmitri Plotnikov * social activity is targeted towards. If more than one direct target, this field may 79088b2918423ef79b92c0b0433f2f59a1fd0f7c1bEvan Millar * be left undefined. This field is analogous to the 80088b2918423ef79b92c0b0433f2f59a1fd0f7c1bEvan Millar * <code>activity:target</code> element defined in the Atom Activity 81088b2918423ef79b92c0b0433f2f59a1fd0f7c1bEvan Millar * Extensions Internet-Draft. 82088b2918423ef79b92c0b0433f2f59a1fd0f7c1bEvan Millar * <p> 83088b2918423ef79b92c0b0433f2f59a1fd0f7c1bEvan Millar * Type: INTEGER 84088b2918423ef79b92c0b0433f2f59a1fd0f7c1bEvan Millar */ 85088b2918423ef79b92c0b0433f2f59a1fd0f7c1bEvan Millar public static final String TARGET_CONTACT_ID = "target_contact_id"; 86088b2918423ef79b92c0b0433f2f59a1fd0f7c1bEvan Millar 87088b2918423ef79b92c0b0433f2f59a1fd0f7c1bEvan Millar /** 88088b2918423ef79b92c0b0433f2f59a1fd0f7c1bEvan Millar * Timestamp when this social activity was published, in a 89088b2918423ef79b92c0b0433f2f59a1fd0f7c1bEvan Millar * {@link System#currentTimeMillis()} time base. This field is analogous 90088b2918423ef79b92c0b0433f2f59a1fd0f7c1bEvan Millar * to the <code>atom:published</code> element defined in RFC 4287. 91088b2918423ef79b92c0b0433f2f59a1fd0f7c1bEvan Millar * <p> 92088b2918423ef79b92c0b0433f2f59a1fd0f7c1bEvan Millar * Type: INTEGER 93088b2918423ef79b92c0b0433f2f59a1fd0f7c1bEvan Millar */ 94088b2918423ef79b92c0b0433f2f59a1fd0f7c1bEvan Millar public static final String PUBLISHED = "published"; 95088b2918423ef79b92c0b0433f2f59a1fd0f7c1bEvan Millar 96088b2918423ef79b92c0b0433f2f59a1fd0f7c1bEvan Millar /** 97088b2918423ef79b92c0b0433f2f59a1fd0f7c1bEvan Millar * Timestamp when the original social activity in a thread was 98088b2918423ef79b92c0b0433f2f59a1fd0f7c1bEvan Millar * published. For activities that have an in-reply-to field specified, the 99088b2918423ef79b92c0b0433f2f59a1fd0f7c1bEvan Millar * content provider will automatically populate this field with the 100088b2918423ef79b92c0b0433f2f59a1fd0f7c1bEvan Millar * timestamp of the original activity. 101088b2918423ef79b92c0b0433f2f59a1fd0f7c1bEvan Millar * <p> 102088b2918423ef79b92c0b0433f2f59a1fd0f7c1bEvan Millar * This field is useful for sorting order of activities that keeps together all 103088b2918423ef79b92c0b0433f2f59a1fd0f7c1bEvan Millar * messages in each thread. 104088b2918423ef79b92c0b0433f2f59a1fd0f7c1bEvan Millar * <p> 105088b2918423ef79b92c0b0433f2f59a1fd0f7c1bEvan Millar * Type: INTEGER 106088b2918423ef79b92c0b0433f2f59a1fd0f7c1bEvan Millar */ 107088b2918423ef79b92c0b0433f2f59a1fd0f7c1bEvan Millar public static final String THREAD_PUBLISHED = "thread_published"; 108088b2918423ef79b92c0b0433f2f59a1fd0f7c1bEvan Millar 109088b2918423ef79b92c0b0433f2f59a1fd0f7c1bEvan Millar /** 110088b2918423ef79b92c0b0433f2f59a1fd0f7c1bEvan Millar * Title of this social activity. This field is analogous to the 111088b2918423ef79b92c0b0433f2f59a1fd0f7c1bEvan Millar * <code>atom:title</code> element defined in RFC 4287. 112088b2918423ef79b92c0b0433f2f59a1fd0f7c1bEvan Millar * <p> 113088b2918423ef79b92c0b0433f2f59a1fd0f7c1bEvan Millar * Type: TEXT 114088b2918423ef79b92c0b0433f2f59a1fd0f7c1bEvan Millar */ 115088b2918423ef79b92c0b0433f2f59a1fd0f7c1bEvan Millar public static final String TITLE = "title"; 116088b2918423ef79b92c0b0433f2f59a1fd0f7c1bEvan Millar 117088b2918423ef79b92c0b0433f2f59a1fd0f7c1bEvan Millar /** 118088b2918423ef79b92c0b0433f2f59a1fd0f7c1bEvan Millar * Summary of this social activity. This field is analogous to the 119088b2918423ef79b92c0b0433f2f59a1fd0f7c1bEvan Millar * <code>atom:summary</code> element defined in RFC 4287. 120088b2918423ef79b92c0b0433f2f59a1fd0f7c1bEvan Millar * <p> 121088b2918423ef79b92c0b0433f2f59a1fd0f7c1bEvan Millar * Type: TEXT 122088b2918423ef79b92c0b0433f2f59a1fd0f7c1bEvan Millar */ 123088b2918423ef79b92c0b0433f2f59a1fd0f7c1bEvan Millar public static final String SUMMARY = "summary"; 124088b2918423ef79b92c0b0433f2f59a1fd0f7c1bEvan Millar 125088b2918423ef79b92c0b0433f2f59a1fd0f7c1bEvan Millar /** 126088b2918423ef79b92c0b0433f2f59a1fd0f7c1bEvan Millar * A URI associated this social activity. This field is analogous to the 127088b2918423ef79b92c0b0433f2f59a1fd0f7c1bEvan Millar * <code>atom:link rel="alternate"</code> element defined in RFC 4287. 128088b2918423ef79b92c0b0433f2f59a1fd0f7c1bEvan Millar * <p> 129088b2918423ef79b92c0b0433f2f59a1fd0f7c1bEvan Millar * Type: TEXT 130088b2918423ef79b92c0b0433f2f59a1fd0f7c1bEvan Millar */ 131088b2918423ef79b92c0b0433f2f59a1fd0f7c1bEvan Millar public static final String LINK = "link"; 132088b2918423ef79b92c0b0433f2f59a1fd0f7c1bEvan Millar 133088b2918423ef79b92c0b0433f2f59a1fd0f7c1bEvan Millar /** 134088b2918423ef79b92c0b0433f2f59a1fd0f7c1bEvan Millar * Optional thumbnail specific to this social activity. This is the raw 135088b2918423ef79b92c0b0433f2f59a1fd0f7c1bEvan Millar * bytes of an image that could be inflated using {@link BitmapFactory}. 136088b2918423ef79b92c0b0433f2f59a1fd0f7c1bEvan Millar * <p> 137088b2918423ef79b92c0b0433f2f59a1fd0f7c1bEvan Millar * Type: BLOB 138088b2918423ef79b92c0b0433f2f59a1fd0f7c1bEvan Millar */ 139088b2918423ef79b92c0b0433f2f59a1fd0f7c1bEvan Millar public static final String THUMBNAIL = "thumbnail"; 140088b2918423ef79b92c0b0433f2f59a1fd0f7c1bEvan Millar } 141088b2918423ef79b92c0b0433f2f59a1fd0f7c1bEvan Millar 142088b2918423ef79b92c0b0433f2f59a1fd0f7c1bEvan Millar public static final class Activities implements BaseColumns, ActivitiesColumns { 143088b2918423ef79b92c0b0433f2f59a1fd0f7c1bEvan Millar /** 144088b2918423ef79b92c0b0433f2f59a1fd0f7c1bEvan Millar * This utility class cannot be instantiated 145088b2918423ef79b92c0b0433f2f59a1fd0f7c1bEvan Millar */ 146088b2918423ef79b92c0b0433f2f59a1fd0f7c1bEvan Millar private Activities() { 147088b2918423ef79b92c0b0433f2f59a1fd0f7c1bEvan Millar } 148088b2918423ef79b92c0b0433f2f59a1fd0f7c1bEvan Millar 149088b2918423ef79b92c0b0433f2f59a1fd0f7c1bEvan Millar /** 150088b2918423ef79b92c0b0433f2f59a1fd0f7c1bEvan Millar * The content:// style URI for this table 151088b2918423ef79b92c0b0433f2f59a1fd0f7c1bEvan Millar */ 152088b2918423ef79b92c0b0433f2f59a1fd0f7c1bEvan Millar public static final Uri CONTENT_URI = Uri.withAppendedPath(AUTHORITY_URI, "activities"); 153088b2918423ef79b92c0b0433f2f59a1fd0f7c1bEvan Millar 154088b2918423ef79b92c0b0433f2f59a1fd0f7c1bEvan Millar /** 155569277732b4180c07c9f917ff8c3fc3111b10338Dmitri Plotnikov * The content:// style URI for this table filtered to the set of social activities 156569277732b4180c07c9f917ff8c3fc3111b10338Dmitri Plotnikov * authored by a specific {@link android.provider.ContactsContract.Contacts#_ID}. 157088b2918423ef79b92c0b0433f2f59a1fd0f7c1bEvan Millar */ 158088b2918423ef79b92c0b0433f2f59a1fd0f7c1bEvan Millar public static final Uri CONTENT_AUTHORED_BY_URI = 159088b2918423ef79b92c0b0433f2f59a1fd0f7c1bEvan Millar Uri.withAppendedPath(CONTENT_URI, "authored_by"); 160088b2918423ef79b92c0b0433f2f59a1fd0f7c1bEvan Millar 161088b2918423ef79b92c0b0433f2f59a1fd0f7c1bEvan Millar /** 162088b2918423ef79b92c0b0433f2f59a1fd0f7c1bEvan Millar * The MIME type of {@link #CONTENT_URI} providing a directory of social 163088b2918423ef79b92c0b0433f2f59a1fd0f7c1bEvan Millar * activities. 164088b2918423ef79b92c0b0433f2f59a1fd0f7c1bEvan Millar */ 165088b2918423ef79b92c0b0433f2f59a1fd0f7c1bEvan Millar public static final String CONTENT_TYPE = "vnd.android.cursor.dir/activity"; 166088b2918423ef79b92c0b0433f2f59a1fd0f7c1bEvan Millar 167088b2918423ef79b92c0b0433f2f59a1fd0f7c1bEvan Millar /** 168088b2918423ef79b92c0b0433f2f59a1fd0f7c1bEvan Millar * The MIME type of a {@link #CONTENT_URI} subdirectory of a single 169088b2918423ef79b92c0b0433f2f59a1fd0f7c1bEvan Millar * social activity. 170088b2918423ef79b92c0b0433f2f59a1fd0f7c1bEvan Millar */ 171088b2918423ef79b92c0b0433f2f59a1fd0f7c1bEvan Millar public static final String CONTENT_ITEM_TYPE = "vnd.android.cursor.item/activity"; 172088b2918423ef79b92c0b0433f2f59a1fd0f7c1bEvan Millar } 173088b2918423ef79b92c0b0433f2f59a1fd0f7c1bEvan Millar 174088b2918423ef79b92c0b0433f2f59a1fd0f7c1bEvan Millar} 175