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