1 /* 2 * Copyright (C) 2012 The Android Open Source Project 3 * 4 * Licensed under the Apache License, Version 2.0 (the "License"); 5 * you may not use this file except in compliance with the License. 6 * You may obtain a copy of the License at 7 * 8 * http://www.apache.org/licenses/LICENSE-2.0 9 * 10 * Unless required by applicable law or agreed to in writing, software 11 * distributed under the License is distributed on an "AS IS" BASIS, 12 * WITHOUT WARRANTIES OR CONDITIONS OF ANY KIND, either express or implied. 13 * See the License for the specific language governing permissions and 14 * limitations under the License. 15 */ 16 17 package android.media; 18 19 import android.media.MediaCryptoException; 20 import java.util.UUID; 21 22 /** 23 * MediaCrypto class can be used in conjunction with {@link android.media.MediaCodec} 24 * to decode encrypted media data. 25 * 26 * Crypto schemes are assigned 16 byte UUIDs, 27 * the method {@link #isCryptoSchemeSupported} can be used to query if a given 28 * scheme is supported on the device. 29 * 30 */ 31 public final class MediaCrypto { 32 /** 33 * Query if the given scheme identified by its UUID is supported on 34 * this device. 35 * @param uuid The UUID of the crypto scheme. 36 */ isCryptoSchemeSupported(UUID uuid)37 public static final boolean isCryptoSchemeSupported(UUID uuid) { 38 return isCryptoSchemeSupportedNative(getByteArrayFromUUID(uuid)); 39 } 40 getByteArrayFromUUID(UUID uuid)41 private static final byte[] getByteArrayFromUUID(UUID uuid) { 42 long msb = uuid.getMostSignificantBits(); 43 long lsb = uuid.getLeastSignificantBits(); 44 45 byte[] uuidBytes = new byte[16]; 46 for (int i = 0; i < 8; ++i) { 47 uuidBytes[i] = (byte)(msb >>> (8 * (7 - i))); 48 uuidBytes[8 + i] = (byte)(lsb >>> (8 * (7 - i))); 49 } 50 51 return uuidBytes; 52 } 53 isCryptoSchemeSupportedNative(byte[] uuid)54 private static final native boolean isCryptoSchemeSupportedNative(byte[] uuid); 55 56 /** 57 * Instantiate a MediaCrypto object using opaque, crypto scheme specific 58 * data. 59 * @param uuid The UUID of the crypto scheme. 60 * @param initData Opaque initialization data specific to the crypto scheme. 61 */ MediaCrypto(UUID uuid, byte[] initData)62 public MediaCrypto(UUID uuid, byte[] initData) throws MediaCryptoException { 63 native_setup(getByteArrayFromUUID(uuid), initData); 64 } 65 66 /** 67 * Query if the crypto scheme requires the use of a secure decoder 68 * to decode data of the given mime type. 69 * @param mime The mime type of the media data 70 */ requiresSecureDecoderComponent(String mime)71 public final native boolean requiresSecureDecoderComponent(String mime); 72 73 @Override finalize()74 protected void finalize() { 75 native_finalize(); 76 } 77 release()78 public native final void release(); native_init()79 private static native final void native_init(); 80 native_setup(byte[] uuid, byte[] initData)81 private native final void native_setup(byte[] uuid, byte[] initData) 82 throws MediaCryptoException; 83 native_finalize()84 private native final void native_finalize(); 85 86 static { 87 System.loadLibrary("media_jni"); native_init()88 native_init(); 89 } 90 91 private long mNativeContext; 92 } 93