| /* |
| * Copyright (C) 2006 The Android Open Source Project |
| * |
| * Licensed under the Apache License, Version 2.0 (the "License"); |
| * you may not use this file except in compliance with the License. |
| * You may obtain a copy of the License at |
| * |
| * http://www.apache.org/licenses/LICENSE-2.0 |
| * |
| * Unless required by applicable law or agreed to in writing, software |
| * distributed under the License is distributed on an "AS IS" BASIS, |
| * WITHOUT WARRANTIES OR CONDITIONS OF ANY KIND, either express or implied. |
| * See the License for the specific language governing permissions and |
| * limitations under the License. |
| */ |
| |
| package android.content; |
| |
| import android.annotation.NonNull; |
| import android.annotation.Nullable; |
| import android.app.AppGlobals; |
| import android.compat.annotation.UnsupportedAppUsage; |
| import android.content.res.AssetFileDescriptor; |
| import android.database.Cursor; |
| import android.net.Uri; |
| import android.os.Binder; |
| import android.os.Build; |
| import android.os.Bundle; |
| import android.os.IBinder; |
| import android.os.ICancellationSignal; |
| import android.os.IInterface; |
| import android.os.ParcelFileDescriptor; |
| import android.os.RemoteCallback; |
| import android.os.RemoteException; |
| |
| import java.io.FileNotFoundException; |
| import java.util.ArrayList; |
| |
| /** |
| * The ipc interface to talk to a content provider. |
| * @hide |
| */ |
| public interface IContentProvider extends IInterface { |
| Cursor query(@NonNull AttributionSource attributionSource, Uri url, |
| @Nullable String[] projection, |
| @Nullable Bundle queryArgs, @Nullable ICancellationSignal cancellationSignal) |
| throws RemoteException; |
| /** |
| * getType function with AttributionSource |
| */ |
| String getType(@NonNull AttributionSource attributionSource, |
| Uri url) throws RemoteException; |
| /** |
| * one way getType function with AttributionSource |
| */ |
| void getTypeAsync(@NonNull AttributionSource attributionSource, |
| Uri url, RemoteCallback callback) throws RemoteException; |
| /** |
| * @deprecated -- use getType with AttributionSource |
| */ |
| @Deprecated |
| default String getType(Uri url) throws RemoteException { |
| return getType(new AttributionSource(Binder.getCallingUid(), |
| AppGlobals.getPackageManager().getPackagesForUid(Binder.getCallingUid())[0], |
| null), url); |
| } |
| |
| /** |
| * A oneway version of getType. The functionality is exactly the same, except that the |
| * call returns immediately, and the resulting type is returned when available via |
| * a binder callback. |
| * |
| * @deprecated -- use getTypeAsync with AttributionSource |
| */ |
| @Deprecated |
| default void getTypeAsync(Uri uri, RemoteCallback callback) throws RemoteException { |
| getTypeAsync(new AttributionSource(Binder.getCallingUid(), |
| AppGlobals.getPackageManager().getPackagesForUid(Binder.getCallingUid())[0], |
| null), uri, callback); |
| } |
| |
| /** oneway version of getTypeAnonymous*/ |
| void getTypeAnonymousAsync(Uri uri, RemoteCallback callback) throws RemoteException; |
| |
| @Deprecated |
| @UnsupportedAppUsage(maxTargetSdk = Build.VERSION_CODES.Q, publicAlternatives = "Use {@link " |
| + "ContentProviderClient#insert(android.net.Uri, android.content.ContentValues)} " |
| + "instead") |
| default Uri insert(String callingPkg, Uri url, ContentValues initialValues) |
| throws RemoteException { |
| return insert(new AttributionSource(Binder.getCallingUid(), callingPkg, null), |
| url, initialValues, null); |
| } |
| Uri insert(@NonNull AttributionSource attributionSource, Uri url, |
| ContentValues initialValues, Bundle extras) throws RemoteException; |
| @Deprecated |
| @UnsupportedAppUsage(maxTargetSdk = Build.VERSION_CODES.Q, publicAlternatives = "Use {@link " |
| + "ContentProviderClient#bulkInsert(android.net.Uri, android.content.ContentValues[])" |
| + "} instead") |
| default int bulkInsert(String callingPkg, Uri url, ContentValues[] initialValues) |
| throws RemoteException { |
| return bulkInsert(new AttributionSource(Binder.getCallingUid(), callingPkg, null), |
| url, initialValues); |
| } |
| int bulkInsert(@NonNull AttributionSource attributionSource, Uri url, |
| ContentValues[] initialValues) throws RemoteException; |
| @Deprecated |
| @UnsupportedAppUsage(maxTargetSdk = Build.VERSION_CODES.Q, publicAlternatives = "Use {@link " |
| + "ContentProviderClient#delete(android.net.Uri, java.lang.String, java.lang" |
| + ".String[])} instead") |
| default int delete(String callingPkg, Uri url, String selection, String[] selectionArgs) |
| throws RemoteException { |
| return delete(new AttributionSource(Binder.getCallingUid(), callingPkg, null), |
| url, ContentResolver.createSqlQueryBundle(selection, selectionArgs)); |
| } |
| int delete(@NonNull AttributionSource attributionSource, Uri url, Bundle extras) |
| throws RemoteException; |
| @Deprecated |
| @UnsupportedAppUsage(maxTargetSdk = Build.VERSION_CODES.Q, publicAlternatives = "Use {@link " |
| + "ContentProviderClient#update(android.net.Uri, android.content.ContentValues, java" |
| + ".lang.String, java.lang.String[])} instead") |
| default int update(String callingPkg, Uri url, ContentValues values, String selection, |
| String[] selectionArgs) throws RemoteException { |
| return update(new AttributionSource(Binder.getCallingUid(), callingPkg, null), |
| url, values, ContentResolver.createSqlQueryBundle(selection, selectionArgs)); |
| } |
| int update(@NonNull AttributionSource attributionSource, Uri url, ContentValues values, |
| Bundle extras) throws RemoteException; |
| |
| ParcelFileDescriptor openFile(@NonNull AttributionSource attributionSource, |
| Uri url, String mode, ICancellationSignal signal) |
| throws RemoteException, FileNotFoundException; |
| |
| AssetFileDescriptor openAssetFile(@NonNull AttributionSource attributionSource, |
| Uri url, String mode, ICancellationSignal signal) |
| throws RemoteException, FileNotFoundException; |
| |
| ContentProviderResult[] applyBatch(@NonNull AttributionSource attributionSource, |
| String authority, ArrayList<ContentProviderOperation> operations) |
| throws RemoteException, OperationApplicationException; |
| |
| @Deprecated |
| @UnsupportedAppUsage(maxTargetSdk = Build.VERSION_CODES.Q, publicAlternatives = "Use {@link " |
| + "ContentProviderClient#call(java.lang.String, java.lang.String, android.os.Bundle)} " |
| + "instead") |
| public default Bundle call(String callingPkg, String method, |
| @Nullable String arg, @Nullable Bundle extras) throws RemoteException { |
| return call(new AttributionSource(Binder.getCallingUid(), callingPkg, null), |
| "unknown", method, arg, extras); |
| } |
| |
| Bundle call(@NonNull AttributionSource attributionSource, String authority, |
| String method, @Nullable String arg, @Nullable Bundle extras) throws RemoteException; |
| |
| int checkUriPermission(@NonNull AttributionSource attributionSource, Uri uri, |
| int uid, int modeFlags) throws RemoteException; |
| |
| ICancellationSignal createCancellationSignal() throws RemoteException; |
| |
| Uri canonicalize(@NonNull AttributionSource attributionSource, Uri uri) |
| throws RemoteException; |
| |
| /** |
| * A oneway version of canonicalize. The functionality is exactly the same, except that the |
| * call returns immediately, and the resulting type is returned when available via |
| * a binder callback. |
| */ |
| void canonicalizeAsync(@NonNull AttributionSource attributionSource, Uri uri, |
| RemoteCallback callback) throws RemoteException; |
| |
| Uri uncanonicalize(@NonNull AttributionSource attributionSource, Uri uri) |
| throws RemoteException; |
| |
| /** |
| * A oneway version of uncanonicalize. The functionality is exactly the same, except that the |
| * call returns immediately, and the resulting type is returned when available via |
| * a binder callback. |
| */ |
| void uncanonicalizeAsync(@NonNull AttributionSource attributionSource, Uri uri, |
| RemoteCallback callback) throws RemoteException; |
| |
| public boolean refresh(@NonNull AttributionSource attributionSource, Uri url, |
| @Nullable Bundle extras, ICancellationSignal cancellationSignal) throws RemoteException; |
| |
| /** |
| * @deprecated -- use getStreamTypes with AttributionSource |
| */ |
| @Deprecated |
| default String[] getStreamTypes(Uri url, String mimeTypeFilter) throws RemoteException { |
| return getStreamTypes(new AttributionSource(Binder.getCallingUid(), |
| AppGlobals.getPackageManager().getPackagesForUid(Binder.getCallingUid())[0], |
| null), url, mimeTypeFilter); |
| } |
| |
| // Data interchange. |
| String[] getStreamTypes(AttributionSource attributionSource, |
| Uri url, String mimeTypeFilter) throws RemoteException; |
| |
| public AssetFileDescriptor openTypedAssetFile(@NonNull AttributionSource attributionSource, |
| Uri url, String mimeType, Bundle opts, ICancellationSignal signal) |
| throws RemoteException, FileNotFoundException; |
| |
| /* IPC constants */ |
| @UnsupportedAppUsage(maxTargetSdk = Build.VERSION_CODES.P, trackingBug = 115609023) |
| static final String descriptor = "android.content.IContentProvider"; |
| |
| @UnsupportedAppUsage(maxTargetSdk = Build.VERSION_CODES.R, trackingBug = 170729553) |
| static final int QUERY_TRANSACTION = IBinder.FIRST_CALL_TRANSACTION; |
| static final int GET_TYPE_TRANSACTION = IBinder.FIRST_CALL_TRANSACTION + 1; |
| static final int INSERT_TRANSACTION = IBinder.FIRST_CALL_TRANSACTION + 2; |
| static final int DELETE_TRANSACTION = IBinder.FIRST_CALL_TRANSACTION + 3; |
| static final int UPDATE_TRANSACTION = IBinder.FIRST_CALL_TRANSACTION + 9; |
| static final int BULK_INSERT_TRANSACTION = IBinder.FIRST_CALL_TRANSACTION + 12; |
| static final int OPEN_FILE_TRANSACTION = IBinder.FIRST_CALL_TRANSACTION + 13; |
| static final int OPEN_ASSET_FILE_TRANSACTION = IBinder.FIRST_CALL_TRANSACTION + 14; |
| static final int APPLY_BATCH_TRANSACTION = IBinder.FIRST_CALL_TRANSACTION + 19; |
| static final int CALL_TRANSACTION = IBinder.FIRST_CALL_TRANSACTION + 20; |
| static final int GET_STREAM_TYPES_TRANSACTION = IBinder.FIRST_CALL_TRANSACTION + 21; |
| static final int OPEN_TYPED_ASSET_FILE_TRANSACTION = IBinder.FIRST_CALL_TRANSACTION + 22; |
| static final int CREATE_CANCELATION_SIGNAL_TRANSACTION = IBinder.FIRST_CALL_TRANSACTION + 23; |
| static final int CANONICALIZE_TRANSACTION = IBinder.FIRST_CALL_TRANSACTION + 24; |
| static final int UNCANONICALIZE_TRANSACTION = IBinder.FIRST_CALL_TRANSACTION + 25; |
| static final int REFRESH_TRANSACTION = IBinder.FIRST_CALL_TRANSACTION + 26; |
| static final int CHECK_URI_PERMISSION_TRANSACTION = IBinder.FIRST_CALL_TRANSACTION + 27; |
| int GET_TYPE_ASYNC_TRANSACTION = IBinder.FIRST_CALL_TRANSACTION + 28; |
| int CANONICALIZE_ASYNC_TRANSACTION = IBinder.FIRST_CALL_TRANSACTION + 29; |
| int UNCANONICALIZE_ASYNC_TRANSACTION = IBinder.FIRST_CALL_TRANSACTION + 30; |
| int GET_TYPE_ANONYMOUS_ASYNC_TRANSACTION = IBinder.FIRST_CALL_TRANSACTION + 31; |
| |
| |
| } |