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