1 /* 2 * Copyright (C) 2017 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 #ifndef CLEAR_KEY_ECM_GENERATOR_H_ 18 #define CLEAR_KEY_ECM_GENERATOR_H_ 19 20 #include <string> 21 22 #include "protos/license_protos.pb.h" 23 24 #include <media/stagefright/foundation/ABuffer.h> 25 #include <media/stagefright/MediaErrors.h> 26 27 using namespace std; 28 29 namespace android { 30 namespace clearkeycas { 31 enum { 32 CLEARKEY_STATUS_BASE = ERROR_DRM_VENDOR_MAX, 33 CLEARKEY_STATUS_INVALIDASSETID = CLEARKEY_STATUS_BASE - 1, 34 CLEARKEY_STATUS_INVALIDSYSTEMID = CLEARKEY_STATUS_BASE - 2, 35 CLEARKEY_STATUS_INVALID_PARAMETER = CLEARKEY_STATUS_BASE - 3, 36 }; 37 class Organization; 38 39 namespace ecm_generator { 40 41 // Layout of the ECM 42 // ECM 43 // 0 - 3 : Old ECM version (deprecated) 44 // 4 - 7 : Clear lead (milliseconds) 45 // 8 : ECM Version 46 // 9 - 11 : System ID 47 // 12 - 15 : Asset ID 48 // 16 - 31 : Content Key (clear) 49 // 50 // The clear asset ID (bytes 12-15) is compared to the encrypted asset ID 51 // (bytes 48-51) as a consistency check. 52 53 struct DefaultEcmFields { 54 uint32_t old_version; 55 uint32_t clear_lead; 56 uint32_t ecm_version; 57 uint32_t system_id; 58 }; 59 60 // Decodes a clear key ecm. 61 // The following fields are decoded from the clear fields portion of the ecm: 62 // asset->id 63 // default_fields->old_version 64 // default_fields->clear_lead 65 // default_fields->system_id 66 // default_fields->ecm_version 67 // 68 // The following fields are decoded from the content key portion of the ecm: 69 // content_key 70 // 71 // |asset|, |content_key|, |default_fields| are owned by caller and must not 72 // be NULL. 73 // Returns failure via ecm_generator::DecodeECMClearFields. 74 // 75 // Example usage: 76 // Asset asset; 77 // string content_key; 78 // DefaultEcmFields default_fields; 79 // // Get a clear key |ecm|. 80 // status_t status = ecm_generator::DecodeECM(ecm, &asset, &content_key, &default_fields); 81 status_t DecodeECM(const sp<ABuffer>& ecm, Asset* asset, 82 sp<ABuffer> *content_key, DefaultEcmFields* default_fields); 83 84 // Decodes the following fields from the clear fields portion of the ecm: 85 // asset->id 86 // default_fields->old_version 87 // default_fields->clear_lead 88 // default_fields->system_id 89 // default_fields->ecm_version 90 // 91 // offset, asset and default_fields are owned by caller and must not be NULL. 92 // offset is updated to show the number of bytes consumed. 93 // Returns: 94 // - BAD_VALUE on short ECM, or 95 // - CLEARKEY_STATUS_INVALIDASSETID via ecm_generator::DecodeEcmClearFields if 96 // asset_id is 0, or 97 // - CLEARKEY_STATUS_INVALIDSYSTEMID via ecm_generator::DecodeEcmClearFields if 98 // system_id is 0. 99 // 100 // Example usage: 101 // Asset asset; 102 // DefaultEcmFields default_fields; 103 // // Get a clear key ecm. 104 // status_t status = ecm_generator::DecodeECMClearFields(ecm, &asset, &default_fields); 105 status_t DecodeECMClearFields(const sp<ABuffer>& ecm, Asset* asset, 106 DefaultEcmFields* default_fields); 107 108 } // namespace ecm_generator 109 } // namespace clearkeycas 110 } // namespace android 111 #endif // CLEAR_KEY_ECM_GENERATOR_H_ 112