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