summaryrefslogtreecommitdiffstats
path: root/drm
diff options
context:
space:
mode:
Diffstat (limited to 'drm')
-rw-r--r--drm/common/Android.mk43
-rw-r--r--drm/common/DrmConstraints.cpp113
-rw-r--r--drm/common/DrmConvertedStatus.cpp28
-rw-r--r--drm/common/DrmEngineBase.cpp156
-rw-r--r--drm/common/DrmInfo.cpp111
-rw-r--r--drm/common/DrmInfoEvent.cpp40
-rw-r--r--drm/common/DrmInfoRequest.cpp106
-rw-r--r--drm/common/DrmInfoStatus.cpp29
-rw-r--r--drm/common/DrmMetadata.cpp117
-rw-r--r--drm/common/DrmRights.cpp63
-rw-r--r--drm/common/DrmSupportInfo.cpp159
-rw-r--r--drm/common/IDrmManagerService.cpp1432
-rw-r--r--drm/common/IDrmServiceListener.cpp61
-rw-r--r--drm/common/ReadWriteUtils.cpp109
-rw-r--r--drm/drmserver/Android.mk41
-rw-r--r--drm/drmserver/DrmManager.cpp603
-rw-r--r--drm/drmserver/DrmManagerService.cpp287
-rw-r--r--drm/drmserver/main_drmserver.cpp40
-rwxr-xr-xdrm/java/android/drm/DrmConvertedStatus.java61
-rwxr-xr-xdrm/java/android/drm/DrmErrorEvent.java30
-rwxr-xr-xdrm/java/android/drm/DrmEvent.java4
-rwxr-xr-xdrm/java/android/drm/DrmInfo.java14
-rwxr-xr-xdrm/java/android/drm/DrmInfoEvent.java40
-rwxr-xr-xdrm/java/android/drm/DrmInfoRequest.java5
-rwxr-xr-xdrm/java/android/drm/DrmInfoStatus.java70
-rwxr-xr-xdrm/java/android/drm/DrmManagerClient.java1
-rwxr-xr-xdrm/java/android/drm/DrmRights.java62
-rwxr-xr-xdrm/java/android/drm/DrmStore.java62
-rwxr-xr-xdrm/java/android/drm/DrmSupportInfo.java61
-rwxr-xr-xdrm/java/android/drm/DrmUtils.java30
-rw-r--r--drm/jni/Android.mk6
-rw-r--r--drm/jni/android_drm_DrmManagerClient.cpp102
-rw-r--r--drm/libdrmframework/Android.mk44
-rw-r--r--drm/libdrmframework/DrmManagerClient.cpp154
-rw-r--r--drm/libdrmframework/DrmManagerClientImpl.cpp347
-rw-r--r--drm/libdrmframework/include/DrmManager.h162
-rw-r--r--drm/libdrmframework/include/DrmManagerClientImpl.h428
-rw-r--r--drm/libdrmframework/include/DrmManagerService.h127
-rw-r--r--drm/libdrmframework/include/IDrmManagerService.h257
-rw-r--r--drm/libdrmframework/include/IDrmServiceListener.h71
-rw-r--r--drm/libdrmframework/include/PlugInManager.h269
-rw-r--r--drm/libdrmframework/include/ReadWriteUtils.h79
-rw-r--r--drm/libdrmframework/plugins/Android.mk16
-rw-r--r--drm/libdrmframework/plugins/common/Android.mk16
-rw-r--r--drm/libdrmframework/plugins/common/include/DrmEngineBase.h465
-rw-r--r--drm/libdrmframework/plugins/common/include/IDrmEngine.h414
-rw-r--r--drm/libdrmframework/plugins/common/util/Android.mk52
-rw-r--r--drm/libdrmframework/plugins/common/util/include/MimeTypeUtil.h46
-rw-r--r--drm/libdrmframework/plugins/common/util/include/SessionMap.h189
-rw-r--r--drm/libdrmframework/plugins/common/util/src/MimeTypeUtil.cpp166
-rw-r--r--drm/libdrmframework/plugins/forward-lock/Android.mk16
-rw-r--r--drm/libdrmframework/plugins/forward-lock/FwdLockEngine/Android.mk70
-rw-r--r--drm/libdrmframework/plugins/forward-lock/FwdLockEngine/include/FwdLockEngine.h559
-rw-r--r--drm/libdrmframework/plugins/forward-lock/FwdLockEngine/include/FwdLockEngineConst.h37
-rw-r--r--drm/libdrmframework/plugins/forward-lock/FwdLockEngine/src/FwdLockEngine.cpp661
-rw-r--r--drm/libdrmframework/plugins/forward-lock/internal-format/Android.mk16
-rw-r--r--drm/libdrmframework/plugins/forward-lock/internal-format/common/Android.mk32
-rw-r--r--drm/libdrmframework/plugins/forward-lock/internal-format/common/FwdLockGlue.c191
-rw-r--r--drm/libdrmframework/plugins/forward-lock/internal-format/common/FwdLockGlue.h85
-rw-r--r--drm/libdrmframework/plugins/forward-lock/internal-format/converter/Android.mk37
-rw-r--r--drm/libdrmframework/plugins/forward-lock/internal-format/converter/FwdLockConv.c1347
-rw-r--r--drm/libdrmframework/plugins/forward-lock/internal-format/converter/FwdLockConv.h282
-rw-r--r--drm/libdrmframework/plugins/forward-lock/internal-format/decoder/Android.mk37
-rw-r--r--drm/libdrmframework/plugins/forward-lock/internal-format/decoder/FwdLockFile.c447
-rw-r--r--drm/libdrmframework/plugins/forward-lock/internal-format/decoder/FwdLockFile.h135
-rwxr-xr-xdrm/libdrmframework/plugins/forward-lock/internal-format/doc/FwdLock.html1039
-rw-r--r--drm/libdrmframework/plugins/forward-lock/internal-format/doc/images/image001.gifbin5571 -> 0 bytes
-rw-r--r--drm/libdrmframework/plugins/forward-lock/internal-format/doc/images/image002.gifbin11149 -> 0 bytes
-rw-r--r--drm/libdrmframework/plugins/forward-lock/internal-format/doc/images/image003.gifbin13873 -> 0 bytes
-rw-r--r--drm/libdrmframework/plugins/forward-lock/internal-format/doc/images/image004.gifbin10779 -> 0 bytes
-rw-r--r--drm/libdrmframework/plugins/forward-lock/internal-format/doc/images/image005.gifbin9351 -> 0 bytes
-rw-r--r--drm/libdrmframework/plugins/forward-lock/internal-format/doc/images/image006.gifbin9048 -> 0 bytes
-rw-r--r--drm/libdrmframework/plugins/passthru/Android.mk42
-rw-r--r--drm/libdrmframework/plugins/passthru/include/DrmPassthruPlugIn.h102
-rw-r--r--drm/libdrmframework/plugins/passthru/src/DrmPassthruPlugIn.cpp299
75 files changed, 383 insertions, 12439 deletions
diff --git a/drm/common/Android.mk b/drm/common/Android.mk
deleted file mode 100644
index f1136c9..0000000
--- a/drm/common/Android.mk
+++ /dev/null
@@ -1,43 +0,0 @@
-#
-# Copyright (C) 2010 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.
-#
-LOCAL_PATH:= $(call my-dir)
-include $(CLEAR_VARS)
-
-LOCAL_SRC_FILES:= \
- DrmConstraints.cpp \
- DrmMetadata.cpp \
- DrmConvertedStatus.cpp \
- DrmEngineBase.cpp \
- DrmInfo.cpp \
- DrmInfoRequest.cpp \
- DrmInfoStatus.cpp \
- DrmRights.cpp \
- DrmSupportInfo.cpp \
- IDrmManagerService.cpp \
- IDrmServiceListener.cpp \
- DrmInfoEvent.cpp \
- ReadWriteUtils.cpp
-
-LOCAL_C_INCLUDES := \
- $(TOP)/frameworks/base/include \
- $(TOP)/frameworks/base/drm/libdrmframework/include \
- $(TOP)/frameworks/base/drm/libdrmframework/plugins/common/include
-
-LOCAL_MODULE:= libdrmframeworkcommon
-
-LOCAL_MODULE_TAGS := optional
-
-include $(BUILD_STATIC_LIBRARY)
diff --git a/drm/common/DrmConstraints.cpp b/drm/common/DrmConstraints.cpp
deleted file mode 100644
index 4a4d798..0000000
--- a/drm/common/DrmConstraints.cpp
+++ /dev/null
@@ -1,113 +0,0 @@
-/*
- * Copyright (C) 2010 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.
- */
-
-#include <drm/DrmConstraints.h>
-
-using namespace android;
-
-const String8 DrmConstraints::MAX_REPEAT_COUNT("max_repeat_count");
-const String8 DrmConstraints::REMAINING_REPEAT_COUNT("remaining_repeat_count");
-const String8 DrmConstraints::LICENSE_START_TIME("license_start_time");
-const String8 DrmConstraints::LICENSE_EXPIRY_TIME("license_expiry_time");
-const String8 DrmConstraints::LICENSE_AVAILABLE_TIME("license_available_time");
-const String8 DrmConstraints::EXTENDED_METADATA("extended_metadata");
-
-int DrmConstraints::getCount(void) const {
- return mConstraintMap.size();
-}
-
-status_t DrmConstraints::put(const String8* key, const char* value) {
- int length = strlen(value);
- char* charValue = new char[length + 1];
- if (NULL != charValue) {
- strncpy(charValue, value, length);
- charValue[length] = '\0';
- mConstraintMap.add(*key, charValue);
- }
- return DRM_NO_ERROR;
-}
-
-String8 DrmConstraints::get(const String8& key) const {
- if (NULL != getValue(&key)) {
- return String8(getValue(&key));
- }
- return String8("");
-}
-
-const char* DrmConstraints::getValue(const String8* key) const {
- if (NAME_NOT_FOUND != mConstraintMap.indexOfKey(*key)) {
- return mConstraintMap.valueFor(*key);
- }
- return NULL;
-}
-
-const char* DrmConstraints::getAsByteArray(const String8* key) const {
- return getValue(key);
-}
-
-bool DrmConstraints::KeyIterator::hasNext() {
- return mIndex < mDrmConstraints->mConstraintMap.size();
-}
-
-const String8& DrmConstraints::KeyIterator::next() {
- const String8& key = mDrmConstraints->mConstraintMap.keyAt(mIndex);
- mIndex++;
- return key;
-}
-
-DrmConstraints::KeyIterator DrmConstraints::keyIterator() {
- return KeyIterator(this);
-}
-
-DrmConstraints::KeyIterator::KeyIterator(const DrmConstraints::KeyIterator& keyIterator)
- : mDrmConstraints(keyIterator.mDrmConstraints),
- mIndex(keyIterator.mIndex) {
-}
-
-DrmConstraints::KeyIterator& DrmConstraints::KeyIterator::operator=(
- const DrmConstraints::KeyIterator& keyIterator) {
- mDrmConstraints = keyIterator.mDrmConstraints;
- mIndex = keyIterator.mIndex;
- return *this;
-}
-
-
-DrmConstraints::Iterator DrmConstraints::iterator() {
- return Iterator(this);
-}
-
-DrmConstraints::Iterator::Iterator(const DrmConstraints::Iterator& iterator) :
- mDrmConstraints(iterator.mDrmConstraints),
- mIndex(iterator.mIndex) {
-}
-
-DrmConstraints::Iterator& DrmConstraints::Iterator::operator=(
- const DrmConstraints::Iterator& iterator) {
- mDrmConstraints = iterator.mDrmConstraints;
- mIndex = iterator.mIndex;
- return *this;
-}
-
-bool DrmConstraints::Iterator::hasNext() {
- return mIndex < mDrmConstraints->mConstraintMap.size();
-}
-
-String8 DrmConstraints::Iterator::next() {
- String8 value = String8(mDrmConstraints->mConstraintMap.editValueAt(mIndex));
- mIndex++;
- return value;
-}
-
diff --git a/drm/common/DrmConvertedStatus.cpp b/drm/common/DrmConvertedStatus.cpp
deleted file mode 100644
index 5d035f5..0000000
--- a/drm/common/DrmConvertedStatus.cpp
+++ /dev/null
@@ -1,28 +0,0 @@
-/*
- * Copyright (C) 2010 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.
- */
-
-#include <drm/DrmConvertedStatus.h>
-
-using namespace android;
-
-DrmConvertedStatus::DrmConvertedStatus(
- int _statusCode, const DrmBuffer* _convertedData, int _offset) :
- statusCode(_statusCode),
- convertedData(_convertedData),
- offset(_offset) {
-
-}
-
diff --git a/drm/common/DrmEngineBase.cpp b/drm/common/DrmEngineBase.cpp
deleted file mode 100644
index 9b16c36..0000000
--- a/drm/common/DrmEngineBase.cpp
+++ /dev/null
@@ -1,156 +0,0 @@
-/*
- * Copyright (C) 2010 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.
- */
-
-#include "DrmEngineBase.h"
-
-using namespace android;
-
-DrmEngineBase::DrmEngineBase() {
-
-}
-
-DrmEngineBase::~DrmEngineBase() {
-
-}
-
-DrmConstraints* DrmEngineBase::getConstraints(
- int uniqueId, const String8* path, int action) {
- return onGetConstraints(uniqueId, path, action);
-}
-
-DrmMetadata* DrmEngineBase::getMetadata(int uniqueId, const String8* path) {
- return onGetMetadata(uniqueId, path);
-}
-
-status_t DrmEngineBase::initialize(int uniqueId) {
- return onInitialize(uniqueId);
-}
-
-status_t DrmEngineBase::setOnInfoListener(
- int uniqueId, const IDrmEngine::OnInfoListener* infoListener) {
- return onSetOnInfoListener(uniqueId, infoListener);
-}
-
-status_t DrmEngineBase::terminate(int uniqueId) {
- return onTerminate(uniqueId);
-}
-
-bool DrmEngineBase::canHandle(int uniqueId, const String8& path) {
- return onCanHandle(uniqueId, path);
-}
-
-DrmInfoStatus* DrmEngineBase::processDrmInfo(int uniqueId, const DrmInfo* drmInfo) {
- return onProcessDrmInfo(uniqueId, drmInfo);
-}
-
-status_t DrmEngineBase::saveRights(
- int uniqueId, const DrmRights& drmRights,
- const String8& rightsPath, const String8& contentPath) {
- return onSaveRights(uniqueId, drmRights, rightsPath, contentPath);
-}
-
-DrmInfo* DrmEngineBase::acquireDrmInfo(int uniqueId, const DrmInfoRequest* drmInfoRequest) {
- return onAcquireDrmInfo(uniqueId, drmInfoRequest);
-}
-
-String8 DrmEngineBase::getOriginalMimeType(int uniqueId, const String8& path) {
- return onGetOriginalMimeType(uniqueId, path);
-}
-
-int DrmEngineBase::getDrmObjectType(int uniqueId, const String8& path, const String8& mimeType) {
- return onGetDrmObjectType(uniqueId, path, mimeType);
-}
-
-int DrmEngineBase::checkRightsStatus(int uniqueId, const String8& path, int action) {
- return onCheckRightsStatus(uniqueId, path, action);
-}
-
-status_t DrmEngineBase::consumeRights(
- int uniqueId, DecryptHandle* decryptHandle, int action, bool reserve) {
- return onConsumeRights(uniqueId, decryptHandle, action, reserve);
-}
-
-status_t DrmEngineBase::setPlaybackStatus(
- int uniqueId, DecryptHandle* decryptHandle, int playbackStatus, int64_t position) {
- return onSetPlaybackStatus(uniqueId, decryptHandle, playbackStatus, position);
-}
-
-bool DrmEngineBase::validateAction(
- int uniqueId, const String8& path,
- int action, const ActionDescription& description) {
- return onValidateAction(uniqueId, path, action, description);
-}
-
-status_t DrmEngineBase::removeRights(int uniqueId, const String8& path) {
- return onRemoveRights(uniqueId, path);
-}
-
-status_t DrmEngineBase::removeAllRights(int uniqueId) {
- return onRemoveAllRights(uniqueId);
-}
-
-status_t DrmEngineBase::openConvertSession(int uniqueId, int convertId) {
- return onOpenConvertSession(uniqueId, convertId);
-}
-
-DrmConvertedStatus* DrmEngineBase::convertData(
- int uniqueId, int convertId, const DrmBuffer* inputData) {
- return onConvertData(uniqueId, convertId, inputData);
-}
-
-DrmConvertedStatus* DrmEngineBase::closeConvertSession(int uniqueId, int convertId) {
- return onCloseConvertSession(uniqueId, convertId);
-}
-
-DrmSupportInfo* DrmEngineBase::getSupportInfo(int uniqueId) {
- return onGetSupportInfo(uniqueId);
-}
-
-status_t DrmEngineBase::openDecryptSession(
- int uniqueId, DecryptHandle* decryptHandle, int fd, off64_t offset, off64_t length) {
- return onOpenDecryptSession(uniqueId, decryptHandle, fd, offset, length);
-}
-
-status_t DrmEngineBase::openDecryptSession(
- int uniqueId, DecryptHandle* decryptHandle, const char* uri) {
- return onOpenDecryptSession(uniqueId, decryptHandle, uri);
-}
-
-status_t DrmEngineBase::closeDecryptSession(int uniqueId, DecryptHandle* decryptHandle) {
- return onCloseDecryptSession(uniqueId, decryptHandle);
-}
-
-status_t DrmEngineBase::initializeDecryptUnit(
- int uniqueId, DecryptHandle* decryptHandle, int decryptUnitId, const DrmBuffer* headerInfo) {
- return onInitializeDecryptUnit(uniqueId, decryptHandle, decryptUnitId, headerInfo);
-}
-
-status_t DrmEngineBase::decrypt(
- int uniqueId, DecryptHandle* decryptHandle, int decryptUnitId,
- const DrmBuffer* encBuffer, DrmBuffer** decBuffer, DrmBuffer* IV) {
- return onDecrypt(uniqueId, decryptHandle, decryptUnitId, encBuffer, decBuffer, IV);
-}
-
-status_t DrmEngineBase::finalizeDecryptUnit(
- int uniqueId, DecryptHandle* decryptHandle, int decryptUnitId) {
- return onFinalizeDecryptUnit(uniqueId, decryptHandle, decryptUnitId);
-}
-
-ssize_t DrmEngineBase::pread(
- int uniqueId, DecryptHandle* decryptHandle, void* buffer, ssize_t numBytes, off64_t offset) {
- return onPread(uniqueId, decryptHandle, buffer, numBytes, offset);
-}
-
diff --git a/drm/common/DrmInfo.cpp b/drm/common/DrmInfo.cpp
deleted file mode 100644
index ddcab33..0000000
--- a/drm/common/DrmInfo.cpp
+++ /dev/null
@@ -1,111 +0,0 @@
-/*
- * Copyright (C) 2010 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.
- */
-
-#include <drm/DrmInfo.h>
-
-using namespace android;
-
-DrmInfo::DrmInfo(int infoType, const DrmBuffer& drmBuffer, const String8& mimeType) :
- mInfoType(infoType),
- mData(drmBuffer),
- mMimeType(mimeType) {
-
-}
-
-int DrmInfo::getInfoType(void) const {
- return mInfoType;
-}
-
-String8 DrmInfo::getMimeType(void) const {
- return mMimeType;
-}
-
-const DrmBuffer& DrmInfo::getData(void) const {
- return mData;
-}
-
-int DrmInfo::getCount(void) const {
- return mAttributes.size();
-}
-
-status_t DrmInfo::put(const String8& key, const String8& value) {
- mAttributes.add(key, value);
- return DRM_NO_ERROR;
-}
-
-String8 DrmInfo::get(const String8& key) const {
- if (NAME_NOT_FOUND != mAttributes.indexOfKey(key)) {
- return mAttributes.valueFor(key);
- }
- return String8("");
-}
-
-int DrmInfo::indexOfKey(const String8& key) const {
- return mAttributes.indexOfKey(key);
-}
-
-DrmInfo::KeyIterator DrmInfo::keyIterator() const {
- return KeyIterator(this);
-}
-
-DrmInfo::Iterator DrmInfo::iterator() const {
- return Iterator(this);
-}
-
-// KeyIterator implementation
-DrmInfo::KeyIterator::KeyIterator(const DrmInfo::KeyIterator& keyIterator) :
- mDrmInfo(keyIterator.mDrmInfo), mIndex(keyIterator.mIndex) {
-
-}
-
-bool DrmInfo::KeyIterator::hasNext() {
- return (mIndex < mDrmInfo->mAttributes.size());
-}
-
-const String8& DrmInfo::KeyIterator::next() {
- const String8& key = mDrmInfo->mAttributes.keyAt(mIndex);
- mIndex++;
- return key;
-}
-
-DrmInfo::KeyIterator& DrmInfo::KeyIterator::operator=(const DrmInfo::KeyIterator& keyIterator) {
- mDrmInfo = keyIterator.mDrmInfo;
- mIndex = keyIterator.mIndex;
- return *this;
-}
-
-// Iterator implementation
-DrmInfo::Iterator::Iterator(const DrmInfo::Iterator& iterator)
- : mDrmInfo(iterator.mDrmInfo), mIndex(iterator.mIndex) {
-
-}
-
-DrmInfo::Iterator& DrmInfo::Iterator::operator=(const DrmInfo::Iterator& iterator) {
- mDrmInfo = iterator.mDrmInfo;
- mIndex = iterator.mIndex;
- return *this;
-}
-
-bool DrmInfo::Iterator::hasNext() {
- return mIndex < mDrmInfo->mAttributes.size();
-}
-
-String8& DrmInfo::Iterator::next() {
- String8& value = mDrmInfo->mAttributes.editValueAt(mIndex);
- mIndex++;
- return value;
-}
-
diff --git a/drm/common/DrmInfoEvent.cpp b/drm/common/DrmInfoEvent.cpp
deleted file mode 100644
index 27a5a2d..0000000
--- a/drm/common/DrmInfoEvent.cpp
+++ /dev/null
@@ -1,40 +0,0 @@
-/*
- * Copyright (C) 2010 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.
- */
-
-#include <utils/String8.h>
-#include <drm/DrmInfoEvent.h>
-
-using namespace android;
-
-DrmInfoEvent::DrmInfoEvent(int uniqueId, int infoType, const String8 message)
- : mUniqueId(uniqueId),
- mInfoType(infoType),
- mMessage(message) {
-
-}
-
-int DrmInfoEvent::getUniqueId() const {
- return mUniqueId;
-}
-
-int DrmInfoEvent::getType() const {
- return mInfoType;
-}
-
-const String8 DrmInfoEvent::getMessage() const {
- return mMessage;
-}
-
diff --git a/drm/common/DrmInfoRequest.cpp b/drm/common/DrmInfoRequest.cpp
deleted file mode 100644
index a646859..0000000
--- a/drm/common/DrmInfoRequest.cpp
+++ /dev/null
@@ -1,106 +0,0 @@
-/*
- * Copyright (C) 2010 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.
- */
-
-#include <drm/DrmInfoRequest.h>
-
-using namespace android;
-
-const String8 DrmInfoRequest::ACCOUNT_ID("account_id");
-const String8 DrmInfoRequest::SUBSCRIPTION_ID("subscription_id");
-
-DrmInfoRequest::DrmInfoRequest(int infoType, const String8& mimeType) :
- mInfoType(infoType), mMimeType(mimeType) {
-
-}
-
-String8 DrmInfoRequest::getMimeType(void) const {
- return mMimeType;
-}
-
-int DrmInfoRequest::getInfoType(void) const {
- return mInfoType;
-}
-
-int DrmInfoRequest::getCount(void) const {
- return mRequestInformationMap.size();
-}
-
-status_t DrmInfoRequest::put(const String8& key, const String8& value) {
- mRequestInformationMap.add(key, value);
- return DRM_NO_ERROR;
-}
-
-String8 DrmInfoRequest::get(const String8& key) const {
- if (NAME_NOT_FOUND != mRequestInformationMap.indexOfKey(key)) {
- return mRequestInformationMap.valueFor(key);
- }
- return String8("");
-}
-
-DrmInfoRequest::KeyIterator DrmInfoRequest::keyIterator() const {
- return KeyIterator(this);
-}
-
-DrmInfoRequest::Iterator DrmInfoRequest::iterator() const {
- return Iterator(this);
-}
-
-// KeyIterator implementation
-DrmInfoRequest::KeyIterator::KeyIterator(const DrmInfoRequest::KeyIterator& keyIterator)
- : mDrmInfoRequest(keyIterator.mDrmInfoRequest),
- mIndex(keyIterator.mIndex) {
-
-}
-
-bool DrmInfoRequest::KeyIterator::hasNext() {
- return (mIndex < mDrmInfoRequest->mRequestInformationMap.size());
-}
-
-const String8& DrmInfoRequest::KeyIterator::next() {
- const String8& key = mDrmInfoRequest->mRequestInformationMap.keyAt(mIndex);
- mIndex++;
- return key;
-}
-
-DrmInfoRequest::KeyIterator& DrmInfoRequest::KeyIterator::operator=(
- const DrmInfoRequest::KeyIterator& keyIterator) {
- mDrmInfoRequest = keyIterator.mDrmInfoRequest;
- mIndex = keyIterator.mIndex;
- return *this;
-}
-
-// Iterator implementation
-DrmInfoRequest::Iterator::Iterator(const DrmInfoRequest::Iterator& iterator) :
- mDrmInfoRequest(iterator.mDrmInfoRequest), mIndex(iterator.mIndex) {
-}
-
-DrmInfoRequest::Iterator& DrmInfoRequest::Iterator::operator=(
- const DrmInfoRequest::Iterator& iterator) {
- mDrmInfoRequest = iterator.mDrmInfoRequest;
- mIndex = iterator.mIndex;
- return *this;
-}
-
-bool DrmInfoRequest::Iterator::hasNext() {
- return mIndex < mDrmInfoRequest->mRequestInformationMap.size();
-}
-
-String8& DrmInfoRequest::Iterator::next() {
- String8& value = mDrmInfoRequest->mRequestInformationMap.editValueAt(mIndex);
- mIndex++;
- return value;
-}
-
diff --git a/drm/common/DrmInfoStatus.cpp b/drm/common/DrmInfoStatus.cpp
deleted file mode 100644
index 8ec7311..0000000
--- a/drm/common/DrmInfoStatus.cpp
+++ /dev/null
@@ -1,29 +0,0 @@
-/*
- * Copyright (C) 2010 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.
- */
-
-#include <drm/DrmInfoStatus.h>
-
-using namespace android;
-
-DrmInfoStatus::DrmInfoStatus(
- int _statusCode, int _infoType, const DrmBuffer* _drmBuffer, const String8& _mimeType) :
- statusCode(_statusCode),
- infoType(_infoType),
- drmBuffer(_drmBuffer),
- mimeType(_mimeType) {
-
-}
-
diff --git a/drm/common/DrmMetadata.cpp b/drm/common/DrmMetadata.cpp
deleted file mode 100644
index 2a4b8c8..0000000
--- a/drm/common/DrmMetadata.cpp
+++ /dev/null
@@ -1,117 +0,0 @@
-/*
- * Copyright (C) 2010 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.
- */
-
-#include <drm/DrmMetadata.h>
-
-using namespace android;
-
-int DrmMetadata::getCount(void) const {
- return mMetadataMap.size();
-}
-
-status_t DrmMetadata::put(const String8* key,
- const char* value) {
- if((value != NULL) && (key != NULL)) {
- int length = strlen(value);
- char* charValue = new char[length + 1];
-
- memcpy(charValue, value, length);
- charValue[length] = '\0';
- mMetadataMap.add(*key, charValue);
- }
- return NO_ERROR;
-}
-
-String8 DrmMetadata::get(const String8& key) const {
- if (NULL != getValue(&key)) {
- return String8(getValue(&key));
- }
- else {
- return String8("");
- }
-}
-
-const char* DrmMetadata::getValue(const String8* key) const {
- if(key != NULL) {
- if (NAME_NOT_FOUND != mMetadataMap.indexOfKey(*key)) {
- return mMetadataMap.valueFor(*key);
- }
- else {
- return NULL;
- }
- } else {
- return NULL;
- }
-}
-
-const char* DrmMetadata::getAsByteArray(const String8* key) const {
- return getValue(key);
-}
-
-bool DrmMetadata::KeyIterator::hasNext() {
- return mIndex < mDrmMetadata->mMetadataMap.size();
-}
-
-const String8& DrmMetadata::KeyIterator::next() {
- const String8& key = mDrmMetadata->mMetadataMap.keyAt(mIndex);
- mIndex++;
- return key;
-}
-
-DrmMetadata::KeyIterator DrmMetadata::keyIterator() {
- return KeyIterator(this);
-}
-
-DrmMetadata::KeyIterator::KeyIterator(const DrmMetadata::KeyIterator& keyIterator) :
- mDrmMetadata(keyIterator.mDrmMetadata),
- mIndex(keyIterator.mIndex) {
- ALOGV("DrmMetadata::KeyIterator::KeyIterator");
-}
-
-DrmMetadata::KeyIterator& DrmMetadata::KeyIterator::operator=(const DrmMetadata::KeyIterator& keyIterator) {
- ALOGV("DrmMetadata::KeyIterator::operator=");
- mDrmMetadata = keyIterator.mDrmMetadata;
- mIndex = keyIterator.mIndex;
- return *this;
-}
-
-
-DrmMetadata::Iterator DrmMetadata::iterator() {
- return Iterator(this);
-}
-
-DrmMetadata::Iterator::Iterator(const DrmMetadata::Iterator& iterator) :
- mDrmMetadata(iterator.mDrmMetadata),
- mIndex(iterator.mIndex) {
- ALOGV("DrmMetadata::Iterator::Iterator");
-}
-
-DrmMetadata::Iterator& DrmMetadata::Iterator::operator=(const DrmMetadata::Iterator& iterator) {
- ALOGV("DrmMetadata::Iterator::operator=");
- mDrmMetadata = iterator.mDrmMetadata;
- mIndex = iterator.mIndex;
- return *this;
-}
-
-bool DrmMetadata::Iterator::hasNext() {
- return mIndex < mDrmMetadata->mMetadataMap.size();
-}
-
-String8 DrmMetadata::Iterator::next() {
- String8 value = String8(mDrmMetadata->mMetadataMap.editValueAt(mIndex));
- mIndex++;
- return value;
-}
diff --git a/drm/common/DrmRights.cpp b/drm/common/DrmRights.cpp
deleted file mode 100644
index 3aecb3d..0000000
--- a/drm/common/DrmRights.cpp
+++ /dev/null
@@ -1,63 +0,0 @@
-/*
- * Copyright (C) 2010 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.
- */
-
-#include <drm/DrmRights.h>
-#include <ReadWriteUtils.h>
-
-using namespace android;
-
-DrmRights::DrmRights(const String8& rightsFilePath, const String8& mimeType,
- const String8& accountId, const String8& subscriptionId) :
- mMimeType(mimeType),
- mAccountId(accountId),
- mSubscriptionId(subscriptionId),
- mRightsFromFile(NULL) {
- int rightsLength = 0;
- if (String8("") != rightsFilePath) {
- rightsLength = ReadWriteUtils::readBytes(rightsFilePath, &mRightsFromFile);
- }
- mData = DrmBuffer(mRightsFromFile, rightsLength);
-}
-
-DrmRights::DrmRights(const DrmBuffer& rightsData, const String8& mimeType,
- const String8& accountId, const String8& subscriptionId) :
- mData(rightsData),
- mMimeType(mimeType),
- mAccountId(accountId),
- mSubscriptionId(subscriptionId),
- mRightsFromFile(NULL) {
-}
-
-DrmRights::~DrmRights() {
- delete[] mRightsFromFile; mRightsFromFile = NULL;
-}
-
-const DrmBuffer& DrmRights::getData(void) const {
- return mData;
-}
-
-String8 DrmRights::getMimeType(void) const {
- return mMimeType;
-}
-
-String8 DrmRights::getAccountId(void) const {
- return mAccountId;
-}
-
-String8 DrmRights::getSubscriptionId(void) const {
- return mSubscriptionId;
-}
-
diff --git a/drm/common/DrmSupportInfo.cpp b/drm/common/DrmSupportInfo.cpp
deleted file mode 100644
index 5400bdd..0000000
--- a/drm/common/DrmSupportInfo.cpp
+++ /dev/null
@@ -1,159 +0,0 @@
-/*
- * Copyright (C) 2010 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.
- */
-
-#include <drm/DrmSupportInfo.h>
-#include <strings.h>
-
-using namespace android;
-
-DrmSupportInfo::DrmSupportInfo() {
-
-}
-
-DrmSupportInfo::DrmSupportInfo(const DrmSupportInfo& drmSupportInfo):
- mMimeTypeVector(drmSupportInfo.mMimeTypeVector),
- mFileSuffixVector(drmSupportInfo.mFileSuffixVector),
- mDescription(drmSupportInfo.mDescription) {
-
-}
-
-bool DrmSupportInfo::operator<(const DrmSupportInfo& drmSupportInfo) const {
- // Do we need to check mMimeTypeVector & mFileSuffixVector ?
- // Note Vector doesn't overrides "<" operator
- return mDescription < drmSupportInfo.mDescription;
-}
-
-bool DrmSupportInfo::operator==(const DrmSupportInfo& drmSupportInfo) const {
- // Do we need to check mMimeTypeVector & mFileSuffixVector ?
- // Note Vector doesn't overrides "==" operator
- return (mDescription == drmSupportInfo.mDescription);
-}
-
-bool DrmSupportInfo::isSupportedMimeType(const String8& mimeType) const {
- if (String8("") == mimeType) {
- return false;
- }
-
- for (unsigned int i = 0; i < mMimeTypeVector.size(); i++) {
- const String8 item = mMimeTypeVector.itemAt(i);
-
- if (!strcasecmp(item.string(), mimeType.string())) {
- return true;
- }
- }
- return false;
-}
-
-bool DrmSupportInfo::isSupportedFileSuffix(const String8& fileType) const {
- for (unsigned int i = 0; i < mFileSuffixVector.size(); i++) {
- const String8 item = mFileSuffixVector.itemAt(i);
-
- if (!strcasecmp(item.string(), fileType.string())) {
- return true;
- }
- }
- return false;
-}
-
-DrmSupportInfo& DrmSupportInfo::operator=(const DrmSupportInfo& drmSupportInfo) {
- mMimeTypeVector = drmSupportInfo.mMimeTypeVector;
- mFileSuffixVector = drmSupportInfo.mFileSuffixVector;
- mDescription = drmSupportInfo.mDescription;
- return *this;
-}
-
-int DrmSupportInfo::getMimeTypeCount(void) const {
- return mMimeTypeVector.size();
-}
-
-int DrmSupportInfo::getFileSuffixCount(void) const {
- return mFileSuffixVector.size();
-}
-
-status_t DrmSupportInfo::addMimeType(const String8& mimeType) {
- mMimeTypeVector.push(mimeType);
- return DRM_NO_ERROR;
-}
-
-status_t DrmSupportInfo::addFileSuffix(const String8& fileSuffix) {
- mFileSuffixVector.push(fileSuffix);
- return DRM_NO_ERROR;
-}
-
-status_t DrmSupportInfo::setDescription(const String8& description) {
- mDescription = description;
- return DRM_NO_ERROR;
-}
-
-String8 DrmSupportInfo::getDescription() const {
- return mDescription;
-}
-
-DrmSupportInfo::FileSuffixIterator DrmSupportInfo::getFileSuffixIterator() {
- return FileSuffixIterator(this);
-}
-
-DrmSupportInfo::MimeTypeIterator DrmSupportInfo::getMimeTypeIterator() {
- return MimeTypeIterator(this);
-}
-
-DrmSupportInfo::FileSuffixIterator::FileSuffixIterator(
- const DrmSupportInfo::FileSuffixIterator& iterator) :
- mDrmSupportInfo(iterator.mDrmSupportInfo),
- mIndex(iterator.mIndex) {
-
-}
-
-DrmSupportInfo::FileSuffixIterator& DrmSupportInfo::FileSuffixIterator::operator=(
- const DrmSupportInfo::FileSuffixIterator& iterator) {
- mDrmSupportInfo = iterator.mDrmSupportInfo;
- mIndex = iterator.mIndex;
- return *this;
-}
-
-bool DrmSupportInfo::FileSuffixIterator::hasNext() {
- return mIndex < mDrmSupportInfo->mFileSuffixVector.size();
-}
-
-String8& DrmSupportInfo::FileSuffixIterator::next() {
- String8& value = mDrmSupportInfo->mFileSuffixVector.editItemAt(mIndex);
- mIndex++;
- return value;
-}
-
-DrmSupportInfo::MimeTypeIterator::MimeTypeIterator(
- const DrmSupportInfo::MimeTypeIterator& iterator) :
- mDrmSupportInfo(iterator.mDrmSupportInfo),
- mIndex(iterator.mIndex) {
-
-}
-
-DrmSupportInfo::MimeTypeIterator& DrmSupportInfo::MimeTypeIterator::operator=(
- const DrmSupportInfo::MimeTypeIterator& iterator) {
- mDrmSupportInfo = iterator.mDrmSupportInfo;
- mIndex = iterator.mIndex;
- return *this;
-}
-
-bool DrmSupportInfo::MimeTypeIterator::hasNext() {
- return mIndex < mDrmSupportInfo->mMimeTypeVector.size();
-}
-
-String8& DrmSupportInfo::MimeTypeIterator::next() {
- String8& value = mDrmSupportInfo->mMimeTypeVector.editItemAt(mIndex);
- mIndex++;
- return value;
-}
diff --git a/drm/common/IDrmManagerService.cpp b/drm/common/IDrmManagerService.cpp
deleted file mode 100644
index 3ed8ade..0000000
--- a/drm/common/IDrmManagerService.cpp
+++ /dev/null
@@ -1,1432 +0,0 @@
-/*
- * Copyright (C) 2010 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.
- */
-
-//#define LOG_NDEBUG 0
-#define LOG_TAG "IDrmManagerService(Native)"
-#include <utils/Log.h>
-
-#include <stdint.h>
-#include <sys/types.h>
-#include <binder/IPCThreadState.h>
-
-#include <drm/DrmInfo.h>
-#include <drm/DrmConstraints.h>
-#include <drm/DrmMetadata.h>
-#include <drm/DrmRights.h>
-#include <drm/DrmInfoStatus.h>
-#include <drm/DrmConvertedStatus.h>
-#include <drm/DrmInfoRequest.h>
-#include <drm/DrmSupportInfo.h>
-
-#include "IDrmManagerService.h"
-
-#define INVALID_BUFFER_LENGTH -1
-
-using namespace android;
-
-static void writeDecryptHandleToParcelData(
- const DecryptHandle* handle, Parcel* data) {
- data->writeInt32(handle->decryptId);
- data->writeString8(handle->mimeType);
- data->writeInt32(handle->decryptApiType);
- data->writeInt32(handle->status);
-
- int size = handle->copyControlVector.size();
- data->writeInt32(size);
- for (int i = 0; i < size; i++) {
- data->writeInt32(handle->copyControlVector.keyAt(i));
- data->writeInt32(handle->copyControlVector.valueAt(i));
- }
-
- size = handle->extendedData.size();
- data->writeInt32(size);
- for (int i = 0; i < size; i++) {
- data->writeString8(handle->extendedData.keyAt(i));
- data->writeString8(handle->extendedData.valueAt(i));
- }
-
- if (NULL != handle->decryptInfo) {
- data->writeInt32(handle->decryptInfo->decryptBufferLength);
- } else {
- data->writeInt32(INVALID_BUFFER_LENGTH);
- }
-}
-
-static void readDecryptHandleFromParcelData(
- DecryptHandle* handle, const Parcel& data) {
- if (0 == data.dataAvail()) {
- return;
- }
-
- handle->decryptId = data.readInt32();
- handle->mimeType = data.readString8();
- handle->decryptApiType = data.readInt32();
- handle->status = data.readInt32();
-
- int size = data.readInt32();
- for (int i = 0; i < size; i++) {
- DrmCopyControl key = (DrmCopyControl)data.readInt32();
- int value = data.readInt32();
- handle->copyControlVector.add(key, value);
- }
-
- size = data.readInt32();
- for (int i = 0; i < size; i++) {
- String8 key = data.readString8();
- String8 value = data.readString8();
- handle->extendedData.add(key, value);
- }
-
- handle->decryptInfo = NULL;
- const int bufferLen = data.readInt32();
- if (INVALID_BUFFER_LENGTH != bufferLen) {
- handle->decryptInfo = new DecryptInfo();
- handle->decryptInfo->decryptBufferLength = bufferLen;
- }
-}
-
-static void clearDecryptHandle(DecryptHandle* handle) {
- if (handle == NULL) {
- return;
- }
- if (handle->decryptInfo) {
- delete handle->decryptInfo;
- handle->decryptInfo = NULL;
- }
- handle->copyControlVector.clear();
- handle->extendedData.clear();
-}
-
-int BpDrmManagerService::addUniqueId(bool isNative) {
- ALOGV("add uniqueid");
- Parcel data, reply;
- data.writeInterfaceToken(IDrmManagerService::getInterfaceDescriptor());
- data.writeInt32(isNative);
- remote()->transact(ADD_UNIQUEID, data, &reply);
- return reply.readInt32();
-}
-
-void BpDrmManagerService::removeUniqueId(int uniqueId) {
- ALOGV("remove uniqueid");
- Parcel data, reply;
- data.writeInterfaceToken(IDrmManagerService::getInterfaceDescriptor());
- data.writeInt32(uniqueId);
- remote()->transact(REMOVE_UNIQUEID, data, &reply);
-}
-
-void BpDrmManagerService::addClient(int uniqueId) {
- Parcel data, reply;
- data.writeInterfaceToken(IDrmManagerService::getInterfaceDescriptor());
- data.writeInt32(uniqueId);
- remote()->transact(ADD_CLIENT, data, &reply);
-}
-
-void BpDrmManagerService::removeClient(int uniqueId) {
- Parcel data, reply;
- data.writeInterfaceToken(IDrmManagerService::getInterfaceDescriptor());
- data.writeInt32(uniqueId);
- remote()->transact(REMOVE_CLIENT, data, &reply);
-}
-
-status_t BpDrmManagerService::setDrmServiceListener(
- int uniqueId, const sp<IDrmServiceListener>& drmServiceListener) {
- ALOGV("setDrmServiceListener");
- Parcel data, reply;
-
- data.writeInterfaceToken(IDrmManagerService::getInterfaceDescriptor());
- data.writeInt32(uniqueId);
- data.writeStrongBinder(drmServiceListener->asBinder());
- remote()->transact(SET_DRM_SERVICE_LISTENER, data, &reply);
- return reply.readInt32();
-}
-
-status_t BpDrmManagerService::installDrmEngine(int uniqueId, const String8& drmEngineFile) {
- ALOGV("Install DRM Engine");
- Parcel data, reply;
-
- data.writeInterfaceToken(IDrmManagerService::getInterfaceDescriptor());
- data.writeInt32(uniqueId);
- data.writeString8(drmEngineFile);
-
- remote()->transact(INSTALL_DRM_ENGINE, data, &reply);
- return reply.readInt32();
-}
-
-DrmConstraints* BpDrmManagerService::getConstraints(
- int uniqueId, const String8* path, const int action) {
- ALOGV("Get Constraints");
- Parcel data, reply;
-
- data.writeInterfaceToken(IDrmManagerService::getInterfaceDescriptor());
- data.writeInt32(uniqueId);
- data.writeString8(*path);
- data.writeInt32(action);
-
- remote()->transact(GET_CONSTRAINTS_FROM_CONTENT, data, &reply);
-
- DrmConstraints* drmConstraints = NULL;
- if (0 != reply.dataAvail()) {
- //Filling Drm Constraints
- drmConstraints = new DrmConstraints();
-
- const int size = reply.readInt32();
- for (int index = 0; index < size; ++index) {
- const String8 key(reply.readString8());
- const int bufferSize = reply.readInt32();
- char* data = NULL;
- if (0 < bufferSize) {
- data = new char[bufferSize];
- reply.read(data, bufferSize);
- }
- drmConstraints->put(&key, data);
- }
- }
- return drmConstraints;
-}
-
-DrmMetadata* BpDrmManagerService::getMetadata(int uniqueId, const String8* path) {
- ALOGV("Get Metadata");
- Parcel data, reply;
- data.writeInterfaceToken(IDrmManagerService::getInterfaceDescriptor());
- data.writeInt32(uniqueId);
-
- DrmMetadata* drmMetadata = NULL;
- data.writeString8(*path);
- remote()->transact(GET_METADATA_FROM_CONTENT, data, &reply);
-
- if (0 != reply.dataAvail()) {
- //Filling Drm Metadata
- drmMetadata = new DrmMetadata();
-
- const int size = reply.readInt32();
- for (int index = 0; index < size; ++index) {
- const String8 key(reply.readString8());
- const int bufferSize = reply.readInt32();
- char* data = NULL;
- if (0 < bufferSize) {
- data = new char[bufferSize];
- reply.read(data, bufferSize);
- }
- drmMetadata->put(&key, data);
- }
- }
- return drmMetadata;
-}
-
-bool BpDrmManagerService::canHandle(int uniqueId, const String8& path, const String8& mimeType) {
- ALOGV("Can Handle");
- Parcel data, reply;
-
- data.writeInterfaceToken(IDrmManagerService::getInterfaceDescriptor());
- data.writeInt32(uniqueId);
-
- data.writeString8(path);
- data.writeString8(mimeType);
-
- remote()->transact(CAN_HANDLE, data, &reply);
-
- return static_cast<bool>(reply.readInt32());
-}
-
-DrmInfoStatus* BpDrmManagerService::processDrmInfo(int uniqueId, const DrmInfo* drmInfo) {
- ALOGV("Process DRM Info");
- Parcel data, reply;
-
- data.writeInterfaceToken(IDrmManagerService::getInterfaceDescriptor());
- data.writeInt32(uniqueId);
-
- //Filling DRM info
- data.writeInt32(drmInfo->getInfoType());
- const DrmBuffer dataBuffer = drmInfo->getData();
- const int dataBufferSize = dataBuffer.length;
- data.writeInt32(dataBufferSize);
- if (0 < dataBufferSize) {
- data.write(dataBuffer.data, dataBufferSize);
- }
- data.writeString8(drmInfo->getMimeType());
-
- data.writeInt32(drmInfo->getCount());
- DrmInfo::KeyIterator keyIt = drmInfo->keyIterator();
-
- while (keyIt.hasNext()) {
- const String8 key = keyIt.next();
- data.writeString8(key);
- const String8 value = drmInfo->get(key);
- data.writeString8((value == String8("")) ? String8("NULL") : value);
- }
-
- remote()->transact(PROCESS_DRM_INFO, data, &reply);
-
- DrmInfoStatus* drmInfoStatus = NULL;
- if (0 != reply.dataAvail()) {
- //Filling DRM Info Status
- const int statusCode = reply.readInt32();
- const int infoType = reply.readInt32();
- const String8 mimeType = reply.readString8();
-
- DrmBuffer* drmBuffer = NULL;
- if (0 != reply.dataAvail()) {
- const int bufferSize = reply.readInt32();
- char* data = NULL;
- if (0 < bufferSize) {
- data = new char[bufferSize];
- reply.read(data, bufferSize);
- }
- drmBuffer = new DrmBuffer(data, bufferSize);
- }
- drmInfoStatus = new DrmInfoStatus(statusCode, infoType, drmBuffer, mimeType);
- }
- return drmInfoStatus;
-}
-
-DrmInfo* BpDrmManagerService::acquireDrmInfo(int uniqueId, const DrmInfoRequest* drmInforequest) {
- ALOGV("Acquire DRM Info");
- Parcel data, reply;
-
- data.writeInterfaceToken(IDrmManagerService::getInterfaceDescriptor());
- data.writeInt32(uniqueId);
-
- //Filling DRM Info Request
- data.writeInt32(drmInforequest->getInfoType());
- data.writeString8(drmInforequest->getMimeType());
-
- data.writeInt32(drmInforequest->getCount());
- DrmInfoRequest::KeyIterator keyIt = drmInforequest->keyIterator();
-
- while (keyIt.hasNext()) {
- const String8 key = keyIt.next();
- data.writeString8(key);
- const String8 value = drmInforequest->get(key);
- data.writeString8((value == String8("")) ? String8("NULL") : value);
- }
-
- remote()->transact(ACQUIRE_DRM_INFO, data, &reply);
-
- DrmInfo* drmInfo = NULL;
- if (0 != reply.dataAvail()) {
- //Filling DRM Info
- const int infoType = reply.readInt32();
- const int bufferSize = reply.readInt32();
- char* data = NULL;
-
- if (0 < bufferSize) {
- data = new char[bufferSize];
- reply.read(data, bufferSize);
- }
- drmInfo = new DrmInfo(infoType, DrmBuffer(data, bufferSize), reply.readString8());
-
- const int size = reply.readInt32();
- for (int index = 0; index < size; ++index) {
- const String8 key(reply.readString8());
- const String8 value(reply.readString8());
- drmInfo->put(key, (value == String8("NULL")) ? String8("") : value);
- }
- }
- return drmInfo;
-}
-
-status_t BpDrmManagerService::saveRights(
- int uniqueId, const DrmRights& drmRights,
- const String8& rightsPath, const String8& contentPath) {
- ALOGV("Save Rights");
- Parcel data, reply;
-
- data.writeInterfaceToken(IDrmManagerService::getInterfaceDescriptor());
- data.writeInt32(uniqueId);
-
- //Filling Drm Rights
- const DrmBuffer dataBuffer = drmRights.getData();
- data.writeInt32(dataBuffer.length);
- data.write(dataBuffer.data, dataBuffer.length);
-
- const String8 mimeType = drmRights.getMimeType();
- data.writeString8((mimeType == String8("")) ? String8("NULL") : mimeType);
-
- const String8 accountId = drmRights.getAccountId();
- data.writeString8((accountId == String8("")) ? String8("NULL") : accountId);
-
- const String8 subscriptionId = drmRights.getSubscriptionId();
- data.writeString8((subscriptionId == String8("")) ? String8("NULL") : subscriptionId);
-
- data.writeString8((rightsPath == String8("")) ? String8("NULL") : rightsPath);
- data.writeString8((contentPath == String8("")) ? String8("NULL") : contentPath);
-
- remote()->transact(SAVE_RIGHTS, data, &reply);
- return reply.readInt32();
-}
-
-String8 BpDrmManagerService::getOriginalMimeType(int uniqueId, const String8& path) {
- ALOGV("Get Original MimeType");
- Parcel data, reply;
-
- data.writeInterfaceToken(IDrmManagerService::getInterfaceDescriptor());
- data.writeInt32(uniqueId);
- data.writeString8(path);
-
- remote()->transact(GET_ORIGINAL_MIMETYPE, data, &reply);
- return reply.readString8();
-}
-
-int BpDrmManagerService::getDrmObjectType(
- int uniqueId, const String8& path, const String8& mimeType) {
- ALOGV("Get Drm object type");
- Parcel data, reply;
-
- data.writeInterfaceToken(IDrmManagerService::getInterfaceDescriptor());
- data.writeInt32(uniqueId);
- data.writeString8(path);
- data.writeString8(mimeType);
-
- remote()->transact(GET_DRM_OBJECT_TYPE, data, &reply);
-
- return reply.readInt32();
-}
-
-int BpDrmManagerService::checkRightsStatus(int uniqueId, const String8& path, int action) {
- ALOGV("checkRightsStatus");
- Parcel data, reply;
-
- data.writeInterfaceToken(IDrmManagerService::getInterfaceDescriptor());
- data.writeInt32(uniqueId);
- data.writeString8(path);
- data.writeInt32(action);
-
- remote()->transact(CHECK_RIGHTS_STATUS, data, &reply);
-
- return reply.readInt32();
-}
-
-status_t BpDrmManagerService::consumeRights(
- int uniqueId, DecryptHandle* decryptHandle, int action, bool reserve) {
- ALOGV("consumeRights");
- Parcel data, reply;
-
- data.writeInterfaceToken(IDrmManagerService::getInterfaceDescriptor());
- data.writeInt32(uniqueId);
-
- writeDecryptHandleToParcelData(decryptHandle, &data);
-
- data.writeInt32(action);
- data.writeInt32(static_cast< int>(reserve));
-
- remote()->transact(CONSUME_RIGHTS, data, &reply);
- return reply.readInt32();
-}
-
-status_t BpDrmManagerService::setPlaybackStatus(
- int uniqueId, DecryptHandle* decryptHandle, int playbackStatus, int64_t position) {
- ALOGV("setPlaybackStatus");
- Parcel data, reply;
-
- data.writeInterfaceToken(IDrmManagerService::getInterfaceDescriptor());
- data.writeInt32(uniqueId);
-
- writeDecryptHandleToParcelData(decryptHandle, &data);
-
- data.writeInt32(playbackStatus);
- data.writeInt64(position);
-
- remote()->transact(SET_PLAYBACK_STATUS, data, &reply);
- return reply.readInt32();
-}
-
-bool BpDrmManagerService::validateAction(
- int uniqueId, const String8& path,
- int action, const ActionDescription& description) {
- ALOGV("validateAction");
- Parcel data, reply;
-
- data.writeInterfaceToken(IDrmManagerService::getInterfaceDescriptor());
- data.writeInt32(uniqueId);
- data.writeString8(path);
- data.writeInt32(action);
- data.writeInt32(description.outputType);
- data.writeInt32(description.configuration);
-
- remote()->transact(VALIDATE_ACTION, data, &reply);
-
- return static_cast<bool>(reply.readInt32());
-}
-
-status_t BpDrmManagerService::removeRights(int uniqueId, const String8& path) {
- ALOGV("removeRights");
- Parcel data, reply;
-
- data.writeInterfaceToken(IDrmManagerService::getInterfaceDescriptor());
- data.writeInt32(uniqueId);
- data.writeString8(path);
-
- remote()->transact(REMOVE_RIGHTS, data, &reply);
- return reply.readInt32();
-}
-
-status_t BpDrmManagerService::removeAllRights(int uniqueId) {
- ALOGV("removeAllRights");
- Parcel data, reply;
-
- data.writeInterfaceToken(IDrmManagerService::getInterfaceDescriptor());
- data.writeInt32(uniqueId);
-
- remote()->transact(REMOVE_ALL_RIGHTS, data, &reply);
- return reply.readInt32();
-}
-
-int BpDrmManagerService::openConvertSession(int uniqueId, const String8& mimeType) {
- ALOGV("openConvertSession");
- Parcel data, reply;
-
- data.writeInterfaceToken(IDrmManagerService::getInterfaceDescriptor());
- data.writeInt32(uniqueId);
- data.writeString8(mimeType);
-
- remote()->transact(OPEN_CONVERT_SESSION, data, &reply);
- return reply.readInt32();
-}
-
-DrmConvertedStatus* BpDrmManagerService::convertData(
- int uniqueId, int convertId, const DrmBuffer* inputData) {
- ALOGV("convertData");
- Parcel data, reply;
-
- data.writeInterfaceToken(IDrmManagerService::getInterfaceDescriptor());
- data.writeInt32(uniqueId);
- data.writeInt32(convertId);
- data.writeInt32(inputData->length);
- data.write(inputData->data, inputData->length);
-
- remote()->transact(CONVERT_DATA, data, &reply);
-
- DrmConvertedStatus* drmConvertedStatus = NULL;
-
- if (0 != reply.dataAvail()) {
- //Filling DRM Converted Status
- const int statusCode = reply.readInt32();
- const off64_t offset = reply.readInt64();
-
- DrmBuffer* convertedData = NULL;
- if (0 != reply.dataAvail()) {
- const int bufferSize = reply.readInt32();
- char* data = NULL;
- if (0 < bufferSize) {
- data = new char[bufferSize];
- reply.read(data, bufferSize);
- }
- convertedData = new DrmBuffer(data, bufferSize);
- }
- drmConvertedStatus = new DrmConvertedStatus(statusCode, convertedData, offset);
- }
- return drmConvertedStatus;
-}
-
-DrmConvertedStatus* BpDrmManagerService::closeConvertSession(int uniqueId, int convertId) {
- ALOGV("closeConvertSession");
- Parcel data, reply;
-
- data.writeInterfaceToken(IDrmManagerService::getInterfaceDescriptor());
- data.writeInt32(uniqueId);
- data.writeInt32(convertId);
-
- remote()->transact(CLOSE_CONVERT_SESSION, data, &reply);
-
- DrmConvertedStatus* drmConvertedStatus = NULL;
-
- if (0 != reply.dataAvail()) {
- //Filling DRM Converted Status
- const int statusCode = reply.readInt32();
- const off64_t offset = reply.readInt64();
-
- DrmBuffer* convertedData = NULL;
- if (0 != reply.dataAvail()) {
- const int bufferSize = reply.readInt32();
- char* data = NULL;
- if (0 < bufferSize) {
- data = new char[bufferSize];
- reply.read(data, bufferSize);
- }
- convertedData = new DrmBuffer(data, bufferSize);
- }
- drmConvertedStatus = new DrmConvertedStatus(statusCode, convertedData, offset);
- }
- return drmConvertedStatus;
-}
-
-status_t BpDrmManagerService::getAllSupportInfo(
- int uniqueId, int* length, DrmSupportInfo** drmSupportInfoArray) {
- ALOGV("Get All Support Info");
- Parcel data, reply;
-
- data.writeInterfaceToken(IDrmManagerService::getInterfaceDescriptor());
- data.writeInt32(uniqueId);
-
- remote()->transact(GET_ALL_SUPPORT_INFO, data, &reply);
-
- //Filling DRM Support Info
- const int arraySize = reply.readInt32();
- if (0 < arraySize) {
- *drmSupportInfoArray = new DrmSupportInfo[arraySize];
-
- for (int index = 0; index < arraySize; ++index) {
- DrmSupportInfo drmSupportInfo;
-
- const int fileSuffixVectorSize = reply.readInt32();
- for (int i = 0; i < fileSuffixVectorSize; ++i) {
- drmSupportInfo.addFileSuffix(reply.readString8());
- }
-
- const int mimeTypeVectorSize = reply.readInt32();
- for (int i = 0; i < mimeTypeVectorSize; ++i) {
- drmSupportInfo.addMimeType(reply.readString8());
- }
-
- drmSupportInfo.setDescription(reply.readString8());
- (*drmSupportInfoArray)[index] = drmSupportInfo;
- }
- }
- *length = arraySize;
- return reply.readInt32();
-}
-
-DecryptHandle* BpDrmManagerService::openDecryptSession(
- int uniqueId, int fd, off64_t offset, off64_t length) {
- ALOGV("Entering BpDrmManagerService::openDecryptSession");
- Parcel data, reply;
-
- data.writeInterfaceToken(IDrmManagerService::getInterfaceDescriptor());
- data.writeInt32(uniqueId);
- data.writeFileDescriptor(fd);
- data.writeInt64(offset);
- data.writeInt64(length);
-
- remote()->transact(OPEN_DECRYPT_SESSION, data, &reply);
-
- DecryptHandle* handle = NULL;
- if (0 != reply.dataAvail()) {
- handle = new DecryptHandle();
- readDecryptHandleFromParcelData(handle, reply);
- }
- return handle;
-}
-
-DecryptHandle* BpDrmManagerService::openDecryptSession(int uniqueId, const char* uri) {
- ALOGV("Entering BpDrmManagerService::openDecryptSession");
- Parcel data, reply;
-
- data.writeInterfaceToken(IDrmManagerService::getInterfaceDescriptor());
- data.writeInt32(uniqueId);
- data.writeString8(String8(uri));
-
- remote()->transact(OPEN_DECRYPT_SESSION_FROM_URI, data, &reply);
-
- DecryptHandle* handle = NULL;
- if (0 != reply.dataAvail()) {
- handle = new DecryptHandle();
- readDecryptHandleFromParcelData(handle, reply);
- } else {
- ALOGV("no decryptHandle is generated in service side");
- }
- return handle;
-}
-
-status_t BpDrmManagerService::closeDecryptSession(int uniqueId, DecryptHandle* decryptHandle) {
- ALOGV("closeDecryptSession");
- Parcel data, reply;
-
- data.writeInterfaceToken(IDrmManagerService::getInterfaceDescriptor());
- data.writeInt32(uniqueId);
-
- writeDecryptHandleToParcelData(decryptHandle, &data);
-
- remote()->transact(CLOSE_DECRYPT_SESSION, data, &reply);
-
- return reply.readInt32();
-}
-
-status_t BpDrmManagerService::initializeDecryptUnit(
- int uniqueId, DecryptHandle* decryptHandle,
- int decryptUnitId, const DrmBuffer* headerInfo) {
- ALOGV("initializeDecryptUnit");
- Parcel data, reply;
-
- data.writeInterfaceToken(IDrmManagerService::getInterfaceDescriptor());
- data.writeInt32(uniqueId);
-
- writeDecryptHandleToParcelData(decryptHandle, &data);
-
- data.writeInt32(decryptUnitId);
-
- data.writeInt32(headerInfo->length);
- data.write(headerInfo->data, headerInfo->length);
-
- remote()->transact(INITIALIZE_DECRYPT_UNIT, data, &reply);
- return reply.readInt32();
-}
-
-status_t BpDrmManagerService::decrypt(
- int uniqueId, DecryptHandle* decryptHandle, int decryptUnitId,
- const DrmBuffer* encBuffer, DrmBuffer** decBuffer, DrmBuffer* IV) {
- ALOGV("decrypt");
- Parcel data, reply;
-
- data.writeInterfaceToken(IDrmManagerService::getInterfaceDescriptor());
- data.writeInt32(uniqueId);
-
- writeDecryptHandleToParcelData(decryptHandle, &data);
-
- data.writeInt32(decryptUnitId);
- data.writeInt32((*decBuffer)->length);
-
- data.writeInt32(encBuffer->length);
- data.write(encBuffer->data, encBuffer->length);
-
- if (NULL != IV) {
- data.writeInt32(IV->length);
- data.write(IV->data, IV->length);
- }
-
- remote()->transact(DECRYPT, data, &reply);
-
- const status_t status = reply.readInt32();
- ALOGV("Return value of decrypt() is %d", status);
-
- const int size = reply.readInt32();
- (*decBuffer)->length = size;
- reply.read((void *)(*decBuffer)->data, size);
-
- return status;
-}
-
-status_t BpDrmManagerService::finalizeDecryptUnit(
- int uniqueId, DecryptHandle* decryptHandle, int decryptUnitId) {
- ALOGV("finalizeDecryptUnit");
- Parcel data, reply;
-
- data.writeInterfaceToken(IDrmManagerService::getInterfaceDescriptor());
- data.writeInt32(uniqueId);
-
- writeDecryptHandleToParcelData(decryptHandle, &data);
-
- data.writeInt32(decryptUnitId);
-
- remote()->transact(FINALIZE_DECRYPT_UNIT, data, &reply);
- return reply.readInt32();
-}
-
-ssize_t BpDrmManagerService::pread(
- int uniqueId, DecryptHandle* decryptHandle, void* buffer,
- ssize_t numBytes, off64_t offset) {
- ALOGV("read");
- Parcel data, reply;
- int result;
-
- data.writeInterfaceToken(IDrmManagerService::getInterfaceDescriptor());
- data.writeInt32(uniqueId);
-
- writeDecryptHandleToParcelData(decryptHandle, &data);
-
- data.writeInt32(numBytes);
- data.writeInt64(offset);
-
- remote()->transact(PREAD, data, &reply);
- result = reply.readInt32();
- if (0 < result) {
- reply.read(buffer, result);
- }
- return result;
-}
-
-IMPLEMENT_META_INTERFACE(DrmManagerService, "drm.IDrmManagerService");
-
-status_t BnDrmManagerService::onTransact(
- uint32_t code, const Parcel& data,
- Parcel* reply, uint32_t flags) {
- ALOGV("Entering BnDrmManagerService::onTransact with code %d", code);
-
- switch (code) {
- case ADD_UNIQUEID:
- {
- ALOGV("BnDrmManagerService::onTransact :ADD_UNIQUEID");
- CHECK_INTERFACE(IDrmManagerService, data, reply);
- int uniqueId = addUniqueId(data.readInt32());
- reply->writeInt32(uniqueId);
- return DRM_NO_ERROR;
- }
-
- case REMOVE_UNIQUEID:
- {
- ALOGV("BnDrmManagerService::onTransact :REMOVE_UNIQUEID");
- CHECK_INTERFACE(IDrmManagerService, data, reply);
- removeUniqueId(data.readInt32());
- return DRM_NO_ERROR;
- }
-
- case ADD_CLIENT:
- {
- ALOGV("BnDrmManagerService::onTransact :ADD_CLIENT");
- CHECK_INTERFACE(IDrmManagerService, data, reply);
- addClient(data.readInt32());
- return DRM_NO_ERROR;
- }
-
- case REMOVE_CLIENT:
- {
- ALOGV("BnDrmManagerService::onTransact :REMOVE_CLIENT");
- CHECK_INTERFACE(IDrmManagerService, data, reply);
- removeClient(data.readInt32());
- return DRM_NO_ERROR;
- }
-
- case SET_DRM_SERVICE_LISTENER:
- {
- ALOGV("BnDrmManagerService::onTransact :SET_DRM_SERVICE_LISTENER");
- CHECK_INTERFACE(IDrmManagerService, data, reply);
-
- const int uniqueId = data.readInt32();
- const sp<IDrmServiceListener> drmServiceListener
- = interface_cast<IDrmServiceListener> (data.readStrongBinder());
-
- status_t status = setDrmServiceListener(uniqueId, drmServiceListener);
-
- reply->writeInt32(status);
- return DRM_NO_ERROR;
- }
-
- case INSTALL_DRM_ENGINE:
- {
- ALOGV("BnDrmManagerService::onTransact :INSTALL_DRM_ENGINE");
- CHECK_INTERFACE(IDrmManagerService, data, reply);
-
- const int uniqueId = data.readInt32();
- const String8 engineFile = data.readString8();
- status_t status = installDrmEngine(uniqueId, engineFile);
-
- reply->writeInt32(status);
- return DRM_NO_ERROR;
- }
-
- case GET_CONSTRAINTS_FROM_CONTENT:
- {
- ALOGV("BnDrmManagerService::onTransact :GET_CONSTRAINTS_FROM_CONTENT");
- CHECK_INTERFACE(IDrmManagerService, data, reply);
-
- const int uniqueId = data.readInt32();
- const String8 path = data.readString8();
-
- DrmConstraints* drmConstraints
- = getConstraints(uniqueId, &path, data.readInt32());
-
- if (NULL != drmConstraints) {
- //Filling DRM Constraints contents
- reply->writeInt32(drmConstraints->getCount());
-
- DrmConstraints::KeyIterator keyIt = drmConstraints->keyIterator();
- while (keyIt.hasNext()) {
- const String8 key = keyIt.next();
- reply->writeString8(key);
- const char* value = drmConstraints->getAsByteArray(&key);
- int bufferSize = 0;
- if (NULL != value) {
- bufferSize = strlen(value);
- }
- reply->writeInt32(bufferSize + 1);
- reply->write(value, bufferSize + 1);
- }
- }
- delete drmConstraints; drmConstraints = NULL;
- return DRM_NO_ERROR;
- }
-
- case GET_METADATA_FROM_CONTENT:
- {
- ALOGV("BnDrmManagerService::onTransact :GET_METADATA_FROM_CONTENT");
- CHECK_INTERFACE(IDrmManagerService, data, reply);
-
- const int uniqueId = data.readInt32();
- const String8 path = data.readString8();
-
- DrmMetadata* drmMetadata = getMetadata(uniqueId, &path);
- if (NULL != drmMetadata) {
- //Filling DRM Metadata contents
- reply->writeInt32(drmMetadata->getCount());
-
- DrmMetadata::KeyIterator keyIt = drmMetadata->keyIterator();
- while (keyIt.hasNext()) {
- const String8 key = keyIt.next();
- reply->writeString8(key);
- const char* value = drmMetadata->getAsByteArray(&key);
- int bufferSize = 0;
- if (NULL != value) {
- bufferSize = strlen(value);
- reply->writeInt32(bufferSize + 1);
- reply->write(value, bufferSize + 1);
- } else {
- reply->writeInt32(0);
- }
- }
- }
- delete drmMetadata; drmMetadata = NULL;
- return NO_ERROR;
- }
-
- case CAN_HANDLE:
- {
- ALOGV("BnDrmManagerService::onTransact :CAN_HANDLE");
- CHECK_INTERFACE(IDrmManagerService, data, reply);
-
- const int uniqueId = data.readInt32();
- const String8 path = data.readString8();
- const String8 mimeType = data.readString8();
-
- bool result = canHandle(uniqueId, path, mimeType);
-
- reply->writeInt32(result);
- return DRM_NO_ERROR;
- }
-
- case PROCESS_DRM_INFO:
- {
- ALOGV("BnDrmManagerService::onTransact :PROCESS_DRM_INFO");
- CHECK_INTERFACE(IDrmManagerService, data, reply);
-
- const int uniqueId = data.readInt32();
-
- //Filling DRM info
- const int infoType = data.readInt32();
- const int bufferSize = data.readInt32();
- char* buffer = NULL;
- if (0 < bufferSize) {
- buffer = (char *)data.readInplace(bufferSize);
- }
- const DrmBuffer drmBuffer(buffer, bufferSize);
- DrmInfo* drmInfo = new DrmInfo(infoType, drmBuffer, data.readString8());
-
- const int size = data.readInt32();
- for (int index = 0; index < size; ++index) {
- const String8 key(data.readString8());
- const String8 value(data.readString8());
- drmInfo->put(key, (value == String8("NULL")) ? String8("") : value);
- }
-
- DrmInfoStatus* drmInfoStatus = processDrmInfo(uniqueId, drmInfo);
-
- if (NULL != drmInfoStatus) {
- //Filling DRM Info Status contents
- reply->writeInt32(drmInfoStatus->statusCode);
- reply->writeInt32(drmInfoStatus->infoType);
- reply->writeString8(drmInfoStatus->mimeType);
-
- if (NULL != drmInfoStatus->drmBuffer) {
- const DrmBuffer* drmBuffer = drmInfoStatus->drmBuffer;
- const int bufferSize = drmBuffer->length;
- reply->writeInt32(bufferSize);
- if (0 < bufferSize) {
- reply->write(drmBuffer->data, bufferSize);
- }
- delete [] drmBuffer->data;
- delete drmBuffer; drmBuffer = NULL;
- }
- }
- delete drmInfo; drmInfo = NULL;
- delete drmInfoStatus; drmInfoStatus = NULL;
- return DRM_NO_ERROR;
- }
-
- case ACQUIRE_DRM_INFO:
- {
- ALOGV("BnDrmManagerService::onTransact :ACQUIRE_DRM_INFO");
- CHECK_INTERFACE(IDrmManagerService, data, reply);
-
- const int uniqueId = data.readInt32();
-
- //Filling DRM info Request
- const int infoType = data.readInt32();
- const String8 mimeType = data.readString8();
- DrmInfoRequest* drmInfoRequest = new DrmInfoRequest(infoType, mimeType);
-
- const int size = data.readInt32();
- for (int index = 0; index < size; ++index) {
- const String8 key(data.readString8());
- const String8 value(data.readString8());
- drmInfoRequest->put(key, (value == String8("NULL")) ? String8("") : value);
- }
-
- DrmInfo* drmInfo = acquireDrmInfo(uniqueId, drmInfoRequest);
-
- if (NULL != drmInfo) {
- //Filling DRM Info
- const DrmBuffer drmBuffer = drmInfo->getData();
- reply->writeInt32(drmInfo->getInfoType());
-
- const int bufferSize = drmBuffer.length;
- reply->writeInt32(bufferSize);
- if (0 < bufferSize) {
- reply->write(drmBuffer.data, bufferSize);
- }
- reply->writeString8(drmInfo->getMimeType());
- reply->writeInt32(drmInfo->getCount());
-
- DrmInfo::KeyIterator keyIt = drmInfo->keyIterator();
- while (keyIt.hasNext()) {
- const String8 key = keyIt.next();
- reply->writeString8(key);
- const String8 value = drmInfo->get(key);
- reply->writeString8((value == String8("")) ? String8("NULL") : value);
- }
- delete [] drmBuffer.data;
- }
- delete drmInfoRequest; drmInfoRequest = NULL;
- delete drmInfo; drmInfo = NULL;
- return DRM_NO_ERROR;
- }
-
- case SAVE_RIGHTS:
- {
- ALOGV("BnDrmManagerService::onTransact :SAVE_RIGHTS");
- CHECK_INTERFACE(IDrmManagerService, data, reply);
-
- const int uniqueId = data.readInt32();
-
- //Filling DRM Rights
- const int bufferSize = data.readInt32();
- const DrmBuffer drmBuffer((char *)data.readInplace(bufferSize), bufferSize);
-
- const String8 mimeType(data.readString8());
- const String8 accountId(data.readString8());
- const String8 subscriptionId(data.readString8());
- const String8 rightsPath(data.readString8());
- const String8 contentPath(data.readString8());
-
- DrmRights drmRights(drmBuffer,
- ((mimeType == String8("NULL")) ? String8("") : mimeType),
- ((accountId == String8("NULL")) ? String8("") : accountId),
- ((subscriptionId == String8("NULL")) ? String8("") : subscriptionId));
-
- const status_t status = saveRights(uniqueId, drmRights,
- ((rightsPath == String8("NULL")) ? String8("") : rightsPath),
- ((contentPath == String8("NULL")) ? String8("") : contentPath));
-
- reply->writeInt32(status);
- return DRM_NO_ERROR;
- }
-
- case GET_ORIGINAL_MIMETYPE:
- {
- ALOGV("BnDrmManagerService::onTransact :GET_ORIGINAL_MIMETYPE");
- CHECK_INTERFACE(IDrmManagerService, data, reply);
-
- const int uniqueId = data.readInt32();
- const String8 path = data.readString8();
- const String8 originalMimeType = getOriginalMimeType(uniqueId, path);
-
- reply->writeString8(originalMimeType);
- return DRM_NO_ERROR;
- }
-
- case GET_DRM_OBJECT_TYPE:
- {
- ALOGV("BnDrmManagerService::onTransact :GET_DRM_OBJECT_TYPE");
- CHECK_INTERFACE(IDrmManagerService, data, reply);
-
- const int uniqueId = data.readInt32();
- const String8 path = data.readString8();
- const String8 mimeType = data.readString8();
- const int drmObjectType = getDrmObjectType(uniqueId, path, mimeType);
-
- reply->writeInt32(drmObjectType);
- return DRM_NO_ERROR;
- }
-
- case CHECK_RIGHTS_STATUS:
- {
- ALOGV("BnDrmManagerService::onTransact :CHECK_RIGHTS_STATUS");
- CHECK_INTERFACE(IDrmManagerService, data, reply);
-
- const int uniqueId = data.readInt32();
- const String8 path = data.readString8();
- const int action = data.readInt32();
- const int result = checkRightsStatus(uniqueId, path, action);
-
- reply->writeInt32(result);
- return DRM_NO_ERROR;
- }
-
- case CONSUME_RIGHTS:
- {
- ALOGV("BnDrmManagerService::onTransact :CONSUME_RIGHTS");
- CHECK_INTERFACE(IDrmManagerService, data, reply);
-
- const int uniqueId = data.readInt32();
-
- DecryptHandle handle;
- readDecryptHandleFromParcelData(&handle, data);
-
- const int action = data.readInt32();
- const bool reserve = static_cast<bool>(data.readInt32());
- const status_t status
- = consumeRights(uniqueId, &handle, action, reserve);
- reply->writeInt32(status);
-
- clearDecryptHandle(&handle);
- return DRM_NO_ERROR;
- }
-
- case SET_PLAYBACK_STATUS:
- {
- ALOGV("BnDrmManagerService::onTransact :SET_PLAYBACK_STATUS");
- CHECK_INTERFACE(IDrmManagerService, data, reply);
-
- const int uniqueId = data.readInt32();
-
- DecryptHandle handle;
- readDecryptHandleFromParcelData(&handle, data);
-
- const int playbackStatus = data.readInt32();
- const int64_t position = data.readInt64();
- const status_t status
- = setPlaybackStatus(uniqueId, &handle, playbackStatus, position);
- reply->writeInt32(status);
-
- clearDecryptHandle(&handle);
- return DRM_NO_ERROR;
- }
-
- case VALIDATE_ACTION:
- {
- ALOGV("BnDrmManagerService::onTransact :VALIDATE_ACTION");
- CHECK_INTERFACE(IDrmManagerService, data, reply);
-
- const int uniqueId = data.readInt32();
- const String8 path = data.readString8();
- const int action = data.readInt32();
- const int outputType = data.readInt32();
- const int configuration = data.readInt32();
- bool result = validateAction(uniqueId, path, action,
- ActionDescription(outputType, configuration));
-
- reply->writeInt32(result);
- return DRM_NO_ERROR;
- }
-
- case REMOVE_RIGHTS:
- {
- ALOGV("BnDrmManagerService::onTransact :REMOVE_RIGHTS");
- CHECK_INTERFACE(IDrmManagerService, data, reply);
-
- int uniqueId = data.readInt32();
- String8 path = data.readString8();
- const status_t status = removeRights(uniqueId, path);
- reply->writeInt32(status);
-
- return DRM_NO_ERROR;
- }
-
- case REMOVE_ALL_RIGHTS:
- {
- ALOGV("BnDrmManagerService::onTransact :REMOVE_ALL_RIGHTS");
- CHECK_INTERFACE(IDrmManagerService, data, reply);
-
- const status_t status = removeAllRights(data.readInt32());
- reply->writeInt32(status);
-
- return DRM_NO_ERROR;
- }
-
- case OPEN_CONVERT_SESSION:
- {
- ALOGV("BnDrmManagerService::onTransact :OPEN_CONVERT_SESSION");
- CHECK_INTERFACE(IDrmManagerService, data, reply);
-
- const int uniqueId = data.readInt32();
- const String8 mimeType = data.readString8();
- const int convertId = openConvertSession(uniqueId, mimeType);
-
- reply->writeInt32(convertId);
- return DRM_NO_ERROR;
- }
-
- case CONVERT_DATA:
- {
- ALOGV("BnDrmManagerService::onTransact :CONVERT_DATA");
- CHECK_INTERFACE(IDrmManagerService, data, reply);
-
- const int uniqueId = data.readInt32();
- const int convertId = data.readInt32();
-
- //Filling input data
- const int bufferSize = data.readInt32();
- DrmBuffer* inputData = new DrmBuffer((char *)data.readInplace(bufferSize), bufferSize);
-
- DrmConvertedStatus* drmConvertedStatus = convertData(uniqueId, convertId, inputData);
-
- if (NULL != drmConvertedStatus) {
- //Filling Drm Converted Ststus
- reply->writeInt32(drmConvertedStatus->statusCode);
- reply->writeInt64(drmConvertedStatus->offset);
-
- if (NULL != drmConvertedStatus->convertedData) {
- const DrmBuffer* convertedData = drmConvertedStatus->convertedData;
- const int bufferSize = convertedData->length;
- reply->writeInt32(bufferSize);
- if (0 < bufferSize) {
- reply->write(convertedData->data, bufferSize);
- }
- delete [] convertedData->data;
- delete convertedData; convertedData = NULL;
- }
- }
- delete inputData; inputData = NULL;
- delete drmConvertedStatus; drmConvertedStatus = NULL;
- return DRM_NO_ERROR;
- }
-
- case CLOSE_CONVERT_SESSION:
- {
- ALOGV("BnDrmManagerService::onTransact :CLOSE_CONVERT_SESSION");
- CHECK_INTERFACE(IDrmManagerService, data, reply);
-
- const int uniqueId = data.readInt32();
- const int convertId = data.readInt32();
- DrmConvertedStatus* drmConvertedStatus
- = closeConvertSession(uniqueId, convertId);
-
- if (NULL != drmConvertedStatus) {
- //Filling Drm Converted Ststus
- reply->writeInt32(drmConvertedStatus->statusCode);
- reply->writeInt64(drmConvertedStatus->offset);
-
- if (NULL != drmConvertedStatus->convertedData) {
- const DrmBuffer* convertedData = drmConvertedStatus->convertedData;
- const int bufferSize = convertedData->length;
- reply->writeInt32(bufferSize);
- if (0 < bufferSize) {
- reply->write(convertedData->data, bufferSize);
- }
- delete [] convertedData->data;
- delete convertedData; convertedData = NULL;
- }
- }
- delete drmConvertedStatus; drmConvertedStatus = NULL;
- return DRM_NO_ERROR;
- }
-
- case GET_ALL_SUPPORT_INFO:
- {
- ALOGV("BnDrmManagerService::onTransact :GET_ALL_SUPPORT_INFO");
- CHECK_INTERFACE(IDrmManagerService, data, reply);
-
- const int uniqueId = data.readInt32();
- int length = 0;
- DrmSupportInfo* drmSupportInfoArray = NULL;
-
- status_t status = getAllSupportInfo(uniqueId, &length, &drmSupportInfoArray);
-
- reply->writeInt32(length);
- for (int i = 0; i < length; ++i) {
- DrmSupportInfo drmSupportInfo = drmSupportInfoArray[i];
-
- reply->writeInt32(drmSupportInfo.getFileSuffixCount());
- DrmSupportInfo::FileSuffixIterator fileSuffixIt
- = drmSupportInfo.getFileSuffixIterator();
- while (fileSuffixIt.hasNext()) {
- reply->writeString8(fileSuffixIt.next());
- }
-
- reply->writeInt32(drmSupportInfo.getMimeTypeCount());
- DrmSupportInfo::MimeTypeIterator mimeTypeIt = drmSupportInfo.getMimeTypeIterator();
- while (mimeTypeIt.hasNext()) {
- reply->writeString8(mimeTypeIt.next());
- }
- reply->writeString8(drmSupportInfo.getDescription());
- }
- delete [] drmSupportInfoArray; drmSupportInfoArray = NULL;
- reply->writeInt32(status);
- return DRM_NO_ERROR;
- }
-
- case OPEN_DECRYPT_SESSION:
- {
- ALOGV("BnDrmManagerService::onTransact :OPEN_DECRYPT_SESSION");
- CHECK_INTERFACE(IDrmManagerService, data, reply);
-
- const int uniqueId = data.readInt32();
- const int fd = data.readFileDescriptor();
-
- const off64_t offset = data.readInt64();
- const off64_t length = data.readInt64();
- DecryptHandle* handle
- = openDecryptSession(uniqueId, fd, offset, length);
-
- if (NULL != handle) {
- writeDecryptHandleToParcelData(handle, reply);
- clearDecryptHandle(handle);
- delete handle; handle = NULL;
- }
- return DRM_NO_ERROR;
- }
-
- case OPEN_DECRYPT_SESSION_FROM_URI:
- {
- ALOGV("BnDrmManagerService::onTransact :OPEN_DECRYPT_SESSION_FROM_URI");
- CHECK_INTERFACE(IDrmManagerService, data, reply);
-
- const int uniqueId = data.readInt32();
- const String8 uri = data.readString8();
-
- DecryptHandle* handle = openDecryptSession(uniqueId, uri.string());
-
- if (NULL != handle) {
- writeDecryptHandleToParcelData(handle, reply);
-
- clearDecryptHandle(handle);
- delete handle; handle = NULL;
- } else {
- ALOGV("NULL decryptHandle is returned");
- }
- return DRM_NO_ERROR;
- }
-
- case CLOSE_DECRYPT_SESSION:
- {
- ALOGV("BnDrmManagerService::onTransact :CLOSE_DECRYPT_SESSION");
- CHECK_INTERFACE(IDrmManagerService, data, reply);
-
- const int uniqueId = data.readInt32();
-
- DecryptHandle* handle = new DecryptHandle();
- readDecryptHandleFromParcelData(handle, data);
-
- const status_t status = closeDecryptSession(uniqueId, handle);
- reply->writeInt32(status);
- return DRM_NO_ERROR;
- }
-
- case INITIALIZE_DECRYPT_UNIT:
- {
- ALOGV("BnDrmManagerService::onTransact :INITIALIZE_DECRYPT_UNIT");
- CHECK_INTERFACE(IDrmManagerService, data, reply);
-
- const int uniqueId = data.readInt32();
-
- DecryptHandle handle;
- readDecryptHandleFromParcelData(&handle, data);
-
- const int decryptUnitId = data.readInt32();
-
- //Filling Header info
- const int bufferSize = data.readInt32();
- DrmBuffer* headerInfo = NULL;
- headerInfo = new DrmBuffer((char *)data.readInplace(bufferSize), bufferSize);
-
- const status_t status
- = initializeDecryptUnit(uniqueId, &handle, decryptUnitId, headerInfo);
- reply->writeInt32(status);
-
- clearDecryptHandle(&handle);
- delete headerInfo; headerInfo = NULL;
- return DRM_NO_ERROR;
- }
-
- case DECRYPT:
- {
- ALOGV("BnDrmManagerService::onTransact :DECRYPT");
- CHECK_INTERFACE(IDrmManagerService, data, reply);
-
- const int uniqueId = data.readInt32();
-
- DecryptHandle handle;
- readDecryptHandleFromParcelData(&handle, data);
-
- const int decryptUnitId = data.readInt32();
- const int decBufferSize = data.readInt32();
-
- const int encBufferSize = data.readInt32();
- DrmBuffer* encBuffer
- = new DrmBuffer((char *)data.readInplace(encBufferSize), encBufferSize);
-
- char* buffer = NULL;
- buffer = new char[decBufferSize];
- DrmBuffer* decBuffer = new DrmBuffer(buffer, decBufferSize);
-
- DrmBuffer* IV = NULL;
- if (0 != data.dataAvail()) {
- const int ivBufferlength = data.readInt32();
- IV = new DrmBuffer((char *)data.readInplace(ivBufferlength), ivBufferlength);
- }
-
- const status_t status
- = decrypt(uniqueId, &handle, decryptUnitId, encBuffer, &decBuffer, IV);
-
- reply->writeInt32(status);
-
- const int size = decBuffer->length;
- reply->writeInt32(size);
- reply->write(decBuffer->data, size);
-
- clearDecryptHandle(&handle);
- delete encBuffer; encBuffer = NULL;
- delete decBuffer; decBuffer = NULL;
- delete [] buffer; buffer = NULL;
- delete IV; IV = NULL;
- return DRM_NO_ERROR;
- }
-
- case FINALIZE_DECRYPT_UNIT:
- {
- ALOGV("BnDrmManagerService::onTransact :FINALIZE_DECRYPT_UNIT");
- CHECK_INTERFACE(IDrmManagerService, data, reply);
-
- const int uniqueId = data.readInt32();
-
- DecryptHandle handle;
- readDecryptHandleFromParcelData(&handle, data);
-
- const status_t status = finalizeDecryptUnit(uniqueId, &handle, data.readInt32());
- reply->writeInt32(status);
-
- clearDecryptHandle(&handle);
- return DRM_NO_ERROR;
- }
-
- case PREAD:
- {
- ALOGV("BnDrmManagerService::onTransact :READ");
- CHECK_INTERFACE(IDrmManagerService, data, reply);
-
- const int uniqueId = data.readInt32();
-
- DecryptHandle handle;
- readDecryptHandleFromParcelData(&handle, data);
-
- const int numBytes = data.readInt32();
- char* buffer = new char[numBytes];
-
- const off64_t offset = data.readInt64();
-
- ssize_t result = pread(uniqueId, &handle, buffer, numBytes, offset);
- reply->writeInt32(result);
- if (0 < result) {
- reply->write(buffer, result);
- }
-
- clearDecryptHandle(&handle);
- delete [] buffer, buffer = NULL;
- return DRM_NO_ERROR;
- }
-
- default:
- return BBinder::onTransact(code, data, reply, flags);
- }
-}
-
diff --git a/drm/common/IDrmServiceListener.cpp b/drm/common/IDrmServiceListener.cpp
deleted file mode 100644
index 6eeea40..0000000
--- a/drm/common/IDrmServiceListener.cpp
+++ /dev/null
@@ -1,61 +0,0 @@
-/*
- * Copyright (C) 2010 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.
- */
-
-#include <stdint.h>
-#include <sys/types.h>
-#include <binder/Parcel.h>
-#include <binder/IPCThreadState.h>
-#include <drm/drm_framework_common.h>
-#include <drm/DrmInfoEvent.h>
-#include "IDrmServiceListener.h"
-
-using namespace android;
-
-status_t BpDrmServiceListener::notify(const DrmInfoEvent& event) {
- Parcel data, reply;
-
- data.writeInterfaceToken(IDrmServiceListener::getInterfaceDescriptor());
- data.writeInt32(event.getUniqueId());
- data.writeInt32(event.getType());
- data.writeString8(event.getMessage());
-
- remote()->transact(NOTIFY, data, &reply);
- return reply.readInt32();
-}
-
-IMPLEMENT_META_INTERFACE(DrmServiceListener, "drm.IDrmServiceListener");
-
-status_t BnDrmServiceListener::onTransact(
- uint32_t code, const Parcel& data, Parcel* reply, uint32_t flags) {
-
- switch (code) {
- case NOTIFY:
- {
- CHECK_INTERFACE(IDrmServiceListener, data, reply);
- int uniqueId = data.readInt32();
- int type = data.readInt32();
- const String8& message = data.readString8();
-
- status_t status = notify(DrmInfoEvent(uniqueId, type, message));
- reply->writeInt32(status);
-
- return DRM_NO_ERROR;
- }
- default:
- return BBinder::onTransact(code, data, reply, flags);
- }
-}
-
diff --git a/drm/common/ReadWriteUtils.cpp b/drm/common/ReadWriteUtils.cpp
deleted file mode 100644
index fd17e98..0000000
--- a/drm/common/ReadWriteUtils.cpp
+++ /dev/null
@@ -1,109 +0,0 @@
-/*
- * Copyright (C) 2010 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.
- */
-
-//#define LOG_NDEBUG 0
-#define LOG_TAG "ReadWriteUtils"
-#include <utils/Log.h>
-
-#include <ReadWriteUtils.h>
-#include <sys/mman.h>
-#include <sys/stat.h>
-#include <sys/types.h>
-#include <fcntl.h>
-#include <stdio.h>
-#include <stdlib.h>
-#include <unistd.h>
-#include <utils/String8.h>
-
-using namespace android;
-
-#define FAILURE -1
-
-String8 ReadWriteUtils::readBytes(const String8& filePath) {
- FILE* file = NULL;
- file = fopen(filePath.string(), "r");
-
- String8 string("");
- if (NULL != file) {
- int fd = fileno(file);
- struct stat sb;
-
- if (fstat(fd, &sb) == 0 && sb.st_size > 0) {
- off64_t length = sb.st_size;
- char* bytes = new char[length];
- if (length == read(fd, (void*) bytes, length)) {
- string.append(bytes, length);
- }
- delete bytes;
- }
- fclose(file);
- }
- return string;
-}
-
-int ReadWriteUtils::readBytes(const String8& filePath, char** buffer) {
- FILE* file = NULL;
- file = fopen(filePath.string(), "r");
- off64_t length = 0;
-
- if (NULL != file) {
- int fd = fileno(file);
- struct stat sb;
-
- if (fstat(fd, &sb) == 0 && sb.st_size > 0) {
- length = sb.st_size;
- *buffer = new char[length];
- if (length != read(fd, (void*) *buffer, length)) {
- length = FAILURE;
- }
- }
- fclose(file);
- }
- return length;
-}
-
-void ReadWriteUtils::writeToFile(const String8& filePath, const String8& data) {
- FILE* file = NULL;
- file = fopen(filePath.string(), "w+");
-
- if (NULL != file) {
- int fd = fileno(file);
-
- int size = data.size();
- if (FAILURE != ftruncate(fd, size)) {
- if (size != write(fd, data.string(), size)) {
- ALOGE("Failed to write the data to: %s", filePath.string());
- }
- }
- fclose(file);
- }
-}
-
-void ReadWriteUtils::appendToFile(const String8& filePath, const String8& data) {
- FILE* file = NULL;
- file = fopen(filePath.string(), "a+");
-
- if (NULL != file) {
- int fd = fileno(file);
-
- int size = data.size();
- if (size != write(fd, data.string(), size)) {
- ALOGE("Failed to write the data to: %s", filePath.string());
- }
- fclose(file);
- }
-}
-
diff --git a/drm/drmserver/Android.mk b/drm/drmserver/Android.mk
deleted file mode 100644
index fd417cb..0000000
--- a/drm/drmserver/Android.mk
+++ /dev/null
@@ -1,41 +0,0 @@
-#
-# Copyright (C) 2010 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.
-#
-LOCAL_PATH:= $(call my-dir)
-include $(CLEAR_VARS)
-
-LOCAL_SRC_FILES:= \
- main_drmserver.cpp \
- DrmManager.cpp \
- DrmManagerService.cpp
-
-LOCAL_SHARED_LIBRARIES := \
- libmedia \
- libutils \
- libbinder \
- libdl
-
-LOCAL_STATIC_LIBRARIES := libdrmframeworkcommon
-
-LOCAL_C_INCLUDES := \
- $(TOP)/frameworks/base/include \
- $(TOP)/frameworks/base/drm/libdrmframework/include \
- $(TOP)/frameworks/base/drm/libdrmframework/plugins/common/include
-
-LOCAL_MODULE:= drmserver
-
-LOCAL_MODULE_TAGS := optional
-
-include $(BUILD_EXECUTABLE)
diff --git a/drm/drmserver/DrmManager.cpp b/drm/drmserver/DrmManager.cpp
deleted file mode 100644
index 3abf3d3..0000000
--- a/drm/drmserver/DrmManager.cpp
+++ /dev/null
@@ -1,603 +0,0 @@
-/*
- * Copyright (C) 2010 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.
- */
-
-//#define LOG_NDEBUG 0
-#define LOG_TAG "DrmManager(Native)"
-#include "utils/Log.h"
-
-#include <utils/String8.h>
-#include <drm/DrmInfo.h>
-#include <drm/DrmInfoEvent.h>
-#include <drm/DrmRights.h>
-#include <drm/DrmConstraints.h>
-#include <drm/DrmMetadata.h>
-#include <drm/DrmInfoStatus.h>
-#include <drm/DrmInfoRequest.h>
-#include <drm/DrmSupportInfo.h>
-#include <drm/DrmConvertedStatus.h>
-#include <IDrmEngine.h>
-
-#include "DrmManager.h"
-#include "ReadWriteUtils.h"
-
-#define DECRYPT_FILE_ERROR -1
-
-using namespace android;
-
-const String8 DrmManager::EMPTY_STRING("");
-
-DrmManager::DrmManager() :
- mDecryptSessionId(0),
- mConvertId(0) {
-
-}
-
-DrmManager::~DrmManager() {
-
-}
-
-int DrmManager::addUniqueId(bool isNative) {
- Mutex::Autolock _l(mLock);
-
- int temp = 0;
- bool foundUniqueId = false;
- const int size = mUniqueIdVector.size();
- const int uniqueIdRange = 0xfff;
- int maxLoopTimes = (uniqueIdRange - 1) / 2;
- srand(time(NULL));
-
- while (!foundUniqueId) {
- temp = rand() & uniqueIdRange;
-
- if (isNative) {
- // set a flag to differentiate DrmManagerClient
- // created from native side and java side
- temp |= 0x1000;
- }
-
- int index = 0;
- for (; index < size; ++index) {
- if (mUniqueIdVector.itemAt(index) == temp) {
- foundUniqueId = false;
- break;
- }
- }
- if (index == size) {
- foundUniqueId = true;
- }
-
- maxLoopTimes --;
- LOG_FATAL_IF(maxLoopTimes <= 0, "cannot find an unique ID for this session");
- }
-
- mUniqueIdVector.push(temp);
- return temp;
-}
-
-void DrmManager::removeUniqueId(int uniqueId) {
- Mutex::Autolock _l(mLock);
- for (unsigned int i = 0; i < mUniqueIdVector.size(); i++) {
- if (uniqueId == mUniqueIdVector.itemAt(i)) {
- mUniqueIdVector.removeAt(i);
- break;
- }
- }
-}
-
-status_t DrmManager::loadPlugIns() {
-
- String8 vendorPluginDirPath("/vendor/lib/drm");
- loadPlugIns(vendorPluginDirPath);
-
- String8 pluginDirPath("/system/lib/drm");
- loadPlugIns(pluginDirPath);
- return DRM_NO_ERROR;
-
-}
-
-status_t DrmManager::loadPlugIns(const String8& plugInDirPath) {
- mPlugInManager.loadPlugIns(plugInDirPath);
- Vector<String8> plugInPathList = mPlugInManager.getPlugInIdList();
- for (unsigned int i = 0; i < plugInPathList.size(); ++i) {
- String8 plugInPath = plugInPathList[i];
- DrmSupportInfo* info = mPlugInManager.getPlugIn(plugInPath).getSupportInfo(0);
- if (NULL != info) {
- if (mSupportInfoToPlugInIdMap.indexOfKey(*info) < 0) {
- mSupportInfoToPlugInIdMap.add(*info, plugInPath);
- }
- delete info;
- }
- }
- return DRM_NO_ERROR;
-}
-
-status_t DrmManager::unloadPlugIns() {
- Mutex::Autolock _l(mLock);
- mConvertSessionMap.clear();
- mDecryptSessionMap.clear();
- mPlugInManager.unloadPlugIns();
- mSupportInfoToPlugInIdMap.clear();
- return DRM_NO_ERROR;
-}
-
-status_t DrmManager::setDrmServiceListener(
- int uniqueId, const sp<IDrmServiceListener>& drmServiceListener) {
- Mutex::Autolock _l(mListenerLock);
- if (NULL != drmServiceListener.get()) {
- mServiceListeners.add(uniqueId, drmServiceListener);
- } else {
- mServiceListeners.removeItem(uniqueId);
- }
- return DRM_NO_ERROR;
-}
-
-void DrmManager::addClient(int uniqueId) {
- Mutex::Autolock _l(mLock);
- if (!mSupportInfoToPlugInIdMap.isEmpty()) {
- Vector<String8> plugInIdList = mPlugInManager.getPlugInIdList();
- for (unsigned int index = 0; index < plugInIdList.size(); index++) {
- IDrmEngine& rDrmEngine = mPlugInManager.getPlugIn(plugInIdList.itemAt(index));
- rDrmEngine.initialize(uniqueId);
- rDrmEngine.setOnInfoListener(uniqueId, this);
- }
- }
-}
-
-void DrmManager::removeClient(int uniqueId) {
- Mutex::Autolock _l(mLock);
- Vector<String8> plugInIdList = mPlugInManager.getPlugInIdList();
- for (unsigned int index = 0; index < plugInIdList.size(); index++) {
- IDrmEngine& rDrmEngine = mPlugInManager.getPlugIn(plugInIdList.itemAt(index));
- rDrmEngine.terminate(uniqueId);
- }
-}
-
-DrmConstraints* DrmManager::getConstraints(int uniqueId, const String8* path, const int action) {
- Mutex::Autolock _l(mLock);
- const String8 plugInId = getSupportedPlugInIdFromPath(uniqueId, *path);
- if (EMPTY_STRING != plugInId) {
- IDrmEngine& rDrmEngine = mPlugInManager.getPlugIn(plugInId);
- return rDrmEngine.getConstraints(uniqueId, path, action);
- }
- return NULL;
-}
-
-DrmMetadata* DrmManager::getMetadata(int uniqueId, const String8* path) {
- Mutex::Autolock _l(mLock);
- const String8 plugInId = getSupportedPlugInIdFromPath(uniqueId, *path);
- if (EMPTY_STRING != plugInId) {
- IDrmEngine& rDrmEngine = mPlugInManager.getPlugIn(plugInId);
- return rDrmEngine.getMetadata(uniqueId, path);
- }
- return NULL;
-}
-
-status_t DrmManager::installDrmEngine(int uniqueId, const String8& absolutePath) {
- Mutex::Autolock _l(mLock);
- mPlugInManager.loadPlugIn(absolutePath);
-
- IDrmEngine& rDrmEngine = mPlugInManager.getPlugIn(absolutePath);
- rDrmEngine.initialize(uniqueId);
- rDrmEngine.setOnInfoListener(uniqueId, this);
-
- DrmSupportInfo* info = rDrmEngine.getSupportInfo(0);
- mSupportInfoToPlugInIdMap.add(*info, absolutePath);
- delete info;
-
- return DRM_NO_ERROR;
-}
-
-bool DrmManager::canHandle(int uniqueId, const String8& path, const String8& mimeType) {
- Mutex::Autolock _l(mLock);
- const String8 plugInId = getSupportedPlugInId(mimeType);
- bool result = (EMPTY_STRING != plugInId) ? true : false;
-
- if (0 < path.length()) {
- if (result) {
- IDrmEngine& rDrmEngine = mPlugInManager.getPlugIn(plugInId);
- result = rDrmEngine.canHandle(uniqueId, path);
- } else {
- String8 extension = path.getPathExtension();
- if (String8("") != extension) {
- result = canHandle(uniqueId, path);
- }
- }
- }
- return result;
-}
-
-DrmInfoStatus* DrmManager::processDrmInfo(int uniqueId, const DrmInfo* drmInfo) {
- Mutex::Autolock _l(mLock);
- const String8 plugInId = getSupportedPlugInId(drmInfo->getMimeType());
- if (EMPTY_STRING != plugInId) {
- IDrmEngine& rDrmEngine = mPlugInManager.getPlugIn(plugInId);
- return rDrmEngine.processDrmInfo(uniqueId, drmInfo);
- }
- return NULL;
-}
-
-bool DrmManager::canHandle(int uniqueId, const String8& path) {
- bool result = false;
- Vector<String8> plugInPathList = mPlugInManager.getPlugInIdList();
-
- for (unsigned int i = 0; i < plugInPathList.size(); ++i) {
- IDrmEngine& rDrmEngine = mPlugInManager.getPlugIn(plugInPathList[i]);
- result = rDrmEngine.canHandle(uniqueId, path);
-
- if (result) {
- break;
- }
- }
- return result;
-}
-
-DrmInfo* DrmManager::acquireDrmInfo(int uniqueId, const DrmInfoRequest* drmInfoRequest) {
- Mutex::Autolock _l(mLock);
- const String8 plugInId = getSupportedPlugInId(drmInfoRequest->getMimeType());
- if (EMPTY_STRING != plugInId) {
- IDrmEngine& rDrmEngine = mPlugInManager.getPlugIn(plugInId);
- return rDrmEngine.acquireDrmInfo(uniqueId, drmInfoRequest);
- }
- return NULL;
-}
-
-status_t DrmManager::saveRights(int uniqueId, const DrmRights& drmRights,
- const String8& rightsPath, const String8& contentPath) {
- Mutex::Autolock _l(mLock);
- const String8 plugInId = getSupportedPlugInId(drmRights.getMimeType());
- status_t result = DRM_ERROR_UNKNOWN;
- if (EMPTY_STRING != plugInId) {
- IDrmEngine& rDrmEngine = mPlugInManager.getPlugIn(plugInId);
- result = rDrmEngine.saveRights(uniqueId, drmRights, rightsPath, contentPath);
- }
- return result;
-}
-
-String8 DrmManager::getOriginalMimeType(int uniqueId, const String8& path) {
- Mutex::Autolock _l(mLock);
- const String8 plugInId = getSupportedPlugInIdFromPath(uniqueId, path);
- if (EMPTY_STRING != plugInId) {
- IDrmEngine& rDrmEngine = mPlugInManager.getPlugIn(plugInId);
- return rDrmEngine.getOriginalMimeType(uniqueId, path);
- }
- return EMPTY_STRING;
-}
-
-int DrmManager::getDrmObjectType(int uniqueId, const String8& path, const String8& mimeType) {
- Mutex::Autolock _l(mLock);
- const String8 plugInId = getSupportedPlugInId(uniqueId, path, mimeType);
- if (EMPTY_STRING != plugInId) {
- IDrmEngine& rDrmEngine = mPlugInManager.getPlugIn(plugInId);
- return rDrmEngine.getDrmObjectType(uniqueId, path, mimeType);
- }
- return DrmObjectType::UNKNOWN;
-}
-
-int DrmManager::checkRightsStatus(int uniqueId, const String8& path, int action) {
- Mutex::Autolock _l(mLock);
- const String8 plugInId = getSupportedPlugInIdFromPath(uniqueId, path);
- if (EMPTY_STRING != plugInId) {
- IDrmEngine& rDrmEngine = mPlugInManager.getPlugIn(plugInId);
- return rDrmEngine.checkRightsStatus(uniqueId, path, action);
- }
- return RightsStatus::RIGHTS_INVALID;
-}
-
-status_t DrmManager::consumeRights(
- int uniqueId, DecryptHandle* decryptHandle, int action, bool reserve) {
- status_t result = DRM_ERROR_UNKNOWN;
- Mutex::Autolock _l(mDecryptLock);
- if (mDecryptSessionMap.indexOfKey(decryptHandle->decryptId) != NAME_NOT_FOUND) {
- IDrmEngine* drmEngine = mDecryptSessionMap.valueFor(decryptHandle->decryptId);
- result = drmEngine->consumeRights(uniqueId, decryptHandle, action, reserve);
- }
- return result;
-}
-
-status_t DrmManager::setPlaybackStatus(
- int uniqueId, DecryptHandle* decryptHandle, int playbackStatus, int64_t position) {
- status_t result = DRM_ERROR_UNKNOWN;
- Mutex::Autolock _l(mDecryptLock);
- if (mDecryptSessionMap.indexOfKey(decryptHandle->decryptId) != NAME_NOT_FOUND) {
- IDrmEngine* drmEngine = mDecryptSessionMap.valueFor(decryptHandle->decryptId);
- result = drmEngine->setPlaybackStatus(uniqueId, decryptHandle, playbackStatus, position);
- }
- return result;
-}
-
-bool DrmManager::validateAction(
- int uniqueId, const String8& path, int action, const ActionDescription& description) {
- Mutex::Autolock _l(mLock);
- const String8 plugInId = getSupportedPlugInIdFromPath(uniqueId, path);
- if (EMPTY_STRING != plugInId) {
- IDrmEngine& rDrmEngine = mPlugInManager.getPlugIn(plugInId);
- return rDrmEngine.validateAction(uniqueId, path, action, description);
- }
- return false;
-}
-
-status_t DrmManager::removeRights(int uniqueId, const String8& path) {
- Mutex::Autolock _l(mLock);
- const String8 plugInId = getSupportedPlugInIdFromPath(uniqueId, path);
- status_t result = DRM_ERROR_UNKNOWN;
- if (EMPTY_STRING != plugInId) {
- IDrmEngine& rDrmEngine = mPlugInManager.getPlugIn(plugInId);
- result = rDrmEngine.removeRights(uniqueId, path);
- }
- return result;
-}
-
-status_t DrmManager::removeAllRights(int uniqueId) {
- Vector<String8> plugInIdList = mPlugInManager.getPlugInIdList();
- status_t result = DRM_ERROR_UNKNOWN;
- for (unsigned int index = 0; index < plugInIdList.size(); index++) {
- IDrmEngine& rDrmEngine = mPlugInManager.getPlugIn(plugInIdList.itemAt(index));
- result = rDrmEngine.removeAllRights(uniqueId);
- if (DRM_NO_ERROR != result) {
- break;
- }
- }
- return result;
-}
-
-int DrmManager::openConvertSession(int uniqueId, const String8& mimeType) {
- Mutex::Autolock _l(mConvertLock);
- int convertId = -1;
-
- const String8 plugInId = getSupportedPlugInId(mimeType);
- if (EMPTY_STRING != plugInId) {
- IDrmEngine& rDrmEngine = mPlugInManager.getPlugIn(plugInId);
-
- if (DRM_NO_ERROR == rDrmEngine.openConvertSession(uniqueId, mConvertId + 1)) {
- ++mConvertId;
- convertId = mConvertId;
- mConvertSessionMap.add(convertId, &rDrmEngine);
- }
- }
- return convertId;
-}
-
-DrmConvertedStatus* DrmManager::convertData(
- int uniqueId, int convertId, const DrmBuffer* inputData) {
- DrmConvertedStatus *drmConvertedStatus = NULL;
-
- Mutex::Autolock _l(mConvertLock);
- if (mConvertSessionMap.indexOfKey(convertId) != NAME_NOT_FOUND) {
- IDrmEngine* drmEngine = mConvertSessionMap.valueFor(convertId);
- drmConvertedStatus = drmEngine->convertData(uniqueId, convertId, inputData);
- }
- return drmConvertedStatus;
-}
-
-DrmConvertedStatus* DrmManager::closeConvertSession(int uniqueId, int convertId) {
- Mutex::Autolock _l(mConvertLock);
- DrmConvertedStatus *drmConvertedStatus = NULL;
-
- if (mConvertSessionMap.indexOfKey(convertId) != NAME_NOT_FOUND) {
- IDrmEngine* drmEngine = mConvertSessionMap.valueFor(convertId);
- drmConvertedStatus = drmEngine->closeConvertSession(uniqueId, convertId);
- mConvertSessionMap.removeItem(convertId);
- }
- return drmConvertedStatus;
-}
-
-status_t DrmManager::getAllSupportInfo(
- int uniqueId, int* length, DrmSupportInfo** drmSupportInfoArray) {
- Mutex::Autolock _l(mLock);
- Vector<String8> plugInPathList = mPlugInManager.getPlugInIdList();
- int size = plugInPathList.size();
- int validPlugins = 0;
-
- if (0 < size) {
- Vector<DrmSupportInfo> drmSupportInfoList;
-
- for (int i = 0; i < size; ++i) {
- String8 plugInPath = plugInPathList[i];
- DrmSupportInfo* drmSupportInfo
- = mPlugInManager.getPlugIn(plugInPath).getSupportInfo(0);
- if (NULL != drmSupportInfo) {
- drmSupportInfoList.add(*drmSupportInfo);
- delete drmSupportInfo; drmSupportInfo = NULL;
- }
- }
-
- validPlugins = drmSupportInfoList.size();
- if (0 < validPlugins) {
- *drmSupportInfoArray = new DrmSupportInfo[validPlugins];
- for (int i = 0; i < validPlugins; ++i) {
- (*drmSupportInfoArray)[i] = drmSupportInfoList[i];
- }
- }
- }
- *length = validPlugins;
- return DRM_NO_ERROR;
-}
-
-DecryptHandle* DrmManager::openDecryptSession(int uniqueId, int fd, off64_t offset, off64_t length) {
- Mutex::Autolock _l(mDecryptLock);
- status_t result = DRM_ERROR_CANNOT_HANDLE;
- Vector<String8> plugInIdList = mPlugInManager.getPlugInIdList();
-
- DecryptHandle* handle = new DecryptHandle();
- if (NULL != handle) {
- handle->decryptId = mDecryptSessionId + 1;
-
- for (unsigned int index = 0; index < plugInIdList.size(); index++) {
- String8 plugInId = plugInIdList.itemAt(index);
- IDrmEngine& rDrmEngine = mPlugInManager.getPlugIn(plugInId);
- result = rDrmEngine.openDecryptSession(uniqueId, handle, fd, offset, length);
-
- if (DRM_NO_ERROR == result) {
- ++mDecryptSessionId;
- mDecryptSessionMap.add(mDecryptSessionId, &rDrmEngine);
- break;
- }
- }
- }
- if (DRM_NO_ERROR != result) {
- delete handle; handle = NULL;
- }
- return handle;
-}
-
-DecryptHandle* DrmManager::openDecryptSession(int uniqueId, const char* uri) {
- Mutex::Autolock _l(mDecryptLock);
- status_t result = DRM_ERROR_CANNOT_HANDLE;
- Vector<String8> plugInIdList = mPlugInManager.getPlugInIdList();
-
- DecryptHandle* handle = new DecryptHandle();
- if (NULL != handle) {
- handle->decryptId = mDecryptSessionId + 1;
-
- for (unsigned int index = 0; index < plugInIdList.size(); index++) {
- String8 plugInId = plugInIdList.itemAt(index);
- IDrmEngine& rDrmEngine = mPlugInManager.getPlugIn(plugInId);
- result = rDrmEngine.openDecryptSession(uniqueId, handle, uri);
-
- if (DRM_NO_ERROR == result) {
- ++mDecryptSessionId;
- mDecryptSessionMap.add(mDecryptSessionId, &rDrmEngine);
- break;
- }
- }
- }
- if (DRM_NO_ERROR != result) {
- delete handle; handle = NULL;
- ALOGV("DrmManager::openDecryptSession: no capable plug-in found");
- }
- return handle;
-}
-
-status_t DrmManager::closeDecryptSession(int uniqueId, DecryptHandle* decryptHandle) {
- Mutex::Autolock _l(mDecryptLock);
- status_t result = DRM_ERROR_UNKNOWN;
- if (mDecryptSessionMap.indexOfKey(decryptHandle->decryptId) != NAME_NOT_FOUND) {
- IDrmEngine* drmEngine = mDecryptSessionMap.valueFor(decryptHandle->decryptId);
- result = drmEngine->closeDecryptSession(uniqueId, decryptHandle);
- if (DRM_NO_ERROR == result) {
- mDecryptSessionMap.removeItem(decryptHandle->decryptId);
- }
- }
- return result;
-}
-
-status_t DrmManager::initializeDecryptUnit(
- int uniqueId, DecryptHandle* decryptHandle, int decryptUnitId, const DrmBuffer* headerInfo) {
- status_t result = DRM_ERROR_UNKNOWN;
- Mutex::Autolock _l(mDecryptLock);
- if (mDecryptSessionMap.indexOfKey(decryptHandle->decryptId) != NAME_NOT_FOUND) {
- IDrmEngine* drmEngine = mDecryptSessionMap.valueFor(decryptHandle->decryptId);
- result = drmEngine->initializeDecryptUnit(uniqueId, decryptHandle, decryptUnitId, headerInfo);
- }
- return result;
-}
-
-status_t DrmManager::decrypt(int uniqueId, DecryptHandle* decryptHandle, int decryptUnitId,
- const DrmBuffer* encBuffer, DrmBuffer** decBuffer, DrmBuffer* IV) {
- status_t result = DRM_ERROR_UNKNOWN;
-
- Mutex::Autolock _l(mDecryptLock);
- if (mDecryptSessionMap.indexOfKey(decryptHandle->decryptId) != NAME_NOT_FOUND) {
- IDrmEngine* drmEngine = mDecryptSessionMap.valueFor(decryptHandle->decryptId);
- result = drmEngine->decrypt(
- uniqueId, decryptHandle, decryptUnitId, encBuffer, decBuffer, IV);
- }
- return result;
-}
-
-status_t DrmManager::finalizeDecryptUnit(
- int uniqueId, DecryptHandle* decryptHandle, int decryptUnitId) {
- status_t result = DRM_ERROR_UNKNOWN;
- Mutex::Autolock _l(mDecryptLock);
- if (mDecryptSessionMap.indexOfKey(decryptHandle->decryptId) != NAME_NOT_FOUND) {
- IDrmEngine* drmEngine = mDecryptSessionMap.valueFor(decryptHandle->decryptId);
- result = drmEngine->finalizeDecryptUnit(uniqueId, decryptHandle, decryptUnitId);
- }
- return result;
-}
-
-ssize_t DrmManager::pread(int uniqueId, DecryptHandle* decryptHandle,
- void* buffer, ssize_t numBytes, off64_t offset) {
- ssize_t result = DECRYPT_FILE_ERROR;
-
- Mutex::Autolock _l(mDecryptLock);
- if (mDecryptSessionMap.indexOfKey(decryptHandle->decryptId) != NAME_NOT_FOUND) {
- IDrmEngine* drmEngine = mDecryptSessionMap.valueFor(decryptHandle->decryptId);
- result = drmEngine->pread(uniqueId, decryptHandle, buffer, numBytes, offset);
- }
- return result;
-}
-
-String8 DrmManager::getSupportedPlugInId(
- int uniqueId, const String8& path, const String8& mimeType) {
- String8 plugInId("");
-
- if (EMPTY_STRING != mimeType) {
- plugInId = getSupportedPlugInId(mimeType);
- } else {
- plugInId = getSupportedPlugInIdFromPath(uniqueId, path);
- }
- return plugInId;
-}
-
-String8 DrmManager::getSupportedPlugInId(const String8& mimeType) {
- String8 plugInId("");
-
- if (EMPTY_STRING != mimeType) {
- for (unsigned int index = 0; index < mSupportInfoToPlugInIdMap.size(); index++) {
- const DrmSupportInfo& drmSupportInfo = mSupportInfoToPlugInIdMap.keyAt(index);
-
- if (drmSupportInfo.isSupportedMimeType(mimeType)) {
- plugInId = mSupportInfoToPlugInIdMap.valueFor(drmSupportInfo);
- break;
- }
- }
- }
- return plugInId;
-}
-
-String8 DrmManager::getSupportedPlugInIdFromPath(int uniqueId, const String8& path) {
- String8 plugInId("");
- const String8 fileSuffix = path.getPathExtension();
-
- for (unsigned int index = 0; index < mSupportInfoToPlugInIdMap.size(); index++) {
- const DrmSupportInfo& drmSupportInfo = mSupportInfoToPlugInIdMap.keyAt(index);
-
- if (drmSupportInfo.isSupportedFileSuffix(fileSuffix)) {
- String8 key = mSupportInfoToPlugInIdMap.valueFor(drmSupportInfo);
- IDrmEngine& drmEngine = mPlugInManager.getPlugIn(key);
-
- if (drmEngine.canHandle(uniqueId, path)) {
- plugInId = key;
- break;
- }
- }
- }
- return plugInId;
-}
-
-void DrmManager::onInfo(const DrmInfoEvent& event) {
- Mutex::Autolock _l(mListenerLock);
- for (unsigned int index = 0; index < mServiceListeners.size(); index++) {
- int uniqueId = mServiceListeners.keyAt(index);
-
- if (uniqueId == event.getUniqueId()) {
- sp<IDrmServiceListener> serviceListener = mServiceListeners.valueFor(uniqueId);
- serviceListener->notify(event);
- }
- }
-}
-
diff --git a/drm/drmserver/DrmManagerService.cpp b/drm/drmserver/DrmManagerService.cpp
deleted file mode 100644
index df17ac5..0000000
--- a/drm/drmserver/DrmManagerService.cpp
+++ /dev/null
@@ -1,287 +0,0 @@
-/*
- * Copyright (C) 2010 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.
- */
-
-//#define LOG_NDEBUG 0
-#define LOG_TAG "DrmManagerService(Native)"
-#include <utils/Log.h>
-
-#include <private/android_filesystem_config.h>
-#include <media/MemoryLeakTrackUtil.h>
-
-#include <errno.h>
-#include <utils/threads.h>
-#include <binder/IServiceManager.h>
-#include <binder/IPCThreadState.h>
-#include <sys/stat.h>
-#include "DrmManagerService.h"
-#include "DrmManager.h"
-
-using namespace android;
-
-static Vector<uid_t> trustedUids;
-
-static bool isProtectedCallAllowed() {
- // TODO
- // Following implementation is just for reference.
- // Each OEM manufacturer should implement/replace with their own solutions.
- bool result = false;
-
- IPCThreadState* ipcState = IPCThreadState::self();
- uid_t uid = ipcState->getCallingUid();
-
- for (unsigned int i = 0; i < trustedUids.size(); ++i) {
- if (trustedUids[i] == uid) {
- result = true;
- break;
- }
- }
- return result;
-}
-
-void DrmManagerService::instantiate() {
- ALOGV("instantiate");
- defaultServiceManager()->addService(String16("drm.drmManager"), new DrmManagerService());
-
- if (0 >= trustedUids.size()) {
- // TODO
- // Following implementation is just for reference.
- // Each OEM manufacturer should implement/replace with their own solutions.
-
- // Add trusted uids here
- trustedUids.push(AID_MEDIA);
- }
-}
-
-DrmManagerService::DrmManagerService() :
- mDrmManager(NULL) {
- ALOGV("created");
- mDrmManager = new DrmManager();
- mDrmManager->loadPlugIns();
-}
-
-DrmManagerService::~DrmManagerService() {
- ALOGV("Destroyed");
- mDrmManager->unloadPlugIns();
- delete mDrmManager; mDrmManager = NULL;
-}
-
-int DrmManagerService::addUniqueId(bool isNative) {
- return mDrmManager->addUniqueId(isNative);
-}
-
-void DrmManagerService::removeUniqueId(int uniqueId) {
- mDrmManager->removeUniqueId(uniqueId);
-}
-
-void DrmManagerService::addClient(int uniqueId) {
- mDrmManager->addClient(uniqueId);
-}
-
-void DrmManagerService::removeClient(int uniqueId) {
- mDrmManager->removeClient(uniqueId);
-}
-
-status_t DrmManagerService::setDrmServiceListener(
- int uniqueId, const sp<IDrmServiceListener>& drmServiceListener) {
- ALOGV("Entering setDrmServiceListener");
- mDrmManager->setDrmServiceListener(uniqueId, drmServiceListener);
- return DRM_NO_ERROR;
-}
-
-status_t DrmManagerService::installDrmEngine(int uniqueId, const String8& drmEngineFile) {
- ALOGV("Entering installDrmEngine");
- return mDrmManager->installDrmEngine(uniqueId, drmEngineFile);
-}
-
-DrmConstraints* DrmManagerService::getConstraints(
- int uniqueId, const String8* path, const int action) {
- ALOGV("Entering getConstraints from content");
- return mDrmManager->getConstraints(uniqueId, path, action);
-}
-
-DrmMetadata* DrmManagerService::getMetadata(int uniqueId, const String8* path) {
- ALOGV("Entering getMetadata from content");
- return mDrmManager->getMetadata(uniqueId, path);
-}
-
-bool DrmManagerService::canHandle(int uniqueId, const String8& path, const String8& mimeType) {
- ALOGV("Entering canHandle");
- return mDrmManager->canHandle(uniqueId, path, mimeType);
-}
-
-DrmInfoStatus* DrmManagerService::processDrmInfo(int uniqueId, const DrmInfo* drmInfo) {
- ALOGV("Entering processDrmInfo");
- return mDrmManager->processDrmInfo(uniqueId, drmInfo);
-}
-
-DrmInfo* DrmManagerService::acquireDrmInfo(int uniqueId, const DrmInfoRequest* drmInfoRequest) {
- ALOGV("Entering acquireDrmInfo");
- return mDrmManager->acquireDrmInfo(uniqueId, drmInfoRequest);
-}
-
-status_t DrmManagerService::saveRights(
- int uniqueId, const DrmRights& drmRights,
- const String8& rightsPath, const String8& contentPath) {
- ALOGV("Entering saveRights");
- return mDrmManager->saveRights(uniqueId, drmRights, rightsPath, contentPath);
-}
-
-String8 DrmManagerService::getOriginalMimeType(int uniqueId, const String8& path) {
- ALOGV("Entering getOriginalMimeType");
- return mDrmManager->getOriginalMimeType(uniqueId, path);
-}
-
-int DrmManagerService::getDrmObjectType(
- int uniqueId, const String8& path, const String8& mimeType) {
- ALOGV("Entering getDrmObjectType");
- return mDrmManager->getDrmObjectType(uniqueId, path, mimeType);
-}
-
-int DrmManagerService::checkRightsStatus(
- int uniqueId, const String8& path, int action) {
- ALOGV("Entering checkRightsStatus");
- return mDrmManager->checkRightsStatus(uniqueId, path, action);
-}
-
-status_t DrmManagerService::consumeRights(
- int uniqueId, DecryptHandle* decryptHandle, int action, bool reserve) {
- ALOGV("Entering consumeRights");
- return mDrmManager->consumeRights(uniqueId, decryptHandle, action, reserve);
-}
-
-status_t DrmManagerService::setPlaybackStatus(
- int uniqueId, DecryptHandle* decryptHandle, int playbackStatus, int64_t position) {
- ALOGV("Entering setPlaybackStatus");
- return mDrmManager->setPlaybackStatus(uniqueId, decryptHandle, playbackStatus, position);
-}
-
-bool DrmManagerService::validateAction(
- int uniqueId, const String8& path,
- int action, const ActionDescription& description) {
- ALOGV("Entering validateAction");
- return mDrmManager->validateAction(uniqueId, path, action, description);
-}
-
-status_t DrmManagerService::removeRights(int uniqueId, const String8& path) {
- ALOGV("Entering removeRights");
- return mDrmManager->removeRights(uniqueId, path);
-}
-
-status_t DrmManagerService::removeAllRights(int uniqueId) {
- ALOGV("Entering removeAllRights");
- return mDrmManager->removeAllRights(uniqueId);
-}
-
-int DrmManagerService::openConvertSession(int uniqueId, const String8& mimeType) {
- ALOGV("Entering openConvertSession");
- return mDrmManager->openConvertSession(uniqueId, mimeType);
-}
-
-DrmConvertedStatus* DrmManagerService::convertData(
- int uniqueId, int convertId, const DrmBuffer* inputData) {
- ALOGV("Entering convertData");
- return mDrmManager->convertData(uniqueId, convertId, inputData);
-}
-
-DrmConvertedStatus* DrmManagerService::closeConvertSession(int uniqueId, int convertId) {
- ALOGV("Entering closeConvertSession");
- return mDrmManager->closeConvertSession(uniqueId, convertId);
-}
-
-status_t DrmManagerService::getAllSupportInfo(
- int uniqueId, int* length, DrmSupportInfo** drmSupportInfoArray) {
- ALOGV("Entering getAllSupportInfo");
- return mDrmManager->getAllSupportInfo(uniqueId, length, drmSupportInfoArray);
-}
-
-DecryptHandle* DrmManagerService::openDecryptSession(
- int uniqueId, int fd, off64_t offset, off64_t length) {
- ALOGV("Entering DrmManagerService::openDecryptSession");
- if (isProtectedCallAllowed()) {
- return mDrmManager->openDecryptSession(uniqueId, fd, offset, length);
- }
-
- return NULL;
-}
-
-DecryptHandle* DrmManagerService::openDecryptSession(
- int uniqueId, const char* uri) {
- ALOGV("Entering DrmManagerService::openDecryptSession with uri");
- if (isProtectedCallAllowed()) {
- return mDrmManager->openDecryptSession(uniqueId, uri);
- }
-
- return NULL;
-}
-
-status_t DrmManagerService::closeDecryptSession(int uniqueId, DecryptHandle* decryptHandle) {
- ALOGV("Entering closeDecryptSession");
- return mDrmManager->closeDecryptSession(uniqueId, decryptHandle);
-}
-
-status_t DrmManagerService::initializeDecryptUnit(int uniqueId, DecryptHandle* decryptHandle,
- int decryptUnitId, const DrmBuffer* headerInfo) {
- ALOGV("Entering initializeDecryptUnit");
- return mDrmManager->initializeDecryptUnit(uniqueId,decryptHandle, decryptUnitId, headerInfo);
-}
-
-status_t DrmManagerService::decrypt(
- int uniqueId, DecryptHandle* decryptHandle, int decryptUnitId,
- const DrmBuffer* encBuffer, DrmBuffer** decBuffer, DrmBuffer* IV) {
- ALOGV("Entering decrypt");
- return mDrmManager->decrypt(uniqueId, decryptHandle, decryptUnitId, encBuffer, decBuffer, IV);
-}
-
-status_t DrmManagerService::finalizeDecryptUnit(
- int uniqueId, DecryptHandle* decryptHandle, int decryptUnitId) {
- ALOGV("Entering finalizeDecryptUnit");
- return mDrmManager->finalizeDecryptUnit(uniqueId, decryptHandle, decryptUnitId);
-}
-
-ssize_t DrmManagerService::pread(int uniqueId, DecryptHandle* decryptHandle,
- void* buffer, ssize_t numBytes, off64_t offset) {
- ALOGV("Entering pread");
- return mDrmManager->pread(uniqueId, decryptHandle, buffer, numBytes, offset);
-}
-
-status_t DrmManagerService::dump(int fd, const Vector<String16>& args)
-{
- const size_t SIZE = 256;
- char buffer[SIZE];
- String8 result;
- if (checkCallingPermission(String16("android.permission.DUMP")) == false) {
- snprintf(buffer, SIZE, "Permission Denial: "
- "can't dump DrmManagerService from pid=%d, uid=%d\n",
- IPCThreadState::self()->getCallingPid(),
- IPCThreadState::self()->getCallingUid());
- result.append(buffer);
- } else {
-#if DRM_MEMORY_LEAK_TRACK
- bool dumpMem = false;
- for (size_t i = 0; i < args.size(); i++) {
- if (args[i] == String16("-m")) {
- dumpMem = true;
- }
- }
- if (dumpMem) {
- dumpMemoryAddresses(fd);
- }
-#endif
- }
- write(fd, result.string(), result.size());
- return NO_ERROR;
-}
-
diff --git a/drm/drmserver/main_drmserver.cpp b/drm/drmserver/main_drmserver.cpp
deleted file mode 100644
index ed42818..0000000
--- a/drm/drmserver/main_drmserver.cpp
+++ /dev/null
@@ -1,40 +0,0 @@
-/*
- * Copyright (C) 2010 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.
- */
-
-#include <sys/types.h>
-#include <unistd.h>
-#include <grp.h>
-
-#include <binder/IPCThreadState.h>
-#include <binder/ProcessState.h>
-#include <binder/IServiceManager.h>
-#include <utils/Log.h>
-#include <private/android_filesystem_config.h>
-
-#include <DrmManagerService.h>
-
-using namespace android;
-
-int main(int argc, char** argv)
-{
- sp<ProcessState> proc(ProcessState::self());
- sp<IServiceManager> sm = defaultServiceManager();
- ALOGI("ServiceManager: %p", sm.get());
- DrmManagerService::instantiate();
- ProcessState::self()->startThreadPool();
- IPCThreadState::self()->joinThreadPool();
-}
-
diff --git a/drm/java/android/drm/DrmConvertedStatus.java b/drm/java/android/drm/DrmConvertedStatus.java
index cecb135..f6e570a 100755
--- a/drm/java/android/drm/DrmConvertedStatus.java
+++ b/drm/java/android/drm/DrmConvertedStatus.java
@@ -18,36 +18,67 @@ package android.drm;
/**
* An entity class that wraps converted data, conversion status, and the
- * offset for appending the header and body signature to the converted data. An instance of this
- * class is returned by the {@link DrmManagerClient#convertData convertData()} and
- * {@link DrmManagerClient#closeConvertSession closeConvertSession()} methods. The offset is provided only when a
- * conversion session is closed by calling {@link DrmManagerClient#closeConvertSession closeConvertSession()}.
+ * offset for appending the header and body signature to the converted data.
+ * An instance of this class may be created two ways by the drm framework:
+ * a) a call to {@link DrmManagerClient#convertData DrmManagerClient.convertData()} and
+ * b) a call to {@link DrmManagerClient#closeConvertSession DrmManagerClient.closeConvertSession()}.
+ * An valid offset value is provided only from a success call to
+ * {@link DrmManagerClient#closeConvertSession DrmManagerClient.closeConvertSession()}.
*
*/
public class DrmConvertedStatus {
- // Should be in sync with DrmConvertedStatus.cpp
+ // The following status code constants must be in sync with
+ // DrmConvertedStatus.cpp. Please also update isValidStatusCode()
+ // when more status code constants are added.
+ /**
+ * Indicate the conversion status is successful.
+ */
public static final int STATUS_OK = 1;
+ /**
+ * Indicate a failed conversion status due to input data.
+ */
public static final int STATUS_INPUTDATA_ERROR = 2;
+ /**
+ * Indicate a general failed conversion status.
+ */
public static final int STATUS_ERROR = 3;
- /** Status code for the conversion.*/
+ /**
+ * Status code for the conversion. Must be one of the defined status
+ * constants above.
+ */
public final int statusCode;
- /** Converted data.*/
+ /**
+ * Converted data. It is optional and thus can be null.
+ */
public final byte[] convertedData;
- /** Offset value for the body and header signature.*/
+ /**
+ * Offset value for the body and header signature.
+ */
public final int offset;
/**
* Creates a <code>DrmConvertedStatus</code> object with the specified parameters.
*
- * @param _statusCode Conversion status.
- * @param _convertedData Converted data.
- * @param _offset Offset value for appending the header and body signature.
+ * @param statusCode Conversion status. Must be one of the status code constants
+ * defined above.
+ * @param convertedData Converted data. It can be null.
+ * @param offset Offset value for appending the header and body signature.
*/
- public DrmConvertedStatus(int _statusCode, byte[] _convertedData, int _offset) {
- statusCode = _statusCode;
- convertedData = _convertedData;
- offset = _offset;
+ public DrmConvertedStatus(int statusCode, byte[] convertedData, int offset) {
+ if (!isValidStatusCode(statusCode)) {
+ throw new IllegalArgumentException("Unsupported status code: " + statusCode);
+ }
+
+ this.statusCode = statusCode;
+ this.convertedData = convertedData;
+ this.offset = offset;
+ }
+
+ private boolean isValidStatusCode(int statusCode) {
+ return statusCode == STATUS_OK ||
+ statusCode == STATUS_INPUTDATA_ERROR ||
+ statusCode == STATUS_ERROR;
}
}
diff --git a/drm/java/android/drm/DrmErrorEvent.java b/drm/java/android/drm/DrmErrorEvent.java
index 2cb82e6..c61819d 100755
--- a/drm/java/android/drm/DrmErrorEvent.java
+++ b/drm/java/android/drm/DrmErrorEvent.java
@@ -24,6 +24,10 @@ import java.util.HashMap;
*
*/
public class DrmErrorEvent extends DrmEvent {
+
+ // Please add newly defined type constants to the end of the list,
+ // and modify checkTypeValidity() accordingly.
+
/**
* Something went wrong installing the rights.
*/
@@ -60,28 +64,46 @@ public class DrmErrorEvent extends DrmEvent {
*/
public static final int TYPE_ACQUIRE_DRM_INFO_FAILED = 2008;
+ // Add more type constants here...
+
+ // FIXME:
+ // We may want to add a user-defined type constant, such as
+ // TYPE_VENDOR_SPECIFIC_FAILED, to take care vendor specific use
+ // cases.
+
+
/**
* Creates a <code>DrmErrorEvent</code> object with the specified parameters.
*
* @param uniqueId Unique session identifier.
- * @param type Type of the event. Could be any of the event types defined above.
- * @param message Message description.
+ * @param type Type of the event. Must be any of the event types defined above.
+ * @param message Message description. It can be null.
*/
public DrmErrorEvent(int uniqueId, int type, String message) {
super(uniqueId, type, message);
+ checkTypeValidity(type);
}
/**
* Creates a <code>DrmErrorEvent</code> object with the specified parameters.
*
* @param uniqueId Unique session identifier.
- * @param type Type of the event. Could be any of the event types defined above.
+ * @param type Type of the event. Must be any of the event types defined above.
* @param message Message description.
* @param attributes Attributes for extensible information. Could be any
- * information provided by the plug-in.
+ * information provided by the plug-in. It can be null.
*/
public DrmErrorEvent(int uniqueId, int type, String message,
HashMap<String, Object> attributes) {
super(uniqueId, type, message, attributes);
+ checkTypeValidity(type);
+ }
+
+ private void checkTypeValidity(int type) {
+ if (type < TYPE_RIGHTS_NOT_INSTALLED ||
+ type > TYPE_ACQUIRE_DRM_INFO_FAILED) {
+ final String msg = "Unsupported type: " + type;
+ throw new IllegalArgumentException(msg);
+ }
}
}
diff --git a/drm/java/android/drm/DrmEvent.java b/drm/java/android/drm/DrmEvent.java
index 4053eb3..1a19f5c 100755
--- a/drm/java/android/drm/DrmEvent.java
+++ b/drm/java/android/drm/DrmEvent.java
@@ -23,6 +23,10 @@ import java.util.HashMap;
*
*/
public class DrmEvent {
+
+ // Please do not add type constants in this class. More event type constants
+ // should go to DrmInfoEvent or DrmErrorEvent classes.
+
/**
* All of the rights information associated with all DRM schemes have been successfully removed.
*/
diff --git a/drm/java/android/drm/DrmInfo.java b/drm/java/android/drm/DrmInfo.java
index 8812bfe..22d06c7 100755
--- a/drm/java/android/drm/DrmInfo.java
+++ b/drm/java/android/drm/DrmInfo.java
@@ -49,6 +49,13 @@ public class DrmInfo {
mInfoType = infoType;
mMimeType = mimeType;
mData = data;
+ if (!isValid()) {
+ final String msg = "infoType: " + infoType + "," +
+ "mimeType: " + mimeType + "," +
+ "data: " + data;
+
+ throw new IllegalArgumentException(msg);
+ }
}
/**
@@ -69,6 +76,13 @@ public class DrmInfo {
// call would fail with IllegalArgumentException because of mData = null
mData = null;
}
+ if (!isValid()) {
+ final String msg = "infoType: " + infoType + "," +
+ "mimeType: " + mimeType + "," +
+ "data: " + mData;
+
+ throw new IllegalArgumentException();
+ }
}
/**
diff --git a/drm/java/android/drm/DrmInfoEvent.java b/drm/java/android/drm/DrmInfoEvent.java
index 67aa0a9..2826dce 100755
--- a/drm/java/android/drm/DrmInfoEvent.java
+++ b/drm/java/android/drm/DrmInfoEvent.java
@@ -24,6 +24,10 @@ import java.util.HashMap;
*
*/
public class DrmInfoEvent extends DrmEvent {
+
+ // Please add newly defined type constants to the end of the list,
+ // and modify checkTypeValidity() accordingly.
+
/**
* The registration has already been done by another account ID.
*/
@@ -50,29 +54,57 @@ public class DrmInfoEvent extends DrmEvent {
*/
public static final int TYPE_RIGHTS_REMOVED = 6;
+ // Add more type constants here...
+
+ // FIXME:
+ // We may want to add a user-defined type constant, such as
+ // TYPE_VENDOR_SPECIFIC, to take care vendor specific use
+ // cases.
+
/**
* Creates a <code>DrmInfoEvent</code> object with the specified parameters.
*
* @param uniqueId Unique session identifier.
- * @param type Type of the event. Could be any of the event types defined above.
- * @param message Message description.
+ * @param type Type of the event. Must be any of the event types defined above,
+ * or the constants defined in {@link DrmEvent}.
+ * @param message Message description. It can be null.
*/
public DrmInfoEvent(int uniqueId, int type, String message) {
super(uniqueId, type, message);
+ checkTypeValidity(type);
}
/**
* Creates a <code>DrmInfoEvent</code> object with the specified parameters.
*
* @param uniqueId Unique session identifier.
- * @param type Type of the event. Could be any of the event types defined above.
- * @param message Message description.
+ * @param type Type of the event. Must be any of the event types defined above,
+ * or the constants defined in {@link DrmEvent}
+ * @param message Message description. It can be null.
* @param attributes Attributes for extensible information. Could be any
* information provided by the plug-in.
*/
public DrmInfoEvent(int uniqueId, int type, String message,
HashMap<String, Object> attributes) {
super(uniqueId, type, message, attributes);
+ checkTypeValidity(type);
+ }
+
+ /*
+ * Check the validity of the given type.
+ * To overcome a design flaw, we need also accept the type constants
+ * defined in super class, DrmEvent.
+ */
+ private void checkTypeValidity(int type) {
+ if (type < TYPE_ALREADY_REGISTERED_BY_ANOTHER_ACCOUNT ||
+ type > TYPE_RIGHTS_REMOVED) {
+
+ if (type != TYPE_ALL_RIGHTS_REMOVED &&
+ type != TYPE_DRM_INFO_PROCESSED) {
+ final String msg = "Unsupported type: " + type;
+ throw new IllegalArgumentException(msg);
+ }
+ }
}
}
diff --git a/drm/java/android/drm/DrmInfoRequest.java b/drm/java/android/drm/DrmInfoRequest.java
index 1429fa5..621da41 100755
--- a/drm/java/android/drm/DrmInfoRequest.java
+++ b/drm/java/android/drm/DrmInfoRequest.java
@@ -67,6 +67,11 @@ public class DrmInfoRequest {
public DrmInfoRequest(int infoType, String mimeType) {
mInfoType = infoType;
mMimeType = mimeType;
+ if (!isValid()) {
+ final String msg = "infoType: " + infoType + "," +
+ "mimeType: " + mimeType;
+ throw new IllegalArgumentException(msg);
+ }
}
/**
diff --git a/drm/java/android/drm/DrmInfoStatus.java b/drm/java/android/drm/DrmInfoStatus.java
index 5c12ae3..9a3a7df 100755
--- a/drm/java/android/drm/DrmInfoStatus.java
+++ b/drm/java/android/drm/DrmInfoStatus.java
@@ -17,49 +17,81 @@
package android.drm;
/**
- * An entity class that wraps the result of communication between a device and an online DRM
- * server. Specifically, when the {@link DrmManagerClient#processDrmInfo processDrmInfo()} method
- * is called, an instance of <code>DrmInfoStatus</code> is returned.
+ * An entity class that wraps the result of communication between a device
+ * and an online DRM server. Specifically, when the
+ * {@link DrmManagerClient#processDrmInfo DrmManagerClient.processDrmInfo()}
+ * method is called, an instance of <code>DrmInfoStatus</code> is returned.
*<p>
- * This class contains the {@link ProcessedData} object, which can be used to instantiate a
- * {@link DrmRights} object during license acquisition.
+ * This class contains the {@link ProcessedData} object, which can be used
+ * to instantiate a {@link DrmRights} object during license acquisition.
*
*/
public class DrmInfoStatus {
- // Should be in sync with DrmInfoStatus.cpp
+ // The following status code constants must be in sync with DrmInfoStatus.cpp
+ // Please update isValidStatusCode() if more status codes are added.
+ /**
+ * Indicate successful communication.
+ */
public static final int STATUS_OK = 1;
+
+ /**
+ * Indicate failed communication.
+ */
public static final int STATUS_ERROR = 2;
/**
- * The status of the communication.
+ * The status of the communication. Must be one of the defined status
+ * constants above.
*/
public final int statusCode;
/**
- * The type of DRM information processed.
+ * The type of DRM information processed. Must be one of the valid type
+ * constants defined in {@link DrmInfoRequest}.
*/
public final int infoType;
/**
- * The MIME type of the content.
+ * The MIME type of the content. Must not be null or an empty string.
*/
public final String mimeType;
/**
- * The processed data.
+ * The processed data. It is optional and thus could be null. When it
+ * is null, it indicates that a particular call to
+ * {@link DrmManagerClient#processDrmInfo DrmManagerClient.processDrmInfo()}
+ * does not return any additional useful information except for the status code.
*/
public final ProcessedData data;
/**
* Creates a <code>DrmInfoStatus</code> object with the specified parameters.
*
- * @param _statusCode The status of the communication.
- * @param _infoType The type of the DRM information processed.
- * @param _data The processed data.
- * @param _mimeType The MIME type.
+ * @param statusCode The status of the communication. Must be one of the defined
+ * status constants above.
+ * @param infoType The type of the DRM information processed. Must be a valid
+ * type for {@link DrmInfoRequest}.
+ * @param data The processed data.
+ * @param mimeType The MIME type.
*/
- public DrmInfoStatus(int _statusCode, int _infoType, ProcessedData _data, String _mimeType) {
- statusCode = _statusCode;
- infoType = _infoType;
- data = _data;
- mimeType = _mimeType;
+ public DrmInfoStatus(int statusCode, int infoType, ProcessedData data, String mimeType) {
+ if (!DrmInfoRequest.isValidType(infoType)) {
+ throw new IllegalArgumentException("infoType: " + infoType);
+ }
+
+ if (!isValidStatusCode(statusCode)) {
+ throw new IllegalArgumentException("Unsupported status code: " + statusCode);
+ }
+
+ if (mimeType == null || mimeType == "") {
+ throw new IllegalArgumentException("mimeType is null or an empty string");
+ }
+
+ this.statusCode = statusCode;
+ this.infoType = infoType;
+ this.data = data;
+ this.mimeType = mimeType;
+ }
+
+ private boolean isValidStatusCode(int statusCode) {
+ return statusCode == STATUS_OK || statusCode == STATUS_ERROR;
}
}
diff --git a/drm/java/android/drm/DrmManagerClient.java b/drm/java/android/drm/DrmManagerClient.java
index f9567a5..482ab0a 100755
--- a/drm/java/android/drm/DrmManagerClient.java
+++ b/drm/java/android/drm/DrmManagerClient.java
@@ -363,6 +363,7 @@ public class DrmManagerClient {
*
* @return A {@link android.content.ContentValues} instance that contains
* key-value pairs representing the constraints. Null in case of failure.
+ * The keys are defined in {@link DrmStore.ConstraintsColumns}.
*/
public ContentValues getConstraints(String path, int action) {
if (null == path || path.equals("") || !DrmStore.Action.isValid(action)) {
diff --git a/drm/java/android/drm/DrmRights.java b/drm/java/android/drm/DrmRights.java
index ef9c21d..a9b4f05 100755
--- a/drm/java/android/drm/DrmRights.java
+++ b/drm/java/android/drm/DrmRights.java
@@ -30,19 +30,24 @@ import java.io.IOException;
* A caller can also instantiate a {@link DrmRights} object by using the
* {@link DrmRights#DrmRights(String, String)} constructor, which takes a path to a file
* containing rights information instead of a <code>ProcessedData</code>.
+ *<p>
+ * Please note that the account id and subscription id is not mandatory by all DRM agents
+ * or plugins. When account id or subscription id is not required by the specific DRM
+ * agent or plugin, they can be either null, or an empty string, or any other don't-care
+ * string value.
*
*/
public class DrmRights {
private byte[] mData;
private String mMimeType;
- private String mAccountId = "_NO_USER";
- private String mSubscriptionId = "";
+ private String mAccountId;
+ private String mSubscriptionId;
/**
* Creates a <code>DrmRights</code> object with the given parameters.
*
* @param rightsFilePath Path to the file containing rights information.
- * @param mimeType MIME type.
+ * @param mimeType MIME type. Must not be null or an empty string.
*/
public DrmRights(String rightsFilePath, String mimeType) {
File file = new File(rightsFilePath);
@@ -53,22 +58,20 @@ public class DrmRights {
* Creates a <code>DrmRights</code> object with the given parameters.
*
* @param rightsFilePath Path to the file containing rights information.
- * @param mimeType MIME type.
+ * @param mimeType MIME type. Must not be null or an empty string.
* @param accountId Account ID of the user.
*/
public DrmRights(String rightsFilePath, String mimeType, String accountId) {
this(rightsFilePath, mimeType);
- if (null != accountId && !accountId.equals("")) {
- mAccountId = accountId;
- }
+ mAccountId = accountId;
}
/**
* Creates a <code>DrmRights</code> object with the given parameters.
*
* @param rightsFilePath Path to the file containing rights information.
- * @param mimeType MIME type.
+ * @param mimeType MIME type. Must not be null or an empty string.
* @param accountId Account ID of the user.
* @param subscriptionId Subscription ID of the user.
*/
@@ -76,20 +79,15 @@ public class DrmRights {
String rightsFilePath, String mimeType, String accountId, String subscriptionId) {
this(rightsFilePath, mimeType);
- if (null != accountId && !accountId.equals("")) {
- mAccountId = accountId;
- }
-
- if (null != subscriptionId && !subscriptionId.equals("")) {
- mSubscriptionId = subscriptionId;
- }
+ mAccountId = accountId;
+ mSubscriptionId = subscriptionId;
}
/**
* Creates a <code>DrmRights</code> object with the given parameters.
*
* @param rightsFile File containing rights information.
- * @param mimeType MIME type.
+ * @param mimeType MIME type. Must not be null or an empty string.
*/
public DrmRights(File rightsFile, String mimeType) {
instantiate(rightsFile, mimeType);
@@ -103,31 +101,35 @@ public class DrmRights {
}
mMimeType = mimeType;
+ if (!isValid()) {
+ final String msg = "mimeType: " + mMimeType + "," +
+ "data: " + mData;
+ throw new IllegalArgumentException(msg);
+ }
}
/**
* Creates a <code>DrmRights</code> object with the given parameters.
*
* @param data A {@link ProcessedData} object containing rights information.
- * data could be null because it's optional for some DRM schemes.
- * @param mimeType The MIME type.
+ * Must not be null.
+ * @param mimeType The MIME type. It must not be null or an empty string.
*/
public DrmRights(ProcessedData data, String mimeType) {
- if (data != null) {
- mData = data.getData();
-
- String accountId = data.getAccountId();
- if (null != accountId && !accountId.equals("")) {
- mAccountId = accountId;
- }
-
- String subscriptionId = data.getSubscriptionId();
- if (null != subscriptionId && !subscriptionId.equals("")) {
- mSubscriptionId = subscriptionId;
- }
+ if (data == null) {
+ throw new IllegalArgumentException("data is null");
}
+ mData = data.getData();
+ mAccountId = data.getAccountId();
+ mSubscriptionId = data.getSubscriptionId();
mMimeType = mimeType;
+
+ if (!isValid()) {
+ final String msg = "mimeType: " + mMimeType + "," +
+ "data: " + mData;
+ throw new IllegalArgumentException(msg);
+ }
}
/**
diff --git a/drm/java/android/drm/DrmStore.java b/drm/java/android/drm/DrmStore.java
index ae311de..3a77ea1 100755
--- a/drm/java/android/drm/DrmStore.java
+++ b/drm/java/android/drm/DrmStore.java
@@ -23,45 +23,65 @@ package android.drm;
public class DrmStore {
/**
* Interface definition for the columns that represent DRM constraints.
+ * {@link android.drm.DrmManagerClient#getConstraints DrmManagerClient.getConstraints()}
+ * can be called by an application to find out the contraints on the
+ * {@link android.drm.DrmStore.Action actions} that can be performed
+ * on right-protected content. The constants defined in this interface
+ * represent three most common types of constraints: count-based,
+ * date-based, and duration-based. Two or more constraints can be used
+ * at the same time to represent more sophisticated constraints.
+ * In addition, user-defined constraint,
+ * {@link #EXTENDED_METADATA extended metadata}, can be
+ * used if these three types of constraints are not sufficient.
*/
public interface ConstraintsColumns {
/**
- * The maximum repeat count.
+ * This is a count-based constraint. It represents the maximum
+ * repeat count that can be performed on an
+ * {@link android.drm.DrmStore.Action action}.
* <p>
* Type: INTEGER
*/
public static final String MAX_REPEAT_COUNT = "max_repeat_count";
/**
- * The remaining repeat count.
+ * This is a count-based constraint. It represents the remaining
+ * repeat count that can be performed on an
+ * {@link android.drm.DrmStore.Action action}.
* <p>
* Type: INTEGER
*/
public static final String REMAINING_REPEAT_COUNT = "remaining_repeat_count";
/**
- * The time before which the rights-protected file cannot be played/viewed.
+ * This is a date-based constraint. It represents the time before which
+ * an {@link android.drm.DrmStore.Action action} can be performed on
+ * the rights-protected content.
* <p>
* Type: TEXT
*/
public static final String LICENSE_START_TIME = "license_start_time";
/**
- * The time after which the rights-protected file cannot be played/viewed.
+ * This is a date-based constaint. It represents the time after which
+ * an {@link android.drm.DrmStore.Action action} can not be performed on
+ * the rights-protected content.
* <p>
* Type: TEXT
*/
public static final String LICENSE_EXPIRY_TIME = "license_expiry_time";
/**
- * The available time left before the license expires.
+ * This is a duration-based constaint. It represents the available time left
+ * before the license expires.
* <p>
* Type: TEXT
*/
public static final String LICENSE_AVAILABLE_TIME = "license_available_time";
/**
- * The data stream for extended metadata.
+ * This is a user-defined constraint. It represents the additional constraint
+ * using extended metadata.
* <p>
* Type: TEXT
*/
@@ -88,6 +108,12 @@ public class DrmStore {
* A trigger information object type.
*/
public static final int TRIGGER_OBJECT = 0x03;
+
+ /**
+ * @deprecated This class should have been an interface instead.
+ * The default constuctor should have not been exposed.
+ */
+ public DrmObjectType() {}
}
/**
@@ -123,6 +149,12 @@ public class DrmStore {
}
return isValid;
}
+
+ /**
+ * @deprecated This class should have been an interface instead.
+ * The default constuctor should have not been exposed.
+ */
+ public Playback() {}
}
/**
@@ -178,6 +210,12 @@ public class DrmStore {
}
return isValid;
}
+
+ /**
+ * @deprecated This class should have been an interface instead.
+ * The default constuctor should have not been exposed.
+ */
+ public Action() {}
}
/**
@@ -200,6 +238,18 @@ public class DrmStore {
* The digital rights have not been acquired for the rights-protected content.
*/
public static final int RIGHTS_NOT_ACQUIRED = 0x03;
+
+ /**
+ * @deprecated This class should have been an interface instead.
+ * The default constuctor should have not been exposed.
+ */
+ public RightsStatus() {}
}
+
+ /**
+ * @deprecated This class should have been an interface instead.
+ * The default constuctor should have not been exposed.
+ */
+ public DrmStore() {}
}
diff --git a/drm/java/android/drm/DrmSupportInfo.java b/drm/java/android/drm/DrmSupportInfo.java
index 720c545..3694ff4 100755
--- a/drm/java/android/drm/DrmSupportInfo.java
+++ b/drm/java/android/drm/DrmSupportInfo.java
@@ -36,8 +36,16 @@ public class DrmSupportInfo {
* Adds the specified MIME type to the list of MIME types this DRM plug-in supports.
*
* @param mimeType MIME type that can be handles by this DRM plug-in.
+ * Must not be null or an empty string.
*/
public void addMimeType(String mimeType) {
+ if (mimeType == null) {
+ throw new IllegalArgumentException("mimeType is null");
+ }
+ if (mimeType == "") {
+ throw new IllegalArgumentException("mimeType is an empty string");
+ }
+
mMimeTypeList.add(mimeType);
}
@@ -45,8 +53,14 @@ public class DrmSupportInfo {
* Adds the specified file suffix to the list of file suffixes this DRM plug-in supports.
*
* @param fileSuffix File suffix that can be handled by this DRM plug-in.
+ * it could be null but not an empty string. When it is null, it indicates
+ * that some DRM content comes with no file suffix.
*/
public void addFileSuffix(String fileSuffix) {
+ if (fileSuffix == "") {
+ throw new IllegalArgumentException("fileSuffix is an empty string");
+ }
+
mFileSuffixList.add(fileSuffix);
}
@@ -73,24 +87,44 @@ public class DrmSupportInfo {
/**
* Sets a description for the DRM plug-in (agent).
*
- * @param description Unique description of plug-in.
+ * @param description Unique description of plug-in. Must not be null
+ * or an empty string.
*/
public void setDescription(String description) {
- if (null != description) {
- mDescription = description;
+ if (description == null) {
+ throw new IllegalArgumentException("description is null");
}
+ if (description == "") {
+ throw new IllegalArgumentException("description is an empty string");
+ }
+
+ mDescription = description;
}
/**
* Retrieves the DRM plug-in (agent) description.
*
* @return The plug-in description.
+ * @deprecated The method name is mis-spelled, and it is replaced by
+ * {@link #getDescription()}.
*/
public String getDescriprition() {
return mDescription;
}
/**
+ * Retrieves the DRM plug-in (agent) description. Even if null or an empty
+ * string is not allowed in {@link #setDescription(String)}, if
+ * {@link #setDescription(String)} is not called, description returned
+ * from this method is an empty string.
+ *
+ * @return The plug-in description.
+ */
+ public String getDescription() {
+ return mDescription;
+ }
+
+ /**
* Overridden hash code implementation.
*
* @return The hash code value.
@@ -100,20 +134,21 @@ public class DrmSupportInfo {
}
/**
- * Overridden <code>equals</code> implementation.
+ * Overridden <code>equals</code> implementation. Two DrmSupportInfo objects
+ * are considered being equal if they support exactly the same set of mime
+ * types, file suffixes, and has exactly the same description.
*
* @param object The object to be compared.
* @return True if equal; false if not equal.
*/
public boolean equals(Object object) {
- boolean result = false;
-
if (object instanceof DrmSupportInfo) {
- result = mFileSuffixList.equals(((DrmSupportInfo) object).mFileSuffixList) &&
- mMimeTypeList.equals(((DrmSupportInfo) object).mMimeTypeList) &&
- mDescription.equals(((DrmSupportInfo) object).mDescription);
+ DrmSupportInfo info = (DrmSupportInfo) object;
+ return mFileSuffixList.equals(info.mFileSuffixList) &&
+ mMimeTypeList.equals(info.mMimeTypeList) &&
+ mDescription.equals(info.mDescription);
}
- return result;
+ return false;
}
/**
@@ -121,11 +156,17 @@ public class DrmSupportInfo {
*
* @param mimeType MIME type.
* @return True if Mime type is supported; false if MIME type is not supported.
+ * Null or empty string is not a supported mimeType.
*/
/* package */ boolean isSupportedMimeType(String mimeType) {
if (null != mimeType && !mimeType.equals("")) {
for (int i = 0; i < mMimeTypeList.size(); i++) {
String completeMimeType = mMimeTypeList.get(i);
+
+ // The reason that equals() is not used is that sometimes,
+ // content distributor might just append something to
+ // the basic MIME type. startsWith() is used to avoid
+ // frequent update of DRM agent.
if (completeMimeType.startsWith(mimeType)) {
return true;
}
diff --git a/drm/java/android/drm/DrmUtils.java b/drm/java/android/drm/DrmUtils.java
index dc5f1fa..4f7cb22 100755
--- a/drm/java/android/drm/DrmUtils.java
+++ b/drm/java/android/drm/DrmUtils.java
@@ -55,8 +55,8 @@ public class DrmUtils {
bufferedStream.read(data);
}
} finally {
- quiteDispose(bufferedStream);
- quiteDispose(inputStream);
+ quietlyDispose(bufferedStream);
+ quietlyDispose(inputStream);
}
return data;
}
@@ -70,7 +70,7 @@ public class DrmUtils {
outputStream = new FileOutputStream(path);
outputStream.write(data);
} finally {
- quiteDispose(outputStream);
+ quietlyDispose(outputStream);
}
}
}
@@ -80,7 +80,7 @@ public class DrmUtils {
file.delete();
}
- private static void quiteDispose(InputStream stream) {
+ private static void quietlyDispose(InputStream stream) {
try {
if (null != stream) {
stream.close();
@@ -90,7 +90,7 @@ public class DrmUtils {
}
}
- private static void quiteDispose(OutputStream stream) {
+ private static void quietlyDispose(OutputStream stream) {
try {
if (null != stream) {
stream.close();
@@ -175,14 +175,34 @@ public class DrmUtils {
}
}
+ /**
+ * This method returns an iterator object that can be used to iterate over
+ * all values of the metadata.
+ *
+ * @return The iterator object.
+ */
public Iterator<String> iterator() {
return mMap.values().iterator();
}
+ /**
+ * This method returns an iterator object that can be used to iterate over
+ * all keys of the metadata.
+ *
+ * @return The iterator object.
+ */
public Iterator<String> keyIterator() {
return mMap.keySet().iterator();
}
+ /**
+ * This method retrieves the metadata value associated with a given key.
+ *
+ * @param key The key whose value is being retrieved.
+ *
+ * @return The metadata value associated with the given key. Returns null
+ * if the key is not found.
+ */
public String get(String key) {
return mMap.get(key);
}
diff --git a/drm/jni/Android.mk b/drm/jni/Android.mk
index 4a55fc0..f8ecc8c 100644
--- a/drm/jni/Android.mk
+++ b/drm/jni/Android.mk
@@ -33,9 +33,9 @@ LOCAL_STATIC_LIBRARIES :=
LOCAL_C_INCLUDES += \
$(JNI_H_INCLUDE) \
- $(TOP)/frameworks/base/drm/libdrmframework/include \
- $(TOP)/frameworks/base/drm/libdrmframework/plugins/common/include \
- $(TOP)/frameworks/base/include
+ $(TOP)/frameworks/av/drm/libdrmframework/include \
+ $(TOP)/frameworks/av/drm/libdrmframework/plugins/common/include \
+ $(TOP)/frameworks/av/include
diff --git a/drm/jni/android_drm_DrmManagerClient.cpp b/drm/jni/android_drm_DrmManagerClient.cpp
index cf58177..14ec4d6 100644
--- a/drm/jni/android_drm_DrmManagerClient.cpp
+++ b/drm/jni/android_drm_DrmManagerClient.cpp
@@ -57,29 +57,16 @@ public:
};
String8 Utility::getStringValue(JNIEnv* env, jobject object, const char* fieldName) {
- String8 dataString("");
-
/* Look for the instance field with the name fieldName */
jfieldID fieldID
= env->GetFieldID(env->GetObjectClass(object), fieldName , "Ljava/lang/String;");
if (NULL != fieldID) {
jstring valueString = (jstring) env->GetObjectField(object, fieldID);
-
- if (NULL != valueString && valueString != env->NewStringUTF("")) {
- char* bytes = const_cast< char* > (env->GetStringUTFChars(valueString, NULL));
-
- const int length = strlen(bytes) + 1;
- char *data = new char[length];
- strncpy(data, bytes, length);
- dataString = String8(data);
-
- env->ReleaseStringUTFChars(valueString, bytes);
- delete [] data; data = NULL;
- } else {
- ALOGV("Failed to retrieve the data from the field %s", fieldName);
- }
+ return Utility::getStringValue(env, valueString);
}
+
+ String8 dataString("");
return dataString;
}
@@ -102,24 +89,16 @@ String8 Utility::getStringValue(JNIEnv* env, jstring string) {
char* Utility::getByteArrayValue(
JNIEnv* env, jobject object, const char* fieldName, int* dataLength) {
- char* data = NULL;
+
*dataLength = 0;
jfieldID fieldID = env->GetFieldID(env->GetObjectClass(object), fieldName , "[B");
if (NULL != fieldID) {
jbyteArray byteArray = (jbyteArray) env->GetObjectField(object, fieldID);
- if (NULL != byteArray) {
- jint length = env->GetArrayLength(byteArray);
-
- *dataLength = length;
- if (0 < *dataLength) {
- data = new char[length];
- env->GetByteArrayRegion(byteArray, (jint)0, length, (jbyte *) data);
- }
- }
+ return Utility::getByteArrayValue(env, byteArray, dataLength);
}
- return data;
+ return NULL;
}
char* Utility::getByteArrayValue(JNIEnv* env, jbyteArray byteArray, int* dataLength) {
@@ -419,7 +398,7 @@ static jint android_drm_DrmManagerClient_saveRights(
Utility::getStringValue(env, contentPath));
}
- delete mData; mData = NULL;
+ delete[] mData; mData = NULL;
ALOGV("saveRights - Exit");
return result;
}
@@ -510,7 +489,7 @@ static jobject android_drm_DrmManagerClient_processDrmInfo(
processedData, env->NewStringUTF(pDrmInfoStatus->mimeType.string()));
}
- delete mData; mData = NULL;
+ delete[] mData; mData = NULL;
delete pDrmInfoStatus; pDrmInfoStatus = NULL;
ALOGV("processDrmInfo - Exit");
@@ -641,17 +620,8 @@ static jint android_drm_DrmManagerClient_openConvertSession(
return convertId;
}
-static jobject android_drm_DrmManagerClient_convertData(
- JNIEnv* env, jobject thiz, jint uniqueId, jint convertId, jbyteArray inputData) {
- ALOGV("convertData Enter");
-
- int dataLength = 0;
- char* mData = Utility::getByteArrayValue(env, inputData, &dataLength);
- const DrmBuffer buffer(mData, dataLength);
-
- DrmConvertedStatus* pDrmConvertedStatus
- = getDrmManagerClientImpl(env, thiz)->convertData(uniqueId, convertId, &buffer);
-
+static jobject GetConvertedStatus(JNIEnv* env, DrmConvertedStatus* pDrmConvertedStatus) {
+ ALOGV("GetConvertedStatus - Enter");
jclass localRef = env->FindClass("android/drm/DrmConvertedStatus");
jobject drmConvertedStatus = NULL;
@@ -663,8 +633,8 @@ static jobject android_drm_DrmManagerClient_convertData(
if (NULL != pDrmConvertedStatus->convertedData) {
int length = pDrmConvertedStatus->convertedData->length;
dataArray = env->NewByteArray(length);
- env->SetByteArrayRegion(dataArray, 0, length,
- (jbyte*) pDrmConvertedStatus->convertedData->data);
+ env->SetByteArrayRegion(
+ dataArray, 0, length, (jbyte*) pDrmConvertedStatus->convertedData->data);
delete [] pDrmConvertedStatus->convertedData->data;
delete pDrmConvertedStatus->convertedData; pDrmConvertedStatus->convertedData = NULL;
@@ -675,48 +645,42 @@ static jobject android_drm_DrmManagerClient_convertData(
statusCode, dataArray, pDrmConvertedStatus->offset);
}
- delete mData; mData = NULL;
delete pDrmConvertedStatus; pDrmConvertedStatus = NULL;
- ALOGV("convertData - Exit");
+ ALOGV("GetConvertedStatus - Exit");
return drmConvertedStatus;
}
-static jobject android_drm_DrmManagerClient_closeConvertSession(
- JNIEnv* env, jobject thiz, int uniqueId, jint convertId) {
+static jobject android_drm_DrmManagerClient_convertData(
+ JNIEnv* env, jobject thiz, jint uniqueId, jint convertId, jbyteArray inputData) {
+ ALOGV("convertData Enter");
- ALOGV("closeConvertSession Enter");
+ int dataLength = 0;
+ char* mData = Utility::getByteArrayValue(env, inputData, &dataLength);
+ const DrmBuffer buffer(mData, dataLength);
DrmConvertedStatus* pDrmConvertedStatus
- = getDrmManagerClientImpl(env, thiz)->closeConvertSession(uniqueId, convertId);
-
- jclass localRef = env->FindClass("android/drm/DrmConvertedStatus");
+ = getDrmManagerClientImpl(env, thiz)->convertData(uniqueId, convertId, &buffer);
+ jobject status = GetConvertedStatus(env, pDrmConvertedStatus);
- jobject drmConvertedStatus = NULL;
+ delete[] mData;
+ mData = NULL;
- if (NULL != localRef && NULL != pDrmConvertedStatus) {
- int statusCode = pDrmConvertedStatus->statusCode;
+ ALOGV("convertData - Exit");
+ return status;
+}
- jbyteArray dataArray = NULL;
- if (NULL != pDrmConvertedStatus->convertedData) {
- int length = pDrmConvertedStatus->convertedData->length;
- dataArray = env->NewByteArray(length);
- env->SetByteArrayRegion(
- dataArray, 0, length, (jbyte*) pDrmConvertedStatus->convertedData->data);
+static jobject android_drm_DrmManagerClient_closeConvertSession(
+ JNIEnv* env, jobject thiz, int uniqueId, jint convertId) {
- delete [] pDrmConvertedStatus->convertedData->data;
- delete pDrmConvertedStatus->convertedData; pDrmConvertedStatus->convertedData = NULL;
- }
- jmethodID constructorId = env->GetMethodID(localRef, "<init>", "(I[BI)V");
- drmConvertedStatus
- = env->NewObject(localRef, constructorId,
- statusCode, dataArray, pDrmConvertedStatus->offset);
- }
+ ALOGV("closeConvertSession Enter");
- delete pDrmConvertedStatus; pDrmConvertedStatus = NULL;
+ DrmConvertedStatus* pDrmConvertedStatus
+ = getDrmManagerClientImpl(env, thiz)->closeConvertSession(uniqueId, convertId);
+ jobject status = GetConvertedStatus(env, pDrmConvertedStatus);
ALOGV("closeConvertSession - Exit");
- return drmConvertedStatus;
+ return status;
}
static JNINativeMethod nativeMethods[] = {
diff --git a/drm/libdrmframework/Android.mk b/drm/libdrmframework/Android.mk
deleted file mode 100644
index c534402..0000000
--- a/drm/libdrmframework/Android.mk
+++ /dev/null
@@ -1,44 +0,0 @@
-#
-# Copyright (C) 2010 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.
-#
-LOCAL_PATH:= $(call my-dir)
-
-include $(CLEAR_VARS)
-
-LOCAL_SRC_FILES:= \
- DrmManagerClientImpl.cpp \
- DrmManagerClient.cpp
-
-LOCAL_MODULE:= libdrmframework
-
-LOCAL_SHARED_LIBRARIES := \
- libutils \
- libbinder \
- libdl
-
-LOCAL_STATIC_LIBRARIES := \
- libdrmframeworkcommon
-
-LOCAL_C_INCLUDES += \
- $(TOP)/frameworks/base/drm/libdrmframework/include \
- $(TOP)/frameworks/base/include
-
-
-
-LOCAL_MODULE_TAGS := optional
-
-include $(BUILD_SHARED_LIBRARY)
-
-include $(call all-makefiles-under,$(LOCAL_PATH))
diff --git a/drm/libdrmframework/DrmManagerClient.cpp b/drm/libdrmframework/DrmManagerClient.cpp
deleted file mode 100644
index c9c0d57..0000000
--- a/drm/libdrmframework/DrmManagerClient.cpp
+++ /dev/null
@@ -1,154 +0,0 @@
-/*
- * Copyright (C) 2010 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.
- */
-
-#include <utils/String8.h>
-#include <binder/IServiceManager.h>
-#include <drm/DrmManagerClient.h>
-
-#include "DrmManagerClientImpl.h"
-
-using namespace android;
-
-DrmManagerClient::DrmManagerClient():
- mUniqueId(0), mDrmManagerClientImpl(NULL) {
- mDrmManagerClientImpl = DrmManagerClientImpl::create(&mUniqueId, true);
- mDrmManagerClientImpl->addClient(mUniqueId);
-}
-
-DrmManagerClient::~DrmManagerClient() {
- DrmManagerClientImpl::remove(mUniqueId);
- mDrmManagerClientImpl->removeClient(mUniqueId);
- mDrmManagerClientImpl->setOnInfoListener(mUniqueId, NULL);
-}
-
-status_t DrmManagerClient::setOnInfoListener(
- const sp<DrmManagerClient::OnInfoListener>& infoListener) {
- return mDrmManagerClientImpl->setOnInfoListener(mUniqueId, infoListener);
-}
-
-DrmConstraints* DrmManagerClient::getConstraints(const String8* path, const int action) {
- return mDrmManagerClientImpl->getConstraints(mUniqueId, path, action);
-}
-
-DrmMetadata* DrmManagerClient::getMetadata(const String8* path) {
- return mDrmManagerClientImpl->getMetadata(mUniqueId, path);
-}
-
-bool DrmManagerClient::canHandle(const String8& path, const String8& mimeType) {
- return mDrmManagerClientImpl->canHandle(mUniqueId, path, mimeType);
-}
-
-DrmInfoStatus* DrmManagerClient::processDrmInfo(const DrmInfo* drmInfo) {
- return mDrmManagerClientImpl->processDrmInfo(mUniqueId, drmInfo);
-}
-
-DrmInfo* DrmManagerClient::acquireDrmInfo(const DrmInfoRequest* drmInfoRequest) {
- return mDrmManagerClientImpl->acquireDrmInfo(mUniqueId, drmInfoRequest);
-}
-
-status_t DrmManagerClient::saveRights(
- const DrmRights& drmRights, const String8& rightsPath, const String8& contentPath) {
- return mDrmManagerClientImpl->saveRights(mUniqueId, drmRights, rightsPath, contentPath);
-}
-
-String8 DrmManagerClient::getOriginalMimeType(const String8& path) {
- return mDrmManagerClientImpl->getOriginalMimeType(mUniqueId, path);
-}
-
-int DrmManagerClient::getDrmObjectType(const String8& path, const String8& mimeType) {
- return mDrmManagerClientImpl->getDrmObjectType( mUniqueId, path, mimeType);
-}
-
-int DrmManagerClient::checkRightsStatus(const String8& path, int action) {
- return mDrmManagerClientImpl->checkRightsStatus(mUniqueId, path, action);
-}
-
-status_t DrmManagerClient::consumeRights(
- sp<DecryptHandle> &decryptHandle, int action, bool reserve) {
- return mDrmManagerClientImpl->consumeRights(mUniqueId, decryptHandle, action, reserve);
-}
-
-status_t DrmManagerClient::setPlaybackStatus(
- sp<DecryptHandle> &decryptHandle, int playbackStatus, int64_t position) {
- return mDrmManagerClientImpl
- ->setPlaybackStatus(mUniqueId, decryptHandle, playbackStatus, position);
-}
-
-bool DrmManagerClient::validateAction(
- const String8& path, int action, const ActionDescription& description) {
- return mDrmManagerClientImpl->validateAction(mUniqueId, path, action, description);
-}
-
-status_t DrmManagerClient::removeRights(const String8& path) {
- return mDrmManagerClientImpl->removeRights(mUniqueId, path);
-}
-
-status_t DrmManagerClient::removeAllRights() {
- return mDrmManagerClientImpl->removeAllRights(mUniqueId);
-}
-
-int DrmManagerClient::openConvertSession(const String8& mimeType) {
- return mDrmManagerClientImpl->openConvertSession(mUniqueId, mimeType);
-}
-
-DrmConvertedStatus* DrmManagerClient::convertData(int convertId, const DrmBuffer* inputData) {
- return mDrmManagerClientImpl->convertData(mUniqueId, convertId, inputData);
-}
-
-DrmConvertedStatus* DrmManagerClient::closeConvertSession(int convertId) {
- return mDrmManagerClientImpl->closeConvertSession(mUniqueId, convertId);
-}
-
-status_t DrmManagerClient::getAllSupportInfo(int* length, DrmSupportInfo** drmSupportInfoArray) {
- return mDrmManagerClientImpl->getAllSupportInfo(mUniqueId, length, drmSupportInfoArray);
-}
-
-sp<DecryptHandle> DrmManagerClient::openDecryptSession(int fd, off64_t offset, off64_t length) {
- return mDrmManagerClientImpl->openDecryptSession(mUniqueId, fd, offset, length);
-}
-
-sp<DecryptHandle> DrmManagerClient::openDecryptSession(const char* uri) {
- return mDrmManagerClientImpl->openDecryptSession(mUniqueId, uri);
-}
-
-status_t DrmManagerClient::closeDecryptSession(sp<DecryptHandle> &decryptHandle) {
- return mDrmManagerClientImpl->closeDecryptSession(mUniqueId, decryptHandle);
-}
-
-status_t DrmManagerClient::initializeDecryptUnit(
- sp<DecryptHandle> &decryptHandle, int decryptUnitId, const DrmBuffer* headerInfo) {
- return mDrmManagerClientImpl->initializeDecryptUnit(
- mUniqueId, decryptHandle, decryptUnitId, headerInfo);
-}
-
-status_t DrmManagerClient::decrypt(
- sp<DecryptHandle> &decryptHandle, int decryptUnitId,
- const DrmBuffer* encBuffer, DrmBuffer** decBuffer, DrmBuffer* IV) {
- return mDrmManagerClientImpl->decrypt(
- mUniqueId, decryptHandle, decryptUnitId, encBuffer, decBuffer, IV);
-}
-
-status_t DrmManagerClient::finalizeDecryptUnit(
- sp<DecryptHandle> &decryptHandle, int decryptUnitId) {
- return mDrmManagerClientImpl->finalizeDecryptUnit(mUniqueId,
- decryptHandle, decryptUnitId);
-}
-
-ssize_t DrmManagerClient::pread(
- sp<DecryptHandle> &decryptHandle, void* buffer, ssize_t numBytes, off64_t offset) {
- return mDrmManagerClientImpl->pread(mUniqueId, decryptHandle, buffer, numBytes, offset);
-}
-
diff --git a/drm/libdrmframework/DrmManagerClientImpl.cpp b/drm/libdrmframework/DrmManagerClientImpl.cpp
deleted file mode 100644
index b222b8f..0000000
--- a/drm/libdrmframework/DrmManagerClientImpl.cpp
+++ /dev/null
@@ -1,347 +0,0 @@
-/*
- * Copyright (C) 2010 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.
- */
-
-//#define LOG_NDEBUG 0
-#define LOG_TAG "DrmManagerClientImpl(Native)"
-#include <utils/Log.h>
-
-#include <utils/String8.h>
-#include <utils/Vector.h>
-#include <binder/IServiceManager.h>
-
-#include "DrmManagerClientImpl.h"
-
-using namespace android;
-
-#define INVALID_VALUE -1
-
-Mutex DrmManagerClientImpl::sMutex;
-sp<IDrmManagerService> DrmManagerClientImpl::sDrmManagerService;
-sp<DrmManagerClientImpl::DeathNotifier> DrmManagerClientImpl::sDeathNotifier;
-const String8 DrmManagerClientImpl::EMPTY_STRING("");
-
-DrmManagerClientImpl* DrmManagerClientImpl::create(
- int* pUniqueId, bool isNative) {
- *pUniqueId = getDrmManagerService()->addUniqueId(isNative);
-
- return new DrmManagerClientImpl();
-}
-
-void DrmManagerClientImpl::remove(int uniqueId) {
- getDrmManagerService()->removeUniqueId(uniqueId);
-}
-
-const sp<IDrmManagerService>& DrmManagerClientImpl::getDrmManagerService() {
- Mutex::Autolock lock(sMutex);
- if (NULL == sDrmManagerService.get()) {
- sp<IServiceManager> sm = defaultServiceManager();
- sp<IBinder> binder;
- do {
- binder = sm->getService(String16("drm.drmManager"));
- if (binder != 0) {
- break;
- }
- ALOGW("DrmManagerService not published, waiting...");
- struct timespec reqt;
- reqt.tv_sec = 0;
- reqt.tv_nsec = 500000000; //0.5 sec
- nanosleep(&reqt, NULL);
- } while (true);
- if (NULL == sDeathNotifier.get()) {
- sDeathNotifier = new DeathNotifier();
- }
- binder->linkToDeath(sDeathNotifier);
- sDrmManagerService = interface_cast<IDrmManagerService>(binder);
- }
- return sDrmManagerService;
-}
-
-void DrmManagerClientImpl::addClient(int uniqueId) {
- getDrmManagerService()->addClient(uniqueId);
-}
-
-void DrmManagerClientImpl::removeClient(int uniqueId) {
- getDrmManagerService()->removeClient(uniqueId);
-}
-
-status_t DrmManagerClientImpl::setOnInfoListener(
- int uniqueId,
- const sp<DrmManagerClient::OnInfoListener>& infoListener) {
- Mutex::Autolock _l(mLock);
- mOnInfoListener = infoListener;
- return getDrmManagerService()->setDrmServiceListener(uniqueId,
- (NULL != infoListener.get()) ? this : NULL);
-}
-
-status_t DrmManagerClientImpl::installDrmEngine(
- int uniqueId, const String8& drmEngineFile) {
- status_t status = DRM_ERROR_UNKNOWN;
- if (EMPTY_STRING != drmEngineFile) {
- status = getDrmManagerService()->installDrmEngine(uniqueId, drmEngineFile);
- }
- return status;
-}
-
-DrmConstraints* DrmManagerClientImpl::getConstraints(
- int uniqueId, const String8* path, const int action) {
- DrmConstraints *drmConstraints = NULL;
- if ((NULL != path) && (EMPTY_STRING != *path)) {
- drmConstraints =
- getDrmManagerService()->getConstraints(uniqueId, path, action);
- }
- return drmConstraints;
-}
-
-DrmMetadata* DrmManagerClientImpl::getMetadata(int uniqueId, const String8* path) {
- DrmMetadata *drmMetadata = NULL;
- if ((NULL != path) && (EMPTY_STRING != *path)) {
- drmMetadata = getDrmManagerService()->getMetadata(uniqueId, path);
- }
- return drmMetadata;
-}
-
-bool DrmManagerClientImpl::canHandle(
- int uniqueId, const String8& path, const String8& mimeType) {
- bool retCode = false;
- if ((EMPTY_STRING != path) || (EMPTY_STRING != mimeType)) {
- retCode = getDrmManagerService()->canHandle(uniqueId, path, mimeType);
- }
- return retCode;
-}
-
-DrmInfoStatus* DrmManagerClientImpl::processDrmInfo(
- int uniqueId, const DrmInfo* drmInfo) {
- DrmInfoStatus *drmInfoStatus = NULL;
- if (NULL != drmInfo) {
- drmInfoStatus = getDrmManagerService()->processDrmInfo(uniqueId, drmInfo);
- }
- return drmInfoStatus;
-}
-
-DrmInfo* DrmManagerClientImpl::acquireDrmInfo(
- int uniqueId, const DrmInfoRequest* drmInfoRequest) {
- DrmInfo* drmInfo = NULL;
- if (NULL != drmInfoRequest) {
- drmInfo = getDrmManagerService()->acquireDrmInfo(uniqueId, drmInfoRequest);
- }
- return drmInfo;
-}
-
-status_t DrmManagerClientImpl::saveRights(int uniqueId, const DrmRights& drmRights,
- const String8& rightsPath, const String8& contentPath) {
- return getDrmManagerService()->saveRights(
- uniqueId, drmRights, rightsPath, contentPath);
-}
-
-String8 DrmManagerClientImpl::getOriginalMimeType(
- int uniqueId, const String8& path) {
- String8 mimeType = EMPTY_STRING;
- if (EMPTY_STRING != path) {
- mimeType = getDrmManagerService()->getOriginalMimeType(uniqueId, path);
- }
- return mimeType;
-}
-
-int DrmManagerClientImpl::getDrmObjectType(
- int uniqueId, const String8& path, const String8& mimeType) {
- int drmOjectType = DrmObjectType::UNKNOWN;
- if ((EMPTY_STRING != path) || (EMPTY_STRING != mimeType)) {
- drmOjectType =
- getDrmManagerService()->getDrmObjectType(uniqueId, path, mimeType);
- }
- return drmOjectType;
-}
-
-int DrmManagerClientImpl::checkRightsStatus(
- int uniqueId, const String8& path, int action) {
- int rightsStatus = RightsStatus::RIGHTS_INVALID;
- if (EMPTY_STRING != path) {
- rightsStatus =
- getDrmManagerService()->checkRightsStatus(uniqueId, path, action);
- }
- return rightsStatus;
-}
-
-status_t DrmManagerClientImpl::consumeRights(
- int uniqueId, sp<DecryptHandle> &decryptHandle,
- int action, bool reserve) {
- status_t status = DRM_ERROR_UNKNOWN;
- if (NULL != decryptHandle.get()) {
- status = getDrmManagerService()->consumeRights(
- uniqueId, decryptHandle.get(), action, reserve);
- }
- return status;
-}
-
-status_t DrmManagerClientImpl::setPlaybackStatus(
- int uniqueId, sp<DecryptHandle> &decryptHandle,
- int playbackStatus, int64_t position) {
- status_t status = DRM_ERROR_UNKNOWN;
- if (NULL != decryptHandle.get()) {
- status = getDrmManagerService()->setPlaybackStatus(
- uniqueId, decryptHandle.get(), playbackStatus, position);
- }
- return status;
-}
-
-bool DrmManagerClientImpl::validateAction(
- int uniqueId, const String8& path,
- int action, const ActionDescription& description) {
- bool retCode = false;
- if (EMPTY_STRING != path) {
- retCode = getDrmManagerService()->validateAction(
- uniqueId, path, action, description);
- }
- return retCode;
-}
-
-status_t DrmManagerClientImpl::removeRights(int uniqueId, const String8& path) {
- status_t status = DRM_ERROR_UNKNOWN;
- if (EMPTY_STRING != path) {
- status = getDrmManagerService()->removeRights(uniqueId, path);
- }
- return status;
-}
-
-status_t DrmManagerClientImpl::removeAllRights(int uniqueId) {
- return getDrmManagerService()->removeAllRights(uniqueId);
-}
-
-int DrmManagerClientImpl::openConvertSession(
- int uniqueId, const String8& mimeType) {
- int retCode = INVALID_VALUE;
- if (EMPTY_STRING != mimeType) {
- retCode = getDrmManagerService()->openConvertSession(uniqueId, mimeType);
- }
- return retCode;
-}
-
-DrmConvertedStatus* DrmManagerClientImpl::convertData(
- int uniqueId, int convertId, const DrmBuffer* inputData) {
- DrmConvertedStatus* drmConvertedStatus = NULL;
- if (NULL != inputData) {
- drmConvertedStatus =
- getDrmManagerService()->convertData(uniqueId, convertId, inputData);
- }
- return drmConvertedStatus;
-}
-
-DrmConvertedStatus* DrmManagerClientImpl::closeConvertSession(
- int uniqueId, int convertId) {
- return getDrmManagerService()->closeConvertSession(uniqueId, convertId);
-}
-
-status_t DrmManagerClientImpl::getAllSupportInfo(
- int uniqueId, int* length, DrmSupportInfo** drmSupportInfoArray) {
- status_t status = DRM_ERROR_UNKNOWN;
- if ((NULL != drmSupportInfoArray) && (NULL != length)) {
- status = getDrmManagerService()->getAllSupportInfo(
- uniqueId, length, drmSupportInfoArray);
- }
- return status;
-}
-
-sp<DecryptHandle> DrmManagerClientImpl::openDecryptSession(
- int uniqueId, int fd, off64_t offset, off64_t length) {
- return getDrmManagerService()->openDecryptSession(uniqueId, fd, offset, length);
-}
-
-sp<DecryptHandle> DrmManagerClientImpl::openDecryptSession(
- int uniqueId, const char* uri) {
- DecryptHandle* handle = NULL;
- if (NULL != uri) {
- handle = getDrmManagerService()->openDecryptSession(uniqueId, uri);
- }
- return handle;
-}
-
-status_t DrmManagerClientImpl::closeDecryptSession(
- int uniqueId, sp<DecryptHandle> &decryptHandle) {
- status_t status = DRM_ERROR_UNKNOWN;
- if (NULL != decryptHandle.get()) {
- status = getDrmManagerService()->closeDecryptSession(
- uniqueId, decryptHandle.get());
- }
- return status;
-}
-
-status_t DrmManagerClientImpl::initializeDecryptUnit(
- int uniqueId, sp<DecryptHandle> &decryptHandle,
- int decryptUnitId, const DrmBuffer* headerInfo) {
- status_t status = DRM_ERROR_UNKNOWN;
- if ((NULL != decryptHandle.get()) && (NULL != headerInfo)) {
- status = getDrmManagerService()->initializeDecryptUnit(
- uniqueId, decryptHandle.get(), decryptUnitId, headerInfo);
- }
- return status;
-}
-
-status_t DrmManagerClientImpl::decrypt(
- int uniqueId, sp<DecryptHandle> &decryptHandle,
- int decryptUnitId, const DrmBuffer* encBuffer,
- DrmBuffer** decBuffer, DrmBuffer* IV) {
- status_t status = DRM_ERROR_UNKNOWN;
- if ((NULL != decryptHandle.get()) && (NULL != encBuffer)
- && (NULL != decBuffer) && (NULL != *decBuffer)) {
- status = getDrmManagerService()->decrypt(
- uniqueId, decryptHandle.get(), decryptUnitId,
- encBuffer, decBuffer, IV);
- }
- return status;
-}
-
-status_t DrmManagerClientImpl::finalizeDecryptUnit(
- int uniqueId, sp<DecryptHandle> &decryptHandle, int decryptUnitId) {
- status_t status = DRM_ERROR_UNKNOWN;
- if (NULL != decryptHandle.get()) {
- status = getDrmManagerService()->finalizeDecryptUnit(
- uniqueId, decryptHandle.get(), decryptUnitId);
- }
- return status;
-}
-
-ssize_t DrmManagerClientImpl::pread(int uniqueId, sp<DecryptHandle> &decryptHandle,
- void* buffer, ssize_t numBytes, off64_t offset) {
- ssize_t retCode = INVALID_VALUE;
- if ((NULL != decryptHandle.get()) && (NULL != buffer) && (0 < numBytes)) {
- retCode = getDrmManagerService()->pread(
- uniqueId, decryptHandle.get(), buffer, numBytes, offset);
- }
- return retCode;
-}
-
-status_t DrmManagerClientImpl::notify(const DrmInfoEvent& event) {
- if (NULL != mOnInfoListener.get()) {
- Mutex::Autolock _l(mLock);
- sp<DrmManagerClient::OnInfoListener> listener = mOnInfoListener;
- listener->onInfo(event);
- }
- return DRM_NO_ERROR;
-}
-
-DrmManagerClientImpl::DeathNotifier::~DeathNotifier() {
- Mutex::Autolock lock(sMutex);
- if (NULL != sDrmManagerService.get()) {
- sDrmManagerService->asBinder()->unlinkToDeath(this);
- }
-}
-
-void DrmManagerClientImpl::DeathNotifier::binderDied(const wp<IBinder>& who) {
- Mutex::Autolock lock(sMutex);
- DrmManagerClientImpl::sDrmManagerService.clear();
- ALOGW("DrmManager server died!");
-}
-
diff --git a/drm/libdrmframework/include/DrmManager.h b/drm/libdrmframework/include/DrmManager.h
deleted file mode 100644
index ac2b946..0000000
--- a/drm/libdrmframework/include/DrmManager.h
+++ /dev/null
@@ -1,162 +0,0 @@
-/*
- * Copyright (C) 2010 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.
- */
-
-#ifndef __DRM_MANAGER_H__
-#define __DRM_MANAGER_H__
-
-#include <utils/Errors.h>
-#include <utils/threads.h>
-#include <drm/drm_framework_common.h>
-#include "IDrmEngine.h"
-#include "PlugInManager.h"
-#include "IDrmServiceListener.h"
-
-namespace android {
-
-class IDrmManager;
-class DrmRegistrationInfo;
-class DrmUnregistrationInfo;
-class DrmRightsAcquisitionInfo;
-class DrmConstraints;
-class DrmMetadata;
-class DrmRights;
-class DrmInfo;
-class DrmInfoStatus;
-class DrmConvertedStatus;
-class DrmInfoRequest;
-class DrmSupportInfo;
-class ActionDescription;
-
-/**
- * This is implementation class for DRM Manager. This class delegates the
- * functionality to corresponding DRM Engine.
- *
- * The DrmManagerService class creates an instance of this class.
- *
- */
-class DrmManager : public IDrmEngine::OnInfoListener {
-public:
- DrmManager();
- virtual ~DrmManager();
-
-public:
- int addUniqueId(bool isNative);
-
- void removeUniqueId(int uniqueId);
-
- void addClient(int uniqueId);
-
- void removeClient(int uniqueId);
-
- status_t loadPlugIns();
-
- status_t loadPlugIns(const String8& plugInDirPath);
-
- status_t unloadPlugIns();
-
- status_t setDrmServiceListener(
- int uniqueId, const sp<IDrmServiceListener>& drmServiceListener);
-
- status_t installDrmEngine(int uniqueId, const String8& drmEngineFile);
-
- DrmConstraints* getConstraints(int uniqueId, const String8* path, const int action);
-
- DrmMetadata* getMetadata(int uniqueId, const String8* path);
-
- bool canHandle(int uniqueId, const String8& path, const String8& mimeType);
-
- DrmInfoStatus* processDrmInfo(int uniqueId, const DrmInfo* drmInfo);
-
- DrmInfo* acquireDrmInfo(int uniqueId, const DrmInfoRequest* drmInfoRequest);
-
- status_t saveRights(int uniqueId, const DrmRights& drmRights,
- const String8& rightsPath, const String8& contentPath);
-
- String8 getOriginalMimeType(int uniqueId, const String8& path);
-
- int getDrmObjectType(int uniqueId, const String8& path, const String8& mimeType);
-
- int checkRightsStatus(int uniqueId, const String8& path, int action);
-
- status_t consumeRights(int uniqueId, DecryptHandle* decryptHandle, int action, bool reserve);
-
- status_t setPlaybackStatus(
- int uniqueId, DecryptHandle* decryptHandle, int playbackStatus, int64_t position);
-
- bool validateAction(
- int uniqueId, const String8& path, int action, const ActionDescription& description);
-
- status_t removeRights(int uniqueId, const String8& path);
-
- status_t removeAllRights(int uniqueId);
-
- int openConvertSession(int uniqueId, const String8& mimeType);
-
- DrmConvertedStatus* convertData(int uniqueId, int convertId, const DrmBuffer* inputData);
-
- DrmConvertedStatus* closeConvertSession(int uniqueId, int convertId);
-
- status_t getAllSupportInfo(int uniqueId, int* length, DrmSupportInfo** drmSupportInfoArray);
-
- DecryptHandle* openDecryptSession(int uniqueId, int fd, off64_t offset, off64_t length);
-
- DecryptHandle* openDecryptSession(int uniqueId, const char* uri);
-
- status_t closeDecryptSession(int uniqueId, DecryptHandle* decryptHandle);
-
- status_t initializeDecryptUnit(int uniqueId, DecryptHandle* decryptHandle,
- int decryptUnitId, const DrmBuffer* headerInfo);
-
- status_t decrypt(int uniqueId, DecryptHandle* decryptHandle, int decryptUnitId,
- const DrmBuffer* encBuffer, DrmBuffer** decBuffer, DrmBuffer* IV);
-
- status_t finalizeDecryptUnit(int uniqueId, DecryptHandle* decryptHandle, int decryptUnitId);
-
- ssize_t pread(int uniqueId, DecryptHandle* decryptHandle,
- void* buffer, ssize_t numBytes, off64_t offset);
-
- void onInfo(const DrmInfoEvent& event);
-
-private:
- String8 getSupportedPlugInId(int uniqueId, const String8& path, const String8& mimeType);
-
- String8 getSupportedPlugInId(const String8& mimeType);
-
- String8 getSupportedPlugInIdFromPath(int uniqueId, const String8& path);
-
- bool canHandle(int uniqueId, const String8& path);
-
-private:
- Vector<int> mUniqueIdVector;
- static const String8 EMPTY_STRING;
-
- int mDecryptSessionId;
- int mConvertId;
- Mutex mLock;
- Mutex mListenerLock;
- Mutex mDecryptLock;
- Mutex mConvertLock;
- TPlugInManager<IDrmEngine> mPlugInManager;
- KeyedVector< DrmSupportInfo, String8 > mSupportInfoToPlugInIdMap;
- KeyedVector< int, IDrmEngine*> mConvertSessionMap;
- KeyedVector< int, sp<IDrmServiceListener> > mServiceListeners;
- KeyedVector< int, IDrmEngine*> mDecryptSessionMap;
-};
-
-};
-
-#endif /* __DRM_MANAGER_H__ */
-
diff --git a/drm/libdrmframework/include/DrmManagerClientImpl.h b/drm/libdrmframework/include/DrmManagerClientImpl.h
deleted file mode 100644
index e3338d9..0000000
--- a/drm/libdrmframework/include/DrmManagerClientImpl.h
+++ /dev/null
@@ -1,428 +0,0 @@
-/*
- * Copyright (C) 2010 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.
- */
-
-#ifndef __DRM_MANAGER_CLIENT_IMPL_H__
-#define __DRM_MANAGER_CLIENT_IMPL_H__
-
-#include <binder/IMemory.h>
-#include <utils/threads.h>
-#include <drm/DrmManagerClient.h>
-
-#include "IDrmManagerService.h"
-
-namespace android {
-
-class DrmInfoEvent;
-/**
- * This is implementation class for DrmManagerClient class.
- *
- * Only the JNI layer creates an instance of this class to delegate
- * functionality to Native later.
- *
- */
-class DrmManagerClientImpl : public BnDrmServiceListener {
-private:
- DrmManagerClientImpl() { }
-
-public:
- static DrmManagerClientImpl* create(int* pUniqueId, bool isNative);
-
- static void remove(int uniqueId);
-
- virtual ~DrmManagerClientImpl() { }
-
-public:
- /**
- * Adds the client respective to given unique id.
- *
- * @param[in] uniqueId Unique identifier for a session
- */
- void addClient(int uniqueId);
-
- /**
- * Removes the client respective to given unique id.
- *
- * @param[in] uniqueId Unique identifier for a session
- */
- void removeClient(int uniqueId);
-
- /**
- * Register a callback to be invoked when the caller required to
- * receive necessary information
- *
- * @param[in] uniqueId Unique identifier for a session
- * @param[in] infoListener Listener
- * @return status_t
- * Returns DRM_NO_ERROR for success, DRM_ERROR_UNKNOWN for failure
- */
- status_t setOnInfoListener(
- int uniqueId, const sp<DrmManagerClient::OnInfoListener>& infoListener);
-
- /**
- * Get constraint information associated with input content
- *
- * @param[in] uniqueId Unique identifier for a session
- * @param[in] path Path of the protected content
- * @param[in] action Actions defined such as,
- * Action::DEFAULT, Action::PLAY, etc
- * @return DrmConstraints
- * key-value pairs of constraint are embedded in it
- * @note
- * In case of error, return NULL
- */
- DrmConstraints* getConstraints(int uniqueId, const String8* path, const int action);
-
- /**
- * Get metadata information associated with input content.
- *
- * @param[in] uniqueId Unique identifier for a session
- * @param[in] path Path of the protected content
- * @return DrmMetadata
- * key-value pairs of metadata are embedded in it
- * @note
- * In case of error, return NULL
- */
- DrmMetadata* getMetadata(int uniqueId, const String8* path);
-
- /**
- * Check whether the given mimetype or path can be handled
- *
- * @param[in] uniqueId Unique identifier for a session
- * @param[in] path Path of the content needs to be handled
- * @param[in] mimetype Mimetype of the content needs to be handled
- * @return
- * True if DrmManager can handle given path or mime type.
- */
- bool canHandle(int uniqueId, const String8& path, const String8& mimeType);
-
- /**
- * Executes given drm information based on its type
- *
- * @param[in] uniqueId Unique identifier for a session
- * @param[in] drmInfo Information needs to be processed
- * @return DrmInfoStatus
- * instance as a result of processing given input
- */
- DrmInfoStatus* processDrmInfo(int uniqueId, const DrmInfo* drmInfo);
-
- /**
- * Retrieves necessary information for registration, unregistration or rights
- * acquisition information.
- *
- * @param[in] uniqueId Unique identifier for a session
- * @param[in] drmInfoRequest Request information to retrieve drmInfo
- * @return DrmInfo
- * instance as a result of processing given input
- */
- DrmInfo* acquireDrmInfo(int uniqueId, const DrmInfoRequest* drmInfoRequest);
-
- /**
- * Save DRM rights to specified rights path
- * and make association with content path
- *
- * @param[in] uniqueId Unique identifier for a session
- * @param[in] drmRights DrmRights to be saved
- * @param[in] rightsPath File path where rights to be saved
- * @param[in] contentPath File path where content was saved
- * @return status_t
- * Returns DRM_NO_ERROR for success, DRM_ERROR_UNKNOWN for failure
- */
- status_t saveRights(int uniqueId, const DrmRights& drmRights,
- const String8& rightsPath, const String8& contentPath);
-
- /**
- * Retrieves the mime type embedded inside the original content
- *
- * @param[in] uniqueId Unique identifier for a session
- * @param[in] path the path of the protected content
- * @return String8
- * Returns mime-type of the original content, such as "video/mpeg"
- */
- String8 getOriginalMimeType(int uniqueId, const String8& path);
-
- /**
- * Retrieves the type of the protected object (content, rights, etc..)
- * using specified path or mimetype. At least one parameter should be non null
- * to retrieve DRM object type
- *
- * @param[in] uniqueId Unique identifier for a session
- * @param[in] path Path of the content or null.
- * @param[in] mimeType Mime type of the content or null.
- * @return type of the DRM content,
- * such as DrmObjectType::CONTENT, DrmObjectType::RIGHTS_OBJECT
- */
- int getDrmObjectType(int uniqueId, const String8& path, const String8& mimeType);
-
- /**
- * Check whether the given content has valid rights or not
- *
- * @param[in] uniqueId Unique identifier for a session
- * @param[in] path Path of the protected content
- * @param[in] action Action to perform (Action::DEFAULT, Action::PLAY, etc)
- * @return the status of the rights for the protected content,
- * such as RightsStatus::RIGHTS_VALID, RightsStatus::RIGHTS_EXPIRED, etc.
- */
- int checkRightsStatus(int uniqueId, const String8& path, int action);
-
- /**
- * Consumes the rights for a content.
- * If the reserve parameter is true the rights is reserved until the same
- * application calls this api again with the reserve parameter set to false.
- *
- * @param[in] uniqueId Unique identifier for a session
- * @param[in] decryptHandle Handle for the decryption session
- * @param[in] action Action to perform. (Action::DEFAULT, Action::PLAY, etc)
- * @param[in] reserve True if the rights should be reserved.
- * @return status_t
- * Returns DRM_NO_ERROR for success, DRM_ERROR_UNKNOWN for failure
- */
- status_t consumeRights(int uniqueId, sp<DecryptHandle> &decryptHandle, int action, bool reserve);
-
- /**
- * Informs the DRM engine about the playback actions performed on the DRM files.
- *
- * @param[in] uniqueId Unique identifier for a session
- * @param[in] decryptHandle Handle for the decryption session
- * @param[in] playbackStatus Playback action (Playback::START, Playback::STOP, Playback::PAUSE)
- * @param[in] position Position in the file (in milliseconds) where the start occurs.
- * Only valid together with Playback::START.
- * @return status_t
- * Returns DRM_NO_ERROR for success, DRM_ERROR_UNKNOWN for failure
- */
- status_t setPlaybackStatus(
- int uniqueId, sp<DecryptHandle> &decryptHandle, int playbackStatus, int64_t position);
-
- /**
- * Validates whether an action on the DRM content is allowed or not.
- *
- * @param[in] uniqueId Unique identifier for a session
- * @param[in] path Path of the protected content
- * @param[in] action Action to validate (Action::PLAY, Action::TRANSFER, etc)
- * @param[in] description Detailed description of the action
- * @return true if the action is allowed.
- */
- bool validateAction(
- int uniqueId, const String8& path, int action, const ActionDescription& description);
-
- /**
- * Removes the rights associated with the given protected content
- *
- * @param[in] uniqueId Unique identifier for a session
- * @param[in] path Path of the protected content
- * @return status_t
- * Returns DRM_NO_ERROR for success, DRM_ERROR_UNKNOWN for failure
- */
- status_t removeRights(int uniqueId, const String8& path);
-
- /**
- * Removes all the rights information of each plug-in associated with
- * DRM framework. Will be used in master reset
- *
- * @param[in] uniqueId Unique identifier for a session
- * @return status_t
- * Returns DRM_NO_ERROR for success, DRM_ERROR_UNKNOWN for failure
- */
- status_t removeAllRights(int uniqueId);
-
- /**
- * This API is for Forward Lock based DRM scheme.
- * Each time the application tries to download a new DRM file
- * which needs to be converted, then the application has to
- * begin with calling this API.
- *
- * @param[in] uniqueId Unique identifier for a session
- * @param[in] mimeType Description/MIME type of the input data packet
- * @return Return handle for the convert session
- */
- int openConvertSession(int uniqueId, const String8& mimeType);
-
- /**
- * Accepts and converts the input data which is part of DRM file.
- * The resultant converted data and the status is returned in the DrmConvertedInfo
- * object. This method will be called each time there are new block
- * of data received by the application.
- *
- * @param[in] uniqueId Unique identifier for a session
- * @param[in] convertId Handle for the convert session
- * @param[in] inputData Input Data which need to be converted
- * @return Return object contains the status of the data conversion,
- * the output converted data and offset. In this case the
- * application will ignore the offset information.
- */
- DrmConvertedStatus* convertData(int uniqueId, int convertId, const DrmBuffer* inputData);
-
- /**
- * Informs the Drm Agent when there is no more data which need to be converted
- * or when an error occurs. Upon successful conversion of the complete data,
- * the agent will inform that where the header and body signature
- * should be added. This signature appending is needed to integrity
- * protect the converted file.
- *
- * @param[in] uniqueId Unique identifier for a session
- * @param[in] convertId Handle for the convert session
- * @return Return object contains the status of the data conversion,
- * the header and body signature data. It also informs
- * the application on which offset these signature data
- * should be appended.
- */
- DrmConvertedStatus* closeConvertSession(int uniqueId, int convertId);
-
- /**
- * Retrieves all DrmSupportInfo instance that native DRM framework can handle.
- * This interface is meant to be used by JNI layer
- *
- * @param[in] uniqueId Unique identifier for a session
- * @param[out] length Number of elements in drmSupportInfoArray
- * @param[out] drmSupportInfoArray Array contains all DrmSupportInfo
- * that native DRM framework can handle
- * @return status_t
- * Returns DRM_NO_ERROR for success, DRM_ERROR_UNKNOWN for failure
- */
- status_t getAllSupportInfo(int uniqueId, int* length, DrmSupportInfo** drmSupportInfoArray);
-
- /**
- * Open the decrypt session to decrypt the given protected content
- *
- * @param[in] uniqueId Unique identifier for a session
- * @param[in] fd File descriptor of the protected content to be decrypted
- * @param[in] offset Start position of the content
- * @param[in] length The length of the protected content
- * @return
- * Handle for the decryption session
- */
- sp<DecryptHandle> openDecryptSession(int uniqueId, int fd, off64_t offset, off64_t length);
-
- /**
- * Open the decrypt session to decrypt the given protected content
- *
- * @param[in] uniqueId Unique identifier for a session
- * @param[in] uri Path of the protected content to be decrypted
- * @return
- * Handle for the decryption session
- */
- sp<DecryptHandle> openDecryptSession(int uniqueId, const char* uri);
-
- /**
- * Close the decrypt session for the given handle
- *
- * @param[in] uniqueId Unique identifier for a session
- * @param[in] decryptHandle Handle for the decryption session
- * @return status_t
- * Returns DRM_NO_ERROR for success, DRM_ERROR_UNKNOWN for failure
- */
- status_t closeDecryptSession(int uniqueId, sp<DecryptHandle> &decryptHandle);
-
- /**
- * Initialize decryption for the given unit of the protected content
- *
- * @param[in] uniqueId Unique identifier for a session
- * @param[in] decryptHandle Handle for the decryption session
- * @param[in] decryptUnitId ID which specifies decryption unit, such as track ID
- * @param[in] headerInfo Information for initializing decryption of this decrypUnit
- * @return status_t
- * Returns DRM_NO_ERROR for success, DRM_ERROR_UNKNOWN for failure
- */
- status_t initializeDecryptUnit(int uniqueId, sp<DecryptHandle> &decryptHandle,
- int decryptUnitId, const DrmBuffer* headerInfo);
-
- /**
- * Decrypt the protected content buffers for the given unit
- * This method will be called any number of times, based on number of
- * encrypted streams received from application.
- *
- * @param[in] uniqueId Unique identifier for a session
- * @param[in] decryptHandle Handle for the decryption session
- * @param[in] decryptUnitId ID which specifies decryption unit, such as track ID
- * @param[in] encBuffer Encrypted data block
- * @param[out] decBuffer Decrypted data block
- * @param[in] IV Optional buffer
- * @return status_t
- * Returns the error code for this API
- * DRM_NO_ERROR for success, and one of DRM_ERROR_UNKNOWN, DRM_ERROR_LICENSE_EXPIRED
- * DRM_ERROR_SESSION_NOT_OPENED, DRM_ERROR_DECRYPT_UNIT_NOT_INITIALIZED,
- * DRM_ERROR_DECRYPT for failure.
- */
- status_t decrypt(int uniqueId, sp<DecryptHandle> &decryptHandle, int decryptUnitId,
- const DrmBuffer* encBuffer, DrmBuffer** decBuffer, DrmBuffer* IV);
-
- /**
- * Finalize decryption for the given unit of the protected content
- *
- * @param[in] uniqueId Unique identifier for a session
- * @param[in] decryptHandle Handle for the decryption session
- * @param[in] decryptUnitId ID which specifies decryption unit, such as track ID
- * @return status_t
- * Returns DRM_NO_ERROR for success, DRM_ERROR_UNKNOWN for failure
- */
- status_t finalizeDecryptUnit(int uniqueId, sp<DecryptHandle> &decryptHandle, int decryptUnitId);
-
- /**
- * Reads the specified number of bytes from an open DRM file.
- *
- * @param[in] uniqueId Unique identifier for a session
- * @param[in] decryptHandle Handle for the decryption session
- * @param[out] buffer Reference to the buffer that should receive the read data.
- * @param[in] numBytes Number of bytes to read.
- * @param[in] offset Offset with which to update the file position.
- *
- * @return Number of bytes read. Returns -1 for Failure.
- */
- ssize_t pread(int uniqueId, sp<DecryptHandle> &decryptHandle,
- void* buffer, ssize_t numBytes, off64_t offset);
-
- /**
- * Notify the event to the registered listener
- *
- * @param[in] event The event to be notified
- * @return status_t
- * Returns DRM_NO_ERROR for success, DRM_ERROR_UNKNOWN for failure
- */
- status_t notify(const DrmInfoEvent& event);
-
-private:
- /**
- * Install new DRM Engine Plug-in at the runtime
- *
- * @param[in] uniqueId Unique identifier for a session
- * @param[in] drmEngine Shared Object(so) File in which DRM Engine defined
- * @return status_t
- * Returns DRM_NO_ERROR for success, DRM_ERROR_UNKNOWN for failure
- */
- status_t installDrmEngine(int uniqueId, const String8& drmEngineFile);
-
-private:
- Mutex mLock;
- sp<DrmManagerClient::OnInfoListener> mOnInfoListener;
-
- class DeathNotifier: public IBinder::DeathRecipient {
- public:
- DeathNotifier() {}
- virtual ~DeathNotifier();
- virtual void binderDied(const wp<IBinder>& who);
- };
-
-private:
- static Mutex sMutex;
- static sp<DeathNotifier> sDeathNotifier;
- static sp<IDrmManagerService> sDrmManagerService;
- static const sp<IDrmManagerService>& getDrmManagerService();
- static const String8 EMPTY_STRING;
-};
-
-};
-
-#endif /* __DRM_MANAGER_CLIENT_IMPL_H__ */
-
diff --git a/drm/libdrmframework/include/DrmManagerService.h b/drm/libdrmframework/include/DrmManagerService.h
deleted file mode 100644
index 9cb5804..0000000
--- a/drm/libdrmframework/include/DrmManagerService.h
+++ /dev/null
@@ -1,127 +0,0 @@
-/*
- * Copyright (C) 2010 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.
- */
-
-#ifndef __DRM_MANAGER_SERVICE_H__
-#define __DRM_MANAGER_SERVICE_H__
-
-#include <utils/RefBase.h>
-#include <utils/KeyedVector.h>
-#include <binder/IInterface.h>
-#include <binder/Parcel.h>
-#include "IDrmManagerService.h"
-#include "IDrmServiceListener.h"
-
-namespace android {
-
-class DrmManager;
-class String8;
-class Mutex;
-
-/**
- * This is the implementation class for DRM manager service. This delegates
- * the responsibility to DrmManager.
- *
- * The instance of this class is created while starting the DRM manager service.
- *
- */
-class DrmManagerService : public BnDrmManagerService {
-public:
- static void instantiate();
-
-private:
- DrmManagerService();
- virtual ~DrmManagerService();
-
-public:
- int addUniqueId(bool isNative);
-
- void removeUniqueId(int uniqueId);
-
- void addClient(int uniqueId);
-
- void removeClient(int uniqueId);
-
- status_t setDrmServiceListener(
- int uniqueId, const sp<IDrmServiceListener>& drmServiceListener);
-
- status_t installDrmEngine(int uniqueId, const String8& drmEngineFile);
-
- DrmConstraints* getConstraints(int uniqueId, const String8* path, const int action);
-
- DrmMetadata* getMetadata(int uniqueId, const String8* path);
-
- bool canHandle(int uniqueId, const String8& path, const String8& mimeType);
-
- DrmInfoStatus* processDrmInfo(int uniqueId, const DrmInfo* drmInfo);
-
- DrmInfo* acquireDrmInfo(int uniqueId, const DrmInfoRequest* drmInforequest);
-
- status_t saveRights(int uniqueId, const DrmRights& drmRights,
- const String8& rightsPath, const String8& contentPath);
-
- String8 getOriginalMimeType(int uniqueId, const String8& path);
-
- int getDrmObjectType(int uniqueId, const String8& path, const String8& mimeType);
-
- int checkRightsStatus(int uniqueId, const String8& path,int action);
-
- status_t consumeRights(int uniqueId, DecryptHandle* decryptHandle, int action, bool reserve);
-
- status_t setPlaybackStatus(
- int uniqueId, DecryptHandle* decryptHandle, int playbackStatus, int64_t position);
-
- bool validateAction(int uniqueId, const String8& path,
- int action, const ActionDescription& description);
-
- status_t removeRights(int uniqueId, const String8& path);
-
- status_t removeAllRights(int uniqueId);
-
- int openConvertSession(int uniqueId, const String8& mimeType);
-
- DrmConvertedStatus* convertData(int uniqueId, int convertId, const DrmBuffer* inputData);
-
- DrmConvertedStatus* closeConvertSession(int uniqueId, int convertId);
-
- status_t getAllSupportInfo(int uniqueId, int* length, DrmSupportInfo** drmSupportInfoArray);
-
- DecryptHandle* openDecryptSession(int uniqueId, int fd, off64_t offset, off64_t length);
-
- DecryptHandle* openDecryptSession(int uniqueId, const char* uri);
-
- status_t closeDecryptSession(int uniqueId, DecryptHandle* decryptHandle);
-
- status_t initializeDecryptUnit(int uniqueId, DecryptHandle* decryptHandle,
- int decryptUnitId, const DrmBuffer* headerInfo);
-
- status_t decrypt(int uniqueId, DecryptHandle* decryptHandle, int decryptUnitId,
- const DrmBuffer* encBuffer, DrmBuffer** decBuffer, DrmBuffer* IV);
-
- status_t finalizeDecryptUnit(int uniqueId, DecryptHandle* decryptHandle, int decryptUnitId);
-
- ssize_t pread(int uniqueId, DecryptHandle* decryptHandle,
- void* buffer, ssize_t numBytes, off64_t offset);
-
- virtual status_t dump(int fd, const Vector<String16>& args);
-
-private:
- DrmManager* mDrmManager;
-};
-
-};
-
-#endif /* __DRM_MANAGER_SERVICE_H__ */
-
diff --git a/drm/libdrmframework/include/IDrmManagerService.h b/drm/libdrmframework/include/IDrmManagerService.h
deleted file mode 100644
index b9618bb..0000000
--- a/drm/libdrmframework/include/IDrmManagerService.h
+++ /dev/null
@@ -1,257 +0,0 @@
-/*
- * Copyright (C) 2010 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.
- */
-
-#ifndef __IDRM_MANAGER_SERVICE_H__
-#define __IDRM_MANAGER_SERVICE_H__
-
-#include <utils/RefBase.h>
-#include <binder/IInterface.h>
-#include <binder/Parcel.h>
-#include <drm/drm_framework_common.h>
-#include "IDrmServiceListener.h"
-
-namespace android {
-
-class DrmConstraints;
-class DrmMetadata;
-class DrmRights;
-class DrmInfo;
-class DrmInfoStatus;
-class DrmInfoRequest;
-class DrmSupportInfo;
-class DrmConvertedStatus;
-class String8;
-class ActionDescription;
-
-/**
- * This is the interface class for DRM Manager service.
- *
- */
-class IDrmManagerService : public IInterface
-{
-public:
- enum {
- ADD_UNIQUEID = IBinder::FIRST_CALL_TRANSACTION,
- REMOVE_UNIQUEID,
- ADD_CLIENT,
- REMOVE_CLIENT,
- SET_DRM_SERVICE_LISTENER,
- INSTALL_DRM_ENGINE,
- GET_CONSTRAINTS_FROM_CONTENT,
- GET_METADATA_FROM_CONTENT,
- CAN_HANDLE,
- PROCESS_DRM_INFO,
- ACQUIRE_DRM_INFO,
- SAVE_RIGHTS,
- GET_ORIGINAL_MIMETYPE,
- GET_DRM_OBJECT_TYPE,
- CHECK_RIGHTS_STATUS,
- CONSUME_RIGHTS,
- SET_PLAYBACK_STATUS,
- VALIDATE_ACTION,
- REMOVE_RIGHTS,
- REMOVE_ALL_RIGHTS,
- OPEN_CONVERT_SESSION,
- CONVERT_DATA,
- CLOSE_CONVERT_SESSION,
- GET_ALL_SUPPORT_INFO,
- OPEN_DECRYPT_SESSION,
- OPEN_DECRYPT_SESSION_FROM_URI,
- CLOSE_DECRYPT_SESSION,
- INITIALIZE_DECRYPT_UNIT,
- DECRYPT,
- FINALIZE_DECRYPT_UNIT,
- PREAD
- };
-
-public:
- DECLARE_META_INTERFACE(DrmManagerService);
-
-public:
- virtual int addUniqueId(bool isNative) = 0;
-
- virtual void removeUniqueId(int uniqueId) = 0;
-
- virtual void addClient(int uniqueId) = 0;
-
- virtual void removeClient(int uniqueId) = 0;
-
- virtual status_t setDrmServiceListener(
- int uniqueId, const sp<IDrmServiceListener>& infoListener) = 0;
-
- virtual status_t installDrmEngine(int uniqueId, const String8& drmEngineFile) = 0;
-
- virtual DrmConstraints* getConstraints(
- int uniqueId, const String8* path, const int action) = 0;
-
- virtual DrmMetadata* getMetadata(int uniqueId, const String8* path) = 0;
-
- virtual bool canHandle(int uniqueId, const String8& path, const String8& mimeType) = 0;
-
- virtual DrmInfoStatus* processDrmInfo(int uniqueId, const DrmInfo* drmInfo) = 0;
-
- virtual DrmInfo* acquireDrmInfo(int uniqueId, const DrmInfoRequest* drmInforequest) = 0;
-
- virtual status_t saveRights(int uniqueId, const DrmRights& drmRights,
- const String8& rightsPath, const String8& contentPath) = 0;
-
- virtual String8 getOriginalMimeType(int uniqueId, const String8& path) = 0;
-
- virtual int getDrmObjectType(
- int uniqueId, const String8& path, const String8& mimeType) = 0;
-
- virtual int checkRightsStatus(int uniqueId, const String8& path, int action) = 0;
-
- virtual status_t consumeRights(
- int uniqueId, DecryptHandle* decryptHandle, int action, bool reserve) = 0;
-
- virtual status_t setPlaybackStatus(
- int uniqueId, DecryptHandle* decryptHandle, int playbackStatus, int64_t position) = 0;
-
- virtual bool validateAction(
- int uniqueId, const String8& path,
- int action, const ActionDescription& description) = 0;
-
- virtual status_t removeRights(int uniqueId, const String8& path) = 0;
-
- virtual status_t removeAllRights(int uniqueId) = 0;
-
- virtual int openConvertSession(int uniqueId, const String8& mimeType) = 0;
-
- virtual DrmConvertedStatus* convertData(
- int uniqueId, int convertId, const DrmBuffer* inputData) = 0;
-
- virtual DrmConvertedStatus* closeConvertSession(int uniqueId, int convertId) = 0;
-
- virtual status_t getAllSupportInfo(
- int uniqueId, int* length, DrmSupportInfo** drmSupportInfoArray) = 0;
-
- virtual DecryptHandle* openDecryptSession(int uniqueId, int fd, off64_t offset, off64_t length) = 0;
-
- virtual DecryptHandle* openDecryptSession(int uniqueId, const char* uri) = 0;
-
- virtual status_t closeDecryptSession(int uniqueId, DecryptHandle* decryptHandle) = 0;
-
- virtual status_t initializeDecryptUnit(int uniqueId, DecryptHandle* decryptHandle,
- int decryptUnitId, const DrmBuffer* headerInfo) = 0;
-
- virtual status_t decrypt(int uniqueId, DecryptHandle* decryptHandle, int decryptUnitId,
- const DrmBuffer* encBuffer, DrmBuffer** decBuffer, DrmBuffer* IV) = 0;
-
- virtual status_t finalizeDecryptUnit(
- int uniqueId, DecryptHandle* decryptHandle, int decryptUnitId) = 0;
-
- virtual ssize_t pread(int uniqueId, DecryptHandle* decryptHandle,
- void* buffer, ssize_t numBytes,off64_t offset) = 0;
-};
-
-/**
- * This is the Binder implementation class for DRM Manager service.
- */
-class BpDrmManagerService: public BpInterface<IDrmManagerService>
-{
-public:
- BpDrmManagerService(const sp<IBinder>& impl)
- : BpInterface<IDrmManagerService>(impl) {}
-
- virtual int addUniqueId(bool isNative);
-
- virtual void removeUniqueId(int uniqueId);
-
- virtual void addClient(int uniqueId);
-
- virtual void removeClient(int uniqueId);
-
- virtual status_t setDrmServiceListener(
- int uniqueId, const sp<IDrmServiceListener>& infoListener);
-
- virtual status_t installDrmEngine(int uniqueId, const String8& drmEngineFile);
-
- virtual DrmConstraints* getConstraints(int uniqueId, const String8* path, const int action);
-
- virtual DrmMetadata* getMetadata(int uniqueId, const String8* path);
-
- virtual bool canHandle(int uniqueId, const String8& path, const String8& mimeType);
-
- virtual DrmInfoStatus* processDrmInfo(int uniqueId, const DrmInfo* drmInfo);
-
- virtual DrmInfo* acquireDrmInfo(int uniqueId, const DrmInfoRequest* drmInforequest);
-
- virtual status_t saveRights(int uniqueId, const DrmRights& drmRights,
- const String8& rightsPath, const String8& contentPath);
-
- virtual String8 getOriginalMimeType(int uniqueId, const String8& path);
-
- virtual int getDrmObjectType(int uniqueId, const String8& path, const String8& mimeType);
-
- virtual int checkRightsStatus(int uniqueId, const String8& path, int action);
-
- virtual status_t consumeRights(
- int uniqueId, DecryptHandle* decryptHandle, int action, bool reserve);
-
- virtual status_t setPlaybackStatus(
- int uniqueId, DecryptHandle* decryptHandle, int playbackStatus, int64_t position);
-
- virtual bool validateAction(
- int uniqueId, const String8& path, int action, const ActionDescription& description);
-
- virtual status_t removeRights(int uniqueId, const String8& path);
-
- virtual status_t removeAllRights(int uniqueId);
-
- virtual int openConvertSession(int uniqueId, const String8& mimeType);
-
- virtual DrmConvertedStatus* convertData(
- int uniqueId, int convertId, const DrmBuffer* inputData);
-
- virtual DrmConvertedStatus* closeConvertSession(int uniqueId, int convertId);
-
- virtual status_t getAllSupportInfo(
- int uniqueId, int* length, DrmSupportInfo** drmSupportInfoArray);
-
- virtual DecryptHandle* openDecryptSession(int uniqueId, int fd, off64_t offset, off64_t length);
-
- virtual DecryptHandle* openDecryptSession(int uniqueId, const char* uri);
-
- virtual status_t closeDecryptSession(int uniqueId, DecryptHandle* decryptHandle);
-
- virtual status_t initializeDecryptUnit(int uniqueId, DecryptHandle* decryptHandle,
- int decryptUnitId, const DrmBuffer* headerInfo);
-
- virtual status_t decrypt(int uniqueId, DecryptHandle* decryptHandle, int decryptUnitId,
- const DrmBuffer* encBuffer, DrmBuffer** decBuffer, DrmBuffer* IV);
-
- virtual status_t finalizeDecryptUnit(
- int uniqueId, DecryptHandle* decryptHandle, int decryptUnitId);
-
- virtual ssize_t pread(int uniqueId, DecryptHandle* decryptHandle,
- void* buffer, ssize_t numBytes, off64_t offset);
-};
-
-/**
- * This is the Binder implementation class for DRM Manager service.
- */
-class BnDrmManagerService: public BnInterface<IDrmManagerService>
-{
-public:
- virtual status_t onTransact(
- uint32_t code, const Parcel& data, Parcel* reply, uint32_t flags = 0);
-};
-
-};
-
-#endif /* __IDRM_MANAGER_SERVICE_H__ */
-
diff --git a/drm/libdrmframework/include/IDrmServiceListener.h b/drm/libdrmframework/include/IDrmServiceListener.h
deleted file mode 100644
index 7f7109f..0000000
--- a/drm/libdrmframework/include/IDrmServiceListener.h
+++ /dev/null
@@ -1,71 +0,0 @@
-/*
- * Copyright (C) 2010 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.
- */
-
-#ifndef __IDRM_SERVICE_LISTENER_H__
-#define __IDRM_SERVICE_LISTENER_H__
-
-#include <utils/RefBase.h>
-#include <binder/IInterface.h>
-#include <binder/Parcel.h>
-
-namespace android {
-
-class DrmInfoEvent;
-
-/**
- * This is the interface class for DRM service listener.
- *
- */
-class IDrmServiceListener : public IInterface
-{
-public:
- enum {
- NOTIFY = IBinder::FIRST_CALL_TRANSACTION,
- };
-
-public:
- DECLARE_META_INTERFACE(DrmServiceListener);
-
-public:
- virtual status_t notify(const DrmInfoEvent& event) = 0;
-};
-
-/**
- * This is the Binder implementation class for DRM service listener.
- */
-class BpDrmServiceListener: public BpInterface<IDrmServiceListener>
-{
-public:
- BpDrmServiceListener(const sp<IBinder>& impl)
- : BpInterface<IDrmServiceListener>(impl) {}
-
- virtual status_t notify(const DrmInfoEvent& event);
-};
-
-/**
- * This is the Binder implementation class for DRM service listener.
- */
-class BnDrmServiceListener: public BnInterface<IDrmServiceListener>
-{
-public:
- virtual status_t onTransact(
- uint32_t code, const Parcel& data, Parcel* reply, uint32_t flags = 0);
-};
-
-};
-
-#endif /* __IDRM_SERVICE_LISTENER_H__ */
-
diff --git a/drm/libdrmframework/include/PlugInManager.h b/drm/libdrmframework/include/PlugInManager.h
deleted file mode 100644
index 7bb143f..0000000
--- a/drm/libdrmframework/include/PlugInManager.h
+++ /dev/null
@@ -1,269 +0,0 @@
-/*
- * Copyright (C) 2010 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.
- */
-
-#ifndef __PLUGIN_MANAGER_H__
-#define __PLUGIN_MANAGER_H__
-
-#include <dlfcn.h>
-#include <sys/types.h>
-#include <dirent.h>
-
-#include <utils/String8.h>
-#include <utils/Vector.h>
-#include <utils/KeyedVector.h>
-
-namespace android {
-
-const char* const PLUGIN_MANAGER_CREATE = "create";
-const char* const PLUGIN_MANAGER_DESTROY = "destroy";
-const char* const PLUGIN_EXTENSION = ".so";
-
-/**
- * This is the template class for Plugin manager.
- *
- * The DrmManager uses this class to handle the plugins.
- *
- */
-template<typename Type>
-class TPlugInManager {
-private:
- typedef void* HANDLE;
- typedef Type* create_t(void);
- typedef void destroy_t(Type*);
- typedef create_t* FPCREATE;
- typedef destroy_t* FPDESTORY;
-
- typedef struct _PlugInContainer {
- String8 sPath;
- HANDLE hHandle;
- FPCREATE fpCreate;
- FPDESTORY fpDestory;
- Type* pInstance;
-
- _PlugInContainer():
- sPath("")
- ,hHandle(NULL)
- ,fpCreate(NULL)
- ,fpDestory(NULL)
- ,pInstance(NULL)
- {}
- } PlugInContainer;
-
- typedef KeyedVector<String8, PlugInContainer*> PlugInMap;
- PlugInMap m_plugInMap;
-
- typedef Vector<String8> PlugInIdList;
- PlugInIdList m_plugInIdList;
-
-public:
- /**
- * Load all the plug-ins in the specified directory
- *
- * @param[in] rsPlugInDirPath
- * Directory path which plug-ins (dynamic library) are stored
- * @note Plug-ins should be implemented according to the specification
- */
- void loadPlugIns(const String8& rsPlugInDirPath) {
- Vector<String8> plugInFileList = getPlugInPathList(rsPlugInDirPath);
-
- if (!plugInFileList.isEmpty()) {
- for (unsigned int i = 0; i < plugInFileList.size(); ++i) {
- loadPlugIn(plugInFileList[i]);
- }
- }
- }
-
- /**
- * Unload all the plug-ins
- *
- */
- void unloadPlugIns() {
- for (unsigned int i = 0; i < m_plugInIdList.size(); ++i) {
- unloadPlugIn(m_plugInIdList[i]);
- }
- m_plugInIdList.clear();
- }
-
- /**
- * Get all the IDs of available plug-ins
- *
- * @return[in] plugInIdList
- * String type Vector in which all plug-in IDs are stored
- */
- Vector<String8> getPlugInIdList() const {
- return m_plugInIdList;
- }
-
- /**
- * Get a plug-in reference of specified ID
- *
- * @param[in] rsPlugInId
- * Plug-in ID to be used
- * @return plugIn
- * Reference of specified plug-in instance
- */
- Type& getPlugIn(const String8& rsPlugInId) {
- if (!contains(rsPlugInId)) {
- // This error case never happens
- }
- return *(m_plugInMap.valueFor(rsPlugInId)->pInstance);
- }
-
-public:
- /**
- * Load a plug-in stored in the specified path
- *
- * @param[in] rsPlugInPath
- * Plug-in (dynamic library) file path
- * @note Plug-in should be implemented according to the specification
- */
- void loadPlugIn(const String8& rsPlugInPath) {
- if (contains(rsPlugInPath)) {
- return;
- }
-
- PlugInContainer* pPlugInContainer = new PlugInContainer();
-
- pPlugInContainer->hHandle = dlopen(rsPlugInPath.string(), RTLD_LAZY);
-
- if (NULL == pPlugInContainer->hHandle) {
- delete pPlugInContainer;
- pPlugInContainer = NULL;
- return;
- }
-
- pPlugInContainer->sPath = rsPlugInPath;
- pPlugInContainer->fpCreate
- = (FPCREATE)dlsym(pPlugInContainer->hHandle, PLUGIN_MANAGER_CREATE);
- pPlugInContainer->fpDestory
- = (FPDESTORY)dlsym(pPlugInContainer->hHandle, PLUGIN_MANAGER_DESTROY);
-
- if (NULL != pPlugInContainer->fpCreate && NULL != pPlugInContainer->fpDestory) {
- pPlugInContainer->pInstance = (Type*)pPlugInContainer->fpCreate();
- m_plugInIdList.add(rsPlugInPath);
- m_plugInMap.add(rsPlugInPath, pPlugInContainer);
- } else {
- dlclose(pPlugInContainer->hHandle);
- delete pPlugInContainer;
- pPlugInContainer = NULL;
- return;
- }
- }
-
- /**
- * Unload a plug-in stored in the specified path
- *
- * @param[in] rsPlugInPath
- * Plug-in (dynamic library) file path
- */
- void unloadPlugIn(const String8& rsPlugInPath) {
- if (!contains(rsPlugInPath)) {
- return;
- }
-
- PlugInContainer* pPlugInContainer = m_plugInMap.valueFor(rsPlugInPath);
- pPlugInContainer->fpDestory(pPlugInContainer->pInstance);
- dlclose(pPlugInContainer->hHandle);
-
- m_plugInMap.removeItem(rsPlugInPath);
- delete pPlugInContainer;
- pPlugInContainer = NULL;
- }
-
-private:
- /**
- * True if TPlugInManager contains rsPlugInId
- */
- bool contains(const String8& rsPlugInId) {
- return m_plugInMap.indexOfKey(rsPlugInId) != NAME_NOT_FOUND;
- }
-
- /**
- * Return file path list of plug-ins stored in the specified directory
- *
- * @param[in] rsDirPath
- * Directory path in which plug-ins are stored
- * @return plugInFileList
- * String type Vector in which file path of plug-ins are stored
- */
- Vector<String8> getPlugInPathList(const String8& rsDirPath) {
- Vector<String8> fileList;
- DIR* pDir = opendir(rsDirPath.string());
- struct dirent* pEntry;
-
- while (NULL != pDir && NULL != (pEntry = readdir(pDir))) {
- if (!isPlugIn(pEntry)) {
- continue;
- }
- String8 plugInPath;
- plugInPath += rsDirPath;
- plugInPath += "/";
- plugInPath += pEntry->d_name;
-
- fileList.add(plugInPath);
- }
-
- if (NULL != pDir) {
- closedir(pDir);
- }
-
- return fileList;
- }
-
- /**
- * True if the input name denotes plug-in
- */
- bool isPlugIn(const struct dirent* pEntry) const {
- String8 sName(pEntry->d_name);
- String8 extension(sName.getPathExtension());
- // Note that the plug-in extension must exactly match case
- return extension == String8(PLUGIN_EXTENSION);
- }
-
- /**
- * True if the input entry is "." or ".."
- */
- bool isDotOrDDot(const struct dirent* pEntry) const {
- String8 sName(pEntry->d_name);
- return "." == sName || ".." == sName;
- }
-
- /**
- * True if input entry is directory
- */
- bool isDirectory(const struct dirent* pEntry) const {
- return DT_DIR == pEntry->d_type;
- }
-
- /**
- * True if input entry is regular file
- */
- bool isRegularFile(const struct dirent* pEntry) const {
- return DT_REG == pEntry->d_type;
- }
-
- /**
- * True if input entry is link
- */
- bool isLink(const struct dirent* pEntry) const {
- return DT_LNK == pEntry->d_type;
- }
-};
-
-};
-
-#endif /* __PLUGIN_MANAGER_H__ */
-
diff --git a/drm/libdrmframework/include/ReadWriteUtils.h b/drm/libdrmframework/include/ReadWriteUtils.h
deleted file mode 100644
index 529b342..0000000
--- a/drm/libdrmframework/include/ReadWriteUtils.h
+++ /dev/null
@@ -1,79 +0,0 @@
-/*
- * Copyright (C) 2010 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.
- */
-
-#ifndef __READ_WRITE_UTILS_H__
-#define __READ_WRITE_UTILS_H__
-
-#include <utils/FileMap.h>
-#include <drm/drm_framework_common.h>
-
-namespace android {
-
-/**
- * This is an utility class which performs IO operations.
- *
- */
-class ReadWriteUtils {
-public:
- /**
- * Constructor for ReadWriteUtils
- */
- ReadWriteUtils() {}
-
- /**
- * Destructor for ReadWriteUtils
- */
- virtual ~ReadWriteUtils();
-
-public:
- /**
- * Reads the data from the file path provided
- *
- * @param[in] filePath Path of the file
- * @return Data read from the file
- */
- static String8 readBytes(const String8& filePath);
- /**
- * Reads the data into the given buffer from the file path provided
- *
- * @param[in] filePath Path of the file
- * @param[out] buffer Data read from the file
- * @return Length of the data read from the file
- */
- static int readBytes(const String8& filePath, char** buffer);
- /**
- * Writes the data into the file path provided
- *
- * @param[in] filePath Path of the file
- * @param[in] dataBuffer Data to write
- */
- static void writeToFile(const String8& filePath, const String8& data);
- /**
- * Appends the data into the file path provided
- *
- * @param[in] filePath Path of the file
- * @param[in] dataBuffer Data to append
- */
- static void appendToFile(const String8& filePath, const String8& data);
-
-private:
- FileMap* mFileMap;
-};
-
-};
-
-#endif /* __READ_WRITE_UTILS_H__ */
-
diff --git a/drm/libdrmframework/plugins/Android.mk b/drm/libdrmframework/plugins/Android.mk
deleted file mode 100644
index 9ee7961..0000000
--- a/drm/libdrmframework/plugins/Android.mk
+++ /dev/null
@@ -1,16 +0,0 @@
-#
-# Copyright (C) 2010 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.
-#
-include $(call all-subdir-makefiles)
diff --git a/drm/libdrmframework/plugins/common/Android.mk b/drm/libdrmframework/plugins/common/Android.mk
deleted file mode 100644
index 9ee7961..0000000
--- a/drm/libdrmframework/plugins/common/Android.mk
+++ /dev/null
@@ -1,16 +0,0 @@
-#
-# Copyright (C) 2010 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.
-#
-include $(call all-subdir-makefiles)
diff --git a/drm/libdrmframework/plugins/common/include/DrmEngineBase.h b/drm/libdrmframework/plugins/common/include/DrmEngineBase.h
deleted file mode 100644
index 4a5afcf..0000000
--- a/drm/libdrmframework/plugins/common/include/DrmEngineBase.h
+++ /dev/null
@@ -1,465 +0,0 @@
-/*
- * Copyright (C) 2010 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.
- */
-
-#ifndef __DRM_ENGINE_BASE_H__
-#define __DRM_ENGINE_BASE_H__
-
-#include <drm/drm_framework_common.h>
-#include "IDrmEngine.h"
-
-namespace android {
-
-/**
- * This class is an interface for plug-in developers
- *
- * Responsibility of this class is control the sequence of actual plug-in.
- * All each plug-in developer has to do is implement onXXX() type virtual interfaces.
- */
-class DrmEngineBase : public IDrmEngine {
-public:
- DrmEngineBase();
- virtual ~DrmEngineBase();
-
-public:
- DrmConstraints* getConstraints(int uniqueId, const String8* path, int action);
-
- DrmMetadata* getMetadata(int uniqueId, const String8* path);
-
- status_t initialize(int uniqueId);
-
- status_t setOnInfoListener(int uniqueId, const IDrmEngine::OnInfoListener* infoListener);
-
- status_t terminate(int uniqueId);
-
- bool canHandle(int uniqueId, const String8& path);
-
- DrmInfoStatus* processDrmInfo(int uniqueId, const DrmInfo* drmInfo);
-
- status_t saveRights(int uniqueId, const DrmRights& drmRights,
- const String8& rightsPath, const String8& contentPath);
-
- DrmInfo* acquireDrmInfo(int uniqueId, const DrmInfoRequest* drmInfoRequest);
-
- String8 getOriginalMimeType(int uniqueId, const String8& path);
-
- int getDrmObjectType(int uniqueId, const String8& path, const String8& mimeType);
-
- int checkRightsStatus(int uniqueId, const String8& path, int action);
-
- status_t consumeRights(int uniqueId, DecryptHandle* decryptHandle, int action, bool reserve);
-
- status_t setPlaybackStatus(
- int uniqueId, DecryptHandle* decryptHandle, int playbackStatus, int64_t position);
-
- bool validateAction(
- int uniqueId, const String8& path, int action, const ActionDescription& description);
-
- status_t removeRights(int uniqueId, const String8& path);
-
- status_t removeAllRights(int uniqueId);
-
- status_t openConvertSession(int uniqueId, int convertId);
-
- DrmConvertedStatus* convertData(int uniqueId, int convertId, const DrmBuffer* inputData);
-
- DrmConvertedStatus* closeConvertSession(int uniqueId, int convertId);
-
- DrmSupportInfo* getSupportInfo(int uniqueId);
-
- status_t openDecryptSession(
- int uniqueId, DecryptHandle* decryptHandle, int fd, off64_t offset, off64_t length);
-
- status_t openDecryptSession(
- int uniqueId, DecryptHandle* decryptHandle, const char* uri);
-
- status_t closeDecryptSession(int uniqueId, DecryptHandle* decryptHandle);
-
- status_t initializeDecryptUnit(int uniqueId, DecryptHandle* decryptHandle,
- int decryptUnitId, const DrmBuffer* headerInfo);
-
- status_t decrypt(int uniqueId, DecryptHandle* decryptHandle, int decryptUnitId,
- const DrmBuffer* encBuffer, DrmBuffer** decBuffer, DrmBuffer* IV);
-
- status_t finalizeDecryptUnit(int uniqueId, DecryptHandle* decryptHandle, int decryptUnitId);
-
- ssize_t pread(int uniqueId, DecryptHandle* decryptHandle,
- void* buffer, ssize_t numBytes, off64_t offset);
-
-protected:
- /////////////////////////////////////////////////////
- // Interface for plug-in developers //
- // each plug-in has to implement following method //
- /////////////////////////////////////////////////////
- /**
- * Get constraint information associated with input content
- *
- * @param[in] uniqueId Unique identifier for a session
- * @param[in] path Path of the protected content
- * @param[in] action Actions defined such as,
- * Action::DEFAULT, Action::PLAY, etc
- * @return DrmConstraints
- * key-value pairs of constraint are embedded in it
- * @note
- * In case of error, return NULL
- */
- virtual DrmConstraints* onGetConstraints(
- int uniqueId, const String8* path, int action) = 0;
-
- /**
- * Get metadata information associated with input content
- *
- * @param[in] uniqueId Unique identifier for a session
- * @param[in] path Path of the protected content
- * @return DrmMetadata
- * key-value pairs of metadata
- * @note
- * In case of error, return NULL
- */
- virtual DrmMetadata* onGetMetadata(int uniqueId, const String8* path) = 0;
-
- /**
- * Initialize plug-in
- *
- * @param[in] uniqueId Unique identifier for a session
- * @return status_t
- * Returns DRM_NO_ERROR for success, DRM_ERROR_UNKNOWN for failure
- */
- virtual status_t onInitialize(int uniqueId) = 0;
-
- /**
- * Register a callback to be invoked when the caller required to
- * receive necessary information
- *
- * @param[in] uniqueId Unique identifier for a session. uniqueId is a random
- * number generated in the DRM service. If the DrmManagerClient
- * is created in native code, uniqueId will be a number ranged
- * from 0x1000 to 0x1fff. If it comes from Java code, the uniqueId
- * will be a number ranged from 0x00 to 0xfff. So bit 0x1000 in
- * uniqueId could be used in DRM plugins to differentiate native
- * OnInfoListener and Java OnInfoListener.
- * @param[in] infoListener Listener
- * @return status_t
- * Returns DRM_NO_ERROR for success, DRM_ERROR_UNKNOWN for failure
- */
- virtual status_t onSetOnInfoListener(
- int uniqueId, const IDrmEngine::OnInfoListener* infoListener) = 0;
-
- /**
- * Terminate the plug-in
- * and release resource bound to plug-in
- *
- * @param[in] uniqueId Unique identifier for a session
- * @return status_t
- * Returns DRM_NO_ERROR for success, DRM_ERROR_UNKNOWN for failure
- */
- virtual status_t onTerminate(int uniqueId) = 0;
-
- /**
- * Get whether the given content can be handled by this plugin or not
- *
- * @param[in] uniqueId Unique identifier for a session
- * @param[in] path Path the protected object
- * @return bool
- * Returns true if this plugin can handle , false in case of not able to handle
- */
- virtual bool onCanHandle(int uniqueId, const String8& path) = 0;
-
- /**
- * Executes given drm information based on its type
- *
- * @param[in] uniqueId Unique identifier for a session
- * @param[in] drmInfo Information needs to be processed
- * @return DrmInfoStatus
- * instance as a result of processing given input
- */
- virtual DrmInfoStatus* onProcessDrmInfo(int uniqueId, const DrmInfo* drmInfo) = 0;
-
- /**
- * Save DRM rights to specified rights path
- * and make association with content path
- *
- * @param[in] uniqueId Unique identifier for a session
- * @param[in] drmRights DrmRights to be saved
- * @param[in] rightsPath File path where rights to be saved
- * @param[in] contentPath File path where content was saved
- * @return status_t
- * Returns DRM_NO_ERROR for success, DRM_ERROR_UNKNOWN for failure
- */
- virtual status_t onSaveRights(int uniqueId, const DrmRights& drmRights,
- const String8& rightspath, const String8& contentPath) = 0;
-
- /**
- * Retrieves necessary information for registration, unregistration or rights
- * acquisition information.
- *
- * @param[in] uniqueId Unique identifier for a session
- * @param[in] drmInfoRequest Request information to retrieve drmInfo
- * @return DrmInfo
- * instance as a result of processing given input
- */
- virtual DrmInfo* onAcquireDrmInfo(int uniqueId, const DrmInfoRequest* drmInforequest) = 0;
-
- /**
- * Retrieves the mime type embedded inside the original content
- *
- * @param[in] uniqueId Unique identifier for a session
- * @param[in] path Path of the protected content
- * @return String8
- * Returns mime-type of the original content, such as "video/mpeg"
- */
- virtual String8 onGetOriginalMimeType(int uniqueId, const String8& path) = 0;
-
- /**
- * Retrieves the type of the protected object (content, rights, etc..)
- * using specified path or mimetype. At least one parameter should be non null
- * to retrieve DRM object type
- *
- * @param[in] uniqueId Unique identifier for a session
- * @param[in] path Path of the content or null.
- * @param[in] mimeType Mime type of the content or null.
- * @return type of the DRM content,
- * such as DrmObjectType::CONTENT, DrmObjectType::RIGHTS_OBJECT
- */
- virtual int onGetDrmObjectType(
- int uniqueId, const String8& path, const String8& mimeType) = 0;
-
- /**
- * Check whether the given content has valid rights or not
- *
- * @param[in] uniqueId Unique identifier for a session
- * @param[in] path Path of the protected content
- * @param[in] action Action to perform (Action::DEFAULT, Action::PLAY, etc)
- * @return the status of the rights for the protected content,
- * such as RightsStatus::RIGHTS_VALID, RightsStatus::RIGHTS_EXPIRED, etc.
- */
- virtual int onCheckRightsStatus(int uniqueId, const String8& path, int action) = 0;
-
- /**
- * Consumes the rights for a content.
- * If the reserve parameter is true the rights is reserved until the same
- * application calls this api again with the reserve parameter set to false.
- *
- * @param[in] uniqueId Unique identifier for a session
- * @param[in] decryptHandle Handle for the decryption session
- * @param[in] action Action to perform. (Action::DEFAULT, Action::PLAY, etc)
- * @param[in] reserve True if the rights should be reserved.
- * @return status_t
- * Returns DRM_NO_ERROR for success, DRM_ERROR_UNKNOWN for failure
- */
- virtual status_t onConsumeRights(int uniqueId, DecryptHandle* decryptHandle,
- int action, bool reserve) = 0;
-
- /**
- * Informs the DRM Engine about the playback actions performed on the DRM files.
- *
- * @param[in] uniqueId Unique identifier for a session
- * @param[in] decryptHandle Handle for the decryption session
- * @param[in] playbackStatus Playback action (Playback::START, Playback::STOP, Playback::PAUSE)
- * @param[in] position Position in the file (in milliseconds) where the start occurs.
- * Only valid together with Playback::START.
- * @return status_t
- * Returns DRM_NO_ERROR for success, DRM_ERROR_UNKNOWN for failure
- */
- virtual status_t onSetPlaybackStatus(
- int uniqueId, DecryptHandle* decryptHandle, int playbackStatus, int64_t position) = 0;
-
- /**
- * Validates whether an action on the DRM content is allowed or not.
- *
- * @param[in] uniqueId Unique identifier for a session
- * @param[in] path Path of the protected content
- * @param[in] action Action to validate (Action::PLAY, Action::TRANSFER, etc)
- * @param[in] description Detailed description of the action
- * @return true if the action is allowed.
- */
- virtual bool onValidateAction(int uniqueId, const String8& path,
- int action, const ActionDescription& description) = 0;
-
- /**
- * Removes the rights associated with the given protected content
- *
- * @param[in] uniqueId Unique identifier for a session
- * @param[in] path Path of the protected content
- * @return status_t
- * Returns DRM_NO_ERROR for success, DRM_ERROR_UNKNOWN for failure
- */
- virtual status_t onRemoveRights(int uniqueId, const String8& path) = 0;
-
- /**
- * Removes all the rights information of each plug-in associated with
- * DRM framework. Will be used in master reset
- *
- * @param[in] uniqueId Unique identifier for a session
- * @return status_t
- * Returns DRM_NO_ERROR for success, DRM_ERROR_UNKNOWN for failure
- */
- virtual status_t onRemoveAllRights(int uniqueId) = 0;
-
- /**
- * This API is for Forward Lock based DRM scheme.
- * Each time the application tries to download a new DRM file
- * which needs to be converted, then the application has to
- * begin with calling this API.
- *
- * @param[in] uniqueId Unique identifier for a session
- * @param[in] convertId Handle for the convert session
- * @return status_t
- * Returns DRM_NO_ERROR for success, DRM_ERROR_UNKNOWN for failure
- */
- virtual status_t onOpenConvertSession(int uniqueId, int convertId) = 0;
-
- /**
- * Accepts and converts the input data which is part of DRM file.
- * The resultant converted data and the status is returned in the DrmConvertedInfo
- * object. This method will be called each time there are new block
- * of data received by the application.
- *
- * @param[in] uniqueId Unique identifier for a session
- * @param[in] convertId Handle for the convert session
- * @param[in] inputData Input Data which need to be converted
- * @return Return object contains the status of the data conversion,
- * the output converted data and offset. In this case the
- * application will ignore the offset information.
- */
- virtual DrmConvertedStatus* onConvertData(
- int uniqueId, int convertId, const DrmBuffer* inputData) = 0;
-
- /**
- * Informs the Drm Agent when there is no more data which need to be converted
- * or when an error occurs. Upon successful conversion of the complete data,
- * the agent will inform that where the header and body signature
- * should be added. This signature appending is needed to integrity
- * protect the converted file.
- *
- * @param[in] uniqueId Unique identifier for a session
- * @param[in] convertId Handle for the convert session
- * @return Return object contains the status of the data conversion,
- * the header and body signature data. It also informs
- * the application on which offset these signature data
- * should be appended.
- */
- virtual DrmConvertedStatus* onCloseConvertSession(int uniqueId, int convertId) = 0;
-
- /**
- * Returns the information about the Drm Engine capabilities which includes
- * supported MimeTypes and file suffixes.
- *
- * @param[in] uniqueId Unique identifier for a session
- * @return DrmSupportInfo
- * instance which holds the capabilities of a plug-in
- */
- virtual DrmSupportInfo* onGetSupportInfo(int uniqueId) = 0;
-
- /**
- * Open the decrypt session to decrypt the given protected content
- *
- * @param[in] uniqueId Unique identifier for a session
- * @param[in] decryptHandle Handle for the current decryption session
- * @param[in] fd File descriptor of the protected content to be decrypted
- * @param[in] offset Start position of the content
- * @param[in] length The length of the protected content
- * @return
- * DRM_ERROR_CANNOT_HANDLE for failure and DRM_NO_ERROR for success
- */
- virtual status_t onOpenDecryptSession(
- int uniqueId, DecryptHandle* decryptHandle, int fd, off64_t offset, off64_t length) = 0;
-
- /**
- * Open the decrypt session to decrypt the given protected content
- *
- * @param[in] uniqueId Unique identifier for a session
- * @param[in] decryptHandle Handle for the current decryption session
- * @param[in] uri Path of the protected content to be decrypted
- * @return
- * DRM_ERROR_CANNOT_HANDLE for failure and DRM_NO_ERROR for success
- */
- virtual status_t onOpenDecryptSession(
- int uniqueId, DecryptHandle* decryptHandle, const char* uri) = 0;
-
- /**
- * Close the decrypt session for the given handle
- *
- * @param[in] uniqueId Unique identifier for a session
- * @param[in] decryptHandle Handle for the decryption session
- * @return status_t
- * Returns DRM_NO_ERROR for success, DRM_ERROR_UNKNOWN for failure
- */
- virtual status_t onCloseDecryptSession(int uniqueId, DecryptHandle* decryptHandle) = 0;
-
- /**
- * Initialize decryption for the given unit of the protected content
- *
- * @param[in] uniqueId Unique identifier for a session
- * @param[in] decryptId Handle for the decryption session
- * @param[in] decryptUnitId ID Specifies decryption unit, such as track ID
- * @param[in] headerInfo Information for initializing decryption of this decrypUnit
- * @return status_t
- * Returns DRM_NO_ERROR for success, DRM_ERROR_UNKNOWN for failure
- */
- virtual status_t onInitializeDecryptUnit(int uniqueId, DecryptHandle* decryptHandle,
- int decryptUnitId, const DrmBuffer* headerInfo) = 0;
-
- /**
- * Decrypt the protected content buffers for the given unit
- * This method will be called any number of times, based on number of
- * encrypted streams received from application.
- *
- * @param[in] uniqueId Unique identifier for a session
- * @param[in] decryptId Handle for the decryption session
- * @param[in] decryptUnitId ID Specifies decryption unit, such as track ID
- * @param[in] encBuffer Encrypted data block
- * @param[out] decBuffer Decrypted data block
- * @param[in] IV Optional buffer
- * @return status_t
- * Returns the error code for this API
- * DRM_NO_ERROR for success, and one of DRM_ERROR_UNKNOWN, DRM_ERROR_LICENSE_EXPIRED
- * DRM_ERROR_SESSION_NOT_OPENED, DRM_ERROR_DECRYPT_UNIT_NOT_INITIALIZED,
- * DRM_ERROR_DECRYPT for failure.
- */
- virtual status_t onDecrypt(int uniqueId, DecryptHandle* decryptHandle, int decryptUnitId,
- const DrmBuffer* encBuffer, DrmBuffer** decBuffer, DrmBuffer* IV) = 0;
-
- /**
- * Finalize decryption for the given unit of the protected content
- *
- * @param[in] uniqueId Unique identifier for a session
- * @param[in] decryptHandle Handle for the decryption session
- * @param[in] decryptUnitId ID Specifies decryption unit, such as track ID
- * @return status_t
- * Returns DRM_NO_ERROR for success, DRM_ERROR_UNKNOWN for failure
- */
- virtual status_t onFinalizeDecryptUnit(
- int uniqueId, DecryptHandle* decryptHandle, int decryptUnitId) = 0;
-
- /**
- * Reads the specified number of bytes from an open DRM file.
- *
- * @param[in] uniqueId Unique identifier for a session
- * @param[in] decryptHandle Handle for the decryption session
- * @param[out] buffer Reference to the buffer that should receive the read data.
- * @param[in] numBytes Number of bytes to read.
- * @param[in] offset Offset with which to update the file position.
- *
- * @return Number of bytes read. Returns -1 for Failure.
- */
- virtual ssize_t onPread(int uniqueId, DecryptHandle* decryptHandle,
- void* buffer, ssize_t numBytes, off64_t offset) = 0;
-};
-
-};
-
-#endif /* __DRM_ENGINE_BASE_H__ */
-
diff --git a/drm/libdrmframework/plugins/common/include/IDrmEngine.h b/drm/libdrmframework/plugins/common/include/IDrmEngine.h
deleted file mode 100644
index 77460f6..0000000
--- a/drm/libdrmframework/plugins/common/include/IDrmEngine.h
+++ /dev/null
@@ -1,414 +0,0 @@
-/*
- * Copyright (C) 2010 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.
- */
-
-#ifndef __IDRM_ENGINE_H__
-#define __IDRM_ENGINE_H__
-
-#include <drm/drm_framework_common.h>
-
-namespace android {
-
-class DrmConstraints;
-class DrmMetadata;
-class DrmRights;
-class DrmInfo;
-class DrmInfoStatus;
-class DrmConvertedStatus;
-class DrmInfoRequest;
-class DrmSupportInfo;
-class DrmInfoEvent;
-
-/**
- * This class is an interface for plug-in user
- *
- * Responsibility of this class is provide generic interface to DRM Engine Manager.
- * Each interface need to be as abstract as possible.
- */
-class IDrmEngine {
-public:
- virtual ~IDrmEngine() {
- }
-
-public:
- class OnInfoListener {
-
- public:
- virtual void onInfo(const DrmInfoEvent& event) = 0;
-
- virtual ~OnInfoListener() { }
- };
-
-public:
-
- //////////////////////////////////
- // Implementation of IDrmEngine //
- //////////////////////////////////
-
- /**
- * Initialize plug-in
- *
- * @param[in] uniqueId Unique identifier for a session
- * @return status_t
- * Returns DRM_NO_ERROR for success, DRM_ERROR_UNKNOWN for failure
- */
- virtual status_t initialize(int uniqueId) = 0;
-
- /**
- * Register a callback to be invoked when the caller required to
- * receive necessary information
- *
- * @param[in] uniqueId Unique identifier for a session
- * @param[in] infoListener Listener
- * @return status_t
- * Returns DRM_NO_ERROR for success, DRM_ERROR_UNKNOWN for failure
- */
- virtual status_t setOnInfoListener(
- int uniqueId, const IDrmEngine::OnInfoListener* infoListener) = 0;
-
- /**
- * Terminate the plug-in
- * and release resource bound to plug-in
- * e.g.) release native resource
- *
- * @param[in] uniqueId Unique identifier for a session
- * @return status_t
- * Returns DRM_NO_ERROR for success, DRM_ERROR_UNKNOWN for failure
- */
- virtual status_t terminate(int uniqueId) = 0;
-
- /**
- * Get constraint information associated with input content
- *
- * @param[in] uniqueId Unique identifier for a session
- * @param[in] path Path of the protected content
- * @param[in] action Actions defined such as,
- * Action::DEFAULT, Action::PLAY, etc
- * @return DrmConstraints
- * key-value pairs of constraint are embedded in it
- * @note
- * In case of error, return NULL
- */
- virtual DrmConstraints* getConstraints(
- int uniqueId, const String8* path, int action) = 0;
-
- /**
- * Get metadata information associated with input content
- *
- * @param[in] uniqueId Unique identifier for a session
- * @param[in] path Path of the protected content
- * @return DrmMetadata
- * key-value pairs of metadata
- * @note
- * In case of error, return NULL
- */
- virtual DrmMetadata* getMetadata(int uniqueId, const String8* path) = 0;
-
- /**
- * Get whether the given content can be handled by this plugin or not
- *
- * @param[in] uniqueId Unique identifier for a session
- * @param[in] path Path the protected object
- * @return bool
- * true if this plugin can handle , false in case of not able to handle
- */
- virtual bool canHandle(int uniqueId, const String8& path) = 0;
-
- /**
- * Executes given drm information based on its type
- *
- * @param[in] uniqueId Unique identifier for a session
- * @param[in] drmInfo Information needs to be processed
- * @return DrmInfoStatus
- * instance as a result of processing given input
- */
- virtual DrmInfoStatus* processDrmInfo(int uniqueId, const DrmInfo* drmInfo) = 0;
-
- /**
- * Retrieves necessary information for registration, unregistration or rights
- * acquisition information.
- *
- * @param[in] uniqueId Unique identifier for a session
- * @param[in] drmInfoRequest Request information to retrieve drmInfo
- * @return DrmInfo
- * instance as a result of processing given input
- */
- virtual DrmInfo* acquireDrmInfo(int uniqueId, const DrmInfoRequest* drmInfoRequest) = 0;
-
- /**
- * Save DRM rights to specified rights path
- * and make association with content path
- *
- * @param[in] uniqueId Unique identifier for a session
- * @param[in] drmRights DrmRights to be saved
- * @param[in] rightsPath File path where rights to be saved
- * @param[in] contentPath File path where content was saved
- * @return status_t
- * Returns DRM_NO_ERROR for success, DRM_ERROR_UNKNOWN for failure
- */
- virtual status_t saveRights(int uniqueId, const DrmRights& drmRights,
- const String8& rightsPath, const String8& contentPath) = 0;
-
- /**
- * Retrieves the mime type embedded inside the original content
- *
- * @param[in] uniqueId Unique identifier for a session
- * @param[in] path Path of the protected content
- * @return String8
- * Returns mime-type of the original content, such as "video/mpeg"
- */
- virtual String8 getOriginalMimeType(int uniqueId, const String8& path) = 0;
-
- /**
- * Retrieves the type of the protected object (content, rights, etc..)
- * using specified path or mimetype. At least one parameter should be non null
- * to retrieve DRM object type
- *
- * @param[in] uniqueId Unique identifier for a session
- * @param[in] path Path of the content or null.
- * @param[in] mimeType Mime type of the content or null.
- * @return type of the DRM content,
- * such as DrmObjectType::CONTENT, DrmObjectType::RIGHTS_OBJECT
- */
- virtual int getDrmObjectType(
- int uniqueId, const String8& path, const String8& mimeType) = 0;
-
- /**
- * Check whether the given content has valid rights or not
- *
- * @param[in] uniqueId Unique identifier for a session
- * @param[in] path Path of the protected content
- * @param[in] action Action to perform (Action::DEFAULT, Action::PLAY, etc)
- * @return the status of the rights for the protected content,
- * such as RightsStatus::RIGHTS_VALID, RightsStatus::RIGHTS_EXPIRED, etc.
- */
- virtual int checkRightsStatus(int uniqueId, const String8& path, int action) = 0;
-
- /**
- * Consumes the rights for a content.
- * If the reserve parameter is true the rights is reserved until the same
- * application calls this api again with the reserve parameter set to false.
- *
- * @param[in] uniqueId Unique identifier for a session
- * @param[in] decryptHandle Handle for the decryption session
- * @param[in] action Action to perform. (Action::DEFAULT, Action::PLAY, etc)
- * @param[in] reserve True if the rights should be reserved.
- * @return status_t
- * Returns DRM_NO_ERROR for success, DRM_ERROR_UNKNOWN for failure
- */
- virtual status_t consumeRights(
- int uniqueId, DecryptHandle* decryptHandle, int action, bool reserve) = 0;
-
- /**
- * Informs the DRM Engine about the playback actions performed on the DRM files.
- *
- * @param[in] uniqueId Unique identifier for a session
- * @param[in] decryptHandle Handle for the decryption session
- * @param[in] playbackStatus Playback action (Playback::START, Playback::STOP, Playback::PAUSE)
- * @param[in] position Position in the file (in milliseconds) where the start occurs.
- * Only valid together with Playback::START.
- * @return status_t
- * Returns DRM_NO_ERROR for success, DRM_ERROR_UNKNOWN for failure
- */
- virtual status_t setPlaybackStatus(int uniqueId, DecryptHandle* decryptHandle,
- int playbackStatus, int64_t position) = 0;
-
- /**
- * Validates whether an action on the DRM content is allowed or not.
- *
- * @param[in] uniqueId Unique identifier for a session
- * @param[in] path Path of the protected content
- * @param[in] action Action to validate (Action::PLAY, Action::TRANSFER, etc)
- * @param[in] description Detailed description of the action
- * @return true if the action is allowed.
- */
- virtual bool validateAction(int uniqueId, const String8& path,
- int action, const ActionDescription& description) = 0;
-
- /**
- * Removes the rights associated with the given protected content
- *
- * @param[in] uniqueId Unique identifier for a session
- * @param[in] path Path of the protected content
- * @return status_t
- * Returns DRM_NO_ERROR for success, DRM_ERROR_UNKNOWN for failure
- */
- virtual status_t removeRights(int uniqueId, const String8& path) = 0;
-
- /**
- * Removes all the rights information of each plug-in associated with
- * DRM framework. Will be used in master reset
- *
- * @param[in] uniqueId Unique identifier for a session
- * @return status_t
- * Returns DRM_NO_ERROR for success, DRM_ERROR_UNKNOWN for failure
- */
- virtual status_t removeAllRights(int uniqueId) = 0;
-
- /**
- * This API is for Forward Lock based DRM scheme.
- * Each time the application tries to download a new DRM file
- * which needs to be converted, then the application has to
- * begin with calling this API.
- *
- * @param[in] uniqueId Unique identifier for a session
- * @param[in] convertId Handle for the convert session
- * @return status_t
- * Returns DRM_NO_ERROR for success, DRM_ERROR_UNKNOWN for failure
- */
- virtual status_t openConvertSession(int uniqueId, int convertId) = 0;
-
- /**
- * Accepts and converts the input data which is part of DRM file.
- * The resultant converted data and the status is returned in the DrmConvertedInfo
- * object. This method will be called each time there are new block
- * of data received by the application.
- *
- * @param[in] uniqueId Unique identifier for a session
- * @param[in] convertId Handle for the convert session
- * @param[in] inputData Input Data which need to be converted
- * @return Return object contains the status of the data conversion,
- * the output converted data and offset. In this case the
- * application will ignore the offset information.
- */
- virtual DrmConvertedStatus* convertData(
- int uniqueId, int convertId, const DrmBuffer* inputData) = 0;
-
- /**
- * Informs the Drm Agent when there is no more data which need to be converted
- * or when an error occurs. Upon successful conversion of the complete data,
- * the agent will inform that where the header and body signature
- * should be added. This signature appending is needed to integrity
- * protect the converted file.
- *
- * @param[in] uniqueId Unique identifier for a session
- * @param[in] convertId Handle for the convert session
- * @return Return object contains the status of the data conversion,
- * the header and body signature data. It also informs
- * the application on which offset these signature data
- * should be appended.
- */
- virtual DrmConvertedStatus* closeConvertSession( int uniqueId, int convertId) = 0;
-
- /**
- * Returns the information about the Drm Engine capabilities which includes
- * supported MimeTypes and file suffixes.
- *
- * @param[in] uniqueId Unique identifier for a session
- * @return DrmSupportInfo
- * instance which holds the capabilities of a plug-in
- */
- virtual DrmSupportInfo* getSupportInfo(int uniqueId) = 0;
-
- /**
- * Open the decrypt session to decrypt the given protected content
- *
- * @param[in] uniqueId Unique identifier for a session
- * @param[in] decryptHandle Handle for the current decryption session
- * @param[in] fd File descriptor of the protected content to be decrypted
- * @param[in] offset Start position of the content
- * @param[in] length The length of the protected content
- * @return
- * DRM_ERROR_CANNOT_HANDLE for failure and DRM_NO_ERROR for success
- */
- virtual status_t openDecryptSession(
- int uniqueId, DecryptHandle* decryptHandle, int fd, off64_t offset, off64_t length) = 0;
-
- /**
- * Open the decrypt session to decrypt the given protected content
- *
- * @param[in] uniqueId Unique identifier for a session
- * @param[in] decryptHandle Handle for the current decryption session
- * @param[in] uri Path of the protected content to be decrypted
- * @return
- * DRM_ERROR_CANNOT_HANDLE for failure and DRM_NO_ERROR for success
- */
- virtual status_t openDecryptSession(
- int uniqueId, DecryptHandle* decryptHandle, const char* uri) = 0;
-
- /**
- * Close the decrypt session for the given handle
- *
- * @param[in] uniqueId Unique identifier for a session
- * @param[in] decryptHandle Handle for the decryption session
- * @return status_t
- * Returns DRM_NO_ERROR for success, DRM_ERROR_UNKNOWN for failure
- */
- virtual status_t closeDecryptSession(int uniqueId, DecryptHandle* decryptHandle) = 0;
-
- /**
- * Initialize decryption for the given unit of the protected content
- *
- * @param[in] uniqueId Unique identifier for a session
- * @param[in] decryptHandle Handle for the decryption session
- * @param[in] decryptUnitId ID which specifies decryption unit, such as track ID
- * @param[in] headerInfo Information for initializing decryption of this decrypUnit
- * @return status_t
- * Returns DRM_NO_ERROR for success, DRM_ERROR_UNKNOWN for failure
- */
- virtual status_t initializeDecryptUnit(int uniqueId, DecryptHandle* decryptHandle,
- int decryptUnitId, const DrmBuffer* headerInfo) = 0;
-
- /**
- * Decrypt the protected content buffers for the given unit
- * This method will be called any number of times, based on number of
- * encrypted streams received from application.
- *
- * @param[in] uniqueId Unique identifier for a session
- * @param[in] decryptHandle Handle for the decryption session
- * @param[in] decryptUnitId ID which specifies decryption unit, such as track ID
- * @param[in] encBuffer Encrypted data block
- * @param[out] decBuffer Decrypted data block
- * @param[in] IV Optional buffer
- * @return status_t
- * Returns the error code for this API
- * DRM_NO_ERROR for success, and one of DRM_ERROR_UNKNOWN, DRM_ERROR_LICENSE_EXPIRED
- * DRM_ERROR_SESSION_NOT_OPENED, DRM_ERROR_DECRYPT_UNIT_NOT_INITIALIZED,
- * DRM_ERROR_DECRYPT for failure.
- */
- virtual status_t decrypt(int uniqueId, DecryptHandle* decryptHandle, int decryptUnitId,
- const DrmBuffer* encBuffer, DrmBuffer** decBuffer, DrmBuffer* IV) = 0;
-
- /**
- * Finalize decryption for the given unit of the protected content
- *
- * @param[in] uniqueId Unique identifier for a session
- * @param[in] decryptHandle Handle for the decryption session
- * @param[in] decryptUnitId ID which specifies decryption unit, such as track ID
- * @return status_t
- * Returns DRM_NO_ERROR for success, DRM_ERROR_UNKNOWN for failure
- */
- virtual status_t finalizeDecryptUnit(
- int uniqueId, DecryptHandle* decryptHandle, int decryptUnitId) = 0;
-
- /**
- * Reads the specified number of bytes from an open DRM file.
- *
- * @param[in] uniqueId Unique identifier for a session
- * @param[in] decryptHandle Handle for the decryption session
- * @param[out] buffer Reference to the buffer that should receive the read data.
- * @param[in] numBytes Number of bytes to read.
- * @param[in] offset Offset with which to update the file position.
- *
- * @return Number of bytes read. Returns -1 for Failure.
- */
- virtual ssize_t pread(int uniqueId, DecryptHandle* decryptHandle,
- void* buffer, ssize_t numBytes, off64_t offset) = 0;
-};
-
-};
-
-#endif /* __IDRM_ENGINE_H__ */
-
diff --git a/drm/libdrmframework/plugins/common/util/Android.mk b/drm/libdrmframework/plugins/common/util/Android.mk
deleted file mode 100644
index 15dda80..0000000
--- a/drm/libdrmframework/plugins/common/util/Android.mk
+++ /dev/null
@@ -1,52 +0,0 @@
-#
-# Copyright (C) 2010 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.
-#
-LOCAL_PATH:= $(call my-dir)
-
-include $(CLEAR_VARS)
-
-LOCAL_SRC_FILES := \
- src/MimeTypeUtil.cpp
-
-LOCAL_MODULE := libdrmutility
-
-LOCAL_SHARED_LIBRARIES := \
- libutils \
- libdl \
- libdvm \
- libandroid_runtime \
- libnativehelper \
- liblog
-
-
-base := frameworks/base
-
-LOCAL_C_INCLUDES += \
- $(JNI_H_INCLUDE) \
- $(base)/include \
- $(base)/include/drm \
- $(base)/include/drm/plugins \
- $(LOCAL_PATH)/include
-
-
-ifneq ($(TARGET_BUILD_VARIANT),user)
-LOCAL_C_INCLUDES += \
- $(LOCAL_PATH)/tools
-
-endif
-
-LOCAL_MODULE_TAGS := optional
-
-include $(BUILD_STATIC_LIBRARY)
diff --git a/drm/libdrmframework/plugins/common/util/include/MimeTypeUtil.h b/drm/libdrmframework/plugins/common/util/include/MimeTypeUtil.h
deleted file mode 100644
index 4d12a61..0000000
--- a/drm/libdrmframework/plugins/common/util/include/MimeTypeUtil.h
+++ /dev/null
@@ -1,46 +0,0 @@
-/*
- * Copyright (C) 2010 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.
- */
-
-#ifndef __MIMETYPEUTIL_H__
-#define __MIMETYPEUTIL_H__
-
-#include <utils/String8.h>
-
-namespace android {
-
-class MimeTypeUtil {
-
-public:
-
- MimeTypeUtil() {}
-
- virtual ~MimeTypeUtil() {}
-
-/**
- * May convert the mimetype if there is a well known
- * replacement mimetype otherwise the original mimetype
- * is returned.
- *
- * @param mimeType - mimetype in lower case to convert.
- *
- * @return mimetype or null.
- */
-static String8 convertMimeType(String8& mimeType);
-
-};
-};
-
-#endif /* __MIMETYPEUTIL_H__ */
diff --git a/drm/libdrmframework/plugins/common/util/include/SessionMap.h b/drm/libdrmframework/plugins/common/util/include/SessionMap.h
deleted file mode 100644
index e563894..0000000
--- a/drm/libdrmframework/plugins/common/util/include/SessionMap.h
+++ /dev/null
@@ -1,189 +0,0 @@
-/*
- * Copyright (C) 2010 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.
- */
-#ifndef __SESSIONMAP_H__
-#define __SESSIONMAP_H__
-
-#include <utils/KeyedVector.h>
-#include <utils/threads.h>
-
-namespace android {
-
-/**
- * A thread safe wrapper template class for session handlings for Drm Engines. It wraps a
- * pointer type over KeyedVector. It keeps pointer as data in the vector and free up memory
- * allocated pointer can be of any type of structure/class meant for keeping session data.
- * so session object here means pointer to the session data.
- */
-template <typename TValue>
-class SessionMap {
-
-public:
- SessionMap() {}
-
- virtual ~SessionMap() {
- Mutex::Autolock lock(mLock);
- destroyMap();
- }
-
- /**
- * Adds a new value in the session map table. It expects memory to be allocated already
- * for the session object
- *
- * @param key - key or Session ID
- * @param value - session object to add
- *
- * @return boolean result of adding value. returns false if key is already exist.
- */
- bool addValue(int key, TValue value) {
- Mutex::Autolock lock(mLock);
- if (!isCreatedInternal(key)) {
- map.add(key, value);
- return true;
- }
- return false;
- }
-
- /**
- * returns the session object by the key
- *
- * @param key - key or Session ID
- *
- * @return session object as per the key
- */
- TValue getValue(int key) {
- Mutex::Autolock lock(mLock);
- return getValueInternal(key);
- }
-
- /**
- * returns the number of objects in the session map table
- *
- * @return count of number of session objects.
- */
- int getSize() {
- Mutex::Autolock lock(mLock);
- return map.size();
- }
-
- /**
- * returns the session object by the index in the session map table
- *
- * @param index - index of the value required
- *
- * @return session object as per the index
- */
- TValue getValueAt(unsigned int index) {
- TValue value = NULL;
- Mutex::Autolock lock(mLock);
-
- if (map.size() > index) {
- value = map.valueAt(index);
- }
- return value;
- }
-
- /**
- * deletes the object from session map. It also frees up memory for the session object.
- *
- * @param key - key of the value to be deleted
- *
- */
- void removeValue(int key) {
- Mutex::Autolock lock(mLock);
- deleteValue(getValueInternal(key));
- map.removeItem(key);
- }
-
- /**
- * decides if session is already created.
- *
- * @param key - key of the value for the session
- *
- * @return boolean result of whether session is created
- */
- bool isCreated(int key) {
- Mutex::Autolock lock(mLock);
- return isCreatedInternal(key);
- }
-
- SessionMap<TValue> & operator=(const SessionMap<TValue> & objectCopy) {
- Mutex::Autolock lock(mLock);
-
- destroyMap();
- map = objectCopy.map;
- return *this;
- }
-
-private:
- KeyedVector<int, TValue> map;
- Mutex mLock;
-
- /**
- * free up the memory for the session object.
- * Make sure if any reference to the session object anywhere, otherwise it will be a
- * dangle pointer after this call.
- *
- * @param value - session object to free
- *
- */
- void deleteValue(TValue value) {
- delete value;
- }
-
- /**
- * free up the memory for the entire map.
- * free up any resources in the sessions before calling this funtion.
- *
- */
- void destroyMap() {
- int size = map.size();
-
- for (int i = 0; i < size; i++) {
- deleteValue(map.valueAt(i));
- }
- map.clear();
- }
-
- /**
- * decides if session is already created.
- *
- * @param key - key of the value for the session
- *
- * @return boolean result of whether session is created
- */
- bool isCreatedInternal(int key) {
- return(0 <= map.indexOfKey(key));
- }
-
- /**
- * returns the session object by the key
- *
- * @param key - key or Session ID
- *
- * @return session object as per the key
- */
- TValue getValueInternal(int key) {
- TValue value = NULL;
- if (isCreatedInternal(key)) {
- value = (TValue) map.valueFor(key);
- }
- return value;
- }
-};
-
-};
-
-#endif /* __SESSIONMAP_H__ */
diff --git a/drm/libdrmframework/plugins/common/util/src/MimeTypeUtil.cpp b/drm/libdrmframework/plugins/common/util/src/MimeTypeUtil.cpp
deleted file mode 100644
index 576ed15..0000000
--- a/drm/libdrmframework/plugins/common/util/src/MimeTypeUtil.cpp
+++ /dev/null
@@ -1,166 +0,0 @@
-/*
- * Copyright (C) 2010 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.
- */
-
-#include <MimeTypeUtil.h>
-#include <utils/Log.h>
-
-namespace android {
-
-#undef LOG_TAG
-#define LOG_TAG "MimeTypeUtil"
-
-#ifdef DRM_OMA_FL_ENGINE_DEBUG
-#define LOG_NDEBUG 0
-#define LOG_DEBUG(...) ALOGD(__VA_ARGS__)
-#else
-#define LOG_DEBUG(...)
-#endif
-
-enum {
- MIMETYPE_AUDIO = 0,
- MIMETYPE_APPLICATION = 1,
- MIMETYPE_IMAGE = 2,
- MIMETYPE_VIDEO = 3,
- MIMETYPE_LAST = -1,
-};
-
-struct MimeGroup{
- int type; // Audio, video,.. use the enum values
- const char* pGroup; // "audio/", "video/",.. should contain the last "/"
- int size; // Number of bytes. e.g. "audio/" = 6 bytes
-};
-
-struct MimeTypeList{
- int type;
- const char* pMimeExt; // Everything after the '/' e.g. audio/x-mpeg -> "x-mpeg"
- int size; // Number of bytes. e.g. "x-mpeg" = 6 bytes
- const char* pMimeType; // Mimetype that should be returned
-};
-
-
-// Known mimetypes by android
-static const char mime_type_audio_mpeg[] = "audio/mpeg";
-static const char mime_type_audio_3gpp[] = "audio/3gpp";
-static const char mime_type_audio_amr[] = "audio/amr-wb";
-static const char mime_type_audio_aac[] = "audio/mp4a-latm";
-static const char mime_type_audio_wav[] = "audio/wav";
-
-static const char mime_type_video_mpeg4[] = "video/mpeg4";
-static const char mime_type_video_3gpp[] = "video/3gpp";
-
-// Known mimetype groups
-static const char mime_group_audio[] = "audio/";
-static const char mime_group_application[] = "application/";
-static const char mime_group_image[] = "image/";
-static const char mime_group_video[] = "video/";
-static const char mime_type_unsupported[] = "unsupported/drm.mimetype";
-
-static struct MimeGroup mimeGroup[] = {
- {MIMETYPE_AUDIO, mime_group_audio, sizeof(mime_group_audio)-1},
- {MIMETYPE_APPLICATION, mime_group_application, sizeof(mime_group_application)-1},
- {MIMETYPE_IMAGE, mime_group_image, sizeof(mime_group_image)-1},
- {MIMETYPE_VIDEO, mime_group_video, sizeof(mime_group_video)-1},
- {MIMETYPE_LAST, NULL, 0} // Must be last entry
-};
-
-// List of all mimetypes that should be converted.
-static struct MimeTypeList mimeTypeList[] = {
- // Mp3 mime types
- {MIMETYPE_AUDIO, "mp3", sizeof("mp3")-1, mime_type_audio_mpeg},
- {MIMETYPE_AUDIO, "x-mpeg", sizeof("x-mpeg")-1, mime_type_audio_mpeg},
- {MIMETYPE_AUDIO, "x-mp3", sizeof("x-mp3")-1, mime_type_audio_mpeg},
- {MIMETYPE_AUDIO, "mpg", sizeof("mpg")-1, mime_type_audio_mpeg},
- {MIMETYPE_AUDIO, "mpg3", sizeof("mpg")-1, mime_type_audio_mpeg},
- {MIMETYPE_AUDIO, "x-mpg", sizeof("x-mpg")-1, mime_type_audio_mpeg},
- {MIMETYPE_AUDIO, "x-mpegaudio", sizeof("x-mpegaudio")-1, mime_type_audio_mpeg},
-
- // 3gpp audio mime types
- {MIMETYPE_AUDIO, "3gp", sizeof("3gp")-1, mime_type_audio_3gpp},
-
- // Amr audio mime types
- {MIMETYPE_AUDIO, "amr", sizeof("amr")-1, mime_type_audio_amr},
-
- // Aac audio mime types
- {MIMETYPE_AUDIO, "aac", sizeof("aac")-1, mime_type_audio_aac},
-
- // Wav audio mime types
- {MIMETYPE_AUDIO, "x-wav", sizeof("x-wav")-1, mime_type_audio_wav},
-
- // Mpeg4 video mime types
- {MIMETYPE_VIDEO, "mpg4", sizeof("mpg4")-1, mime_type_video_mpeg4},
- {MIMETYPE_VIDEO, "mp4v-es", sizeof("mp4v-es")-1, mime_type_video_mpeg4},
-
- // 3gpp video mime types
- {MIMETYPE_VIDEO, "3gp", sizeof("3gp")-1, mime_type_video_3gpp},
-
- // Must be last entry
- {MIMETYPE_LAST, NULL, 0, NULL}
-};
-
-/**
- * May convert the mimetype if there is a well known
- * replacement mimetype otherwise the original mimetype
- * is returned.
- *
- * If the mimetype is of unsupported group i.e. application/*
- * then "unsupported/drm.mimetype" will be returned.
- *
- * @param mimeType - mimetype in lower case to convert.
- *
- * @return mimetype or "unsupported/drm.mimetype".
- */
-String8 MimeTypeUtil::convertMimeType(String8& mimeType) {
- String8 result = mimeType;
- const char* pMimeType;
- struct MimeGroup* pGroup;
- struct MimeTypeList* pMimeItem;
- int len;
- pMimeType = mimeType.string();
- if (NULL != pMimeType) {
- if ((0 == strncmp(pMimeType, mime_group_audio, (sizeof mime_group_audio) - 1)) ||
- (0 == strncmp(pMimeType, mime_group_video, (sizeof mime_group_video) - 1))) {
- /* Check which group the mimetype is */
- pGroup = mimeGroup;
- while (MIMETYPE_LAST != pGroup->type) {
- if (0 == strncmp(pMimeType, pGroup->pGroup, pGroup->size)) {
- break;
- }
- pGroup++;
- }
-
- /* Go through the mimetype list. Only check items of the correct group */
- if (MIMETYPE_LAST != pGroup->type) {
- pMimeItem = mimeTypeList;
- len = strlen (pMimeType+pGroup->size);
- while (MIMETYPE_LAST != pMimeItem->type) {
- if ((pGroup->type == pMimeItem->type) &&
- (len == pMimeItem->size) &&
- (0 == strcmp(pMimeType+pGroup->size, pMimeItem->pMimeExt))) {
- result = String8(pMimeItem->pMimeType);
- break;
- }
- pMimeItem++;
- }
- }
- } else {
- result = String8(mime_type_unsupported);
- }
- LOG_DEBUG("convertMimeType got mimetype %s, converted into mimetype %s",
- pMimeType, result.string());
- }
- return result;
-}
-};
diff --git a/drm/libdrmframework/plugins/forward-lock/Android.mk b/drm/libdrmframework/plugins/forward-lock/Android.mk
deleted file mode 100644
index 9ee7961..0000000
--- a/drm/libdrmframework/plugins/forward-lock/Android.mk
+++ /dev/null
@@ -1,16 +0,0 @@
-#
-# Copyright (C) 2010 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.
-#
-include $(call all-subdir-makefiles)
diff --git a/drm/libdrmframework/plugins/forward-lock/FwdLockEngine/Android.mk b/drm/libdrmframework/plugins/forward-lock/FwdLockEngine/Android.mk
deleted file mode 100644
index e359dbd..0000000
--- a/drm/libdrmframework/plugins/forward-lock/FwdLockEngine/Android.mk
+++ /dev/null
@@ -1,70 +0,0 @@
-#
-# Copyright (C) 2010 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.
-#
-LOCAL_PATH := $(call my-dir)
-
-include $(CLEAR_VARS)
-
-# The flag below turns on local debug printouts
-#LOCAL_CFLAGS += -DDRM_OMA_FL_ENGINE_DEBUG
-
-base := frameworks/base
-
-# Determine whether the DRM framework uses 64-bit data types for file offsets and do the same.
-ifneq ($(shell grep -c 'off64_t offset' $(base)/drm/libdrmframework/plugins/common/include/IDrmEngine.h), 0)
-LOCAL_CFLAGS += -DUSE_64BIT_DRM_API
-endif
-
-LOCAL_SRC_FILES:= \
- src/FwdLockEngine.cpp
-
-LOCAL_MODULE := libfwdlockengine
-
-LOCAL_SHARED_LIBRARIES := \
- libicui18n \
- libicuuc \
- libutils \
- libdl \
- libandroid_runtime \
- libnativehelper \
- libcrypto \
- libssl \
- libdrmframework
-
-LOCAL_STATIC_LIBRARIES := \
- libdrmutility \
- libdrmframeworkcommon \
- libfwdlock-common \
- libfwdlock-converter \
- libfwdlock-decoder
-
-
-
-LOCAL_C_INCLUDES += \
- $(JNI_H_INCLUDE) \
- $(base)/include/drm \
- $(base)/drm/libdrmframework/plugins/common/include \
- $(base)/drm/libdrmframework/plugins/common/util/include \
- $(base)/drm/libdrmframework/plugins/forward-lock/internal-format/common \
- $(base)/drm/libdrmframework/plugins/forward-lock/internal-format/converter \
- $(base)/drm/libdrmframework/plugins/forward-lock/internal-format/decoder \
- $(LOCAL_PATH)/include \
- external/openssl/include
-
-LOCAL_MODULE_PATH := $(TARGET_OUT_SHARED_LIBRARIES)/drm
-
-LOCAL_MODULE_TAGS := optional
-
-include $(BUILD_SHARED_LIBRARY)
diff --git a/drm/libdrmframework/plugins/forward-lock/FwdLockEngine/include/FwdLockEngine.h b/drm/libdrmframework/plugins/forward-lock/FwdLockEngine/include/FwdLockEngine.h
deleted file mode 100644
index 34804cf..0000000
--- a/drm/libdrmframework/plugins/forward-lock/FwdLockEngine/include/FwdLockEngine.h
+++ /dev/null
@@ -1,559 +0,0 @@
-/*
- * Copyright (C) 2010 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.
- */
-
-#ifndef __FWDLOCKENGINE_H__
-#define __FWDLOCKENGINE_H__
-
-#include <DrmEngineBase.h>
-#include <DrmConstraints.h>
-#include <DrmRights.h>
-#include <DrmInfo.h>
-#include <DrmInfoStatus.h>
-#include <DrmConvertedStatus.h>
-#include <DrmInfoRequest.h>
-#include <DrmSupportInfo.h>
-#include <DrmInfoEvent.h>
-
-#include "SessionMap.h"
-#include "FwdLockConv.h"
-
-namespace android {
-
-/**
- * Forward Lock Engine class.
- */
-class FwdLockEngine : public android::DrmEngineBase {
-
-public:
- FwdLockEngine();
- virtual ~FwdLockEngine();
-
-protected:
-/**
- * Get constraint information associated with input content.
- *
- * @param uniqueId Unique identifier for a session
- * @param path Path of the protected content
- * @param action Actions defined such as,
- * Action::DEFAULT, Action::PLAY, etc
- * @return DrmConstraints
- * key-value pairs of constraint are embedded in it
- * @note
- * In case of error, return NULL
- */
-DrmConstraints* onGetConstraints(int uniqueId, const String8* path, int action);
-
-/**
- * Get metadata information associated with input content.
- *
- * @param uniqueId Unique identifier for a session
- * @param path Path of the protected content
- * @return DrmMetadata
- * For Forward Lock engine, it returns an empty object
- * @note
- * In case of error, returns NULL
- */
-DrmMetadata* onGetMetadata(int uniqueId, const String8* path);
-
-/**
- * Initialize plug-in.
- *
- * @param uniqueId Unique identifier for a session
- * @return status_t
- * Returns DRM_NO_ERROR for success, DRM_ERROR_UNKNOWN for failure
- */
-status_t onInitialize(int uniqueId);
-
-/**
- * Register a callback to be invoked when the caller required to
- * receive necessary information.
- *
- * @param uniqueId Unique identifier for a session
- * @param infoListener Listener
- * @return status_t
- * Returns DRM_NO_ERROR for success, DRM_ERROR_UNKNOWN for failure
- */
-status_t onSetOnInfoListener(int uniqueId, const IDrmEngine::OnInfoListener* infoListener);
-
-/**
- * Terminate the plug-in and release resources bound to it.
- *
- * @param uniqueId Unique identifier for a session
- * @return status_t
- * Returns DRM_NO_ERROR for success, DRM_ERROR_UNKNOWN for failure
- */
-status_t onTerminate(int uniqueId);
-
-/**
- * Get whether the given content can be handled by this plugin or not.
- *
- * @param uniqueId Unique identifier for a session
- * @param path Path to the protected object
- * @return bool
- * Returns true if this plugin can handle , false in case of not able to handle
- */
-bool onCanHandle(int uniqueId, const String8& path);
-
-/**
- * Processes the given DRM information as appropriate for its type.
- * Not used for Forward Lock Engine.
- *
- * @param uniqueId Unique identifier for a session
- * @param drmInfo Information that needs to be processed
- * @return DrmInfoStatus
- * instance as a result of processing given input
- */
-DrmInfoStatus* onProcessDrmInfo(int uniqueId, const DrmInfo* drmInfo);
-
-/**
- * Save DRM rights to specified rights path
- * and make association with content path.
- *
- * @param uniqueId Unique identifier for a session
- * @param drmRights DrmRights to be saved
- * @param rightsPath File path where rights to be saved
- * @param contentPath File path where content was saved
- * @return status_t
- * Returns DRM_NO_ERROR for success, DRM_ERROR_UNKNOWN for failure
- */
-status_t onSaveRights(int uniqueId,
- const DrmRights& drmRights,
- const String8& rightsPath,
- const String8& contentPath);
-
-/**
- * Retrieves necessary information for registration, unregistration or rights
- * acquisition information.
- *
- * @param uniqueId Unique identifier for a session
- * @param drmInfoRequest Request information to retrieve drmInfo
- * @return DrmInfo
- * instance as a result of processing given input
- */
-DrmInfo* onAcquireDrmInfo(int uniqueId,
- const DrmInfoRequest* drmInfoRequest);
-
-/**
- * Retrieves the mime type embedded inside the original content.
- *
- * @param uniqueId Unique identifier for a session
- * @param path Path of the protected content
- * @return String8
- * Returns mime-type of the original content, such as "video/mpeg"
- */
-String8 onGetOriginalMimeType(int uniqueId, const String8& path);
-
-/**
- * Retrieves the type of the protected object (content, rights, etc..)
- * using specified path or mimetype. At least one parameter should be non null
- * to retrieve DRM object type.
- *
- * @param uniqueId Unique identifier for a session
- * @param path Path of the content or null.
- * @param mimeType Mime type of the content or null.
- * @return type of the DRM content,
- * such as DrmObjectType::CONTENT, DrmObjectType::RIGHTS_OBJECT
- */
-int onGetDrmObjectType(int uniqueId,
- const String8& path,
- const String8& mimeType);
-
-/**
- * Check whether the given content has valid rights or not.
- *
- * @param uniqueId Unique identifier for a session
- * @param path Path of the protected content
- * @param action Action to perform (Action::DEFAULT, Action::PLAY, etc)
- * @return the status of the rights for the protected content,
- * such as RightsStatus::RIGHTS_VALID, RightsStatus::RIGHTS_EXPIRED, etc.
- */
-int onCheckRightsStatus(int uniqueId,
- const String8& path,
- int action);
-
-/**
- * Consumes the rights for a content.
- * If the reserve parameter is true the rights are reserved until the same
- * application calls this api again with the reserve parameter set to false.
- *
- * @param uniqueId Unique identifier for a session
- * @param decryptHandle Handle for the decryption session
- * @param action Action to perform. (Action::DEFAULT, Action::PLAY, etc)
- * @param reserve True if the rights should be reserved.
- * @return status_t
- * Returns DRM_NO_ERROR for success, DRM_ERROR_UNKNOWN for failure
- */
-status_t onConsumeRights(int uniqueId,
- DecryptHandle* decryptHandle,
- int action,
- bool reserve);
-
-/**
- * Informs the DRM Engine about the playback actions performed on the DRM files.
- *
- * @param uniqueId Unique identifier for a session
- * @param decryptHandle Handle for the decryption session
- * @param playbackStatus Playback action (Playback::START, Playback::STOP, Playback::PAUSE)
- * @param position Position in the file (in milliseconds) where the start occurs.
- * Only valid together with Playback::START.
- * @return status_t
- * Returns DRM_NO_ERROR for success, DRM_ERROR_UNKNOWN for failure
- */
-#ifdef USE_64BIT_DRM_API
-status_t onSetPlaybackStatus(int uniqueId,
- DecryptHandle* decryptHandle,
- int playbackStatus,
- int64_t position);
-#else
-status_t onSetPlaybackStatus(int uniqueId,
- DecryptHandle* decryptHandle,
- int playbackStatus,
- int position);
-#endif
-
-/**
- * Validates whether an action on the DRM content is allowed or not.
- *
- * @param uniqueId Unique identifier for a session
- * @param path Path of the protected content
- * @param action Action to validate (Action::PLAY, Action::TRANSFER, etc)
- * @param description Detailed description of the action
- * @return true if the action is allowed.
- */
-bool onValidateAction(int uniqueId,
- const String8& path,
- int action,
- const ActionDescription& description);
-
-/**
- * Removes the rights associated with the given protected content.
- * Not used for Forward Lock Engine.
- *
- * @param uniqueId Unique identifier for a session
- * @param path Path of the protected content
- * @return status_t
- * Returns DRM_NO_ERROR for success, DRM_ERROR_UNKNOWN for failure
- */
-status_t onRemoveRights(int uniqueId, const String8& path);
-
-/**
- * Removes all the rights information of each plug-in associated with
- * DRM framework. Will be used in master reset but does nothing for
- * Forward Lock Engine.
- *
- * @param uniqueId Unique identifier for a session
- * @return status_t
- * Returns DRM_NO_ERROR for success, DRM_ERROR_UNKNOWN for failure
- */
-status_t onRemoveAllRights(int uniqueId);
-
-/**
- * Starts the Forward Lock file conversion session.
- * Each time the application tries to download a new DRM file
- * which needs to be converted, then the application has to
- * begin with calling this API. The convertId is used as the conversion session key
- * and must not be the same for different convert sessions.
- *
- * @param uniqueId Unique identifier for a session
- * @param convertId Handle for the convert session
- * @return status_t
- * Returns DRM_NO_ERROR for success, DRM_ERROR_UNKNOWN for failure
- */
-status_t onOpenConvertSession(int uniqueId, int convertId);
-
-/**
- * Accepts and converts the input data which is part of DRM file.
- * The resultant converted data and the status is returned in the DrmConvertedInfo
- * object. This method will be called each time there is a new block
- * of data received by the application.
- *
- * @param uniqueId Unique identifier for a session
- * @param convertId Handle for the convert session
- * @param inputData Input Data which need to be converted
- * @return Return object contains the status of the data conversion,
- * the output converted data and offset. In this case the
- * application will ignore the offset information.
- */
-DrmConvertedStatus* onConvertData(int uniqueId,
- int convertId,
- const DrmBuffer* inputData);
-
-/**
- * Closes the convert session in case of data supply completed or error occurred.
- * Upon successful conversion of the complete data, it returns signature calculated over
- * the entire data used over a conversion session. This signature must be copied to the offset
- * mentioned in the DrmConvertedStatus. Signature is used for data integrity protection.
- *
- * @param uniqueId Unique identifier for a session
- * @param convertId Handle for the convert session
- * @return Return object contains the status of the data conversion,
- * the header and body signature data. It also informs
- * the application about the file offset at which this
- * signature data should be written.
- */
-DrmConvertedStatus* onCloseConvertSession(int uniqueId, int convertId);
-
-/**
- * Returns the information about the Drm Engine capabilities which includes
- * supported MimeTypes and file suffixes.
- *
- * @param uniqueId Unique identifier for a session
- * @return DrmSupportInfo
- * instance which holds the capabilities of a plug-in
- */
-DrmSupportInfo* onGetSupportInfo(int uniqueId);
-
-/**
- * Open the decrypt session to decrypt the given protected content.
- *
- * @param uniqueId Unique identifier for a session
- * @param decryptHandle Handle for the current decryption session
- * @param fd File descriptor of the protected content to be decrypted
- * @param offset Start position of the content
- * @param length The length of the protected content
- * @return
- * DRM_ERROR_CANNOT_HANDLE for failure and DRM_NO_ERROR for success
- */
-#ifdef USE_64BIT_DRM_API
-status_t onOpenDecryptSession(int uniqueId,
- DecryptHandle* decryptHandle,
- int fd, off64_t offset, off64_t length);
-#else
-status_t onOpenDecryptSession(int uniqueId,
- DecryptHandle* decryptHandle,
- int fd, int offset, int length);
-#endif
-
-/**
- * Open the decrypt session to decrypt the given protected content.
- *
- * @param uniqueId Unique identifier for a session
- * @param decryptHandle Handle for the current decryption session
- * @param uri Path of the protected content to be decrypted
- * @return
- * DRM_ERROR_CANNOT_HANDLE for failure and DRM_NO_ERROR for success
- */
-status_t onOpenDecryptSession(int uniqueId,
- DecryptHandle* decryptHandle,
- const char* uri);
-
-/**
- * Close the decrypt session for the given handle.
- *
- * @param uniqueId Unique identifier for a session
- * @param decryptHandle Handle for the decryption session
- * @return status_t
- * Returns DRM_NO_ERROR for success, DRM_ERROR_UNKNOWN for failure
- */
-status_t onCloseDecryptSession(int uniqueId,
- DecryptHandle* decryptHandle);
-
-/**
- * Initialize decryption for the given unit of the protected content.
- *
- * @param uniqueId Unique identifier for a session
- * @param decryptHandle Handle for the decryption session
- * @param decryptUnitId ID which specifies decryption unit, such as track ID
- * @param headerInfo Information for initializing decryption of this decrypUnit
- * @return
- * DRM_ERROR_CANNOT_HANDLE for failure and DRM_NO_ERROR for success
- */
-status_t onInitializeDecryptUnit(int uniqueId,
- DecryptHandle* decryptHandle,
- int decryptUnitId,
- const DrmBuffer* headerInfo);
-
-/**
- * Decrypt the protected content buffers for the given unit.
- * This method will be called any number of times, based on number of
- * encrypted streams received from application.
- *
- * @param uniqueId Unique identifier for a session
- * @param decryptHandle Handle for the decryption session
- * @param decryptUnitId ID which specifies decryption unit, such as track ID
- * @param encBuffer Encrypted data block
- * @param decBuffer Decrypted data block
- * @return status_t
- * Returns the error code for this API
- * DRM_NO_ERROR for success, and one of DRM_ERROR_UNKNOWN, DRM_ERROR_LICENSE_EXPIRED
- * DRM_ERROR_SESSION_NOT_OPENED, DRM_ERROR_DECRYPT_UNIT_NOT_INITIALIZED,
- * DRM_ERROR_DECRYPT for failure.
- */
-status_t onDecrypt(int uniqueId,
- DecryptHandle* decryptHandle,
- int decryptUnitId,
- const DrmBuffer* encBuffer,
- DrmBuffer** decBuffer);
-
-/**
- * Decrypt the protected content buffers for the given unit.
- * This method will be called any number of times, based on number of
- * encrypted streams received from application.
- *
- * @param uniqueId Unique identifier for a session
- * @param decryptId Handle for the decryption session
- * @param decryptUnitId ID Specifies decryption unit, such as track ID
- * @param encBuffer Encrypted data block
- * @param decBuffer Decrypted data block
- * @param IV Optional buffer
- * @return status_t
- * Returns the error code for this API
- * DRM_NO_ERROR for success, and one of DRM_ERROR_UNKNOWN, DRM_ERROR_LICENSE_EXPIRED
- * DRM_ERROR_SESSION_NOT_OPENED, DRM_ERROR_DECRYPT_UNIT_NOT_INITIALIZED,
- * DRM_ERROR_DECRYPT for failure.
- */
-status_t onDecrypt(int uniqueId, DecryptHandle* decryptHandle,
- int decryptUnitId, const DrmBuffer* encBuffer,
- DrmBuffer** decBuffer, DrmBuffer* IV);
-
-/**
- * Finalize decryption for the given unit of the protected content.
- *
- * @param uniqueId Unique identifier for a session
- * @param decryptHandle Handle for the decryption session
- * @param decryptUnitId ID Specifies decryption unit, such as track ID
- * @return
- * DRM_ERROR_CANNOT_HANDLE for failure and DRM_NO_ERROR for success
- */
-status_t onFinalizeDecryptUnit(int uniqueId,
- DecryptHandle* decryptHandle,
- int decryptUnitId);
-
-/**
- * Reads the specified number of bytes from an open DRM file.
- *
- * @param uniqueId Unique identifier for a session
- * @param decryptHandle Handle for the decryption session
- * @param buffer Reference to the buffer that should receive the read data.
- * @param numBytes Number of bytes to read.
- *
- * @return Number of bytes read.
- * @retval -1 Failure.
- */
-ssize_t onRead(int uniqueId,
- DecryptHandle* decryptHandle,
- void* pBuffer,
- int numBytes);
-
-/**
- * Updates the file position within an open DRM file.
- *
- * @param uniqueId Unique identifier for a session
- * @param decryptHandle Handle for the decryption session
- * @param offset Offset with which to update the file position.
- * @param whence One of SEEK_SET, SEEK_CUR, and SEEK_END.
- * These constants are defined in unistd.h.
- *
- * @return New file position.
- * @retval ((off_t)-1) Failure.
- */
-#ifdef USE_64BIT_DRM_API
-off64_t onLseek(int uniqueId,
- DecryptHandle* decryptHandle,
- off64_t offset,
- int whence);
-#else
-off_t onLseek(int uniqueId,
- DecryptHandle* decryptHandle,
- off_t offset,
- int whence);
-#endif
-
-/**
- * Reads the specified number of bytes from an open DRM file.
- *
- * @param uniqueId Unique identifier for a session
- * @param decryptHandle Handle for the decryption session
- * @param buffer Reference to the buffer that should receive the read data.
- * @param numBytes Number of bytes to read.
- * @param offset Offset with which to update the file position.
- *
- * @return Number of bytes read. Returns -1 for Failure.
- */
-#ifdef USE_64BIT_DRM_API
-ssize_t onPread(int uniqueId,
- DecryptHandle* decryptHandle,
- void* buffer,
- ssize_t numBytes,
- off64_t offset);
-#else
-ssize_t onPread(int uniqueId,
- DecryptHandle* decryptHandle,
- void* buffer,
- ssize_t numBytes,
- off_t offset);
-#endif
-
-private:
-
-/**
- * Session Class for Forward Lock Conversion. An object of this class is created
- * for every conversion.
- */
-class ConvertSession {
- public :
- int uniqueId;
- FwdLockConv_Output_t output;
-
- ConvertSession() {
- uniqueId = 0;
- memset(&output, 0, sizeof(FwdLockConv_Output_t));
- }
-
- virtual ~ConvertSession() {}
-};
-
-/**
- * Session Class for Forward Lock decoder. An object of this class is created
- * for every decoding session.
- */
-class DecodeSession {
- public :
- int fileDesc;
- off_t offset;
-
- DecodeSession() {
- fileDesc = -1;
- offset = 0;
- }
-
- DecodeSession(int fd) {
- fileDesc = fd;
- offset = 0;
- }
-
- virtual ~DecodeSession() {}
-};
-
-/**
- * Session Map Tables for Conversion and Decoding of forward lock files.
- */
-SessionMap<ConvertSession*> convertSessionMap;
-SessionMap<DecodeSession*> decodeSessionMap;
-
-/**
- * Converts the error code from Forward Lock Converter to DrmConvertStatus error code.
- *
- * @param Forward Lock Converter error code
- *
- * @return Status code from DrmConvertStatus.
- */
-static int getConvertedStatus(FwdLockConv_Status_t status);
-};
-
-};
-
-#endif /* __FWDLOCKENGINE_H__ */
diff --git a/drm/libdrmframework/plugins/forward-lock/FwdLockEngine/include/FwdLockEngineConst.h b/drm/libdrmframework/plugins/forward-lock/FwdLockEngine/include/FwdLockEngineConst.h
deleted file mode 100644
index da95d60..0000000
--- a/drm/libdrmframework/plugins/forward-lock/FwdLockEngine/include/FwdLockEngineConst.h
+++ /dev/null
@@ -1,37 +0,0 @@
-/*
- * Copyright (C) 2010 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.
- */
-
-#ifndef __FWDLOCKENGINECONST_H__
-#define __FWDLOCKENGINECONST_H__
-
-namespace android {
-
-/**
- * Constants for forward Lock Engine used for exposing engine's capabilities.
- */
-#define FWDLOCK_EXTENSION_FL ("FL")
-#define FWDLOCK_DOTEXTENSION_FL (".fl")
-#define FWDLOCK_MIMETYPE_FL ("application/x-android-drm-fl")
-
-#define FWDLOCK_EXTENSION_DM ("DM")
-#define FWDLOCK_DOTEXTENSION_DM (".dm")
-#define FWDLOCK_MIMETYPE_DM ("application/vnd.oma.drm.message")
-
-#define FWDLOCK_DESCRIPTION ("OMA V1 Forward Lock")
-
-};
-
-#endif /* __FWDLOCKENGINECONST_H__ */
diff --git a/drm/libdrmframework/plugins/forward-lock/FwdLockEngine/src/FwdLockEngine.cpp b/drm/libdrmframework/plugins/forward-lock/FwdLockEngine/src/FwdLockEngine.cpp
deleted file mode 100644
index 0273a4b..0000000
--- a/drm/libdrmframework/plugins/forward-lock/FwdLockEngine/src/FwdLockEngine.cpp
+++ /dev/null
@@ -1,661 +0,0 @@
-/*
- * Copyright (C) 2010 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.
- */
-
-#include "SessionMap.h"
-#include "FwdLockEngine.h"
-#include <utils/Log.h>
-#include <errno.h>
-#include <stdio.h>
-#include <unistd.h>
-#include "drm_framework_common.h"
-#include <fcntl.h>
-#include <limits.h>
-#include <DrmRights.h>
-#include <DrmConstraints.h>
-#include <DrmMetadata.h>
-#include <DrmInfo.h>
-#include <DrmInfoStatus.h>
-#include <DrmInfoRequest.h>
-#include <DrmSupportInfo.h>
-#include <DrmConvertedStatus.h>
-#include <utils/String8.h>
-#include "FwdLockConv.h"
-#include "FwdLockFile.h"
-#include "FwdLockGlue.h"
-#include "FwdLockEngineConst.h"
-#include "MimeTypeUtil.h"
-
-#undef LOG_TAG
-#define LOG_TAG "FwdLockEngine"
-
-#ifdef DRM_OMA_FL_ENGINE_DEBUG
-#define LOG_NDEBUG 0
-#define LOG_VERBOSE(...) ALOGV(__VA_ARGS__)
-#else
-#define LOG_VERBOSE(...)
-#endif
-
-using namespace android;
-// This extern "C" is mandatory to be managed by TPlugInManager
-extern "C" IDrmEngine* create() {
- return new FwdLockEngine();
-}
-
-// This extern "C" is mandatory to be managed by TPlugInManager
-extern "C" void destroy(IDrmEngine* plugIn) {
- delete plugIn;
-}
-
-FwdLockEngine::FwdLockEngine() {
- LOG_VERBOSE("FwdLockEngine Construction");
-}
-
-FwdLockEngine::~FwdLockEngine() {
- LOG_VERBOSE("FwdLockEngine Destruction");
-
- int size = decodeSessionMap.getSize();
-
- for (int i = 0; i < size; i++) {
- DecodeSession *session = (DecodeSession*) decodeSessionMap.getValueAt(i);
- FwdLockFile_detach(session->fileDesc);
- ::close(session->fileDesc);
- }
-
- size = convertSessionMap.getSize();
- for (int i = 0; i < size; i++) {
- ConvertSession *convSession = (ConvertSession*) convertSessionMap.getValueAt(i);
- FwdLockConv_CloseSession(convSession->uniqueId, &(convSession->output));
- }
-}
-
-int FwdLockEngine::getConvertedStatus(FwdLockConv_Status_t status) {
- int retStatus = DrmConvertedStatus::STATUS_ERROR;
-
- switch(status) {
- case FwdLockConv_Status_OK:
- retStatus = DrmConvertedStatus::STATUS_OK;
- break;
- case FwdLockConv_Status_SyntaxError:
- case FwdLockConv_Status_InvalidArgument:
- case FwdLockConv_Status_UnsupportedFileFormat:
- case FwdLockConv_Status_UnsupportedContentTransferEncoding:
- ALOGE("FwdLockEngine getConvertedStatus: file conversion Error %d. "
- "Returning STATUS_INPUTDATA_ERROR", status);
- retStatus = DrmConvertedStatus::STATUS_INPUTDATA_ERROR;
- break;
- default:
- ALOGE("FwdLockEngine getConvertedStatus: file conversion Error %d. "
- "Returning STATUS_ERROR", status);
- retStatus = DrmConvertedStatus::STATUS_ERROR;
- break;
- }
-
- return retStatus;
-}
-
-DrmConstraints* FwdLockEngine::onGetConstraints(int uniqueId, const String8* path, int action) {
- DrmConstraints* drmConstraints = NULL;
-
- LOG_VERBOSE("FwdLockEngine::onGetConstraints");
-
- if (NULL != path &&
- (RightsStatus::RIGHTS_VALID == onCheckRightsStatus(uniqueId, *path, action))) {
- // Return the empty constraints to show no error condition.
- drmConstraints = new DrmConstraints();
- }
-
- return drmConstraints;
-}
-
-DrmMetadata* FwdLockEngine::onGetMetadata(int uniqueId, const String8* path) {
- DrmMetadata* drmMetadata = NULL;
-
- LOG_VERBOSE("FwdLockEngine::onGetMetadata");
-
- if (NULL != path) {
- // Returns empty metadata to show no error condition.
- drmMetadata = new DrmMetadata();
- }
-
- return drmMetadata;
-}
-
-android::status_t FwdLockEngine::onInitialize(int uniqueId) {
- LOG_VERBOSE("FwdLockEngine::onInitialize");
-
- if (FwdLockGlue_InitializeKeyEncryption()) {
- LOG_VERBOSE("FwdLockEngine::onInitialize -- FwdLockGlue_InitializeKeyEncryption succeeded");
- } else {
- ALOGE("FwdLockEngine::onInitialize -- FwdLockGlue_InitializeKeyEncryption failed:"
- "errno = %d", errno);
- }
-
- return DRM_NO_ERROR;
-}
-
-android::status_t
-FwdLockEngine::onSetOnInfoListener(int uniqueId, const IDrmEngine::OnInfoListener* infoListener) {
- // Not used
- LOG_VERBOSE("FwdLockEngine::onSetOnInfoListener");
-
- return DRM_NO_ERROR;
-}
-
-android::status_t FwdLockEngine::onTerminate(int uniqueId) {
- LOG_VERBOSE("FwdLockEngine::onTerminate");
-
- return DRM_NO_ERROR;
-}
-
-DrmSupportInfo* FwdLockEngine::onGetSupportInfo(int uniqueId) {
- DrmSupportInfo* pSupportInfo = new DrmSupportInfo();
-
- LOG_VERBOSE("FwdLockEngine::onGetSupportInfo");
-
- // fill all Forward Lock mimetypes and extensions
- if (NULL != pSupportInfo) {
- pSupportInfo->addMimeType(String8(FWDLOCK_MIMETYPE_FL));
- pSupportInfo->addFileSuffix(String8(FWDLOCK_DOTEXTENSION_FL));
- pSupportInfo->addMimeType(String8(FWDLOCK_MIMETYPE_DM));
- pSupportInfo->addFileSuffix(String8(FWDLOCK_DOTEXTENSION_DM));
-
- pSupportInfo->setDescription(String8(FWDLOCK_DESCRIPTION));
- }
-
- return pSupportInfo;
-}
-
-bool FwdLockEngine::onCanHandle(int uniqueId, const String8& path) {
- bool result = false;
-
- String8 extString = path.getPathExtension();
-
- extString.toLower();
-
- if ((extString == String8(FWDLOCK_DOTEXTENSION_FL)) ||
- (extString == String8(FWDLOCK_DOTEXTENSION_DM))) {
- result = true;
- }
- return result;
-}
-
-DrmInfoStatus* FwdLockEngine::onProcessDrmInfo(int uniqueId, const DrmInfo* drmInfo) {
- DrmInfoStatus *drmInfoStatus = NULL;
-
- // Nothing to process
-
- drmInfoStatus = new DrmInfoStatus((int)DrmInfoStatus::STATUS_OK, 0, NULL, String8(""));
-
- LOG_VERBOSE("FwdLockEngine::onProcessDrmInfo");
-
- return drmInfoStatus;
-}
-
-status_t FwdLockEngine::onSaveRights(
- int uniqueId,
- const DrmRights& drmRights,
- const String8& rightsPath,
- const String8& contentPath) {
- // No rights to save. Return
- LOG_VERBOSE("FwdLockEngine::onSaveRights");
- return DRM_ERROR_UNKNOWN;
-}
-
-DrmInfo* FwdLockEngine::onAcquireDrmInfo(int uniqueId, const DrmInfoRequest* drmInfoRequest) {
- DrmInfo* drmInfo = NULL;
-
- // Nothing to be done for Forward Lock file
- LOG_VERBOSE("FwdLockEngine::onAcquireDrmInfo");
-
- return drmInfo;
-}
-
-int FwdLockEngine::onCheckRightsStatus(int uniqueId,
- const String8& path,
- int action) {
- int result = RightsStatus::RIGHTS_INVALID;
-
- LOG_VERBOSE("FwdLockEngine::onCheckRightsStatus");
-
- // Only Transfer action is not allowed for forward Lock files.
- if (onCanHandle(uniqueId, path)) {
- switch(action) {
- case Action::DEFAULT:
- case Action::PLAY:
- case Action::RINGTONE:
- case Action::OUTPUT:
- case Action::PREVIEW:
- case Action::EXECUTE:
- case Action::DISPLAY:
- result = RightsStatus::RIGHTS_VALID;
- break;
-
- case Action::TRANSFER:
- default:
- result = RightsStatus::RIGHTS_INVALID;
- break;
- }
- }
-
- return result;
-}
-
-status_t FwdLockEngine::onConsumeRights(int uniqueId,
- DecryptHandle* decryptHandle,
- int action,
- bool reserve) {
- // No rights consumption
- LOG_VERBOSE("FwdLockEngine::onConsumeRights");
- return DRM_NO_ERROR;
-}
-
-bool FwdLockEngine::onValidateAction(int uniqueId,
- const String8& path,
- int action,
- const ActionDescription& description) {
- LOG_VERBOSE("FwdLockEngine::onValidateAction");
-
- // For the forwardlock engine checkRights and ValidateAction are the same.
- return (onCheckRightsStatus(uniqueId, path, action) == RightsStatus::RIGHTS_VALID);
-}
-
-String8 FwdLockEngine::onGetOriginalMimeType(int uniqueId, const String8& path) {
- LOG_VERBOSE("FwdLockEngine::onGetOriginalMimeType");
- String8 mimeString = String8("");
- int fileDesc = FwdLockFile_open(path.string());
-
- if (-1 < fileDesc) {
- const char* pMimeType = FwdLockFile_GetContentType(fileDesc);
-
- if (NULL != pMimeType) {
- String8 contentType = String8(pMimeType);
- contentType.toLower();
- mimeString = MimeTypeUtil::convertMimeType(contentType);
- }
-
- FwdLockFile_close(fileDesc);
- }
-
- return mimeString;
-}
-
-int FwdLockEngine::onGetDrmObjectType(int uniqueId,
- const String8& path,
- const String8& mimeType) {
- String8 mimeStr = String8(mimeType);
-
- LOG_VERBOSE("FwdLockEngine::onGetDrmObjectType");
-
- mimeStr.toLower();
-
- /* Checks whether
- * 1. path and mime type both are not empty strings (meaning unavailable) else content is unknown
- * 2. if one of them is empty string and if other is known then its a DRM Content Object.
- * 3. if both of them are available, then both may be of known type
- * (regardless of the relation between them to make it compatible with other DRM Engines)
- */
- if (((0 == path.length()) || onCanHandle(uniqueId, path)) &&
- ((0 == mimeType.length()) || ((mimeStr == String8(FWDLOCK_MIMETYPE_FL)) ||
- (mimeStr == String8(FWDLOCK_MIMETYPE_DM)))) && (mimeType != path) ) {
- return DrmObjectType::CONTENT;
- }
-
- return DrmObjectType::UNKNOWN;
-}
-
-status_t FwdLockEngine::onRemoveRights(int uniqueId, const String8& path) {
- // No Rights to remove
- LOG_VERBOSE("FwdLockEngine::onRemoveRights");
- return DRM_NO_ERROR;
-}
-
-status_t FwdLockEngine::onRemoveAllRights(int uniqueId) {
- // No rights to remove
- LOG_VERBOSE("FwdLockEngine::onRemoveAllRights");
- return DRM_NO_ERROR;
-}
-
-#ifdef USE_64BIT_DRM_API
-status_t FwdLockEngine::onSetPlaybackStatus(int uniqueId, DecryptHandle* decryptHandle,
- int playbackStatus, int64_t position) {
-#else
-status_t FwdLockEngine::onSetPlaybackStatus(int uniqueId, DecryptHandle* decryptHandle,
- int playbackStatus, int position) {
-#endif
- // Not used
- LOG_VERBOSE("FwdLockEngine::onSetPlaybackStatus");
- return DRM_NO_ERROR;
-}
-
-status_t FwdLockEngine::onOpenConvertSession(int uniqueId,
- int convertId) {
- status_t result = DRM_ERROR_UNKNOWN;
- LOG_VERBOSE("FwdLockEngine::onOpenConvertSession");
- if (!convertSessionMap.isCreated(convertId)) {
- ConvertSession *newSession = new ConvertSession();
- if (FwdLockConv_Status_OK ==
- FwdLockConv_OpenSession(&(newSession->uniqueId), &(newSession->output))) {
- convertSessionMap.addValue(convertId, newSession);
- result = DRM_NO_ERROR;
- } else {
- ALOGE("FwdLockEngine::onOpenConvertSession -- FwdLockConv_OpenSession failed.");
- delete newSession;
- }
- }
- return result;
-}
-
-DrmConvertedStatus* FwdLockEngine::onConvertData(int uniqueId,
- int convertId,
- const DrmBuffer* inputData) {
- FwdLockConv_Status_t retStatus = FwdLockConv_Status_InvalidArgument;
- DrmBuffer *convResult = new DrmBuffer(NULL, 0);
- int offset = -1;
-
- if (NULL != inputData && convertSessionMap.isCreated(convertId)) {
- ConvertSession *convSession = convertSessionMap.getValue(convertId);
-
- if (NULL != convSession) {
- retStatus = FwdLockConv_ConvertData(convSession->uniqueId,
- inputData->data,
- inputData->length,
- &(convSession->output));
-
- if (FwdLockConv_Status_OK == retStatus) {
- // return bytes from conversion if available
- if (convSession->output.fromConvertData.numBytes > 0) {
- convResult->data = new char[convSession->output.fromConvertData.numBytes];
-
- if (NULL != convResult->data) {
- convResult->length = convSession->output.fromConvertData.numBytes;
- memcpy(convResult->data,
- (char *)convSession->output.fromConvertData.pBuffer,
- convResult->length);
- }
- }
- } else {
- offset = convSession->output.fromConvertData.errorPos;
- }
- }
- }
- return new DrmConvertedStatus(getConvertedStatus(retStatus), convResult, offset);
-}
-
-DrmConvertedStatus* FwdLockEngine::onCloseConvertSession(int uniqueId,
- int convertId) {
- FwdLockConv_Status_t retStatus = FwdLockConv_Status_InvalidArgument;
- DrmBuffer *convResult = new DrmBuffer(NULL, 0);
- int offset = -1;
-
- LOG_VERBOSE("FwdLockEngine::onCloseConvertSession");
-
- if (convertSessionMap.isCreated(convertId)) {
- ConvertSession *convSession = convertSessionMap.getValue(convertId);
-
- if (NULL != convSession) {
- retStatus = FwdLockConv_CloseSession(convSession->uniqueId, &(convSession->output));
-
- if (FwdLockConv_Status_OK == retStatus) {
- offset = convSession->output.fromCloseSession.fileOffset;
- convResult->data = new char[FWD_LOCK_SIGNATURES_SIZE];
-
- if (NULL != convResult->data) {
- convResult->length = FWD_LOCK_SIGNATURES_SIZE;
- memcpy(convResult->data,
- (char *)convSession->output.fromCloseSession.signatures,
- convResult->length);
- }
- }
- }
- convertSessionMap.removeValue(convertId);
- }
- return new DrmConvertedStatus(getConvertedStatus(retStatus), convResult, offset);
-}
-
-#ifdef USE_64BIT_DRM_API
-status_t FwdLockEngine::onOpenDecryptSession(int uniqueId,
- DecryptHandle* decryptHandle,
- int fd,
- off64_t offset,
- off64_t length) {
-#else
-status_t FwdLockEngine::onOpenDecryptSession(int uniqueId,
- DecryptHandle* decryptHandle,
- int fd,
- int offset,
- int length) {
-#endif
- status_t result = DRM_ERROR_CANNOT_HANDLE;
- int fileDesc = -1;
-
- LOG_VERBOSE("FwdLockEngine::onOpenDecryptSession");
-
- if ((-1 < fd) &&
- (NULL != decryptHandle) &&
- (!decodeSessionMap.isCreated(decryptHandle->decryptId))) {
- fileDesc = dup(fd);
- } else {
- ALOGE("FwdLockEngine::onOpenDecryptSession parameter error");
- return result;
- }
-
- if (-1 < fileDesc &&
- -1 < ::lseek(fileDesc, offset, SEEK_SET) &&
- -1 < FwdLockFile_attach(fileDesc)) {
- // check for file integrity. This must be done to protect the content mangling.
- int retVal = FwdLockFile_CheckHeaderIntegrity(fileDesc);
- DecodeSession* decodeSession = new DecodeSession(fileDesc);
-
- if (retVal && NULL != decodeSession) {
- decodeSessionMap.addValue(decryptHandle->decryptId, decodeSession);
- const char *pmime= FwdLockFile_GetContentType(fileDesc);
- String8 contentType = String8(pmime == NULL ? "" : pmime);
- contentType.toLower();
- decryptHandle->mimeType = MimeTypeUtil::convertMimeType(contentType);
- decryptHandle->decryptApiType = DecryptApiType::CONTAINER_BASED;
- decryptHandle->status = RightsStatus::RIGHTS_VALID;
- decryptHandle->decryptInfo = NULL;
- result = DRM_NO_ERROR;
- } else {
- LOG_VERBOSE("FwdLockEngine::onOpenDecryptSession Integrity Check failed for the fd");
- FwdLockFile_detach(fileDesc);
- delete decodeSession;
- }
- }
-
- if (DRM_NO_ERROR != result && -1 < fileDesc) {
- ::close(fileDesc);
- }
-
- LOG_VERBOSE("FwdLockEngine::onOpenDecryptSession Exit. result = %d", result);
-
- return result;
-}
-
-status_t FwdLockEngine::onOpenDecryptSession(int uniqueId,
- DecryptHandle* decryptHandle,
- const char* uri) {
- status_t result = DRM_ERROR_CANNOT_HANDLE;
- const char fileTag [] = "file://";
-
- if (NULL != decryptHandle && NULL != uri && strlen(uri) > sizeof(fileTag)) {
- String8 uriTag = String8(uri);
- uriTag.toLower();
-
- if (0 == strncmp(uriTag.string(), fileTag, sizeof(fileTag) - 1)) {
- const char *filePath = strchr(uri + sizeof(fileTag) - 1, '/');
- if (NULL != filePath && onCanHandle(uniqueId, String8(filePath))) {
- int fd = open(filePath, O_RDONLY);
-
- if (-1 < fd) {
- // offset is always 0 and length is not used. so any positive size.
- result = onOpenDecryptSession(uniqueId, decryptHandle, fd, 0, 1);
-
- // fd is duplicated already if success. closing the file
- close(fd);
- }
- }
- }
- }
-
- return result;
-}
-
-status_t FwdLockEngine::onCloseDecryptSession(int uniqueId,
- DecryptHandle* decryptHandle) {
- status_t result = DRM_ERROR_UNKNOWN;
- LOG_VERBOSE("FwdLockEngine::onCloseDecryptSession");
-
- if (NULL != decryptHandle && decodeSessionMap.isCreated(decryptHandle->decryptId)) {
- DecodeSession* session = decodeSessionMap.getValue(decryptHandle->decryptId);
- if (NULL != session && session->fileDesc > -1) {
- FwdLockFile_detach(session->fileDesc);
- ::close(session->fileDesc);
- decodeSessionMap.removeValue(decryptHandle->decryptId);
- result = DRM_NO_ERROR;
- }
- }
-
- if (NULL != decryptHandle) {
- if (NULL != decryptHandle->decryptInfo) {
- delete decryptHandle->decryptInfo;
- decryptHandle->decryptInfo = NULL;
- }
-
- decryptHandle->copyControlVector.clear();
- decryptHandle->extendedData.clear();
-
- delete decryptHandle;
- decryptHandle = NULL;
- }
-
- LOG_VERBOSE("FwdLockEngine::onCloseDecryptSession Exit");
- return result;
-}
-
-status_t FwdLockEngine::onInitializeDecryptUnit(int uniqueId,
- DecryptHandle* decryptHandle,
- int decryptUnitId,
- const DrmBuffer* headerInfo) {
- ALOGE("FwdLockEngine::onInitializeDecryptUnit is not supported for this DRM scheme");
- return DRM_ERROR_UNKNOWN;
-}
-
-status_t FwdLockEngine::onDecrypt(int uniqueId, DecryptHandle* decryptHandle, int decryptUnitId,
- const DrmBuffer* encBuffer, DrmBuffer** decBuffer, DrmBuffer* IV) {
- ALOGE("FwdLockEngine::onDecrypt is not supported for this DRM scheme");
- return DRM_ERROR_UNKNOWN;
-}
-
-status_t FwdLockEngine::onDecrypt(int uniqueId,
- DecryptHandle* decryptHandle,
- int decryptUnitId,
- const DrmBuffer* encBuffer,
- DrmBuffer** decBuffer) {
- ALOGE("FwdLockEngine::onDecrypt is not supported for this DRM scheme");
- return DRM_ERROR_UNKNOWN;
-}
-
-status_t FwdLockEngine::onFinalizeDecryptUnit(int uniqueId,
- DecryptHandle* decryptHandle,
- int decryptUnitId) {
- ALOGE("FwdLockEngine::onFinalizeDecryptUnit is not supported for this DRM scheme");
- return DRM_ERROR_UNKNOWN;
-}
-
-ssize_t FwdLockEngine::onRead(int uniqueId,
- DecryptHandle* decryptHandle,
- void* buffer,
- int numBytes) {
- ssize_t size = -1;
-
- if (NULL != decryptHandle &&
- decodeSessionMap.isCreated(decryptHandle->decryptId) &&
- NULL != buffer &&
- numBytes > -1) {
- DecodeSession* session = decodeSessionMap.getValue(decryptHandle->decryptId);
- if (NULL != session && session->fileDesc > -1) {
- size = FwdLockFile_read(session->fileDesc, buffer, numBytes);
-
- if (0 > size) {
- session->offset = ((off_t)-1);
- } else {
- session->offset += size;
- }
- }
- }
-
- return size;
-}
-
-#ifdef USE_64BIT_DRM_API
-off64_t FwdLockEngine::onLseek(int uniqueId, DecryptHandle* decryptHandle,
- off64_t offset, int whence) {
-#else
-off_t FwdLockEngine::onLseek(int uniqueId, DecryptHandle* decryptHandle,
- off_t offset, int whence) {
-#endif
- off_t offval = -1;
-
- if (NULL != decryptHandle && decodeSessionMap.isCreated(decryptHandle->decryptId)) {
- DecodeSession* session = decodeSessionMap.getValue(decryptHandle->decryptId);
- if (NULL != session && session->fileDesc > -1) {
- offval = FwdLockFile_lseek(session->fileDesc, offset, whence);
- session->offset = offval;
- }
- }
-
- return offval;
-}
-
-#ifdef USE_64BIT_DRM_API
-ssize_t FwdLockEngine::onPread(int uniqueId,
- DecryptHandle* decryptHandle,
- void* buffer,
- ssize_t numBytes,
- off64_t offset) {
-#else
-ssize_t FwdLockEngine::onPread(int uniqueId,
- DecryptHandle* decryptHandle,
- void* buffer,
- ssize_t numBytes,
- off_t offset) {
-#endif
- ssize_t bytesRead = -1;
-
- DecodeSession* decoderSession = NULL;
-
- if ((NULL != decryptHandle) &&
- (NULL != (decoderSession = decodeSessionMap.getValue(decryptHandle->decryptId))) &&
- (NULL != buffer) &&
- (numBytes > -1) &&
- (offset > -1)) {
- if (offset != decoderSession->offset) {
- decoderSession->offset = onLseek(uniqueId, decryptHandle, offset, SEEK_SET);
- }
-
- if (((off_t)-1) != decoderSession->offset) {
- bytesRead = onRead(uniqueId, decryptHandle, buffer, numBytes);
- if (bytesRead < 0) {
- ALOGE("FwdLockEngine::onPread error reading");
- }
- }
- } else {
- ALOGE("FwdLockEngine::onPread decryptId not found");
- }
-
- return bytesRead;
-}
diff --git a/drm/libdrmframework/plugins/forward-lock/internal-format/Android.mk b/drm/libdrmframework/plugins/forward-lock/internal-format/Android.mk
deleted file mode 100644
index 9ee7961..0000000
--- a/drm/libdrmframework/plugins/forward-lock/internal-format/Android.mk
+++ /dev/null
@@ -1,16 +0,0 @@
-#
-# Copyright (C) 2010 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.
-#
-include $(call all-subdir-makefiles)
diff --git a/drm/libdrmframework/plugins/forward-lock/internal-format/common/Android.mk b/drm/libdrmframework/plugins/forward-lock/internal-format/common/Android.mk
deleted file mode 100644
index 6c5d3cf..0000000
--- a/drm/libdrmframework/plugins/forward-lock/internal-format/common/Android.mk
+++ /dev/null
@@ -1,32 +0,0 @@
-#
-# Copyright (C) 2010 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.
-#
-LOCAL_PATH := $(call my-dir)
-
-include $(CLEAR_VARS)
-
-LOCAL_SRC_FILES := \
- FwdLockGlue.c
-
-LOCAL_C_INCLUDES := \
- external/openssl/include
-
-LOCAL_SHARED_LIBRARIES := libcrypto
-
-LOCAL_MODULE := libfwdlock-common
-
-LOCAL_MODULE_TAGS := optional
-
-include $(BUILD_STATIC_LIBRARY)
diff --git a/drm/libdrmframework/plugins/forward-lock/internal-format/common/FwdLockGlue.c b/drm/libdrmframework/plugins/forward-lock/internal-format/common/FwdLockGlue.c
deleted file mode 100644
index 92bda8f..0000000
--- a/drm/libdrmframework/plugins/forward-lock/internal-format/common/FwdLockGlue.c
+++ /dev/null
@@ -1,191 +0,0 @@
-/*
- * Copyright (C) 2010 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.
- */
-
-#include <assert.h>
-#include <errno.h>
-#include <fcntl.h>
-#include <pthread.h>
-#include <stdlib.h>
-#include <string.h>
-#include <sys/stat.h>
-#include <unistd.h>
-#include <openssl/aes.h>
-
-#include "FwdLockGlue.h"
-
-#define TRUE 1
-#define FALSE 0
-
-#define KEY_SIZE 16
-#define KEY_SIZE_IN_BITS (KEY_SIZE * 8)
-
-static int isInitialized = FALSE;
-
-static const char strKeyFilename[] = "/data/drm/fwdlock/kek.dat";
-
-static AES_KEY encryptionRoundKeys;
-static AES_KEY decryptionRoundKeys;
-
-/**
- * Creates all directories along the fully qualified path of the given file.
- *
- * @param[in] path A reference to the fully qualified path of a file.
- * @param[in] mode The access mode to use for the directories being created.
- *
- * @return A Boolean value indicating whether the operation was successful.
- */
-static int FwdLockGlue_CreateDirectories(const char *path, mode_t mode) {
- int result = TRUE;
- size_t partialPathLength = strlen(path);
- char *partialPath = malloc(partialPathLength + 1);
- if (partialPath == NULL) {
- result = FALSE;
- } else {
- size_t i;
- for (i = 0; i < partialPathLength; ++i) {
- if (path[i] == '/' && i > 0) {
- partialPath[i] = '\0';
- if (mkdir(partialPath, mode) != 0 && errno != EEXIST) {
- result = FALSE;
- break;
- }
- }
- partialPath[i] = path[i];
- }
- free(partialPath);
- }
- return result;
-}
-
-/**
- * Initializes the round keys used for encryption and decryption of session keys. First creates a
- * device-unique key-encryption key if none exists yet.
- */
-static void FwdLockGlue_InitializeRoundKeys() {
- unsigned char keyEncryptionKey[KEY_SIZE];
- int fileDesc = open(strKeyFilename, O_RDONLY);
- if (fileDesc >= 0) {
- if (read(fileDesc, keyEncryptionKey, KEY_SIZE) == KEY_SIZE) {
- isInitialized = TRUE;
- }
- (void)close(fileDesc);
- } else if (errno == ENOENT &&
- FwdLockGlue_GetRandomNumber(keyEncryptionKey, KEY_SIZE) &&
- FwdLockGlue_CreateDirectories(strKeyFilename, S_IRWXU)) {
- fileDesc = open(strKeyFilename, O_CREAT | O_TRUNC | O_WRONLY, S_IRUSR);
- if (fileDesc >= 0) {
- if (write(fileDesc, keyEncryptionKey, KEY_SIZE) == KEY_SIZE) {
- isInitialized = TRUE;
- }
- (void)close(fileDesc);
- }
- }
- if (isInitialized) {
- if (AES_set_encrypt_key(keyEncryptionKey, KEY_SIZE_IN_BITS, &encryptionRoundKeys) != 0 ||
- AES_set_decrypt_key(keyEncryptionKey, KEY_SIZE_IN_BITS, &decryptionRoundKeys) != 0) {
- isInitialized = FALSE;
- }
- }
- memset(keyEncryptionKey, 0, KEY_SIZE); // Zero out key data.
-}
-
-/**
- * Validates the padding of a decrypted key.
- *
- * @param[in] pData A reference to the buffer containing the decrypted key and padding.
- * @param[in] decryptedKeyLength The length in bytes of the decrypted key.
- *
- * @return A Boolean value indicating whether the padding was valid.
- */
-static int FwdLockGlue_ValidatePadding(const unsigned char *pData, size_t decryptedKeyLength) {
- size_t i;
- size_t padding = AES_BLOCK_SIZE - (decryptedKeyLength % AES_BLOCK_SIZE);
- pData += decryptedKeyLength;
- for (i = 0; i < padding; ++i) {
- if ((size_t)*pData != padding) {
- return FALSE;
- }
- ++pData;
- }
- return TRUE;
-}
-
-int FwdLockGlue_GetRandomNumber(void *pBuffer, size_t numBytes) {
- // Generate 'cryptographically secure' random bytes by reading them from "/dev/urandom" (the
- // non-blocking version of "/dev/random").
- ssize_t numBytesRead = 0;
- int fileDesc = open("/dev/urandom", O_RDONLY);
- if (fileDesc >= 0) {
- numBytesRead = read(fileDesc, pBuffer, numBytes);
- (void)close(fileDesc);
- }
- return numBytesRead >= 0 && (size_t)numBytesRead == numBytes;
-}
-
-int FwdLockGlue_InitializeKeyEncryption() {
- static pthread_once_t once = PTHREAD_ONCE_INIT;
- pthread_once(&once, FwdLockGlue_InitializeRoundKeys);
- return isInitialized;
-}
-
-size_t FwdLockGlue_GetEncryptedKeyLength(size_t plaintextKeyLength) {
- return ((plaintextKeyLength / AES_BLOCK_SIZE) + 2) * AES_BLOCK_SIZE;
-}
-
-int FwdLockGlue_EncryptKey(const void *pPlaintextKey,
- size_t plaintextKeyLength,
- void *pEncryptedKey,
- size_t encryptedKeyLength) {
- int result = FALSE;
- assert(encryptedKeyLength == FwdLockGlue_GetEncryptedKeyLength(plaintextKeyLength));
- if (FwdLockGlue_InitializeKeyEncryption()) {
- unsigned char initVector[AES_BLOCK_SIZE];
- if (FwdLockGlue_GetRandomNumber(initVector, AES_BLOCK_SIZE)) {
- size_t padding = AES_BLOCK_SIZE - (plaintextKeyLength % AES_BLOCK_SIZE);
- size_t dataLength = encryptedKeyLength - AES_BLOCK_SIZE;
- memcpy(pEncryptedKey, pPlaintextKey, plaintextKeyLength);
- memset((unsigned char *)pEncryptedKey + plaintextKeyLength, (int)padding, padding);
- memcpy((unsigned char *)pEncryptedKey + dataLength, initVector, AES_BLOCK_SIZE);
- AES_cbc_encrypt(pEncryptedKey, pEncryptedKey, dataLength, &encryptionRoundKeys,
- initVector, AES_ENCRYPT);
- result = TRUE;
- }
- }
- return result;
-}
-
-int FwdLockGlue_DecryptKey(const void *pEncryptedKey,
- size_t encryptedKeyLength,
- void *pDecryptedKey,
- size_t decryptedKeyLength) {
- int result = FALSE;
- assert(encryptedKeyLength == FwdLockGlue_GetEncryptedKeyLength(decryptedKeyLength));
- if (FwdLockGlue_InitializeKeyEncryption()) {
- size_t dataLength = encryptedKeyLength - AES_BLOCK_SIZE;
- unsigned char *pData = malloc(dataLength);
- if (pData != NULL) {
- unsigned char initVector[AES_BLOCK_SIZE];
- memcpy(pData, pEncryptedKey, dataLength);
- memcpy(initVector, (const unsigned char *)pEncryptedKey + dataLength, AES_BLOCK_SIZE);
- AES_cbc_encrypt(pData, pData, dataLength, &decryptionRoundKeys, initVector,
- AES_DECRYPT);
- memcpy(pDecryptedKey, pData, decryptedKeyLength);
- result = FwdLockGlue_ValidatePadding(pData, decryptedKeyLength);
- free(pData);
- }
- }
- return result;
-}
diff --git a/drm/libdrmframework/plugins/forward-lock/internal-format/common/FwdLockGlue.h b/drm/libdrmframework/plugins/forward-lock/internal-format/common/FwdLockGlue.h
deleted file mode 100644
index f36f6ea..0000000
--- a/drm/libdrmframework/plugins/forward-lock/internal-format/common/FwdLockGlue.h
+++ /dev/null
@@ -1,85 +0,0 @@
-/*
- * Copyright (C) 2010 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.
- */
-
-#ifndef __FWDLOCKGLUE_H__
-#define __FWDLOCKGLUE_H__
-
-#ifdef __cplusplus
-extern "C" {
-#endif
-
-/**
- * Generates the specified number of cryptographically secure random bytes.
- *
- * @param[out] pBuffer A reference to the buffer that should receive the random data.
- * @param[in] numBytes The number of random bytes to generate.
- *
- * @return A Boolean value indicating whether the operation was successful.
- */
-int FwdLockGlue_GetRandomNumber(void *pBuffer, size_t numBytes);
-
-/**
- * Performs initialization of the key-encryption key. Should be called once during startup to
- * facilitate encryption and decryption of session keys.
- *
- * @return A Boolean value indicating whether the operation was successful.
- */
-int FwdLockGlue_InitializeKeyEncryption();
-
-/**
- * Returns the length of the encrypted key, given the length of the plaintext key.
- *
- * @param[in] plaintextKeyLength The length in bytes of the plaintext key.
- *
- * @return The length in bytes of the encrypted key.
- */
-size_t FwdLockGlue_GetEncryptedKeyLength(size_t plaintextKeyLength);
-
-/**
- * Encrypts the given session key using a key-encryption key unique to this device.
- *
- * @param[in] pPlaintextKey A reference to the buffer containing the plaintext key.
- * @param[in] plaintextKeyLength The length in bytes of the plaintext key.
- * @param[out] pEncryptedKey A reference to the buffer containing the encrypted key.
- * @param[in] encryptedKeyLength The length in bytes of the encrypted key.
- *
- * @return A Boolean value indicating whether the operation was successful.
- */
-int FwdLockGlue_EncryptKey(const void *pPlaintextKey,
- size_t plaintextKeyLength,
- void *pEncryptedKey,
- size_t encryptedKeyLength);
-
-/**
- * Decrypts the given session key using a key-encryption key unique to this device.
- *
- * @param[in] pEncryptedKey A reference to the buffer containing the encrypted key.
- * @param[in] encryptedKeyLength The length in bytes of the encrypted key.
- * @param[out] pDecryptedKey A reference to the buffer containing the decrypted key.
- * @param[in] decryptedKeyLength The length in bytes of the decrypted key.
- *
- * @return A Boolean value indicating whether the operation was successful.
- */
-int FwdLockGlue_DecryptKey(const void *pEncryptedKey,
- size_t encryptedKeyLength,
- void *pDecryptedKey,
- size_t decryptedKeyLength);
-
-#ifdef __cplusplus
-}
-#endif
-
-#endif // __FWDLOCKGLUE_H__
diff --git a/drm/libdrmframework/plugins/forward-lock/internal-format/converter/Android.mk b/drm/libdrmframework/plugins/forward-lock/internal-format/converter/Android.mk
deleted file mode 100644
index 00bb788..0000000
--- a/drm/libdrmframework/plugins/forward-lock/internal-format/converter/Android.mk
+++ /dev/null
@@ -1,37 +0,0 @@
-#
-# Copyright (C) 2010 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.
-#
-LOCAL_PATH := $(call my-dir)
-
-include $(CLEAR_VARS)
-
-LOCAL_SRC_FILES := \
- FwdLockConv.c
-
-LOCAL_C_INCLUDES := \
- frameworks/base/drm/libdrmframework/plugins/forward-lock/internal-format/common \
- external/openssl/include
-
-LOCAL_SHARED_LIBRARIES := libcrypto
-
-LOCAL_WHOLE_STATIC_LIBRARIES := libfwdlock-common
-
-LOCAL_STATIC_LIBRARIES := libfwdlock-common
-
-LOCAL_MODULE := libfwdlock-converter
-
-LOCAL_MODULE_TAGS := optional
-
-include $(BUILD_STATIC_LIBRARY)
diff --git a/drm/libdrmframework/plugins/forward-lock/internal-format/converter/FwdLockConv.c b/drm/libdrmframework/plugins/forward-lock/internal-format/converter/FwdLockConv.c
deleted file mode 100644
index 299116d..0000000
--- a/drm/libdrmframework/plugins/forward-lock/internal-format/converter/FwdLockConv.c
+++ /dev/null
@@ -1,1347 +0,0 @@
-/*
- * Copyright (C) 2010 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.
- */
-
-#include <assert.h>
-#include <ctype.h>
-#include <fcntl.h>
-#include <limits.h>
-#include <pthread.h>
-#include <string.h>
-#include <sys/stat.h>
-#include <unistd.h>
-#include <openssl/aes.h>
-#include <openssl/hmac.h>
-
-#include "FwdLockConv.h"
-#include "FwdLockGlue.h"
-
-#define TRUE 1
-#define FALSE 0
-
-#define INVALID_OFFSET ((off64_t)-1)
-
-#define MAX_NUM_SESSIONS 32
-
-#define OUTPUT_BUFFER_SIZE_INCREMENT 1024
-#define READ_BUFFER_SIZE 1024
-
-#define MAX_BOUNDARY_LENGTH 70
-#define MAX_DELIMITER_LENGTH (MAX_BOUNDARY_LENGTH + 4)
-
-#define STRING_LENGTH_INCREMENT 25
-
-#define KEY_SIZE AES_BLOCK_SIZE
-#define KEY_SIZE_IN_BITS (KEY_SIZE * 8)
-
-#define SHA1_HASH_SIZE 20
-
-#define FWD_LOCK_VERSION 0
-#define FWD_LOCK_SUBFORMAT 0
-#define USAGE_RESTRICTION_FLAGS 0
-#define CONTENT_TYPE_LENGTH_POS 7
-#define TOP_HEADER_SIZE 8
-
-/**
- * Data type for the parser states of the converter.
- */
-typedef enum FwdLockConv_ParserState {
- FwdLockConv_ParserState_WantsOpenDelimiter,
- FwdLockConv_ParserState_WantsMimeHeaders,
- FwdLockConv_ParserState_WantsBinaryEncodedData,
- FwdLockConv_ParserState_WantsBase64EncodedData,
- FwdLockConv_ParserState_Done
-} FwdLockConv_ParserState_t;
-
-/**
- * Data type for the scanner states of the converter.
- */
-typedef enum FwdLockConv_ScannerState {
- FwdLockConv_ScannerState_WantsFirstDash,
- FwdLockConv_ScannerState_WantsSecondDash,
- FwdLockConv_ScannerState_WantsCR,
- FwdLockConv_ScannerState_WantsLF,
- FwdLockConv_ScannerState_WantsBoundary,
- FwdLockConv_ScannerState_WantsBoundaryEnd,
- FwdLockConv_ScannerState_WantsMimeHeaderNameStart,
- FwdLockConv_ScannerState_WantsMimeHeaderName,
- FwdLockConv_ScannerState_WantsMimeHeaderNameEnd,
- FwdLockConv_ScannerState_WantsContentTypeStart,
- FwdLockConv_ScannerState_WantsContentType,
- FwdLockConv_ScannerState_WantsContentTransferEncodingStart,
- FwdLockConv_ScannerState_Wants_A_OR_I,
- FwdLockConv_ScannerState_Wants_N,
- FwdLockConv_ScannerState_Wants_A,
- FwdLockConv_ScannerState_Wants_R,
- FwdLockConv_ScannerState_Wants_Y,
- FwdLockConv_ScannerState_Wants_S,
- FwdLockConv_ScannerState_Wants_E,
- FwdLockConv_ScannerState_Wants_6,
- FwdLockConv_ScannerState_Wants_4,
- FwdLockConv_ScannerState_Wants_B,
- FwdLockConv_ScannerState_Wants_I,
- FwdLockConv_ScannerState_Wants_T,
- FwdLockConv_ScannerState_WantsContentTransferEncodingEnd,
- FwdLockConv_ScannerState_WantsMimeHeaderValueEnd,
- FwdLockConv_ScannerState_WantsMimeHeadersEnd,
- FwdLockConv_ScannerState_WantsByte1,
- FwdLockConv_ScannerState_WantsByte1_AfterCRLF,
- FwdLockConv_ScannerState_WantsByte2,
- FwdLockConv_ScannerState_WantsByte3,
- FwdLockConv_ScannerState_WantsByte4,
- FwdLockConv_ScannerState_WantsPadding,
- FwdLockConv_ScannerState_WantsWhitespace,
- FwdLockConv_ScannerState_WantsWhitespace_AfterCRLF,
- FwdLockConv_ScannerState_WantsDelimiter
-} FwdLockConv_ScannerState_t;
-
-/**
- * Data type for the content transfer encoding.
- */
-typedef enum FwdLockConv_ContentTransferEncoding {
- FwdLockConv_ContentTransferEncoding_Undefined,
- FwdLockConv_ContentTransferEncoding_Binary,
- FwdLockConv_ContentTransferEncoding_Base64
-} FwdLockConv_ContentTransferEncoding_t;
-
-/**
- * Data type for a dynamically growing string.
- */
-typedef struct FwdLockConv_String {
- char *ptr;
- size_t length;
- size_t maxLength;
- size_t lengthIncrement;
-} FwdLockConv_String_t;
-
-/**
- * Data type for the per-file state information needed by the converter.
- */
-typedef struct FwdLockConv_Session {
- FwdLockConv_ParserState_t parserState;
- FwdLockConv_ScannerState_t scannerState;
- FwdLockConv_ScannerState_t savedScannerState;
- off64_t numCharsConsumed;
- char delimiter[MAX_DELIMITER_LENGTH];
- size_t delimiterLength;
- size_t delimiterMatchPos;
- FwdLockConv_String_t mimeHeaderName;
- FwdLockConv_String_t contentType;
- FwdLockConv_ContentTransferEncoding_t contentTransferEncoding;
- unsigned char sessionKey[KEY_SIZE];
- void *pEncryptedSessionKey;
- size_t encryptedSessionKeyLength;
- AES_KEY encryptionRoundKeys;
- HMAC_CTX signingContext;
- unsigned char topHeader[TOP_HEADER_SIZE];
- unsigned char counter[AES_BLOCK_SIZE];
- unsigned char keyStream[AES_BLOCK_SIZE];
- int keyStreamIndex;
- unsigned char ch;
- size_t outputBufferSize;
- size_t dataOffset;
- size_t numDataBytes;
-} FwdLockConv_Session_t;
-
-static FwdLockConv_Session_t *sessionPtrs[MAX_NUM_SESSIONS] = { NULL };
-
-static pthread_mutex_t sessionAcquisitionMutex = PTHREAD_MUTEX_INITIALIZER;
-
-static const FwdLockConv_String_t nullString = { NULL, 0, 0, STRING_LENGTH_INCREMENT };
-
-static const unsigned char topHeaderTemplate[] =
- { 'F', 'W', 'L', 'K', FWD_LOCK_VERSION, FWD_LOCK_SUBFORMAT, USAGE_RESTRICTION_FLAGS };
-
-static const char strContent[] = "content-";
-static const char strType[] = "type";
-static const char strTransferEncoding[] = "transfer-encoding";
-static const char strTextPlain[] = "text/plain";
-static const char strApplicationVndOmaDrmRightsXml[] = "application/vnd.oma.drm.rights+xml";
-static const char strApplicationVndOmaDrmContent[] = "application/vnd.oma.drm.content";
-
-static const size_t strlenContent = sizeof strContent - 1;
-static const size_t strlenTextPlain = sizeof strTextPlain - 1;
-
-static const signed char base64Values[] = {
- -1, -1, -1, -1, -1, -1, -1, -1, -1, -1, -1, -1, -1, -1, -1, -1,
- -1, -1, -1, -1, -1, -1, -1, -1, -1, -1, -1, -1, -1, -1, -1, -1,
- -1, -1, -1, -1, -1, -1, -1, -1, -1, -1, -1, 62, -1, -1, -1, 63,
- 52, 53, 54, 55, 56, 57, 58, 59, 60, 61, -1, -1, -1, -2, -1, -1,
- -1, 0, 1, 2, 3, 4, 5, 6, 7, 8, 9, 10, 11, 12, 13, 14,
- 15, 16, 17, 18, 19, 20, 21, 22, 23, 24, 25, -1, -1, -1, -1, -1,
- -1, 26, 27, 28, 29, 30, 31, 32, 33, 34, 35, 36, 37, 38, 39, 40,
- 41, 42, 43, 44, 45, 46, 47, 48, 49, 50, 51
-};
-
-/**
- * Acquires an unused converter session.
- *
- * @return A session ID.
- */
-static int FwdLockConv_AcquireSession() {
- int sessionId = -1;
- int i;
- pthread_mutex_lock(&sessionAcquisitionMutex);
- for (i = 0; i < MAX_NUM_SESSIONS; ++i) {
- if (sessionPtrs[i] == NULL) {
- sessionPtrs[i] = malloc(sizeof *sessionPtrs[i]);
- if (sessionPtrs[i] != NULL) {
- sessionId = i;
- }
- break;
- }
- }
- pthread_mutex_unlock(&sessionAcquisitionMutex);
- return sessionId;
-}
-
-/**
- * Checks whether a session ID is in range and currently in use.
- *
- * @param[in] sessionID A session ID.
- *
- * @return A Boolean value indicating whether the session ID is in range and currently in use.
- */
-static int FwdLockConv_IsValidSession(int sessionId) {
- return 0 <= sessionId && sessionId < MAX_NUM_SESSIONS && sessionPtrs[sessionId] != NULL;
-}
-
-/**
- * Releases a converter session.
- *
- * @param[in] sessionID A session ID.
- */
-static void FwdLockConv_ReleaseSession(int sessionId) {
- pthread_mutex_lock(&sessionAcquisitionMutex);
- assert(FwdLockConv_IsValidSession(sessionId));
- memset(sessionPtrs[sessionId], 0, sizeof *sessionPtrs[sessionId]); // Zero out key data.
- free(sessionPtrs[sessionId]);
- sessionPtrs[sessionId] = NULL;
- pthread_mutex_unlock(&sessionAcquisitionMutex);
-}
-
-/**
- * Derives cryptographically independent keys for encryption and signing from the session key.
- *
- * @param[in,out] pSession A reference to a converter session.
- *
- * @return A status code.
- */
-static int FwdLockConv_DeriveKeys(FwdLockConv_Session_t *pSession) {
- FwdLockConv_Status_t status;
- struct FwdLockConv_DeriveKeys_Data {
- AES_KEY sessionRoundKeys;
- unsigned char value[KEY_SIZE];
- unsigned char key[KEY_SIZE];
- } *pData = malloc(sizeof *pData);
- if (pData == NULL) {
- status = FwdLockConv_Status_OutOfMemory;
- } else {
- if (AES_set_encrypt_key(pSession->sessionKey, KEY_SIZE_IN_BITS,
- &pData->sessionRoundKeys) != 0) {
- status = FwdLockConv_Status_ProgramError;
- } else {
- // Encrypt the 16-byte value {0, 0, ..., 0} to produce the encryption key.
- memset(pData->value, 0, KEY_SIZE);
- AES_encrypt(pData->value, pData->key, &pData->sessionRoundKeys);
- if (AES_set_encrypt_key(pData->key, KEY_SIZE_IN_BITS,
- &pSession->encryptionRoundKeys) != 0) {
- status = FwdLockConv_Status_ProgramError;
- } else {
- // Encrypt the 16-byte value {1, 0, ..., 0} to produce the signing key.
- ++pData->value[0];
- AES_encrypt(pData->value, pData->key, &pData->sessionRoundKeys);
- HMAC_CTX_init(&pSession->signingContext);
- HMAC_Init_ex(&pSession->signingContext, pData->key, KEY_SIZE, EVP_sha1(), NULL);
- status = FwdLockConv_Status_OK;
- }
- }
- memset(pData, 0, sizeof pData); // Zero out key data.
- free(pData);
- }
- return status;
-}
-
-/**
- * Checks whether a given character is valid in a boundary. Allows some non-standard characters that
- * are invalid according to RFC 2046 but nevertheless used by one vendor's DRM packager. Note that
- * the boundary may contain leading and internal spaces.
- *
- * @param[in] ch The character to check.
- *
- * @return A Boolean value indicating whether the given character is valid in a boundary.
- */
-static int FwdLockConv_IsBoundaryChar(int ch) {
- return isalnum(ch) || ch == '\'' || ch == '(' || ch == ')' || ch == '+' || ch == '_' ||
- ch == ',' || ch == '-' || ch == '.' || ch == '/' || ch == ':' || ch == '=' ||
- ch == '?' || ch == ' ' || ch == '%' || ch == '[' || ch == '&' || ch == '*' || ch == '^';
-}
-
-/**
- * Checks whether a given character should be considered whitespace, using a narrower definition
- * than the standard-library isspace() function.
- *
- * @param[in] ch The character to check.
- *
- * @return A Boolean value indicating whether the given character should be considered whitespace.
- */
-static int FwdLockConv_IsWhitespace(int ch) {
- return ch == ' ' || ch == '\t';
-}
-
-/**
- * Removes trailing spaces from the delimiter.
- *
- * @param[in,out] pSession A reference to a converter session.
- *
- * @return A status code.
- */
-static FwdLockConv_Status_t FwdLockConv_RightTrimDelimiter(FwdLockConv_Session_t *pSession) {
- while (pSession->delimiterLength > 4 &&
- pSession->delimiter[pSession->delimiterLength - 1] == ' ') {
- --pSession->delimiterLength;
- }
- if (pSession->delimiterLength > 4) {
- return FwdLockConv_Status_OK;
- }
- return FwdLockConv_Status_SyntaxError;
-}
-
-/**
- * Matches the open delimiter.
- *
- * @param[in,out] pSession A reference to a converter session.
- * @param[in] ch A character.
- *
- * @return A status code.
- */
-static FwdLockConv_Status_t FwdLockConv_MatchOpenDelimiter(FwdLockConv_Session_t *pSession,
- int ch) {
- FwdLockConv_Status_t status = FwdLockConv_Status_OK;
- switch (pSession->scannerState) {
- case FwdLockConv_ScannerState_WantsFirstDash:
- if (ch == '-') {
- pSession->scannerState = FwdLockConv_ScannerState_WantsSecondDash;
- } else if (ch == '\r') {
- pSession->scannerState = FwdLockConv_ScannerState_WantsLF;
- } else {
- pSession->scannerState = FwdLockConv_ScannerState_WantsCR;
- }
- break;
- case FwdLockConv_ScannerState_WantsSecondDash:
- if (ch == '-') {
- // The delimiter starts with "\r\n--" (the open delimiter may omit the initial "\r\n").
- // The rest is the user-defined boundary that should come next.
- pSession->delimiter[0] = '\r';
- pSession->delimiter[1] = '\n';
- pSession->delimiter[2] = '-';
- pSession->delimiter[3] = '-';
- pSession->delimiterLength = 4;
- pSession->scannerState = FwdLockConv_ScannerState_WantsBoundary;
- } else if (ch == '\r') {
- pSession->scannerState = FwdLockConv_ScannerState_WantsLF;
- } else {
- pSession->scannerState = FwdLockConv_ScannerState_WantsCR;
- }
- break;
- case FwdLockConv_ScannerState_WantsCR:
- if (ch == '\r') {
- pSession->scannerState = FwdLockConv_ScannerState_WantsLF;
- }
- break;
- case FwdLockConv_ScannerState_WantsLF:
- if (ch == '\n') {
- pSession->scannerState = FwdLockConv_ScannerState_WantsFirstDash;
- } else if (ch != '\r') {
- pSession->scannerState = FwdLockConv_ScannerState_WantsCR;
- }
- break;
- case FwdLockConv_ScannerState_WantsBoundary:
- if (FwdLockConv_IsBoundaryChar(ch)) {
- // The boundary may contain leading and internal spaces, so trailing spaces will also be
- // matched here. These will be removed later.
- if (pSession->delimiterLength < MAX_DELIMITER_LENGTH) {
- pSession->delimiter[pSession->delimiterLength++] = ch;
- } else if (ch != ' ') {
- status = FwdLockConv_Status_SyntaxError;
- }
- } else if (ch == '\r') {
- status = FwdLockConv_RightTrimDelimiter(pSession);
- if (status == FwdLockConv_Status_OK) {
- pSession->scannerState = FwdLockConv_ScannerState_WantsBoundaryEnd;
- }
- } else if (ch == '\t') {
- status = FwdLockConv_RightTrimDelimiter(pSession);
- if (status == FwdLockConv_Status_OK) {
- pSession->scannerState = FwdLockConv_ScannerState_WantsWhitespace;
- }
- } else {
- status = FwdLockConv_Status_SyntaxError;
- }
- break;
- case FwdLockConv_ScannerState_WantsWhitespace:
- if (ch == '\r') {
- pSession->scannerState = FwdLockConv_ScannerState_WantsBoundaryEnd;
- } else if (!FwdLockConv_IsWhitespace(ch)) {
- status = FwdLockConv_Status_SyntaxError;
- }
- break;
- case FwdLockConv_ScannerState_WantsBoundaryEnd:
- if (ch == '\n') {
- pSession->parserState = FwdLockConv_ParserState_WantsMimeHeaders;
- pSession->scannerState = FwdLockConv_ScannerState_WantsMimeHeaderNameStart;
- } else {
- status = FwdLockConv_Status_SyntaxError;
- }
- break;
- default:
- status = FwdLockConv_Status_ProgramError;
- break;
- }
- return status;
-}
-
-/**
- * Checks whether a given character is valid in a MIME header name.
- *
- * @param[in] ch The character to check.
- *
- * @return A Boolean value indicating whether the given character is valid in a MIME header name.
- */
-static int FwdLockConv_IsMimeHeaderNameChar(int ch) {
- return isgraph(ch) && ch != ':';
-}
-
-/**
- * Checks whether a given character is valid in a MIME header value.
- *
- * @param[in] ch The character to check.
- *
- * @return A Boolean value indicating whether the given character is valid in a MIME header value.
- */
-static int FwdLockConv_IsMimeHeaderValueChar(int ch) {
- return isgraph(ch) && ch != ';';
-}
-
-/**
- * Appends a character to the specified dynamically growing string.
- *
- * @param[in,out] pString A reference to a dynamically growing string.
- * @param[in] ch The character to append.
- *
- * @return A status code.
- */
-static FwdLockConv_Status_t FwdLockConv_StringAppend(FwdLockConv_String_t *pString, int ch) {
- if (pString->length == pString->maxLength) {
- size_t newMaxLength = pString->maxLength + pString->lengthIncrement;
- char *newPtr = realloc(pString->ptr, newMaxLength + 1);
- if (newPtr == NULL) {
- return FwdLockConv_Status_OutOfMemory;
- }
- pString->ptr = newPtr;
- pString->maxLength = newMaxLength;
- }
- pString->ptr[pString->length++] = ch;
- pString->ptr[pString->length] = '\0';
- return FwdLockConv_Status_OK;
-}
-
-/**
- * Attempts to recognize the MIME header name and changes the scanner state accordingly.
- *
- * @param[in,out] pSession A reference to a converter session.
- *
- * @return A status code.
- */
-static FwdLockConv_Status_t FwdLockConv_RecognizeMimeHeaderName(FwdLockConv_Session_t *pSession) {
- FwdLockConv_Status_t status = FwdLockConv_Status_OK;
- if (strncmp(pSession->mimeHeaderName.ptr, strContent, strlenContent) == 0) {
- if (strcmp(pSession->mimeHeaderName.ptr + strlenContent, strType) == 0) {
- if (pSession->contentType.ptr == NULL) {
- pSession->scannerState = FwdLockConv_ScannerState_WantsContentTypeStart;
- } else {
- status = FwdLockConv_Status_SyntaxError;
- }
- } else if (strcmp(pSession->mimeHeaderName.ptr + strlenContent, strTransferEncoding) == 0) {
- if (pSession->contentTransferEncoding ==
- FwdLockConv_ContentTransferEncoding_Undefined) {
- pSession->scannerState = FwdLockConv_ScannerState_WantsContentTransferEncodingStart;
- } else {
- status = FwdLockConv_Status_SyntaxError;
- }
- } else {
- pSession->scannerState = FwdLockConv_ScannerState_WantsCR;
- }
- } else {
- pSession->scannerState = FwdLockConv_ScannerState_WantsCR;
- }
- return status;
-}
-
-/**
- * Applies defaults to missing MIME header values.
- *
- * @param[in,out] pSession A reference to a converter session.
- *
- * @return A status code.
- */
-static FwdLockConv_Status_t FwdLockConv_ApplyDefaults(FwdLockConv_Session_t *pSession) {
- if (pSession->contentType.ptr == NULL) {
- // Content type is missing: default to "text/plain".
- pSession->contentType.ptr = malloc(sizeof strTextPlain);
- if (pSession->contentType.ptr == NULL) {
- return FwdLockConv_Status_OutOfMemory;
- }
- memcpy(pSession->contentType.ptr, strTextPlain, sizeof strTextPlain);
- pSession->contentType.length = strlenTextPlain;
- pSession->contentType.maxLength = strlenTextPlain;
- }
- if (pSession->contentTransferEncoding == FwdLockConv_ContentTransferEncoding_Undefined) {
- // Content transfer encoding is missing: default to binary.
- pSession->contentTransferEncoding = FwdLockConv_ContentTransferEncoding_Binary;
- }
- return FwdLockConv_Status_OK;
-}
-
-/**
- * Verifies that the content type is supported.
- *
- * @param[in,out] pSession A reference to a converter session.
- *
- * @return A status code.
- */
-static FwdLockConv_Status_t FwdLockConv_VerifyContentType(FwdLockConv_Session_t *pSession) {
- FwdLockConv_Status_t status;
- if (pSession->contentType.ptr == NULL) {
- status = FwdLockConv_Status_ProgramError;
- } else if (strcmp(pSession->contentType.ptr, strApplicationVndOmaDrmRightsXml) == 0 ||
- strcmp(pSession->contentType.ptr, strApplicationVndOmaDrmContent) == 0) {
- status = FwdLockConv_Status_UnsupportedFileFormat;
- } else {
- status = FwdLockConv_Status_OK;
- }
- return status;
-}
-
-/**
- * Writes the header of the output file.
- *
- * @param[in,out] pSession A reference to a converter session.
- * @param[out] pOutput The output from the conversion process.
- *
- * @return A status code.
- */
-static FwdLockConv_Status_t FwdLockConv_WriteHeader(FwdLockConv_Session_t *pSession,
- FwdLockConv_Output_t *pOutput) {
- FwdLockConv_Status_t status;
- if (pSession->contentType.length > UCHAR_MAX) {
- status = FwdLockConv_Status_SyntaxError;
- } else {
- pSession->outputBufferSize = OUTPUT_BUFFER_SIZE_INCREMENT;
- pOutput->fromConvertData.pBuffer = malloc(pSession->outputBufferSize);
- if (pOutput->fromConvertData.pBuffer == NULL) {
- status = FwdLockConv_Status_OutOfMemory;
- } else {
- size_t encryptedSessionKeyPos = TOP_HEADER_SIZE + pSession->contentType.length;
- size_t dataSignaturePos = encryptedSessionKeyPos + pSession->encryptedSessionKeyLength;
- size_t headerSignaturePos = dataSignaturePos + SHA1_HASH_SIZE;
- pSession->dataOffset = headerSignaturePos + SHA1_HASH_SIZE;
- memcpy(pSession->topHeader, topHeaderTemplate, sizeof topHeaderTemplate);
- pSession->topHeader[CONTENT_TYPE_LENGTH_POS] =
- (unsigned char)pSession->contentType.length;
- memcpy(pOutput->fromConvertData.pBuffer, pSession->topHeader, TOP_HEADER_SIZE);
- memcpy((char *)pOutput->fromConvertData.pBuffer + TOP_HEADER_SIZE,
- pSession->contentType.ptr, pSession->contentType.length);
- memcpy((char *)pOutput->fromConvertData.pBuffer + encryptedSessionKeyPos,
- pSession->pEncryptedSessionKey, pSession->encryptedSessionKeyLength);
-
- // Set the signatures to all zeros for now; they will have to be updated later.
- memset((char *)pOutput->fromConvertData.pBuffer + dataSignaturePos, 0,
- SHA1_HASH_SIZE);
- memset((char *)pOutput->fromConvertData.pBuffer + headerSignaturePos, 0,
- SHA1_HASH_SIZE);
-
- pOutput->fromConvertData.numBytes = pSession->dataOffset;
- status = FwdLockConv_Status_OK;
- }
- }
- return status;
-}
-
-/**
- * Matches the MIME headers.
- *
- * @param[in,out] pSession A reference to a converter session.
- * @param[in] ch A character.
- * @param[out] pOutput The output from the conversion process.
- *
- * @return A status code.
- */
-static FwdLockConv_Status_t FwdLockConv_MatchMimeHeaders(FwdLockConv_Session_t *pSession,
- int ch,
- FwdLockConv_Output_t *pOutput) {
- FwdLockConv_Status_t status = FwdLockConv_Status_OK;
- switch (pSession->scannerState) {
- case FwdLockConv_ScannerState_WantsMimeHeaderNameStart:
- if (FwdLockConv_IsMimeHeaderNameChar(ch)) {
- pSession->mimeHeaderName.length = 0;
- status = FwdLockConv_StringAppend(&pSession->mimeHeaderName, tolower(ch));
- if (status == FwdLockConv_Status_OK) {
- pSession->scannerState = FwdLockConv_ScannerState_WantsMimeHeaderName;
- }
- } else if (ch == '\r') {
- pSession->scannerState = FwdLockConv_ScannerState_WantsMimeHeadersEnd;
- } else if (!FwdLockConv_IsWhitespace(ch)) {
- status = FwdLockConv_Status_SyntaxError;
- }
- break;
- case FwdLockConv_ScannerState_WantsMimeHeaderName:
- if (FwdLockConv_IsMimeHeaderNameChar(ch)) {
- status = FwdLockConv_StringAppend(&pSession->mimeHeaderName, tolower(ch));
- } else if (ch == ':') {
- status = FwdLockConv_RecognizeMimeHeaderName(pSession);
- } else if (FwdLockConv_IsWhitespace(ch)) {
- pSession->scannerState = FwdLockConv_ScannerState_WantsMimeHeaderNameEnd;
- } else {
- status = FwdLockConv_Status_SyntaxError;
- }
- break;
- case FwdLockConv_ScannerState_WantsMimeHeaderNameEnd:
- if (ch == ':') {
- status = FwdLockConv_RecognizeMimeHeaderName(pSession);
- } else if (!FwdLockConv_IsWhitespace(ch)) {
- status = FwdLockConv_Status_SyntaxError;
- }
- break;
- case FwdLockConv_ScannerState_WantsContentTypeStart:
- if (FwdLockConv_IsMimeHeaderValueChar(ch)) {
- status = FwdLockConv_StringAppend(&pSession->contentType, tolower(ch));
- if (status == FwdLockConv_Status_OK) {
- pSession->scannerState = FwdLockConv_ScannerState_WantsContentType;
- }
- } else if (!FwdLockConv_IsWhitespace(ch)) {
- status = FwdLockConv_Status_SyntaxError;
- }
- break;
- case FwdLockConv_ScannerState_WantsContentType:
- if (FwdLockConv_IsMimeHeaderValueChar(ch)) {
- status = FwdLockConv_StringAppend(&pSession->contentType, tolower(ch));
- } else if (ch == ';') {
- pSession->scannerState = FwdLockConv_ScannerState_WantsCR;
- } else if (ch == '\r') {
- pSession->scannerState = FwdLockConv_ScannerState_WantsLF;
- } else if (FwdLockConv_IsWhitespace(ch)) {
- pSession->scannerState = FwdLockConv_ScannerState_WantsMimeHeaderValueEnd;
- } else {
- status = FwdLockConv_Status_SyntaxError;
- }
- break;
- case FwdLockConv_ScannerState_WantsContentTransferEncodingStart:
- if (ch == 'b' || ch == 'B') {
- pSession->scannerState = FwdLockConv_ScannerState_Wants_A_OR_I;
- } else if (ch == '7' || ch == '8') {
- pSession->scannerState = FwdLockConv_ScannerState_Wants_B;
- } else if (!FwdLockConv_IsWhitespace(ch)) {
- status = FwdLockConv_Status_UnsupportedContentTransferEncoding;
- }
- break;
- case FwdLockConv_ScannerState_Wants_A_OR_I:
- if (ch == 'i' || ch == 'I') {
- pSession->scannerState = FwdLockConv_ScannerState_Wants_N;
- } else if (ch == 'a' || ch == 'A') {
- pSession->scannerState = FwdLockConv_ScannerState_Wants_S;
- } else {
- status = FwdLockConv_Status_UnsupportedContentTransferEncoding;
- }
- break;
- case FwdLockConv_ScannerState_Wants_N:
- if (ch == 'n' || ch == 'N') {
- pSession->scannerState = FwdLockConv_ScannerState_Wants_A;
- } else {
- status = FwdLockConv_Status_UnsupportedContentTransferEncoding;
- }
- break;
- case FwdLockConv_ScannerState_Wants_A:
- if (ch == 'a' || ch == 'A') {
- pSession->scannerState = FwdLockConv_ScannerState_Wants_R;
- } else {
- status = FwdLockConv_Status_UnsupportedContentTransferEncoding;
- }
- break;
- case FwdLockConv_ScannerState_Wants_R:
- if (ch == 'r' || ch == 'R') {
- pSession->scannerState = FwdLockConv_ScannerState_Wants_Y;
- } else {
- status = FwdLockConv_Status_UnsupportedContentTransferEncoding;
- }
- break;
- case FwdLockConv_ScannerState_Wants_Y:
- if (ch == 'y' || ch == 'Y') {
- pSession->contentTransferEncoding = FwdLockConv_ContentTransferEncoding_Binary;
- pSession->scannerState = FwdLockConv_ScannerState_WantsContentTransferEncodingEnd;
- } else {
- status = FwdLockConv_Status_UnsupportedContentTransferEncoding;
- }
- break;
- case FwdLockConv_ScannerState_Wants_S:
- if (ch == 's' || ch == 'S') {
- pSession->scannerState = FwdLockConv_ScannerState_Wants_E;
- } else {
- status = FwdLockConv_Status_UnsupportedContentTransferEncoding;
- }
- break;
- case FwdLockConv_ScannerState_Wants_E:
- if (ch == 'e' || ch == 'E') {
- pSession->scannerState = FwdLockConv_ScannerState_Wants_6;
- } else {
- status = FwdLockConv_Status_UnsupportedContentTransferEncoding;
- }
- break;
- case FwdLockConv_ScannerState_Wants_6:
- if (ch == '6') {
- pSession->scannerState = FwdLockConv_ScannerState_Wants_4;
- } else {
- status = FwdLockConv_Status_UnsupportedContentTransferEncoding;
- }
- break;
- case FwdLockConv_ScannerState_Wants_4:
- if (ch == '4') {
- pSession->contentTransferEncoding = FwdLockConv_ContentTransferEncoding_Base64;
- pSession->scannerState = FwdLockConv_ScannerState_WantsContentTransferEncodingEnd;
- } else {
- status = FwdLockConv_Status_UnsupportedContentTransferEncoding;
- }
- break;
- case FwdLockConv_ScannerState_Wants_B:
- if (ch == 'b' || ch == 'B') {
- pSession->scannerState = FwdLockConv_ScannerState_Wants_I;
- } else {
- status = FwdLockConv_Status_UnsupportedContentTransferEncoding;
- }
- break;
- case FwdLockConv_ScannerState_Wants_I:
- if (ch == 'i' || ch == 'I') {
- pSession->scannerState = FwdLockConv_ScannerState_Wants_T;
- } else {
- status = FwdLockConv_Status_UnsupportedContentTransferEncoding;
- }
- break;
- case FwdLockConv_ScannerState_Wants_T:
- if (ch == 't' || ch == 'T') {
- pSession->contentTransferEncoding = FwdLockConv_ContentTransferEncoding_Binary;
- pSession->scannerState = FwdLockConv_ScannerState_WantsContentTransferEncodingEnd;
- } else {
- status = FwdLockConv_Status_UnsupportedContentTransferEncoding;
- }
- break;
- case FwdLockConv_ScannerState_WantsContentTransferEncodingEnd:
- if (ch == ';') {
- pSession->scannerState = FwdLockConv_ScannerState_WantsCR;
- } else if (ch == '\r') {
- pSession->scannerState = FwdLockConv_ScannerState_WantsLF;
- } else if (FwdLockConv_IsWhitespace(ch)) {
- pSession->scannerState = FwdLockConv_ScannerState_WantsMimeHeaderValueEnd;
- } else {
- status = FwdLockConv_Status_UnsupportedContentTransferEncoding;
- }
- break;
- case FwdLockConv_ScannerState_WantsMimeHeaderValueEnd:
- if (ch == ';') {
- pSession->scannerState = FwdLockConv_ScannerState_WantsCR;
- } else if (ch == '\r') {
- pSession->scannerState = FwdLockConv_ScannerState_WantsLF;
- } else if (!FwdLockConv_IsWhitespace(ch)) {
- status = FwdLockConv_Status_SyntaxError;
- }
- break;
- case FwdLockConv_ScannerState_WantsCR:
- if (ch == '\r') {
- pSession->scannerState = FwdLockConv_ScannerState_WantsLF;
- }
- break;
- case FwdLockConv_ScannerState_WantsLF:
- if (ch == '\n') {
- pSession->scannerState = FwdLockConv_ScannerState_WantsMimeHeaderNameStart;
- } else {
- status = FwdLockConv_Status_SyntaxError;
- }
- break;
- case FwdLockConv_ScannerState_WantsMimeHeadersEnd:
- if (ch == '\n') {
- status = FwdLockConv_ApplyDefaults(pSession);
- if (status == FwdLockConv_Status_OK) {
- status = FwdLockConv_VerifyContentType(pSession);
- }
- if (status == FwdLockConv_Status_OK) {
- status = FwdLockConv_WriteHeader(pSession, pOutput);
- }
- if (status == FwdLockConv_Status_OK) {
- if (pSession->contentTransferEncoding ==
- FwdLockConv_ContentTransferEncoding_Binary) {
- pSession->parserState = FwdLockConv_ParserState_WantsBinaryEncodedData;
- } else {
- pSession->parserState = FwdLockConv_ParserState_WantsBase64EncodedData;
- }
- pSession->scannerState = FwdLockConv_ScannerState_WantsByte1;
- }
- } else {
- status = FwdLockConv_Status_SyntaxError;
- }
- break;
- default:
- status = FwdLockConv_Status_ProgramError;
- break;
- }
- return status;
-}
-
-/**
- * Increments the counter, treated as a 16-byte little-endian number, by one.
- *
- * @param[in,out] pSession A reference to a converter session.
- */
-static void FwdLockConv_IncrementCounter(FwdLockConv_Session_t *pSession) {
- size_t i = 0;
- while ((++pSession->counter[i] == 0) && (++i < AES_BLOCK_SIZE))
- ;
-}
-
-/**
- * Encrypts the given character and writes it to the output buffer.
- *
- * @param[in,out] pSession A reference to a converter session.
- * @param[in] ch The character to encrypt and write.
- * @param[in,out] pOutput The output from the conversion process.
- *
- * @return A status code.
- */
-static FwdLockConv_Status_t FwdLockConv_WriteEncryptedChar(FwdLockConv_Session_t *pSession,
- unsigned char ch,
- FwdLockConv_Output_t *pOutput) {
- if (pOutput->fromConvertData.numBytes == pSession->outputBufferSize) {
- void *pBuffer;
- pSession->outputBufferSize += OUTPUT_BUFFER_SIZE_INCREMENT;
- pBuffer = realloc(pOutput->fromConvertData.pBuffer, pSession->outputBufferSize);
- if (pBuffer == NULL) {
- return FwdLockConv_Status_OutOfMemory;
- }
- pOutput->fromConvertData.pBuffer = pBuffer;
- }
- if (++pSession->keyStreamIndex == AES_BLOCK_SIZE) {
- FwdLockConv_IncrementCounter(pSession);
- pSession->keyStreamIndex = 0;
- }
- if (pSession->keyStreamIndex == 0) {
- AES_encrypt(pSession->counter, pSession->keyStream, &pSession->encryptionRoundKeys);
- }
- ch ^= pSession->keyStream[pSession->keyStreamIndex];
- ((unsigned char *)pOutput->fromConvertData.pBuffer)[pOutput->fromConvertData.numBytes++] = ch;
- ++pSession->numDataBytes;
- return FwdLockConv_Status_OK;
-}
-
-/**
- * Matches binary-encoded content data and encrypts it, while looking out for the close delimiter.
- *
- * @param[in,out] pSession A reference to a converter session.
- * @param[in] ch A character.
- * @param[in,out] pOutput The output from the conversion process.
- *
- * @return A status code.
- */
-static FwdLockConv_Status_t FwdLockConv_MatchBinaryEncodedData(FwdLockConv_Session_t *pSession,
- int ch,
- FwdLockConv_Output_t *pOutput) {
- FwdLockConv_Status_t status = FwdLockConv_Status_OK;
- switch (pSession->scannerState) {
- case FwdLockConv_ScannerState_WantsByte1:
- if (ch != pSession->delimiter[pSession->delimiterMatchPos]) {
- // The partial match of the delimiter turned out to be spurious. Flush the matched bytes
- // to the output buffer and start over.
- size_t i;
- for (i = 0; i < pSession->delimiterMatchPos; ++i) {
- status = FwdLockConv_WriteEncryptedChar(pSession, pSession->delimiter[i], pOutput);
- if (status != FwdLockConv_Status_OK) {
- return status;
- }
- }
- pSession->delimiterMatchPos = 0;
- }
- if (ch != pSession->delimiter[pSession->delimiterMatchPos]) {
- // The current character isn't part of the delimiter. Write it to the output buffer.
- status = FwdLockConv_WriteEncryptedChar(pSession, ch, pOutput);
- } else if (++pSession->delimiterMatchPos == pSession->delimiterLength) {
- // The entire delimiter has been matched. The only valid characters now are the "--"
- // that complete the close delimiter (no more message parts are expected).
- pSession->scannerState = FwdLockConv_ScannerState_WantsFirstDash;
- }
- break;
- case FwdLockConv_ScannerState_WantsFirstDash:
- if (ch == '-') {
- pSession->scannerState = FwdLockConv_ScannerState_WantsSecondDash;
- } else {
- status = FwdLockConv_Status_SyntaxError;
- }
- break;
- case FwdLockConv_ScannerState_WantsSecondDash:
- if (ch == '-') {
- pSession->parserState = FwdLockConv_ParserState_Done;
- } else {
- status = FwdLockConv_Status_SyntaxError;
- }
- break;
- default:
- status = FwdLockConv_Status_ProgramError;
- break;
- }
- return status;
-}
-
-/**
- * Checks whether a given character is valid in base64-encoded data.
- *
- * @param[in] ch The character to check.
- *
- * @return A Boolean value indicating whether the given character is valid in base64-encoded data.
- */
-static int FwdLockConv_IsBase64Char(int ch) {
- return 0 <= ch && ch <= 'z' && base64Values[ch] >= 0;
-}
-
-/**
- * Matches base64-encoded content data and encrypts it, while looking out for the close delimiter.
- *
- * @param[in,out] pSession A reference to a converter session.
- * @param[in] ch A character.
- * @param[in,out] pOutput The output from the conversion process.
- *
- * @return A status code.
- */
-static FwdLockConv_Status_t FwdLockConv_MatchBase64EncodedData(FwdLockConv_Session_t *pSession,
- int ch,
- FwdLockConv_Output_t *pOutput) {
- FwdLockConv_Status_t status = FwdLockConv_Status_OK;
- switch (pSession->scannerState) {
- case FwdLockConv_ScannerState_WantsByte1:
- case FwdLockConv_ScannerState_WantsByte1_AfterCRLF:
- if (FwdLockConv_IsBase64Char(ch)) {
- pSession->ch = base64Values[ch] << 2;
- pSession->scannerState = FwdLockConv_ScannerState_WantsByte2;
- } else if (ch == '\r') {
- pSession->savedScannerState = FwdLockConv_ScannerState_WantsByte1_AfterCRLF;
- pSession->scannerState = FwdLockConv_ScannerState_WantsLF;
- } else if (ch == '-') {
- if (pSession->scannerState == FwdLockConv_ScannerState_WantsByte1_AfterCRLF) {
- pSession->delimiterMatchPos = 3;
- pSession->scannerState = FwdLockConv_ScannerState_WantsDelimiter;
- } else {
- status = FwdLockConv_Status_SyntaxError;
- }
- } else if (!FwdLockConv_IsWhitespace(ch)) {
- status = FwdLockConv_Status_SyntaxError;
- }
- break;
- case FwdLockConv_ScannerState_WantsByte2:
- if (FwdLockConv_IsBase64Char(ch)) {
- pSession->ch |= base64Values[ch] >> 4;
- status = FwdLockConv_WriteEncryptedChar(pSession, pSession->ch, pOutput);
- if (status == FwdLockConv_Status_OK) {
- pSession->ch = base64Values[ch] << 4;
- pSession->scannerState = FwdLockConv_ScannerState_WantsByte3;
- }
- } else if (ch == '\r') {
- pSession->savedScannerState = pSession->scannerState;
- pSession->scannerState = FwdLockConv_ScannerState_WantsLF;
- } else if (!FwdLockConv_IsWhitespace(ch)) {
- status = FwdLockConv_Status_SyntaxError;
- }
- break;
- case FwdLockConv_ScannerState_WantsByte3:
- if (FwdLockConv_IsBase64Char(ch)) {
- pSession->ch |= base64Values[ch] >> 2;
- status = FwdLockConv_WriteEncryptedChar(pSession, pSession->ch, pOutput);
- if (status == FwdLockConv_Status_OK) {
- pSession->ch = base64Values[ch] << 6;
- pSession->scannerState = FwdLockConv_ScannerState_WantsByte4;
- }
- } else if (ch == '\r') {
- pSession->savedScannerState = pSession->scannerState;
- pSession->scannerState = FwdLockConv_ScannerState_WantsLF;
- } else if (ch == '=') {
- pSession->scannerState = FwdLockConv_ScannerState_WantsPadding;
- } else if (!FwdLockConv_IsWhitespace(ch)) {
- status = FwdLockConv_Status_SyntaxError;
- }
- break;
- case FwdLockConv_ScannerState_WantsByte4:
- if (FwdLockConv_IsBase64Char(ch)) {
- pSession->ch |= base64Values[ch];
- status = FwdLockConv_WriteEncryptedChar(pSession, pSession->ch, pOutput);
- if (status == FwdLockConv_Status_OK) {
- pSession->scannerState = FwdLockConv_ScannerState_WantsByte1;
- }
- } else if (ch == '\r') {
- pSession->savedScannerState = pSession->scannerState;
- pSession->scannerState = FwdLockConv_ScannerState_WantsLF;
- } else if (ch == '=') {
- pSession->scannerState = FwdLockConv_ScannerState_WantsWhitespace;
- } else if (!FwdLockConv_IsWhitespace(ch)) {
- status = FwdLockConv_Status_SyntaxError;
- }
- break;
- case FwdLockConv_ScannerState_WantsLF:
- if (ch == '\n') {
- pSession->scannerState = pSession->savedScannerState;
- } else {
- status = FwdLockConv_Status_SyntaxError;
- }
- break;
- case FwdLockConv_ScannerState_WantsPadding:
- if (ch == '=') {
- pSession->scannerState = FwdLockConv_ScannerState_WantsWhitespace;
- } else {
- status = FwdLockConv_Status_SyntaxError;
- }
- break;
- case FwdLockConv_ScannerState_WantsWhitespace:
- case FwdLockConv_ScannerState_WantsWhitespace_AfterCRLF:
- if (ch == '\r') {
- pSession->savedScannerState = FwdLockConv_ScannerState_WantsWhitespace_AfterCRLF;
- pSession->scannerState = FwdLockConv_ScannerState_WantsLF;
- } else if (ch == '-') {
- if (pSession->scannerState == FwdLockConv_ScannerState_WantsWhitespace_AfterCRLF) {
- pSession->delimiterMatchPos = 3;
- pSession->scannerState = FwdLockConv_ScannerState_WantsDelimiter;
- } else {
- status = FwdLockConv_Status_SyntaxError;
- }
- } else if (FwdLockConv_IsWhitespace(ch)) {
- pSession->scannerState = FwdLockConv_ScannerState_WantsWhitespace;
- } else {
- status = FwdLockConv_Status_SyntaxError;
- }
- break;
- case FwdLockConv_ScannerState_WantsDelimiter:
- if (ch != pSession->delimiter[pSession->delimiterMatchPos]) {
- status = FwdLockConv_Status_SyntaxError;
- } else if (++pSession->delimiterMatchPos == pSession->delimiterLength) {
- pSession->scannerState = FwdLockConv_ScannerState_WantsFirstDash;
- }
- break;
- case FwdLockConv_ScannerState_WantsFirstDash:
- if (ch == '-') {
- pSession->scannerState = FwdLockConv_ScannerState_WantsSecondDash;
- } else {
- status = FwdLockConv_Status_SyntaxError;
- }
- break;
- case FwdLockConv_ScannerState_WantsSecondDash:
- if (ch == '-') {
- pSession->parserState = FwdLockConv_ParserState_Done;
- } else {
- status = FwdLockConv_Status_SyntaxError;
- }
- break;
- default:
- status = FwdLockConv_Status_ProgramError;
- break;
- }
- return status;
-}
-
-/**
- * Pushes a single character into the converter's state machine.
- *
- * @param[in,out] pSession A reference to a converter session.
- * @param[in] ch A character.
- * @param[in,out] pOutput The output from the conversion process.
- *
- * @return A status code.
- */
-static FwdLockConv_Status_t FwdLockConv_PushChar(FwdLockConv_Session_t *pSession,
- int ch,
- FwdLockConv_Output_t *pOutput) {
- FwdLockConv_Status_t status;
- ++pSession->numCharsConsumed;
- switch (pSession->parserState) {
- case FwdLockConv_ParserState_WantsOpenDelimiter:
- status = FwdLockConv_MatchOpenDelimiter(pSession, ch);
- break;
- case FwdLockConv_ParserState_WantsMimeHeaders:
- status = FwdLockConv_MatchMimeHeaders(pSession, ch, pOutput);
- break;
- case FwdLockConv_ParserState_WantsBinaryEncodedData:
- status = FwdLockConv_MatchBinaryEncodedData(pSession, ch, pOutput);
- break;
- case FwdLockConv_ParserState_WantsBase64EncodedData:
- if (ch == '\n' && pSession->scannerState != FwdLockConv_ScannerState_WantsLF) {
- // Repair base64-encoded data that doesn't have carriage returns in its line breaks.
- status = FwdLockConv_MatchBase64EncodedData(pSession, '\r', pOutput);
- if (status != FwdLockConv_Status_OK) {
- break;
- }
- }
- status = FwdLockConv_MatchBase64EncodedData(pSession, ch, pOutput);
- break;
- case FwdLockConv_ParserState_Done:
- status = FwdLockConv_Status_OK;
- break;
- default:
- status = FwdLockConv_Status_ProgramError;
- break;
- }
- return status;
-}
-
-FwdLockConv_Status_t FwdLockConv_OpenSession(int *pSessionId, FwdLockConv_Output_t *pOutput) {
- FwdLockConv_Status_t status;
- if (pSessionId == NULL || pOutput == NULL) {
- status = FwdLockConv_Status_InvalidArgument;
- } else {
- *pSessionId = FwdLockConv_AcquireSession();
- if (*pSessionId < 0) {
- status = FwdLockConv_Status_TooManySessions;
- } else {
- FwdLockConv_Session_t *pSession = sessionPtrs[*pSessionId];
- pSession->encryptedSessionKeyLength = FwdLockGlue_GetEncryptedKeyLength(KEY_SIZE);
- if (pSession->encryptedSessionKeyLength < AES_BLOCK_SIZE) {
- // The encrypted session key is used as the CTR-mode nonce, so it must be at least
- // the size of a single AES block.
- status = FwdLockConv_Status_ProgramError;
- } else {
- pSession->pEncryptedSessionKey = malloc(pSession->encryptedSessionKeyLength);
- if (pSession->pEncryptedSessionKey == NULL) {
- status = FwdLockConv_Status_OutOfMemory;
- } else {
- if (!FwdLockGlue_GetRandomNumber(pSession->sessionKey, KEY_SIZE)) {
- status = FwdLockConv_Status_RandomNumberGenerationFailed;
- } else if (!FwdLockGlue_EncryptKey(pSession->sessionKey, KEY_SIZE,
- pSession->pEncryptedSessionKey,
- pSession->encryptedSessionKeyLength)) {
- status = FwdLockConv_Status_KeyEncryptionFailed;
- } else {
- status = FwdLockConv_DeriveKeys(pSession);
- }
- if (status == FwdLockConv_Status_OK) {
- memset(pSession->sessionKey, 0, KEY_SIZE); // Zero out key data.
- memcpy(pSession->counter, pSession->pEncryptedSessionKey, AES_BLOCK_SIZE);
- pSession->parserState = FwdLockConv_ParserState_WantsOpenDelimiter;
- pSession->scannerState = FwdLockConv_ScannerState_WantsFirstDash;
- pSession->numCharsConsumed = 0;
- pSession->delimiterMatchPos = 0;
- pSession->mimeHeaderName = nullString;
- pSession->contentType = nullString;
- pSession->contentTransferEncoding =
- FwdLockConv_ContentTransferEncoding_Undefined;
- pSession->keyStreamIndex = -1;
- pOutput->fromConvertData.pBuffer = NULL;
- pOutput->fromConvertData.errorPos = INVALID_OFFSET;
- } else {
- free(pSession->pEncryptedSessionKey);
- }
- }
- }
- if (status != FwdLockConv_Status_OK) {
- FwdLockConv_ReleaseSession(*pSessionId);
- *pSessionId = -1;
- }
- }
- }
- return status;
-}
-
-FwdLockConv_Status_t FwdLockConv_ConvertData(int sessionId,
- const void *pBuffer,
- size_t numBytes,
- FwdLockConv_Output_t *pOutput) {
- FwdLockConv_Status_t status;
- if (!FwdLockConv_IsValidSession(sessionId) || pBuffer == NULL || pOutput == NULL) {
- status = FwdLockConv_Status_InvalidArgument;
- } else {
- size_t i;
- FwdLockConv_Session_t *pSession = sessionPtrs[sessionId];
- pSession->dataOffset = 0;
- pSession->numDataBytes = 0;
- pOutput->fromConvertData.numBytes = 0;
- status = FwdLockConv_Status_OK;
-
- for (i = 0; i < numBytes; ++i) {
- status = FwdLockConv_PushChar(pSession, ((char *)pBuffer)[i], pOutput);
- if (status != FwdLockConv_Status_OK) {
- break;
- }
- }
- if (status == FwdLockConv_Status_OK) {
- // Update the data signature.
- HMAC_Update(&pSession->signingContext,
- &((unsigned char *)pOutput->fromConvertData.pBuffer)[pSession->dataOffset],
- pSession->numDataBytes);
- } else if (status == FwdLockConv_Status_SyntaxError) {
- pOutput->fromConvertData.errorPos = pSession->numCharsConsumed;
- }
- }
- return status;
-}
-
-FwdLockConv_Status_t FwdLockConv_CloseSession(int sessionId, FwdLockConv_Output_t *pOutput) {
- FwdLockConv_Status_t status;
- if (!FwdLockConv_IsValidSession(sessionId) || pOutput == NULL) {
- status = FwdLockConv_Status_InvalidArgument;
- } else {
- FwdLockConv_Session_t *pSession = sessionPtrs[sessionId];
- free(pOutput->fromConvertData.pBuffer);
- if (pSession->parserState != FwdLockConv_ParserState_Done) {
- pOutput->fromCloseSession.errorPos = pSession->numCharsConsumed;
- status = FwdLockConv_Status_SyntaxError;
- } else {
- // Finalize the data signature.
- unsigned int signatureSize = SHA1_HASH_SIZE;
- HMAC_Final(&pSession->signingContext, pOutput->fromCloseSession.signatures,
- &signatureSize);
- if (signatureSize != SHA1_HASH_SIZE) {
- status = FwdLockConv_Status_ProgramError;
- } else {
- // Calculate the header signature, which is a signature of the rest of the header
- // including the data signature.
- HMAC_Init_ex(&pSession->signingContext, NULL, KEY_SIZE, NULL, NULL);
- HMAC_Update(&pSession->signingContext, pSession->topHeader, TOP_HEADER_SIZE);
- HMAC_Update(&pSession->signingContext, (unsigned char *)pSession->contentType.ptr,
- pSession->contentType.length);
- HMAC_Update(&pSession->signingContext, pSession->pEncryptedSessionKey,
- pSession->encryptedSessionKeyLength);
- HMAC_Update(&pSession->signingContext, pOutput->fromCloseSession.signatures,
- SHA1_HASH_SIZE);
- HMAC_Final(&pSession->signingContext,
- &pOutput->fromCloseSession.signatures[SHA1_HASH_SIZE], &signatureSize);
- if (signatureSize != SHA1_HASH_SIZE) {
- status = FwdLockConv_Status_ProgramError;
- } else {
- pOutput->fromCloseSession.fileOffset = TOP_HEADER_SIZE +
- pSession->contentType.length + pSession->encryptedSessionKeyLength;
- status = FwdLockConv_Status_OK;
- }
- }
- pOutput->fromCloseSession.errorPos = INVALID_OFFSET;
- }
- free(pSession->mimeHeaderName.ptr);
- free(pSession->contentType.ptr);
- free(pSession->pEncryptedSessionKey);
- HMAC_CTX_cleanup(&pSession->signingContext);
- FwdLockConv_ReleaseSession(sessionId);
- }
- return status;
-}
-
-FwdLockConv_Status_t FwdLockConv_ConvertOpenFile(int inputFileDesc,
- FwdLockConv_ReadFunc_t *fpReadFunc,
- int outputFileDesc,
- FwdLockConv_WriteFunc_t *fpWriteFunc,
- FwdLockConv_LSeekFunc_t *fpLSeekFunc,
- off64_t *pErrorPos) {
- FwdLockConv_Status_t status;
- if (pErrorPos != NULL) {
- *pErrorPos = INVALID_OFFSET;
- }
- if (fpReadFunc == NULL || fpWriteFunc == NULL || fpLSeekFunc == NULL || inputFileDesc < 0 ||
- outputFileDesc < 0) {
- status = FwdLockConv_Status_InvalidArgument;
- } else {
- char *pReadBuffer = malloc(READ_BUFFER_SIZE);
- if (pReadBuffer == NULL) {
- status = FwdLockConv_Status_OutOfMemory;
- } else {
- int sessionId;
- FwdLockConv_Output_t output;
- status = FwdLockConv_OpenSession(&sessionId, &output);
- if (status == FwdLockConv_Status_OK) {
- ssize_t numBytesRead;
- FwdLockConv_Status_t closeStatus;
- while ((numBytesRead =
- fpReadFunc(inputFileDesc, pReadBuffer, READ_BUFFER_SIZE)) > 0) {
- status = FwdLockConv_ConvertData(sessionId, pReadBuffer, (size_t)numBytesRead,
- &output);
- if (status == FwdLockConv_Status_OK) {
- if (output.fromConvertData.pBuffer != NULL &&
- output.fromConvertData.numBytes > 0) {
- ssize_t numBytesWritten = fpWriteFunc(outputFileDesc,
- output.fromConvertData.pBuffer,
- output.fromConvertData.numBytes);
- if (numBytesWritten != (ssize_t)output.fromConvertData.numBytes) {
- status = FwdLockConv_Status_FileWriteError;
- break;
- }
- }
- } else {
- if (status == FwdLockConv_Status_SyntaxError && pErrorPos != NULL) {
- *pErrorPos = output.fromConvertData.errorPos;
- }
- break;
- }
- } // end while
- if (numBytesRead < 0) {
- status = FwdLockConv_Status_FileReadError;
- }
- closeStatus = FwdLockConv_CloseSession(sessionId, &output);
- if (status == FwdLockConv_Status_OK) {
- if (closeStatus != FwdLockConv_Status_OK) {
- if (closeStatus == FwdLockConv_Status_SyntaxError && pErrorPos != NULL) {
- *pErrorPos = output.fromCloseSession.errorPos;
- }
- status = closeStatus;
- } else if (fpLSeekFunc(outputFileDesc, output.fromCloseSession.fileOffset,
- SEEK_SET) < 0) {
- status = FwdLockConv_Status_FileSeekError;
- } else if (fpWriteFunc(outputFileDesc, output.fromCloseSession.signatures,
- FWD_LOCK_SIGNATURES_SIZE) != FWD_LOCK_SIGNATURES_SIZE) {
- status = FwdLockConv_Status_FileWriteError;
- }
- }
- }
- free(pReadBuffer);
- }
- }
- return status;
-}
-
-FwdLockConv_Status_t FwdLockConv_ConvertFile(const char *pInputFilename,
- const char *pOutputFilename,
- off64_t *pErrorPos) {
- FwdLockConv_Status_t status;
- if (pErrorPos != NULL) {
- *pErrorPos = INVALID_OFFSET;
- }
- if (pInputFilename == NULL || pOutputFilename == NULL) {
- status = FwdLockConv_Status_InvalidArgument;
- } else {
- int inputFileDesc = open(pInputFilename, O_RDONLY);
- if (inputFileDesc < 0) {
- status = FwdLockConv_Status_FileNotFound;
- } else {
- int outputFileDesc = open(pOutputFilename, O_CREAT | O_TRUNC | O_WRONLY,
- S_IRUSR | S_IWUSR | S_IRGRP | S_IROTH);
- if (outputFileDesc < 0) {
- status = FwdLockConv_Status_FileCreationFailed;
- } else {
- status = FwdLockConv_ConvertOpenFile(inputFileDesc, read, outputFileDesc, write,
- lseek64, pErrorPos);
- if (close(outputFileDesc) == 0 && status != FwdLockConv_Status_OK) {
- remove(pOutputFilename);
- }
- }
- (void)close(inputFileDesc);
- }
- }
- return status;
-}
diff --git a/drm/libdrmframework/plugins/forward-lock/internal-format/converter/FwdLockConv.h b/drm/libdrmframework/plugins/forward-lock/internal-format/converter/FwdLockConv.h
deleted file mode 100644
index e20c0c3..0000000
--- a/drm/libdrmframework/plugins/forward-lock/internal-format/converter/FwdLockConv.h
+++ /dev/null
@@ -1,282 +0,0 @@
-/*
- * Copyright (C) 2010 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.
- */
-
-#ifndef __FWDLOCKCONV_H__
-#define __FWDLOCKCONV_H__
-
-#ifdef __cplusplus
-extern "C" {
-#endif
-
-#include <sys/types.h>
-
-/**
- * The size of the data and header signatures combined. The signatures are adjacent to each other in
- * the produced output file.
- */
-#define FWD_LOCK_SIGNATURES_SIZE (2 * 20)
-
-/**
- * Data type for the output from FwdLockConv_ConvertData.
- */
-typedef struct FwdLockConv_ConvertData_Output {
- /// The converted data.
- void *pBuffer;
-
- /// The size of the converted data.
- size_t numBytes;
-
- /// The file position where the error occurred, in the case of a syntax error.
- off64_t errorPos;
-} FwdLockConv_ConvertData_Output_t;
-
-/**
- * Data type for the output from FwdLockConv_CloseSession.
- */
-typedef struct FwdLockConv_CloseSession_Output {
- /// The final set of signatures.
- unsigned char signatures[FWD_LOCK_SIGNATURES_SIZE];
-
- /// The offset in the produced output file where the signatures are located.
- off64_t fileOffset;
-
- /// The file position where the error occurred, in the case of a syntax error.
- off64_t errorPos;
-} FwdLockConv_CloseSession_Output_t;
-
-/**
- * Data type for the output from the conversion process.
- */
-typedef union FwdLockConv_Output {
- FwdLockConv_ConvertData_Output_t fromConvertData;
- FwdLockConv_CloseSession_Output_t fromCloseSession;
-} FwdLockConv_Output_t;
-
-/**
- * Data type for the Posix-style read function used by the converter in pull mode.
- *
- * @param[in] fileDesc The file descriptor of a file opened for reading.
- * @param[out] pBuffer A reference to the buffer that should receive the read data.
- * @param[in] numBytes The number of bytes to read.
- *
- * @return The number of bytes read.
- * @retval -1 Failure.
- */
-typedef ssize_t FwdLockConv_ReadFunc_t(int fileDesc, void *pBuffer, size_t numBytes);
-
-/**
- * Data type for the Posix-style write function used by the converter in pull mode.
- *
- * @param[in] fileDesc The file descriptor of a file opened for writing.
- * @param[in] pBuffer A reference to the buffer containing the data to be written.
- * @param[in] numBytes The number of bytes to write.
- *
- * @return The number of bytes written.
- * @retval -1 Failure.
- */
-typedef ssize_t FwdLockConv_WriteFunc_t(int fileDesc, const void *pBuffer, size_t numBytes);
-
-/**
- * Data type for the Posix-style lseek function used by the converter in pull mode.
- *
- * @param[in] fileDesc The file descriptor of a file opened for writing.
- * @param[in] offset The offset with which to update the file position.
- * @param[in] whence One of SEEK_SET, SEEK_CUR, and SEEK_END.
- *
- * @return The new file position.
- * @retval ((off64_t)-1) Failure.
- */
-typedef off64_t FwdLockConv_LSeekFunc_t(int fileDesc, off64_t offset, int whence);
-
-/**
- * The status codes returned by the converter functions.
- */
-typedef enum FwdLockConv_Status {
- /// The operation was successful.
- FwdLockConv_Status_OK = 0,
-
- /// An actual argument to the function is invalid (a program error on the caller's part).
- FwdLockConv_Status_InvalidArgument = 1,
-
- /// There is not enough free dynamic memory to complete the operation.
- FwdLockConv_Status_OutOfMemory = 2,
-
- /// An error occurred while opening the input file.
- FwdLockConv_Status_FileNotFound = 3,
-
- /// An error occurred while creating the output file.
- FwdLockConv_Status_FileCreationFailed = 4,
-
- /// An error occurred while reading from the input file.
- FwdLockConv_Status_FileReadError = 5,
-
- /// An error occurred while writing to the output file.
- FwdLockConv_Status_FileWriteError = 6,
-
- /// An error occurred while seeking to a new file position within the output file.
- FwdLockConv_Status_FileSeekError = 7,
-
- /// The input file is not a syntactically correct OMA DRM v1 Forward Lock file.
- FwdLockConv_Status_SyntaxError = 8,
-
- /// Support for this DRM file format has been disabled in the current product configuration.
- FwdLockConv_Status_UnsupportedFileFormat = 9,
-
- /// The content transfer encoding is not one of "binary", "base64", "7bit", or "8bit"
- /// (case-insensitive).
- FwdLockConv_Status_UnsupportedContentTransferEncoding = 10,
-
- /// The generation of a random number failed.
- FwdLockConv_Status_RandomNumberGenerationFailed = 11,
-
- /// Key encryption failed.
- FwdLockConv_Status_KeyEncryptionFailed = 12,
-
- /// The calculation of a keyed hash for integrity protection failed.
- FwdLockConv_Status_IntegrityProtectionFailed = 13,
-
- /// There are too many ongoing sessions for another one to be opened.
- FwdLockConv_Status_TooManySessions = 14,
-
- /// An unexpected error occurred.
- FwdLockConv_Status_ProgramError = 15
-} FwdLockConv_Status_t;
-
-/**
- * Opens a session for converting an OMA DRM v1 Forward Lock file to the internal Forward Lock file
- * format.
- *
- * @param[out] pSessionId The session ID.
- * @param[out] pOutput The output from the conversion process (initialized).
- *
- * @return A status code.
- * @retval FwdLockConv_Status_OK
- * @retval FwdLockConv_Status_InvalidArgument
- * @retval FwdLockConv_Status_TooManySessions
- */
-FwdLockConv_Status_t FwdLockConv_OpenSession(int *pSessionId, FwdLockConv_Output_t *pOutput);
-
-/**
- * Supplies the converter with data to convert. The caller is expected to write the converted data
- * to file. Can be called an arbitrary number of times.
- *
- * @param[in] sessionId The session ID.
- * @param[in] pBuffer A reference to a buffer containing the data to convert.
- * @param[in] numBytes The number of bytes to convert.
- * @param[in,out] pOutput The output from the conversion process (allocated/reallocated).
- *
- * @return A status code.
- * @retval FwdLockConv_Status_OK
- * @retval FwdLockConv_Status_InvalidArgument
- * @retval FwdLockConv_Status_OutOfMemory
- * @retval FwdLockConv_Status_SyntaxError
- * @retval FwdLockConv_Status_UnsupportedFileFormat
- * @retval FwdLockConv_Status_UnsupportedContentTransferEncoding
- * @retval FwdLockConv_Status_RandomNumberGenerationFailed
- * @retval FwdLockConv_Status_KeyEncryptionFailed
- * @retval FwdLockConv_Status_DataEncryptionFailed
- */
-FwdLockConv_Status_t FwdLockConv_ConvertData(int sessionId,
- const void *pBuffer,
- size_t numBytes,
- FwdLockConv_Output_t *pOutput);
-
-/**
- * Closes a session for converting an OMA DRM v1 Forward Lock file to the internal Forward Lock
- * file format. The caller must update the produced output file at the indicated file offset with
- * the final set of signatures.
- *
- * @param[in] sessionId The session ID.
- * @param[in,out] pOutput The output from the conversion process (deallocated and overwritten).
- *
- * @return A status code.
- * @retval FwdLockConv_Status_OK
- * @retval FwdLockConv_Status_InvalidArgument
- * @retval FwdLockConv_Status_OutOfMemory
- * @retval FwdLockConv_Status_IntegrityProtectionFailed
- */
-FwdLockConv_Status_t FwdLockConv_CloseSession(int sessionId, FwdLockConv_Output_t *pOutput);
-
-/**
- * Converts an open OMA DRM v1 Forward Lock file to the internal Forward Lock file format in pull
- * mode.
- *
- * @param[in] inputFileDesc The file descriptor of the open input file.
- * @param[in] fpReadFunc A reference to a read function that can operate on the open input file.
- * @param[in] outputFileDesc The file descriptor of the open output file.
- * @param[in] fpWriteFunc A reference to a write function that can operate on the open output file.
- * @param[in] fpLSeekFunc A reference to an lseek function that can operate on the open output file.
- * @param[out] pErrorPos
- * The file position where the error occurred, in the case of a syntax error. May be NULL.
- *
- * @return A status code.
- * @retval FwdLockConv_Status_OK
- * @retval FwdLockConv_Status_InvalidArgument
- * @retval FwdLockConv_Status_OutOfMemory
- * @retval FwdLockConv_Status_FileReadError
- * @retval FwdLockConv_Status_FileWriteError
- * @retval FwdLockConv_Status_FileSeekError
- * @retval FwdLockConv_Status_SyntaxError
- * @retval FwdLockConv_Status_UnsupportedFileFormat
- * @retval FwdLockConv_Status_UnsupportedContentTransferEncoding
- * @retval FwdLockConv_Status_RandomNumberGenerationFailed
- * @retval FwdLockConv_Status_KeyEncryptionFailed
- * @retval FwdLockConv_Status_DataEncryptionFailed
- * @retval FwdLockConv_Status_IntegrityProtectionFailed
- * @retval FwdLockConv_Status_TooManySessions
- */
-FwdLockConv_Status_t FwdLockConv_ConvertOpenFile(int inputFileDesc,
- FwdLockConv_ReadFunc_t *fpReadFunc,
- int outputFileDesc,
- FwdLockConv_WriteFunc_t *fpWriteFunc,
- FwdLockConv_LSeekFunc_t *fpLSeekFunc,
- off64_t *pErrorPos);
-
-/**
- * Converts an OMA DRM v1 Forward Lock file to the internal Forward Lock file format in pull mode.
- *
- * @param[in] pInputFilename A reference to the input filename.
- * @param[in] pOutputFilename A reference to the output filename.
- * @param[out] pErrorPos
- * The file position where the error occurred, in the case of a syntax error. May be NULL.
- *
- * @return A status code.
- * @retval FwdLockConv_Status_OK
- * @retval FwdLockConv_Status_InvalidArgument
- * @retval FwdLockConv_Status_OutOfMemory
- * @retval FwdLockConv_Status_FileNotFound
- * @retval FwdLockConv_Status_FileCreationFailed
- * @retval FwdLockConv_Status_FileReadError
- * @retval FwdLockConv_Status_FileWriteError
- * @retval FwdLockConv_Status_FileSeekError
- * @retval FwdLockConv_Status_SyntaxError
- * @retval FwdLockConv_Status_UnsupportedFileFormat
- * @retval FwdLockConv_Status_UnsupportedContentTransferEncoding
- * @retval FwdLockConv_Status_RandomNumberGenerationFailed
- * @retval FwdLockConv_Status_KeyEncryptionFailed
- * @retval FwdLockConv_Status_DataEncryptionFailed
- * @retval FwdLockConv_Status_IntegrityProtectionFailed
- * @retval FwdLockConv_Status_TooManySessions
- */
-FwdLockConv_Status_t FwdLockConv_ConvertFile(const char *pInputFilename,
- const char *pOutputFilename,
- off64_t *pErrorPos);
-
-#ifdef __cplusplus
-}
-#endif
-
-#endif // __FWDLOCKCONV_H__
diff --git a/drm/libdrmframework/plugins/forward-lock/internal-format/decoder/Android.mk b/drm/libdrmframework/plugins/forward-lock/internal-format/decoder/Android.mk
deleted file mode 100644
index b625edf..0000000
--- a/drm/libdrmframework/plugins/forward-lock/internal-format/decoder/Android.mk
+++ /dev/null
@@ -1,37 +0,0 @@
-#
-# Copyright (C) 2010 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.
-#
-LOCAL_PATH := $(call my-dir)
-
-include $(CLEAR_VARS)
-
-LOCAL_SRC_FILES := \
- FwdLockFile.c
-
-LOCAL_C_INCLUDES := \
- frameworks/base/drm/libdrmframework/plugins/forward-lock/internal-format/common \
- external/openssl/include
-
-LOCAL_SHARED_LIBRARIES := libcrypto
-
-LOCAL_WHOLE_STATIC_LIBRARIES := libfwdlock-common
-
-LOCAL_STATIC_LIBRARIES := libfwdlock-common
-
-LOCAL_MODULE := libfwdlock-decoder
-
-LOCAL_MODULE_TAGS := optional
-
-include $(BUILD_STATIC_LIBRARY)
diff --git a/drm/libdrmframework/plugins/forward-lock/internal-format/decoder/FwdLockFile.c b/drm/libdrmframework/plugins/forward-lock/internal-format/decoder/FwdLockFile.c
deleted file mode 100644
index dacf00e..0000000
--- a/drm/libdrmframework/plugins/forward-lock/internal-format/decoder/FwdLockFile.c
+++ /dev/null
@@ -1,447 +0,0 @@
-/*
- * Copyright (C) 2010 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.
- */
-
-#include <assert.h>
-#include <errno.h>
-#include <fcntl.h>
-#include <limits.h>
-#include <pthread.h>
-#include <stdlib.h>
-#include <string.h>
-#include <unistd.h>
-#include <openssl/aes.h>
-#include <openssl/hmac.h>
-
-#include "FwdLockFile.h"
-#include "FwdLockGlue.h"
-
-#define TRUE 1
-#define FALSE 0
-
-#define INVALID_OFFSET ((off64_t)-1)
-
-#define INVALID_BLOCK_INDEX ((uint64_t)-1)
-
-#define MAX_NUM_SESSIONS 128
-
-#define KEY_SIZE AES_BLOCK_SIZE
-#define KEY_SIZE_IN_BITS (KEY_SIZE * 8)
-
-#define SHA1_HASH_SIZE 20
-#define SHA1_BLOCK_SIZE 64
-
-#define FWD_LOCK_VERSION 0
-#define FWD_LOCK_SUBFORMAT 0
-#define USAGE_RESTRICTION_FLAGS 0
-#define CONTENT_TYPE_LENGTH_POS 7
-#define TOP_HEADER_SIZE 8
-
-#define SIG_CALC_BUFFER_SIZE (16 * SHA1_BLOCK_SIZE)
-
-/**
- * Data type for the per-file state information needed by the decoder.
- */
-typedef struct FwdLockFile_Session {
- int fileDesc;
- unsigned char topHeader[TOP_HEADER_SIZE];
- char *pContentType;
- size_t contentTypeLength;
- void *pEncryptedSessionKey;
- size_t encryptedSessionKeyLength;
- unsigned char dataSignature[SHA1_HASH_SIZE];
- unsigned char headerSignature[SHA1_HASH_SIZE];
- off64_t dataOffset;
- off64_t filePos;
- AES_KEY encryptionRoundKeys;
- HMAC_CTX signingContext;
- unsigned char keyStream[AES_BLOCK_SIZE];
- uint64_t blockIndex;
-} FwdLockFile_Session_t;
-
-static FwdLockFile_Session_t *sessionPtrs[MAX_NUM_SESSIONS] = { NULL };
-
-static pthread_mutex_t sessionAcquisitionMutex = PTHREAD_MUTEX_INITIALIZER;
-
-static const unsigned char topHeaderTemplate[] =
- { 'F', 'W', 'L', 'K', FWD_LOCK_VERSION, FWD_LOCK_SUBFORMAT, USAGE_RESTRICTION_FLAGS };
-
-/**
- * Acquires an unused file session for the given file descriptor.
- *
- * @param[in] fileDesc A file descriptor.
- *
- * @return A session ID.
- */
-static int FwdLockFile_AcquireSession(int fileDesc) {
- int sessionId = -1;
- if (fileDesc < 0) {
- errno = EBADF;
- } else {
- int i;
- pthread_mutex_lock(&sessionAcquisitionMutex);
- for (i = 0; i < MAX_NUM_SESSIONS; ++i) {
- int candidateSessionId = (fileDesc + i) % MAX_NUM_SESSIONS;
- if (sessionPtrs[candidateSessionId] == NULL) {
- sessionPtrs[candidateSessionId] = malloc(sizeof **sessionPtrs);
- if (sessionPtrs[candidateSessionId] != NULL) {
- sessionPtrs[candidateSessionId]->fileDesc = fileDesc;
- sessionPtrs[candidateSessionId]->pContentType = NULL;
- sessionPtrs[candidateSessionId]->pEncryptedSessionKey = NULL;
- sessionId = candidateSessionId;
- }
- break;
- }
- }
- pthread_mutex_unlock(&sessionAcquisitionMutex);
- if (i == MAX_NUM_SESSIONS) {
- errno = ENFILE;
- }
- }
- return sessionId;
-}
-
-/**
- * Finds the file session associated with the given file descriptor.
- *
- * @param[in] fileDesc A file descriptor.
- *
- * @return A session ID.
- */
-static int FwdLockFile_FindSession(int fileDesc) {
- int sessionId = -1;
- if (fileDesc < 0) {
- errno = EBADF;
- } else {
- int i;
- pthread_mutex_lock(&sessionAcquisitionMutex);
- for (i = 0; i < MAX_NUM_SESSIONS; ++i) {
- int candidateSessionId = (fileDesc + i) % MAX_NUM_SESSIONS;
- if (sessionPtrs[candidateSessionId] != NULL &&
- sessionPtrs[candidateSessionId]->fileDesc == fileDesc) {
- sessionId = candidateSessionId;
- break;
- }
- }
- pthread_mutex_unlock(&sessionAcquisitionMutex);
- if (i == MAX_NUM_SESSIONS) {
- errno = EBADF;
- }
- }
- return sessionId;
-}
-
-/**
- * Releases a file session.
- *
- * @param[in] sessionID A session ID.
- */
-static void FwdLockFile_ReleaseSession(int sessionId) {
- pthread_mutex_lock(&sessionAcquisitionMutex);
- assert(0 <= sessionId && sessionId < MAX_NUM_SESSIONS && sessionPtrs[sessionId] != NULL);
- free(sessionPtrs[sessionId]->pContentType);
- free(sessionPtrs[sessionId]->pEncryptedSessionKey);
- memset(sessionPtrs[sessionId], 0, sizeof *sessionPtrs[sessionId]); // Zero out key data.
- free(sessionPtrs[sessionId]);
- sessionPtrs[sessionId] = NULL;
- pthread_mutex_unlock(&sessionAcquisitionMutex);
-}
-
-/**
- * Derives keys for encryption and signing from the encrypted session key.
- *
- * @param[in,out] pSession A reference to a file session.
- *
- * @return A Boolean value indicating whether key derivation was successful.
- */
-static int FwdLockFile_DeriveKeys(FwdLockFile_Session_t * pSession) {
- int result;
- struct FwdLockFile_DeriveKeys_Data {
- AES_KEY sessionRoundKeys;
- unsigned char value[KEY_SIZE];
- unsigned char key[KEY_SIZE];
- } *pData = malloc(sizeof *pData);
- if (pData == NULL) {
- result = FALSE;
- } else {
- result = FwdLockGlue_DecryptKey(pSession->pEncryptedSessionKey,
- pSession->encryptedSessionKeyLength, pData->key, KEY_SIZE);
- if (result) {
- if (AES_set_encrypt_key(pData->key, KEY_SIZE_IN_BITS, &pData->sessionRoundKeys) != 0) {
- result = FALSE;
- } else {
- // Encrypt the 16-byte value {0, 0, ..., 0} to produce the encryption key.
- memset(pData->value, 0, KEY_SIZE);
- AES_encrypt(pData->value, pData->key, &pData->sessionRoundKeys);
- if (AES_set_encrypt_key(pData->key, KEY_SIZE_IN_BITS,
- &pSession->encryptionRoundKeys) != 0) {
- result = FALSE;
- } else {
- // Encrypt the 16-byte value {1, 0, ..., 0} to produce the signing key.
- ++pData->value[0];
- AES_encrypt(pData->value, pData->key, &pData->sessionRoundKeys);
- HMAC_CTX_init(&pSession->signingContext);
- HMAC_Init_ex(&pSession->signingContext, pData->key, KEY_SIZE, EVP_sha1(), NULL);
- }
- }
- }
- if (!result) {
- errno = ENOSYS;
- }
- memset(pData, 0, sizeof pData); // Zero out key data.
- free(pData);
- }
- return result;
-}
-
-/**
- * Calculates the counter, treated as a 16-byte little-endian number, used to generate the keystream
- * for the given block.
- *
- * @param[in] pNonce A reference to the nonce.
- * @param[in] blockIndex The index number of the block.
- * @param[out] pCounter A reference to the counter.
- */
-static void FwdLockFile_CalculateCounter(const unsigned char *pNonce,
- uint64_t blockIndex,
- unsigned char *pCounter) {
- unsigned char carry = 0;
- size_t i = 0;
- for (; i < sizeof blockIndex; ++i) {
- unsigned char part = pNonce[i] + (unsigned char)(blockIndex >> (i * CHAR_BIT));
- pCounter[i] = part + carry;
- carry = (part < pNonce[i] || pCounter[i] < part) ? 1 : 0;
- }
- for (; i < AES_BLOCK_SIZE; ++i) {
- pCounter[i] = pNonce[i] + carry;
- carry = (pCounter[i] < pNonce[i]) ? 1 : 0;
- }
-}
-
-/**
- * Decrypts the byte at the current file position using AES-128-CTR. In CTR (or "counter") mode,
- * encryption and decryption are performed using the same algorithm.
- *
- * @param[in,out] pSession A reference to a file session.
- * @param[in] pByte The byte to decrypt.
- */
-void FwdLockFile_DecryptByte(FwdLockFile_Session_t * pSession, unsigned char *pByte) {
- uint64_t blockIndex = pSession->filePos / AES_BLOCK_SIZE;
- uint64_t blockOffset = pSession->filePos % AES_BLOCK_SIZE;
- if (blockIndex != pSession->blockIndex) {
- // The first 16 bytes of the encrypted session key is used as the nonce.
- unsigned char counter[AES_BLOCK_SIZE];
- FwdLockFile_CalculateCounter(pSession->pEncryptedSessionKey, blockIndex, counter);
- AES_encrypt(counter, pSession->keyStream, &pSession->encryptionRoundKeys);
- pSession->blockIndex = blockIndex;
- }
- *pByte ^= pSession->keyStream[blockOffset];
-}
-
-int FwdLockFile_attach(int fileDesc) {
- int sessionId = FwdLockFile_AcquireSession(fileDesc);
- if (sessionId >= 0) {
- FwdLockFile_Session_t *pSession = sessionPtrs[sessionId];
- int isSuccess = FALSE;
- if (read(fileDesc, pSession->topHeader, TOP_HEADER_SIZE) == TOP_HEADER_SIZE &&
- memcmp(pSession->topHeader, topHeaderTemplate, sizeof topHeaderTemplate) == 0) {
- pSession->contentTypeLength = pSession->topHeader[CONTENT_TYPE_LENGTH_POS];
- assert(pSession->contentTypeLength <= UCHAR_MAX); // Untaint scalar for code checkers.
- pSession->pContentType = malloc(pSession->contentTypeLength + 1);
- if (pSession->pContentType != NULL &&
- read(fileDesc, pSession->pContentType, pSession->contentTypeLength) ==
- (ssize_t)pSession->contentTypeLength) {
- pSession->pContentType[pSession->contentTypeLength] = '\0';
- pSession->encryptedSessionKeyLength = FwdLockGlue_GetEncryptedKeyLength(KEY_SIZE);
- pSession->pEncryptedSessionKey = malloc(pSession->encryptedSessionKeyLength);
- if (pSession->pEncryptedSessionKey != NULL &&
- read(fileDesc, pSession->pEncryptedSessionKey,
- pSession->encryptedSessionKeyLength) ==
- (ssize_t)pSession->encryptedSessionKeyLength &&
- read(fileDesc, pSession->dataSignature, SHA1_HASH_SIZE) ==
- SHA1_HASH_SIZE &&
- read(fileDesc, pSession->headerSignature, SHA1_HASH_SIZE) ==
- SHA1_HASH_SIZE) {
- isSuccess = FwdLockFile_DeriveKeys(pSession);
- }
- }
- }
- if (isSuccess) {
- pSession->dataOffset = pSession->contentTypeLength +
- pSession->encryptedSessionKeyLength + TOP_HEADER_SIZE + 2 * SHA1_HASH_SIZE;
- pSession->filePos = 0;
- pSession->blockIndex = INVALID_BLOCK_INDEX;
- } else {
- FwdLockFile_ReleaseSession(sessionId);
- sessionId = -1;
- }
- }
- return (sessionId >= 0) ? 0 : -1;
-}
-
-int FwdLockFile_open(const char *pFilename) {
- int fileDesc = open(pFilename, O_RDONLY);
- if (fileDesc >= 0 && FwdLockFile_attach(fileDesc) < 0) {
- (void)close(fileDesc);
- fileDesc = -1;
- }
- return fileDesc;
-}
-
-ssize_t FwdLockFile_read(int fileDesc, void *pBuffer, size_t numBytes) {
- ssize_t numBytesRead;
- int sessionId = FwdLockFile_FindSession(fileDesc);
- if (sessionId < 0) {
- numBytesRead = -1;
- } else {
- FwdLockFile_Session_t *pSession = sessionPtrs[sessionId];
- ssize_t i;
- numBytesRead = read(pSession->fileDesc, pBuffer, numBytes);
- for (i = 0; i < numBytesRead; ++i) {
- FwdLockFile_DecryptByte(pSession, &((unsigned char *)pBuffer)[i]);
- ++pSession->filePos;
- }
- }
- return numBytesRead;
-}
-
-off64_t FwdLockFile_lseek(int fileDesc, off64_t offset, int whence) {
- off64_t newFilePos;
- int sessionId = FwdLockFile_FindSession(fileDesc);
- if (sessionId < 0) {
- newFilePos = INVALID_OFFSET;
- } else {
- FwdLockFile_Session_t *pSession = sessionPtrs[sessionId];
- switch (whence) {
- case SEEK_SET:
- newFilePos = lseek64(pSession->fileDesc, pSession->dataOffset + offset, whence);
- break;
- case SEEK_CUR:
- case SEEK_END:
- newFilePos = lseek64(pSession->fileDesc, offset, whence);
- break;
- default:
- errno = EINVAL;
- newFilePos = INVALID_OFFSET;
- break;
- }
- if (newFilePos != INVALID_OFFSET) {
- if (newFilePos < pSession->dataOffset) {
- // The new file position is illegal for an internal Forward Lock file. Restore the
- // original file position.
- (void)lseek64(pSession->fileDesc, pSession->dataOffset + pSession->filePos,
- SEEK_SET);
- errno = EINVAL;
- newFilePos = INVALID_OFFSET;
- } else {
- // The return value should be the file position that lseek64() would have returned
- // for the embedded content file.
- pSession->filePos = newFilePos - pSession->dataOffset;
- newFilePos = pSession->filePos;
- }
- }
- }
- return newFilePos;
-}
-
-int FwdLockFile_detach(int fileDesc) {
- int sessionId = FwdLockFile_FindSession(fileDesc);
- if (sessionId < 0) {
- return -1;
- }
- HMAC_CTX_cleanup(&sessionPtrs[sessionId]->signingContext);
- FwdLockFile_ReleaseSession(sessionId);
- return 0;
-}
-
-int FwdLockFile_close(int fileDesc) {
- return (FwdLockFile_detach(fileDesc) == 0) ? close(fileDesc) : -1;
-}
-
-int FwdLockFile_CheckDataIntegrity(int fileDesc) {
- int result;
- int sessionId = FwdLockFile_FindSession(fileDesc);
- if (sessionId < 0) {
- result = FALSE;
- } else {
- struct FwdLockFile_CheckDataIntegrity_Data {
- unsigned char signature[SHA1_HASH_SIZE];
- unsigned char buffer[SIG_CALC_BUFFER_SIZE];
- } *pData = malloc(sizeof *pData);
- if (pData == NULL) {
- result = FALSE;
- } else {
- FwdLockFile_Session_t *pSession = sessionPtrs[sessionId];
- if (lseek64(pSession->fileDesc, pSession->dataOffset, SEEK_SET) !=
- pSession->dataOffset) {
- result = FALSE;
- } else {
- ssize_t numBytesRead;
- unsigned int signatureSize = SHA1_HASH_SIZE;
- while ((numBytesRead =
- read(pSession->fileDesc, pData->buffer, SIG_CALC_BUFFER_SIZE)) > 0) {
- HMAC_Update(&pSession->signingContext, pData->buffer, (size_t)numBytesRead);
- }
- if (numBytesRead < 0) {
- result = FALSE;
- } else {
- HMAC_Final(&pSession->signingContext, pData->signature, &signatureSize);
- assert(signatureSize == SHA1_HASH_SIZE);
- result = memcmp(pData->signature, pSession->dataSignature, SHA1_HASH_SIZE) == 0;
- }
- HMAC_Init_ex(&pSession->signingContext, NULL, KEY_SIZE, NULL, NULL);
- (void)lseek64(pSession->fileDesc, pSession->dataOffset + pSession->filePos,
- SEEK_SET);
- }
- free(pData);
- }
- }
- return result;
-}
-
-int FwdLockFile_CheckHeaderIntegrity(int fileDesc) {
- int result;
- int sessionId = FwdLockFile_FindSession(fileDesc);
- if (sessionId < 0) {
- result = FALSE;
- } else {
- FwdLockFile_Session_t *pSession = sessionPtrs[sessionId];
- unsigned char signature[SHA1_HASH_SIZE];
- unsigned int signatureSize = SHA1_HASH_SIZE;
- HMAC_Update(&pSession->signingContext, pSession->topHeader, TOP_HEADER_SIZE);
- HMAC_Update(&pSession->signingContext, (unsigned char *)pSession->pContentType,
- pSession->contentTypeLength);
- HMAC_Update(&pSession->signingContext, pSession->pEncryptedSessionKey,
- pSession->encryptedSessionKeyLength);
- HMAC_Update(&pSession->signingContext, pSession->dataSignature, SHA1_HASH_SIZE);
- HMAC_Final(&pSession->signingContext, signature, &signatureSize);
- assert(signatureSize == SHA1_HASH_SIZE);
- result = memcmp(signature, pSession->headerSignature, SHA1_HASH_SIZE) == 0;
- HMAC_Init_ex(&pSession->signingContext, NULL, KEY_SIZE, NULL, NULL);
- }
- return result;
-}
-
-int FwdLockFile_CheckIntegrity(int fileDesc) {
- return FwdLockFile_CheckHeaderIntegrity(fileDesc) && FwdLockFile_CheckDataIntegrity(fileDesc);
-}
-
-const char *FwdLockFile_GetContentType(int fileDesc) {
- int sessionId = FwdLockFile_FindSession(fileDesc);
- if (sessionId < 0) {
- return NULL;
- }
- return sessionPtrs[sessionId]->pContentType;
-}
diff --git a/drm/libdrmframework/plugins/forward-lock/internal-format/decoder/FwdLockFile.h b/drm/libdrmframework/plugins/forward-lock/internal-format/decoder/FwdLockFile.h
deleted file mode 100644
index fc64050..0000000
--- a/drm/libdrmframework/plugins/forward-lock/internal-format/decoder/FwdLockFile.h
+++ /dev/null
@@ -1,135 +0,0 @@
-/*
- * Copyright (C) 2010 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.
- */
-
-#ifndef __FWDLOCKFILE_H__
-#define __FWDLOCKFILE_H__
-
-#ifdef __cplusplus
-extern "C" {
-#endif
-
-#include <sys/types.h>
-
-/**
- * Attaches to an open Forward Lock file. The file position is assumed to be at the beginning of the
- * file.
- *
- * @param[in] fileDesc The file descriptor of an open Forward Lock file.
- *
- * @return A status code.
- * @retval 0 Success.
- * @retval -1 Failure.
- */
-int FwdLockFile_attach(int fileDesc);
-
-/**
- * Opens a Forward Lock file for reading.
- *
- * @param[in] pFilename A reference to a filename.
- *
- * @return A file descriptor.
- * @retval -1 Failure.
- */
-int FwdLockFile_open(const char *pFilename);
-
-/**
- * Reads the specified number of bytes from an open Forward Lock file.
- *
- * @param[in] fileDesc The file descriptor of an open Forward Lock file.
- * @param[out] pBuffer A reference to the buffer that should receive the read data.
- * @param[in] numBytes The number of bytes to read.
- *
- * @return The number of bytes read.
- * @retval -1 Failure.
- */
-ssize_t FwdLockFile_read(int fileDesc, void *pBuffer, size_t numBytes);
-
-/**
- * Updates the file position within an open Forward Lock file.
- *
- * @param[in] fileDesc The file descriptor of an open Forward Lock file.
- * @param[in] offset The offset with which to update the file position.
- * @param[in] whence One of SEEK_SET, SEEK_CUR, and SEEK_END.
- *
- * @return The new file position.
- * @retval ((off64_t)-1) Failure.
- */
-off64_t FwdLockFile_lseek(int fileDesc, off64_t offset, int whence);
-
-/**
- * Detaches from an open Forward Lock file.
- *
- * @param[in] fileDesc The file descriptor of an open Forward Lock file.
- *
- * @return A status code.
- * @retval 0 Success.
- * @retval -1 Failure.
- */
-int FwdLockFile_detach(int fileDesc);
-
-/**
- * Closes an open Forward Lock file.
- *
- * @param[in] fileDesc The file descriptor of an open Forward Lock file.
- *
- * @return A status code.
- * @retval 0 Success.
- * @retval -1 Failure.
- */
-int FwdLockFile_close(int fileDesc);
-
-/**
- * Checks the data integrity of an open Forward Lock file.
- *
- * @param[in] fileDesc The file descriptor of an open Forward Lock file.
- *
- * @return A Boolean value indicating whether the integrity check was successful.
- */
-int FwdLockFile_CheckDataIntegrity(int fileDesc);
-
-/**
- * Checks the header integrity of an open Forward Lock file.
- *
- * @param[in] fileDesc The file descriptor of an open Forward Lock file.
- *
- * @return A Boolean value indicating whether the integrity check was successful.
- */
-int FwdLockFile_CheckHeaderIntegrity(int fileDesc);
-
-/**
- * Checks both the data and header integrity of an open Forward Lock file.
- *
- * @param[in] fileDesc The file descriptor of an open Forward Lock file.
- *
- * @return A Boolean value indicating whether the integrity check was successful.
- */
-int FwdLockFile_CheckIntegrity(int fileDesc);
-
-/**
- * Returns the content type of an open Forward Lock file.
- *
- * @param[in] fileDesc The file descriptor of an open Forward Lock file.
- *
- * @return
- * A reference to the content type. The reference remains valid as long as the file is kept open.
- */
-const char *FwdLockFile_GetContentType(int fileDesc);
-
-#ifdef __cplusplus
-}
-#endif
-
-#endif // __FWDLOCKFILE_H__
diff --git a/drm/libdrmframework/plugins/forward-lock/internal-format/doc/FwdLock.html b/drm/libdrmframework/plugins/forward-lock/internal-format/doc/FwdLock.html
deleted file mode 100755
index 8f95cd2..0000000
--- a/drm/libdrmframework/plugins/forward-lock/internal-format/doc/FwdLock.html
+++ /dev/null
@@ -1,1039 +0,0 @@
-<html>
-
-<head>
-<meta http-equiv=Content-Type content="text/html; charset=windows-1252">
-<meta name=Generator content="Microsoft Word 12 (filtered)">
-<title>Forward Lock Converter and Decoder</title>
-<style>
-<!--
- /* Font Definitions */
- @font-face
- {font-family:SimSun;
- panose-1:2 1 6 0 3 1 1 1 1 1;}
-@font-face
- {font-family:"Cambria Math";
- panose-1:2 4 5 3 5 4 6 3 2 4;}
-@font-face
- {font-family:Tahoma;
- panose-1:2 11 6 4 3 5 4 4 2 4;}
-@font-face
- {font-family:"Lucida Console","DejaVu Sans Mono";
- panose-1:2 11 6 9 4 5 4 2 2 4;}
-@font-face
- {font-family:"\@SimSun";
- panose-1:2 1 6 0 3 1 1 1 1 1;}
- /* Style Definitions */
- p.MsoNormal, li.MsoNormal, div.MsoNormal
- {margin:0cm;
- margin-bottom:.0001pt;
- font-size:12.0pt;
- font-family:"Times New Roman","serif";}
-h1
- {margin-right:0cm;
- margin-left:21.6pt;
- text-indent:-21.6pt;
- page-break-after:avoid;
- font-size:16.0pt;
- font-family:"Arial","sans-serif";}
-h2
- {margin-top:12.0pt;
- margin-right:0cm;
- margin-bottom:3.0pt;
- margin-left:28.8pt;
- text-indent:-28.8pt;
- page-break-after:avoid;
- font-size:14.0pt;
- font-family:"Arial","sans-serif";
- font-style:italic;}
-h3
- {margin-top:12.0pt;
- margin-right:0cm;
- margin-bottom:3.0pt;
- margin-left:36.0pt;
- text-indent:-36.0pt;
- page-break-after:avoid;
- font-size:13.0pt;
- font-family:"Arial","sans-serif";}
-h4
- {margin-top:12.0pt;
- margin-right:0cm;
- margin-bottom:3.0pt;
- margin-left:43.2pt;
- text-indent:-43.2pt;
- page-break-after:avoid;
- font-size:14.0pt;
- font-family:"Times New Roman","serif";}
-h5
- {margin-top:12.0pt;
- margin-right:0cm;
- margin-bottom:3.0pt;
- margin-left:50.4pt;
- text-indent:-50.4pt;
- font-size:13.0pt;
- font-family:"Times New Roman","serif";
- font-style:italic;}
-h6
- {margin-top:12.0pt;
- margin-right:0cm;
- margin-bottom:3.0pt;
- margin-left:57.6pt;
- text-indent:-57.6pt;
- font-size:11.0pt;
- font-family:"Times New Roman","serif";}
-p.MsoHeading7, li.MsoHeading7, div.MsoHeading7
- {margin-top:12.0pt;
- margin-right:0cm;
- margin-bottom:3.0pt;
- margin-left:64.8pt;
- text-indent:-64.8pt;
- font-size:12.0pt;
- font-family:"Times New Roman","serif";}
-p.MsoHeading8, li.MsoHeading8, div.MsoHeading8
- {margin-top:12.0pt;
- margin-right:0cm;
- margin-bottom:3.0pt;
- margin-left:72.0pt;
- text-indent:-72.0pt;
- font-size:12.0pt;
- font-family:"Times New Roman","serif";
- font-style:italic;}
-p.MsoHeading9, li.MsoHeading9, div.MsoHeading9
- {margin-top:12.0pt;
- margin-right:0cm;
- margin-bottom:3.0pt;
- margin-left:79.2pt;
- text-indent:-79.2pt;
- font-size:11.0pt;
- font-family:"Arial","sans-serif";}
-p.MsoToc1, li.MsoToc1, div.MsoToc1
- {margin-top:6.0pt;
- margin-right:0cm;
- margin-bottom:6.0pt;
- margin-left:0cm;
- line-height:150%;
- font-size:10.5pt;
- font-family:"Times New Roman","serif";
- text-transform:uppercase;
- font-weight:bold;}
-p.MsoToc2, li.MsoToc2, div.MsoToc2
- {margin-top:0cm;
- margin-right:0cm;
- margin-bottom:0cm;
- margin-left:12.0pt;
- margin-bottom:.0001pt;
- line-height:150%;
- font-size:10.5pt;
- font-family:"Times New Roman","serif";
- font-variant:small-caps;}
-p.MsoToc3, li.MsoToc3, div.MsoToc3
- {margin-top:0cm;
- margin-right:0cm;
- margin-bottom:0cm;
- margin-left:24.0pt;
- margin-bottom:.0001pt;
- line-height:150%;
- font-size:10.5pt;
- font-family:"Times New Roman","serif";
- font-style:italic;}
-p.MsoToc4, li.MsoToc4, div.MsoToc4
- {margin-top:0cm;
- margin-right:0cm;
- margin-bottom:0cm;
- margin-left:36.0pt;
- margin-bottom:.0001pt;
- font-size:9.0pt;
- font-family:"Times New Roman","serif";}
-p.MsoToc5, li.MsoToc5, div.MsoToc5
- {margin-top:0cm;
- margin-right:0cm;
- margin-bottom:0cm;
- margin-left:48.0pt;
- margin-bottom:.0001pt;
- font-size:9.0pt;
- font-family:"Times New Roman","serif";}
-p.MsoToc6, li.MsoToc6, div.MsoToc6
- {margin-top:0cm;
- margin-right:0cm;
- margin-bottom:0cm;
- margin-left:60.0pt;
- margin-bottom:.0001pt;
- font-size:9.0pt;
- font-family:"Times New Roman","serif";}
-p.MsoToc7, li.MsoToc7, div.MsoToc7
- {margin-top:0cm;
- margin-right:0cm;
- margin-bottom:0cm;
- margin-left:72.0pt;
- margin-bottom:.0001pt;
- font-size:9.0pt;
- font-family:"Times New Roman","serif";}
-p.MsoToc8, li.MsoToc8, div.MsoToc8
- {margin-top:0cm;
- margin-right:0cm;
- margin-bottom:0cm;
- margin-left:84.0pt;
- margin-bottom:.0001pt;
- font-size:9.0pt;
- font-family:"Times New Roman","serif";}
-p.MsoToc9, li.MsoToc9, div.MsoToc9
- {margin-top:0cm;
- margin-right:0cm;
- margin-bottom:0cm;
- margin-left:96.0pt;
- margin-bottom:.0001pt;
- font-size:9.0pt;
- font-family:"Times New Roman","serif";}
-p.MsoFootnoteText, li.MsoFootnoteText, div.MsoFootnoteText
- {margin:0cm;
- margin-bottom:.0001pt;
- font-size:10.0pt;
- font-family:"Times New Roman","serif";}
-p.MsoHeader, li.MsoHeader, div.MsoHeader
- {margin:0cm;
- margin-bottom:.0001pt;
- font-size:12.0pt;
- font-family:"Times New Roman","serif";}
-p.MsoFooter, li.MsoFooter, div.MsoFooter
- {margin:0cm;
- margin-bottom:.0001pt;
- font-size:12.0pt;
- font-family:"Times New Roman","serif";}
-p.MsoCaption, li.MsoCaption, div.MsoCaption
- {margin:0cm;
- margin-bottom:.0001pt;
- font-size:11.0pt;
- font-family:"Times New Roman","serif";
- font-weight:bold;}
-span.MsoFootnoteReference
- {vertical-align:super;}
-p.MsoTitle, li.MsoTitle, div.MsoTitle
- {margin-top:12.0pt;
- margin-right:0cm;
- margin-bottom:120.0pt;
- margin-left:0cm;
- text-align:center;
- font-size:16.0pt;
- font-family:"Arial","sans-serif";
- font-weight:bold;}
-p.MsoBodyText, li.MsoBodyText, div.MsoBodyText
- {mso-style-link:"Body Text Char";
- margin-top:0cm;
- margin-right:0cm;
- margin-bottom:6.0pt;
- margin-left:0cm;
- font-size:12.0pt;
- font-family:"Times New Roman","serif";}
-a:link, span.MsoHyperlink
- {color:blue;
- text-decoration:underline;}
-a:visited, span.MsoHyperlinkFollowed
- {color:purple;
- text-decoration:underline;}
-p.MsoAcetate, li.MsoAcetate, div.MsoAcetate
- {margin:0cm;
- margin-bottom:.0001pt;
- font-size:8.0pt;
- font-family:"Tahoma","sans-serif";}
-span.BodyTextChar
- {mso-style-name:"Body Text Char";
- mso-style-link:"Body Text";}
- /* Page Definitions */
- @page WordSection1
- {size:595.45pt 841.7pt;
- margin:72.0pt 90.0pt 72.0pt 90.0pt;}
-div.WordSection1
- {page:WordSection1;}
-@page WordSection2
- {size:595.45pt 841.7pt;
- margin:72.0pt 90.0pt 72.0pt 90.0pt;}
-div.WordSection2
- {page:WordSection2;}
- /* List Definitions */
- ol
- {margin-bottom:0cm;}
-ul
- {margin-bottom:0cm;}
--->
-</style>
-
-</head>
-
-<body lang=EN-US link=blue vlink=purple>
-
-<div class=WordSection1>
-
-<p class=MsoTitle>Forward Lock Converter And Decoder</p>
-
-<p class=MsoToc1><span
-class=MsoHyperlink><a href="#_Toc276471422">1<span style='font-size:12.0pt;
-line-height:150%;color:windowtext;text-transform:none;font-weight:normal;
-text-decoration:none'>      </span>Introduction<span style='color:windowtext;
-display:none;text-decoration:none'>. </span><span
-style='color:windowtext;display:none;text-decoration:none'>3</span></a></span></p>
-
-<p class=MsoToc1><span class=MsoHyperlink><a href="#_Toc276471423">2<span
-style='font-size:12.0pt;line-height:150%;color:windowtext;text-transform:none;
-font-weight:normal;text-decoration:none'>      </span>Overview<span
-style='color:windowtext;display:none;text-decoration:none'>... </span><span
-style='color:windowtext;display:none;text-decoration:none'>3</span></a></span></p>
-
-<p class=MsoToc1><span class=MsoHyperlink><a href="#_Toc276471424">3<span
-style='font-size:12.0pt;line-height:150%;color:windowtext;text-transform:none;
-font-weight:normal;text-decoration:none'>      </span>Use Cases<span
-style='color:windowtext;display:none;text-decoration:none'>. </span><span
-style='color:windowtext;display:none;text-decoration:none'>4</span></a></span></p>
-
-<p class=MsoToc2><span class=MsoHyperlink><span style='font-variant:normal !important;
-text-transform:uppercase'><a href="#_Toc276471425">3.1<span style='font-size:
-12.0pt;line-height:150%;color:windowtext;text-transform:none;text-decoration:
-none'>        </span>Converter<span style='color:windowtext;display:none;
-text-decoration:none'>. </span><span
-style='color:windowtext;display:none;text-decoration:none'>4</span></a></span></span></p>
-
-<p class=MsoToc3><span class=MsoHyperlink><a href="#_Toc276471426">3.1.1<span
-style='font-size:12.0pt;line-height:150%;color:windowtext;font-style:normal;
-text-decoration:none'>     </span>Convert Data (Push-Mode Conversion)<span
-style='color:windowtext;display:none;text-decoration:none'> </span><span
-style='color:windowtext;display:none;text-decoration:none'>4</span></a></span></p>
-
-<p class=MsoToc3><span class=MsoHyperlink><a href="#_Toc276471427">3.1.2<span
-style='font-size:12.0pt;line-height:150%;color:windowtext;font-style:normal;
-text-decoration:none'>     </span>Convert File (Pull-Mode Conversion)<span
-style='color:windowtext;display:none;text-decoration:none'> </span><span
-style='color:windowtext;display:none;text-decoration:none'>6</span></a></span></p>
-
-<p class=MsoToc2><span class=MsoHyperlink><span style='font-variant:normal !important;
-text-transform:uppercase'><a href="#_Toc276471428">3.2<span style='font-size:
-12.0pt;line-height:150%;color:windowtext;text-transform:none;text-decoration:
-none'>        </span>Decoder<span style='color:windowtext;display:none;
-text-decoration:none'>. </span><span
-style='color:windowtext;display:none;text-decoration:none'>7</span></a></span></span></p>
-
-<p class=MsoToc3><span class=MsoHyperlink><a href="#_Toc276471429">3.2.1<span
-style='font-size:12.0pt;line-height:150%;color:windowtext;font-style:normal;
-text-decoration:none'>     </span>Check Integrity<span style='color:windowtext;
-display:none;text-decoration:none'>. </span><span
-style='color:windowtext;display:none;text-decoration:none'>8</span></a></span></p>
-
-<p class=MsoToc3><span class=MsoHyperlink><a href="#_Toc276471430">3.2.2<span
-style='font-size:12.0pt;line-height:150%;color:windowtext;font-style:normal;
-text-decoration:none'>     </span>Get Content Type<span style='color:windowtext;
-display:none;text-decoration:none'>. </span><span
-style='color:windowtext;display:none;text-decoration:none'>9</span></a></span></p>
-
-<p class=MsoToc3><span class=MsoHyperlink><a href="#_Toc276471431">3.2.3<span
-style='font-size:12.0pt;line-height:150%;color:windowtext;font-style:normal;
-text-decoration:none'>     </span>Decode File<span style='color:windowtext;
-display:none;text-decoration:none'>. </span><span
-style='color:windowtext;display:none;text-decoration:none'>10</span></a></span></p>
-
-<p class=MsoToc1><span class=MsoHyperlink><a href="#_Toc276471432">4<span
-style='font-size:12.0pt;line-height:150%;color:windowtext;text-transform:none;
-font-weight:normal;text-decoration:none'>      </span>Definition of the
-Internal Forward Lock File Format<span style='color:windowtext;display:none;
-text-decoration:none'>. </span><span
-style='color:windowtext;display:none;text-decoration:none'>11</span></a></span></p>
-
-<p class=MsoToc2><span class=MsoHyperlink><span style='font-variant:normal !important;
-text-transform:uppercase'><a href="#_Toc276471433">4.1<span style='font-size:
-12.0pt;line-height:150%;color:windowtext;text-transform:none;text-decoration:
-none'>        </span>Key Derivation<span style='color:windowtext;display:none;
-text-decoration:none'>.. </span><span
-style='color:windowtext;display:none;text-decoration:none'>11</span></a></span></span></p>
-
-<p class=MsoToc2><span class=MsoHyperlink><span style='font-variant:normal !important;
-text-transform:uppercase'><a href="#_Toc276471434">4.2<span style='font-size:
-12.0pt;line-height:150%;color:windowtext;text-transform:none;text-decoration:
-none'>        </span>Calculation of the Counters<span style='color:windowtext;
-display:none;text-decoration:none'>. </span><span
-style='color:windowtext;display:none;text-decoration:none'>12</span></a></span></span></p>
-
-<p class=MsoToc1><span class=MsoHyperlink><a href="#_Toc276471435">5<span
-style='font-size:12.0pt;line-height:150%;color:windowtext;text-transform:none;
-font-weight:normal;text-decoration:none'>      </span>Unit Test Cases<span
-style='color:windowtext;display:none;text-decoration:none'>. </span><span
-style='color:windowtext;display:none;text-decoration:none'>12</span></a></span></p>
-
-<p class=MsoToc1><span class=MsoHyperlink><a href="#_Toc276471436">6<span
-style='font-size:12.0pt;line-height:150%;color:windowtext;text-transform:none;
-font-weight:normal;text-decoration:none'>      </span>References<span
-style='color:windowtext;display:none;text-decoration:none'>. </span><span
-style='color:windowtext;display:none;text-decoration:none'>12</span></a></span></p>
-
-<p class=MsoBodyText></p>
-
-</div>
-
-<span style='font-size:12.0pt;font-family:"Times New Roman","serif"'><br
-clear=all style='page-break-before:right'>
-</span>
-
-<div class=WordSection2>
-
-<h1><a name="_Toc276471422"></a><a name="_Ref263085474">1<span
-style='font:7.0pt "Times New Roman"'>&nbsp;&nbsp;&nbsp;&nbsp;&nbsp; </span>Introduction</a></h1>
-
-<p class=MsoBodyText>The internal Forward Lock file format is used for encrypting
-inherently unencrypted OMA DRM version 1 Forward Lock and Combined Delivery
-files so they can be securely stored on externally accessible file system partitions
-such as memory stick.</p>
-
-<p class=MsoBodyText>Our general strategy is to convert such <i>OMA DRM Message</i>
-(‘.dm’) files to internal Forward Lock (‘.fl’) files as soon as they are
-downloaded or otherwise transferred to the phone, and not actually provide any
-decoders for ‘.dm’ files.</p>
-
-<h1><a name="_Toc276471423">2<span style='font:7.0pt "Times New Roman"'>&nbsp;&nbsp;&nbsp;&nbsp;&nbsp;
-</span>Overview</a></h1>
-
-<p class=MsoBodyText>The <i>Forward Lock Converter</i> converts OMA DRM Message
-files to the internal file format. The <i>Forward Lock Decoder</i> provides a
-POSIX-level API for transparent reading and seeking through such a converted
-file as if it were unencrypted. The API also includes functions for checking a
-file’s integrity and getting the MIME type of its embedded content.</p>
-
-<p class=MsoBodyText style='margin-bottom:24.0pt'>The converter and decoder are
-built into two separate libraries, which share common code for random number
-generation and key encryption in a third library. For test purposes there is
-also a unit test application. See Figure 1.</p>
-
-<p class=MsoBodyText style='page-break-after:avoid'><img width=288 height=364
-src="images/image001.gif"></p>
-
-<p class=MsoCaption style='margin-top:12.0pt;margin-right:0cm;margin-bottom:
-12.0pt;margin-left:0cm'><a name="_Ref262730885">Figure </a>1. Block diagram illustrating the dependencies between the executable modules.</p>
-
-<b><span style='font-size:16.0pt;font-family:"Arial","sans-serif"'><br
-clear=all style='page-break-before:always'>
-</span></b>
-
-<h1><a name="_Toc276471424">3<span style='font:7.0pt "Times New Roman"'>&nbsp;&nbsp;&nbsp;&nbsp;&nbsp;
-</span>Use Cases</a></h1>
-
-<p class=MsoBodyText>This section describes all the use cases for the converter
-and decoder. It shows the sequence of API calls that should be used to solve
-these use cases.</p>
-
-<h2><a name="_Toc276471425">3.1<span style='font:7.0pt "Times New Roman"'>&nbsp;&nbsp;&nbsp;
-</span>Converter</a></h2>
-
-<p class=MsoBodyText>Through the converter API, conversion can be performed in one
-of two ways:</p>
-
-<p class=MsoBodyText style='margin-left:36.0pt;text-indent:-18.0pt'>1.<span
-style='font:7.0pt "Times New Roman"'>&nbsp;&nbsp;&nbsp;&nbsp;&nbsp; </span><i>Push-mode
-conversion</i> is when the client progressively feeds data to the converter as
-it arrives. This is appropriate when data arrives gradually in chunks, with
-idle time in between. Consequently, push mode is used for converting files
-being downloaded through HTTP. See section 3.1.1.</p>
-
-<p class=MsoBodyText style='margin-left:36.0pt;text-indent:-18.0pt'>2.<span
-style='font:7.0pt "Times New Roman"'>&nbsp;&nbsp;&nbsp;&nbsp;&nbsp; </span><i>Pull-mode
-conversion</i> is when the converter drives the process and consumes data from
-the client as it needs it. This is appropriate when the entire file to be
-converted is readily available. Hence, pull mode is used by the unit test application.
-See section 3.1.2.</p>
-
-<p class=MsoBodyText>Internally, pull-mode conversion is implemented in terms
-of the API for push-mode conversion.</p>
-
-<h3><a name="_Toc276471426"></a><a name="_Ref263085478">3.1.1<span
-style='font:7.0pt "Times New Roman"'>&nbsp;&nbsp;&nbsp; </span>Convert Data
-(Push-Mode Conversion)</a></h3>
-
-<p class=MsoBodyText>Push-mode conversion is performed as follows (see also Figure 2):</p>
-
-<p class=MsoBodyText style='margin-left:36.0pt;text-indent:-18.0pt'>1.<span
-style='font:7.0pt "Times New Roman"'>&nbsp;&nbsp;&nbsp;&nbsp;&nbsp; </span><span
-style='font-size:10.0pt;font-family:"Lucida Console","DejaVu Sans Mono"'>FwdLockConv_OpenSession</span>
-initializes the output parameter and returns a <i>session ID</i> to be used in
-subsequent calls to the API. The output parameter is a union of return values
-whose correct use at any given moment is determined by the API function last
-called.</p>
-
-<p class=MsoBodyText style='margin-left:36.0pt;text-indent:-18.0pt'>2.<span
-style='font:7.0pt "Times New Roman"'>&nbsp;&nbsp;&nbsp;&nbsp;&nbsp; </span><span
-style='font-size:10.0pt;font-family:"Lucida Console","DejaVu Sans Mono"'>FwdLockConv_ConvertData</span>
-is called repeatedly until no more input data remains. Each call converts the
-maximum amount of data possible and writes it to the output buffer. The client then
-writes this data to file.</p>
-
-<p class=MsoBodyText style='margin-left:36.0pt;text-indent:-18.0pt'>3.<span
-style='font:7.0pt "Times New Roman"'>&nbsp;&nbsp;&nbsp;&nbsp;&nbsp; </span><span
-style='font-size:10.0pt;font-family:"Lucida Console","DejaVu Sans Mono"'>FwdLockConv_CloseSession</span>
-cleans up the session and deallocates the output buffer. If all has gone well, a
-two-part cryptographic signature of the output file is calculated. The client
-must go back and rewrite part of the file header with this updated signature
-information.</p>
-
-<p class=MsoBodyText>Every time a file is being converted, the converter calls <span
-style='font-size:10.0pt;font-family:"Lucida Console","DejaVu Sans Mono"'>FwdLockGlue_GetRandomNumber</span>
-to generate a new, unique session key. No two converted files look alike, even
-if the original files are the same.</p>
-
-<p class=MsoBodyText><b>Note:</b> The random bytes cannot come from any bare-minimum
-implementation of the C-library <span style='font-size:10.0pt;font-family:"Lucida Console","DejaVu Sans Mono"'>rand</span>
-function—they must be cryptographically secure. Otherwise, security will be
-compromised.</p>
-
-<p class=MsoBodyText>The session key is encrypted and stored within the
-converted file. Key encryption is performed using <span style='font-size:10.0pt;
-font-family:"Lucida Console","DejaVu Sans Mono"'>FwdLockGlue_GetEncryptedKeyLength</span> and <span
-style='font-size:10.0pt;font-family:"Lucida Console","DejaVu Sans Mono"'>FwdLockGlue_EncryptKey</span>.
-These two functions, together with the corresponding decryption function (<span
-style='font-size:10.0pt;font-family:"Lucida Console","DejaVu Sans Mono"'>FwdLockGlue_DecryptKey</span>),
-are the integration points where an OEM manufacturer may implement their own
-key-encryption scheme.</p>
-
-<p class=MsoBodyText><b>Note:</b> The key-encryption key must be unique to each
-device; this is what makes the files forward lock–protected. Ideally, it should
-be derived from secret hardware parameters, but at the very least it should be
-persistent from one master reset to the next.</p>
-
-<div style='margin-bottom:24.0pt;border:solid windowtext 1.0pt;padding:1.0pt 4.0pt 1.0pt 4.0pt;
-background:#F2F2F2'>
-
-<p class=MsoBodyText style='background:#F2F2F2;border:
-none;padding:0cm'><b>Note:</b> In the open-source implementation of the <span
-style='font-size:10.0pt;font-family:"Lucida Console","DejaVu Sans Mono"'>libfwdlock-common</span>
-library, a random key-encryption key is generated and stored in plaintext in
-the file system, without being obfuscated in any way (doing so would be futile
-since the source code is openly available). This key must be kept secret from
-the user, and shouldn’t be possible to extract through backup-and-restore
-functionality or the like. OEM manufacturers will probably want to implement a
-truly hardware-based device-unique key.</p>
-
-</div>
-
-<p class=MsoBodyText style='page-break-after:avoid'><img width=531 height=563
-src="images/image002.gif"></p>
-
-<p class=MsoCaption style='margin-top:6.0pt;margin-right:0cm;margin-bottom:
-12.0pt;margin-left:0cm'><a name="_Ref263085187">Figure </a>2. Converter UC: Convert Data.</p>
-
-<b><span style='font-size:13.0pt;font-family:"Arial","sans-serif"'><br
-clear=all style='page-break-before:always'>
-</span></b>
-
-<h3><a name="_Toc276471427"></a><a name="_Ref263163082">3.1.2<span
-style='font:7.0pt "Times New Roman"'>&nbsp;&nbsp;&nbsp; </span>Convert File
-(Pull-Mode Conversion)</a></h3>
-
-<p class=MsoBodyText>Pull-mode conversion is performed by calling <span
-style='font-size:10.0pt;font-family:"Lucida Console","DejaVu Sans Mono"'>FwdLockFile_ConvertFile</span>
-with the filename, unless there is need for a specialized <span
-style='font-size:10.0pt;font-family:"Lucida Console","DejaVu Sans Mono"'>read</span> function, in
-which case <span style='font-size:10.0pt;font-family:"Lucida Console","DejaVu Sans Mono"'>FwdLockFile_ConvertOpenFile</span>
-should be used directly instead. See Figure 3.</p>
-
-<p class=MsoBodyText style='margin-bottom:24.0pt'>Internally, <span
-style='font-size:10.0pt;font-family:"Lucida Console","DejaVu Sans Mono"'>FwdLockFile_ConvertFile</span>
-calls <span style='font-size:10.0pt;font-family:"Lucida Console","DejaVu Sans Mono"'>FwdLockFile_ConvertOpenFile</span>.
-The latter then proceeds with the conversion using the push-mode API, acting as
-the client in the previous use case; see section 3.1.1.</p>
-
-<p class=MsoBodyText style='page-break-after:avoid'><img width=531 height=731
-src="images/image003.gif"></p>
-
-<p class=MsoCaption style='margin-top:6.0pt;margin-right:0cm;margin-bottom:
-12.0pt;margin-left:0cm'><a name="_Ref263085208">Figure </a>3. Converter UC: Convert File.</p>
-
-<b><i><span style='font-size:14.0pt;font-family:"Arial","sans-serif"'><br
-clear=all style='page-break-before:always'>
-</span></i></b>
-
-<h2><a name="_Toc276471428">3.2<span style='font:7.0pt "Times New Roman"'>&nbsp;&nbsp;&nbsp;
-</span>Decoder</a></h2>
-
-<p class=MsoBodyText>The decoder API allows the client to do the following:</p>
-
-<p class=MsoBodyText style='margin-left:36.0pt;text-indent:-18.0pt'>1.<span
-style='font:7.0pt "Times New Roman"'>&nbsp;&nbsp;&nbsp;&nbsp;&nbsp; </span>Check
-the integrity of an internal Forward Lock file, i.e., detect whether it has
-been manipulated in any way; see section 3.2.1.</p>
-
-<p class=MsoBodyText style='margin-left:36.0pt;text-indent:-18.0pt'>2.<span
-style='font:7.0pt "Times New Roman"'>&nbsp;&nbsp;&nbsp;&nbsp;&nbsp; </span>Get
-the MIME type of the embedded content (the “original” MIME type before DRM protection
-was applied); see section 3.2.2.</p>
-
-<p class=MsoBodyText style='margin-left:36.0pt;text-indent:-18.0pt'>3.<span
-style='font:7.0pt "Times New Roman"'>&nbsp;&nbsp;&nbsp;&nbsp;&nbsp; </span>Decode
-the file by random access, i.e., read and seek through it in an arbitrary
-manner; see section 3.2.3.</p>
-
-<p class=MsoBodyText>All subsequent operations on a file first require it to be
-opened. Opening a file returns a <i>file descriptor</i>—a handle to be used in
-these subsequent operations.</p>
-
-<p class=MsoBodyText>If the filename is known, an internal Forward Lock file
-can be opened using <span style='font-size:10.0pt;font-family:"Lucida Console","DejaVu Sans Mono"'>FwdLockFile_open</span>.
-If only the file descriptor of an already open file is available, a decoding
-session can instead be initialized using <span style='font-size:10.0pt;
-font-family:"Lucida Console","DejaVu Sans Mono"'>FwdLockFile_attach</span>.</p>
-
-<p class=MsoBodyText>Internally, <span style='font-size:10.0pt;font-family:
-"Lucida Console","DejaVu Sans Mono"'>FwdLockFile_open</span> calls <span style='font-size:10.0pt;
-font-family:"Lucida Console","DejaVu Sans Mono"'>FwdLockFile_attach</span>. For efficiency
-reasons, <span style='font-size:10.0pt;font-family:"Lucida Console","DejaVu Sans Mono"'>FwdLockFile_attach</span>
-therefore assumes that the file position is at the beginning of the file when
-the function gets called. A client who calls it directly must make sure that
-this assumption holds.</p>
-
-<p class=MsoBodyText>When a file is being attached, the session key stored in
-the file during conversion is decrypted using <span style='font-size:10.0pt;
-font-family:"Lucida Console","DejaVu Sans Mono"'>FwdLockGlue_GetEncryptedKeyLength</span> and <span
-style='font-size:10.0pt;font-family:"Lucida Console","DejaVu Sans Mono"'>FwdLockGlue_DecryptKey</span>,
-in order to set up for decoding and integrity checking.</p>
-
-<p class=MsoBodyText>For just getting the content type, however, retrieving the
-session key would strictly speaking not be necessary, so there is an
-opportunity here to optimize for that if it proves necessary later.</p>
-
-<p class=MsoBodyText>Symmetrical to <span style='font-size:10.0pt;font-family:
-"Lucida Console","DejaVu Sans Mono"'>FwdLockFile_open</span> and <span style='font-size:10.0pt;
-font-family:"Lucida Console","DejaVu Sans Mono"'>FwdLockFile_attach</span>, there are also functions
-for closing a file or detaching from it:</p>
-
-<p class=MsoBodyText style='margin-left:36.0pt;text-indent:-18.0pt'>1.<span
-style='font:7.0pt "Times New Roman"'>&nbsp;&nbsp;&nbsp;&nbsp;&nbsp; </span>If
-it was opened with <span style='font-size:10.0pt;font-family:"Lucida Console","DejaVu Sans Mono"'>FwdLockFile_open</span>
-it should be closed with <span style='font-size:10.0pt;font-family:"Lucida Console","DejaVu Sans Mono"'>FwdLockFile_close</span>.</p>
-
-<p class=MsoBodyText style='margin-left:36.0pt;text-indent:-18.0pt'>2.<span
-style='font:7.0pt "Times New Roman"'>&nbsp;&nbsp;&nbsp;&nbsp;&nbsp; </span>If
-it was attached with <span style='font-size:10.0pt;font-family:"Lucida Console","DejaVu Sans Mono"'>FwdLockFile_attach</span>
-it should be detached with <span style='font-size:10.0pt;font-family:"Lucida Console","DejaVu Sans Mono"'>FwdLockFile_detach</span>.</p>
-
-<b><span style='font-size:13.0pt;font-family:"Arial","sans-serif"'><br
-clear=all style='page-break-before:always'>
-</span></b>
-
-<h3><a name="_Ref263163099"></a><a name="_Toc276471429">3.2.1<span
-style='font:7.0pt "Times New Roman"'>&nbsp;&nbsp;&nbsp; </span>Check Integrity</a></h3>
-
-<p class=MsoBodyText>There are three methods for checking the integrity of an
-internal Forward Lock file, in whole or in part (see also Figure 4):</p>
-
-<p class=MsoBodyText style='margin-left:36.0pt;text-indent:-18.0pt'>1.<span
-style='font:7.0pt "Times New Roman"'>&nbsp;&nbsp;&nbsp;&nbsp;&nbsp; </span><span
-style='font-size:10.0pt;font-family:"Lucida Console","DejaVu Sans Mono"'>FwdLockFile_CheckDataIntegrity</span>,
-which checks the integrity of the encrypted content data.</p>
-
-<p class=MsoBodyText style='margin-left:36.0pt;text-indent:-18.0pt'>2.<span
-style='font:7.0pt "Times New Roman"'>&nbsp;&nbsp;&nbsp;&nbsp;&nbsp; </span><span
-style='font-size:10.0pt;font-family:"Lucida Console","DejaVu Sans Mono"'>FwdLockFile_CheckHeaderIntegrity</span>,
-which checks the integrity of the file header, including the content type and
-other fields not currently supported but reserved for future use.</p>
-
-<p class=MsoBodyText style='margin-left:36.0pt;text-indent:-18.0pt'>3.<span
-style='font:7.0pt "Times New Roman"'>&nbsp;&nbsp;&nbsp;&nbsp;&nbsp; </span><span
-style='font-size:10.0pt;font-family:"Lucida Console","DejaVu Sans Mono"'>FwdLockFile_CheckIntegrity</span>,
-which internally calls first <span style='font-size:10.0pt;font-family:"Lucida Console","DejaVu Sans Mono"'>FwdLockFile_CheckHeaderIntegrity</span>
-and then <span style='font-size:10.0pt;font-family:"Lucida Console","DejaVu Sans Mono"'>FwdLockFile_CheckDataIntegrity</span>.</p>
-
-<p class=MsoBodyText style='margin-bottom:24.0pt'><span style='font-size:10.0pt;
-font-family:"Lucida Console","DejaVu Sans Mono"'>FwdLockFile_CheckHeaderIntegrity</span> is
-generally much faster than <span style='font-size:10.0pt;font-family:"Lucida Console","DejaVu Sans Mono"'>FwdLockFile_CheckDataIntegrity</span>,
-whose running time is directly proportional to the size of the file.</p>
-
-<p class=MsoBodyText style='page-break-after:avoid'><img width=543 height=575
-src="images/image004.gif"></p>
-
-<p class=MsoCaption style='margin-top:6.0pt;margin-right:0cm;margin-bottom:
-12.0pt;margin-left:0cm'><a name="_Ref263163308">Figure </a>4. Decoder UC: Check Integrity.</p>
-
-<b><span style='font-size:13.0pt;font-family:"Arial","sans-serif"'><br
-clear=all style='page-break-before:always'>
-</span></b>
-
-<h3><a name="_Toc276471430"></a><a name="_Ref263163117">3.2.2<span
-style='font:7.0pt "Times New Roman"'>&nbsp;&nbsp;&nbsp; </span>Get Content Type</a></h3>
-
-<p class=MsoBodyText style='margin-bottom:24.0pt'><span style='font-size:10.0pt;
-font-family:"Lucida Console","DejaVu Sans Mono"'>FwdLockFile_GetContentType</span> returns a
-read-only reference to an ASCII string containing the MIME type of the
-embedded content. This reference is valid as long as the file is kept open.
-Clients who need access to the content type after closing the file should make
-a copy of the string. See Figure 5 below.</p>
-
-<p class=MsoBodyText style='page-break-after:avoid'><img width=543 height=488
-src="images/image005.gif"></p>
-
-<p class=MsoCaption style='margin-top:6.0pt;margin-right:0cm;margin-bottom:
-12.0pt;margin-left:0cm'><a name="_Ref263163392">Figure </a>5. Decoder UC: Get Content Type.</p>
-
-<b><span style='font-size:13.0pt;font-family:"Arial","sans-serif"'><br
-clear=all style='page-break-before:always'>
-</span></b>
-
-<h3><a name="_Toc276471431"></a><a name="_Ref263163137">3.2.3<span
-style='font:7.0pt "Times New Roman"'>&nbsp;&nbsp;&nbsp; </span>Decode File</a></h3>
-
-<p class=MsoBodyText>After opening an internal Forward Lock file (or attaching
-to an already open one), it can be transparently read from as if it were
-unencrypted. Any number of calls to read data from the current file position or
-set it to a new one (which is what <span style='font-size:10.0pt;font-family:
-"Lucida Console","DejaVu Sans Mono"'>lseek</span> does) can be made in any order; this is what we
-call <i>random access</i>. See Figure 6.</p>
-
-<p class=MsoBodyText>The Forward Lock Decoder versions of the <span
-style='font-size:10.0pt;font-family:"Lucida Console","DejaVu Sans Mono"'>read</span>, <span
-style='font-size:10.0pt;font-family:"Lucida Console","DejaVu Sans Mono"'>lseek</span>, and <span
-style='font-size:10.0pt;font-family:"Lucida Console","DejaVu Sans Mono"'>close</span> functions
-have the exact same signatures as their POSIX counterparts. So, for example,
-the call <span style='font-size:10.0pt;font-family:"Lucida Console","DejaVu Sans Mono"'>FwdLockFile_lseek(fd,
-0, SEEK_END)</span> returns the size of the embedded content data, i.e., the
-size of the original file before DRM protection.</p>
-
-<p class=MsoBodyText style='margin-bottom:24.0pt'>Moreover, <span
-style='font-size:10.0pt;font-family:"Lucida Console","DejaVu Sans Mono"'>FwdLockFile_open</span>
-is like regular POSIX <span style='font-size:10.0pt;font-family:"Lucida Console","DejaVu Sans Mono"'>open</span>
-except it takes only the filename as a parameter—access is always read-only.</p>
-
-<p class=MsoBodyText style='page-break-after:avoid'><img width=543 height=522
-src="images/image006.gif"></p>
-
-<p class=MsoCaption style='margin-top:6.0pt;margin-right:0cm;margin-bottom:
-12.0pt;margin-left:0cm'><a name="_Ref263166303">Figure </a>6. Decoder UC: Decode File.</p>
-
-<b><span style='font-size:16.0pt;font-family:"Arial","sans-serif"'><br
-clear=all style='page-break-before:always'>
-</span></b>
-
-<h1><a name="_Toc276471432">4<span style='font:7.0pt "Times New Roman"'>&nbsp;&nbsp;&nbsp;&nbsp;&nbsp;
-</span>Definition of the Internal Forward Lock File Format</a></h1>
-
-<p class=MsoBodyText style='margin-bottom:12.0pt'>The inner structure of an internal
-Forward Lock file is defined in Table 1 below.</p>
-
-<table class=MsoNormalTable border=1 cellspacing=0 cellpadding=0
- style='border-collapse:collapse;border:none'>
- <tr>
- <td width=111 valign=top style='width:83.4pt;border:solid windowtext 1.0pt;
- padding:0cm 5.4pt 0cm 5.4pt'>
- <p class=MsoNormal style='page-break-after:avoid'><b>Offset [bytes]</b></p>
- </td>
- <td width=96 valign=top style='width:72.0pt;border:solid windowtext 1.0pt;
- border-left:none;padding:0cm 5.4pt 0cm 5.4pt'>
- <p class=MsoNormal style='page-break-after:avoid'><b>Size [bytes]</b></p>
- </td>
- <td width=361 valign=top style='width:270.85pt;border:solid windowtext 1.0pt;
- border-left:none;padding:0cm 5.4pt 0cm 5.4pt'>
- <p class=MsoNormal style='page-break-after:avoid'><b>Description</b></p>
- </td>
- </tr>
- <tr>
- <td width=111 valign=top style='width:83.4pt;border:solid windowtext 1.0pt;
- border-top:none;padding:0cm 5.4pt 0cm 5.4pt'>
- <p class=MsoNormal style='page-break-after:avoid'>0</p>
- </td>
- <td width=96 valign=top style='width:72.0pt;border-top:none;border-left:none;
- border-bottom:solid windowtext 1.0pt;border-right:solid windowtext 1.0pt;
- padding:0cm 5.4pt 0cm 5.4pt'>
- <p class=MsoNormal style='page-break-after:avoid'>4</p>
- </td>
- <td width=361 valign=top style='width:270.85pt;border-top:none;border-left:
- none;border-bottom:solid windowtext 1.0pt;border-right:solid windowtext 1.0pt;
- padding:0cm 5.4pt 0cm 5.4pt'>
- <p class=MsoNormal style='page-break-after:avoid'>The file signature (so-called
- <i>magic number</i>): a four-character code consisting of the letters
- F-W-L-K.</p>
- </td>
- </tr>
- <tr>
- <td width=111 valign=top style='width:83.4pt;border:solid windowtext 1.0pt;
- border-top:none;padding:0cm 5.4pt 0cm 5.4pt'>
- <p class=MsoNormal style='page-break-after:avoid'>4</p>
- </td>
- <td width=96 valign=top style='width:72.0pt;border-top:none;border-left:none;
- border-bottom:solid windowtext 1.0pt;border-right:solid windowtext 1.0pt;
- padding:0cm 5.4pt 0cm 5.4pt'>
- <p class=MsoNormal style='page-break-after:avoid'>1</p>
- </td>
- <td width=361 valign=top style='width:270.85pt;border-top:none;border-left:
- none;border-bottom:solid windowtext 1.0pt;border-right:solid windowtext 1.0pt;
- padding:0cm 5.4pt 0cm 5.4pt'>
- <p class=MsoNormal style='page-break-after:avoid'>Version number (0 for the
- first version).</p>
- </td>
- </tr>
- <tr>
- <td width=111 valign=top style='width:83.4pt;border:solid windowtext 1.0pt;
- border-top:none;padding:0cm 5.4pt 0cm 5.4pt'>
- <p class=MsoNormal style='page-break-after:avoid'>5</p>
- </td>
- <td width=96 valign=top style='width:72.0pt;border-top:none;border-left:none;
- border-bottom:solid windowtext 1.0pt;border-right:solid windowtext 1.0pt;
- padding:0cm 5.4pt 0cm 5.4pt'>
- <p class=MsoNormal style='page-break-after:avoid'>1</p>
- </td>
- <td width=361 valign=top style='width:270.85pt;border-top:none;border-left:
- none;border-bottom:solid windowtext 1.0pt;border-right:solid windowtext 1.0pt;
- padding:0cm 5.4pt 0cm 5.4pt'>
- <p class=MsoNormal style='page-break-after:avoid'>Indicates the subformat:</p>
- <p class=MsoNormal style='page-break-after:avoid'><i>0x00 Forward Lock</i></p>
- <p class=MsoNormal style='page-break-after:avoid'><i>0x01 Combined Delivery</i></p>
- </td>
- </tr>
- <tr>
- <td width=111 valign=top style='width:83.4pt;border:solid windowtext 1.0pt;
- border-top:none;padding:0cm 5.4pt 0cm 5.4pt'>
- <p class=MsoNormal style='page-break-after:avoid'>6</p>
- </td>
- <td width=96 valign=top style='width:72.0pt;border-top:none;border-left:none;
- border-bottom:solid windowtext 1.0pt;border-right:solid windowtext 1.0pt;
- padding:0cm 5.4pt 0cm 5.4pt'>
- <p class=MsoNormal style='page-break-after:avoid'>1</p>
- </td>
- <td width=361 valign=top style='width:270.85pt;border-top:none;border-left:
- none;border-bottom:solid windowtext 1.0pt;border-right:solid windowtext 1.0pt;
- padding:0cm 5.4pt 0cm 5.4pt'>
- <p class=MsoNormal style='page-break-after:avoid'>Usage restriction flags (prohibitions
- against usage as ringtone or as wallpaper and screen saver). Also indicates
- if the file is bound to a specific SIM card.</p>
- <p class=MsoNormal style='page-break-after:avoid'><i>0x00 No usage
- restrictions</i></p>
- <p class=MsoNormal style='page-break-after:avoid'><i>0x01 Ringtone usage
- prohibited</i></p>
- <p class=MsoNormal style='page-break-after:avoid'><i>0x02 Screen usage
- prohibited</i></p>
- <p class=MsoNormal style='page-break-after:avoid'><i>0x80 Bound to SIM</i></p>
- <p class=MsoNormal style='page-break-after:avoid'>(Any number of these may be
- OR-ed together.)</p>
- </td>
- </tr>
- <tr>
- <td width=111 valign=top style='width:83.4pt;border:solid windowtext 1.0pt;
- border-top:none;padding:0cm 5.4pt 0cm 5.4pt'>
- <p class=MsoNormal style='page-break-after:avoid'>7</p>
- </td>
- <td width=96 valign=top style='width:72.0pt;border-top:none;border-left:none;
- border-bottom:solid windowtext 1.0pt;border-right:solid windowtext 1.0pt;
- padding:0cm 5.4pt 0cm 5.4pt'>
- <p class=MsoNormal style='page-break-after:avoid'>1</p>
- </td>
- <td width=361 valign=top style='width:270.85pt;border-top:none;border-left:
- none;border-bottom:solid windowtext 1.0pt;border-right:solid windowtext 1.0pt;
- padding:0cm 5.4pt 0cm 5.4pt'>
- <p class=MsoNormal style='page-break-after:avoid'>Length of the MIME content
- type (<i>k</i>).</p>
- </td>
- </tr>
- <tr>
- <td width=111 valign=top style='width:83.4pt;border:solid windowtext 1.0pt;
- border-top:none;padding:0cm 5.4pt 0cm 5.4pt'>
- <p class=MsoNormal style='page-break-after:avoid'>8</p>
- </td>
- <td width=96 valign=top style='width:72.0pt;border-top:none;border-left:none;
- border-bottom:solid windowtext 1.0pt;border-right:solid windowtext 1.0pt;
- padding:0cm 5.4pt 0cm 5.4pt'>
- <p class=MsoNormal style='page-break-after:avoid'><i>k</i></p>
- </td>
- <td width=361 valign=top style='width:270.85pt;border-top:none;border-left:
- none;border-bottom:solid windowtext 1.0pt;border-right:solid windowtext 1.0pt;
- padding:0cm 5.4pt 0cm 5.4pt'>
- <p class=MsoNormal style='page-break-after:avoid'>The MIME content type
- (ASCII-encoded without null-character termination).</p>
- </td>
- </tr>
- <tr>
- <td width=111 valign=top style='width:83.4pt;border:solid windowtext 1.0pt;
- border-top:none;padding:0cm 5.4pt 0cm 5.4pt'>
- <p class=MsoNormal style='page-break-after:avoid'>8+<i>k</i></p>
- </td>
- <td width=96 valign=top style='width:72.0pt;border-top:none;border-left:none;
- border-bottom:solid windowtext 1.0pt;border-right:solid windowtext 1.0pt;
- padding:0cm 5.4pt 0cm 5.4pt'>
- <p class=MsoNormal style='page-break-after:avoid'><i>l </i>= 0 or 16</p>
- </td>
- <td width=361 valign=top style='width:270.85pt;border-top:none;border-left:
- none;border-bottom:solid windowtext 1.0pt;border-right:solid windowtext 1.0pt;
- padding:0cm 5.4pt 0cm 5.4pt'>
- <p class=MsoNormal style='page-break-after:avoid'>If the subformat is
- Combined Delivery, this field contains the auto-generated content ID (16&nbsp;bytes).
- If not, this field is zero-size.</p>
- </td>
- </tr>
- <tr>
- <td width=111 valign=top style='width:83.4pt;border:solid windowtext 1.0pt;
- border-top:none;padding:0cm 5.4pt 0cm 5.4pt'>
- <p class=MsoNormal style='page-break-after:avoid'>8+<i>k</i>+<i>l</i></p>
- </td>
- <td width=96 valign=top style='width:72.0pt;border-top:none;border-left:none;
- border-bottom:solid windowtext 1.0pt;border-right:solid windowtext 1.0pt;
- padding:0cm 5.4pt 0cm 5.4pt'>
- <p class=MsoNormal style='page-break-after:avoid'><i>m </i>= 0 or 9</p>
- </td>
- <td width=361 valign=top style='width:270.85pt;border-top:none;border-left:
- none;border-bottom:solid windowtext 1.0pt;border-right:solid windowtext 1.0pt;
- padding:0cm 5.4pt 0cm 5.4pt'>
- <p class=MsoNormal style='page-break-after:avoid'>If the file is bound to a
- specific SIM card, this field contains the 9-byte packed IMSI number. If not,
- this field is zero-size.</p>
- </td>
- </tr>
- <tr>
- <td width=111 valign=top style='width:83.4pt;border:solid windowtext 1.0pt;
- border-top:none;padding:0cm 5.4pt 0cm 5.4pt'>
- <p class=MsoNormal style='page-break-after:avoid'>8+<i>k</i>+<i>l</i>+<i>m</i></p>
- </td>
- <td width=96 valign=top style='width:72.0pt;border-top:none;border-left:none;
- border-bottom:solid windowtext 1.0pt;border-right:solid windowtext 1.0pt;
- padding:0cm 5.4pt 0cm 5.4pt'>
- <p class=MsoNormal style='page-break-after:avoid'><i>n</i> &#8805; 16</p>
- </td>
- <td width=361 valign=top style='width:270.85pt;border-top:none;border-left:
- none;border-bottom:solid windowtext 1.0pt;border-right:solid windowtext 1.0pt;
- padding:0cm 5.4pt 0cm 5.4pt'>
- <p class=MsoNormal style='page-break-after:avoid'>The encrypted session key, the
- first sixteen bytes of which are also used as the CTR-mode <i>nonce</i> (similar
- to the CBC-mode <i>initialization vector</i>).</p>
- </td>
- </tr>
- <tr>
- <td width=111 valign=top style='width:83.4pt;border:solid windowtext 1.0pt;
- border-top:none;padding:0cm 5.4pt 0cm 5.4pt'>
- <p class=MsoNormal style='page-break-after:avoid'>8+<i>k</i>+<i>l</i>+<i>m</i>+<i>n</i></p>
- </td>
- <td width=96 valign=top style='width:72.0pt;border-top:none;border-left:none;
- border-bottom:solid windowtext 1.0pt;border-right:solid windowtext 1.0pt;
- padding:0cm 5.4pt 0cm 5.4pt'>
- <p class=MsoNormal style='page-break-after:avoid'>20</p>
- </td>
- <td width=361 valign=top style='width:270.85pt;border-top:none;border-left:
- none;border-bottom:solid windowtext 1.0pt;border-right:solid windowtext 1.0pt;
- padding:0cm 5.4pt 0cm 5.4pt'>
- <p class=MsoNormal style='page-break-after:avoid'>Data signature—the SHA-1
- HMAC of the encrypted content data.</p>
- </td>
- </tr>
- <tr>
- <td width=111 valign=top style='width:83.4pt;border:solid windowtext 1.0pt;
- border-top:none;padding:0cm 5.4pt 0cm 5.4pt'>
- <p class=MsoNormal style='page-break-after:avoid'>28+<i>k</i>+<i>l</i>+<i>m</i>+<i>n</i></p>
- </td>
- <td width=96 valign=top style='width:72.0pt;border-top:none;border-left:none;
- border-bottom:solid windowtext 1.0pt;border-right:solid windowtext 1.0pt;
- padding:0cm 5.4pt 0cm 5.4pt'>
- <p class=MsoNormal style='page-break-after:avoid'>20</p>
- </td>
- <td width=361 valign=top style='width:270.85pt;border-top:none;border-left:
- none;border-bottom:solid windowtext 1.0pt;border-right:solid windowtext 1.0pt;
- padding:0cm 5.4pt 0cm 5.4pt'>
- <p class=MsoNormal style='page-break-after:avoid'>Header signature—the SHA-1
- HMAC of all the fields above, including the encrypted session key and data
- signature.</p>
- </td>
- </tr>
- <tr>
- <td width=111 valign=top style='width:83.4pt;border:solid windowtext 1.0pt;
- border-top:none;padding:0cm 5.4pt 0cm 5.4pt'>
- <p class=MsoNormal style='page-break-after:avoid'>48+<i>k</i>+<i>l</i>+<i>m</i>+<i>n</i></p>
- </td>
- <td width=96 valign=top style='width:72.0pt;border-top:none;border-left:none;
- border-bottom:solid windowtext 1.0pt;border-right:solid windowtext 1.0pt;
- padding:0cm 5.4pt 0cm 5.4pt'>
- <p class=MsoNormal style='page-break-after:avoid'><i>&lt;to the end of the
- file&gt;</i></p>
- </td>
- <td width=361 valign=top style='width:270.85pt;border-top:none;border-left:
- none;border-bottom:solid windowtext 1.0pt;border-right:solid windowtext 1.0pt;
- padding:0cm 5.4pt 0cm 5.4pt'>
- <p class=MsoNormal style='page-break-after:avoid'>The content data encrypted
- using 128-bit AES in CTR mode.</p>
- </td>
- </tr>
-</table>
-
-<p class=MsoCaption style='margin-top:6.0pt;margin-right:0cm;margin-bottom:
-12.0pt;margin-left:0cm;page-break-after:avoid'><a name="_Ref151269206">Table </a>1. Definition of the fields of an internal Forward Lock file.</p>
-
-<p class=MsoBodyText>As of now, neither Combined Delivery nor usage
-restrictions (including SIM binding) are supported. These fields are reserved
-for future use.</p>
-
-<h2><a name="_Toc276471433">4.1<span style='font:7.0pt "Times New Roman"'>&nbsp;&nbsp;&nbsp;
-</span>Key Derivation</a></h2>
-
-<p class=MsoBodyText>The session key consists of sixteen bytes fetched from a
-cryptographically secure random number generator. From the session key, two
-separate keys are derived: one used for encryption, the other for signing.</p>
-
-<p class=MsoBodyText>The encryption key is the output from encrypting the
-16-byte all-zero input block {0, 0, …, 0} using 128-bit AES with the random session
-key as the key. The signing key is the output from encrypting the 16-byte input
-block {1, 0, …, 0} the same way. The keys so derived will be cryptographically
-independent from each other.</p>
-
-<p class=MsoBodyText>The session key is encrypted using a hardware-dependent
-key-encryption key unique to each device. The encrypted session key is stored
-inside the file, and its first sixteen bytes are also used as the <i>nonce</i>
-for the CTR-mode encryption of the content data.</p>
-
-<h2><a name="_Toc276471434">4.2<span style='font:7.0pt "Times New Roman"'>&nbsp;&nbsp;&nbsp;
-</span>Calculation of the Counters</a></h2>
-
-<p class=MsoBodyText>Using CTR (“counter”) mode, a block cipher such as AES can
-be turned into a stream cipher. The process of encryption and decryption is
-well defined in [1], except for the specifics of the calculation of the
-counters. For the internal Forward Lock file format, the counters are
-calculated as follows:</p>
-
-<p class=MsoBodyText style='margin-left:36.0pt;text-indent:-18.0pt'>1.<span
-style='font:7.0pt "Times New Roman"'>&nbsp;&nbsp;&nbsp;&nbsp;&nbsp; </span>The
-nonce is interpreted as a 128-bit unsigned integer in little-endian format.</p>
-
-<p class=MsoBodyText style='margin-left:36.0pt;text-indent:-18.0pt'>2.<span
-style='font:7.0pt "Times New Roman"'>&nbsp;&nbsp;&nbsp;&nbsp;&nbsp; </span>The
-zero-based block sequence number (also a little-endian unsigned integer) is
-added modulo 2<sup>128</sup> to the nonce to produce the counter for a given
-block.</p>
-
-<h1><a name="_Toc276471435">5<span style='font:7.0pt "Times New Roman"'>&nbsp;&nbsp;&nbsp;&nbsp;&nbsp;
-</span>Unit Test Cases</a></h1>
-
-<p class=MsoBodyText>Unit test cases for the converter and decoder come in two
-varieties:</p>
-
-<p class=MsoBodyText style='margin-left:36.0pt;text-indent:-18.0pt'>1.<span
-style='font:7.0pt "Times New Roman"'>&nbsp;&nbsp;&nbsp;&nbsp;&nbsp; </span><i>Black-box</i>
-test cases aim to verify that you get sensible results from malformed or
-“tricky” input data.</p>
-
-<p class=MsoBodyText style='margin-left:36.0pt;text-indent:-18.0pt'>2.<span
-style='font:7.0pt "Times New Roman"'>&nbsp;&nbsp;&nbsp;&nbsp;&nbsp; </span><i>White-box</i>
-test cases aim to maximize code coverage using knowledge of code internals.</p>
-
-<p class=MsoBodyText>The black-box test cases are dependent on a specifically
-designed set of input files found in the <span style='font-size:10.0pt;
-font-family:"Lucida Console","DejaVu Sans Mono"'>forward-lock/internal-format/test/res</span>
-directory in the repository. For ‘tests’ variants of the software, these input
-files will be automatically installed in the file system image during build.</p>
-
-<p class=MsoBodyText>Run the test cases from the ADB shell command line as
-follows:</p>
-
-<p class=MsoNormal style='margin-top:0cm;margin-right:0cm;margin-bottom:6.0pt;
-margin-left:21.55pt'><span style='font-size:10.0pt;font-family:"Lucida Console","DejaVu Sans Mono"'>#
-gtest_fwdlock</span></p>
-
-<p class=MsoBodyText>If all black-box but no white-box test cases fail, the
-input files probably can’t be found in the working directory.</p>
-
-<h1><a name="_Toc276471436">6<span style='font:7.0pt "Times New Roman"'>&nbsp;&nbsp;&nbsp;&nbsp;&nbsp;
-</span>References</a></h1>
-
-<p class=MsoBodyText style='margin-left:28.9pt;text-indent:-28.9pt'>[1]<span
-style='font:7.0pt "Times New Roman"'>&nbsp;&nbsp;&nbsp;&nbsp;&nbsp;&nbsp;&nbsp;&nbsp;&nbsp;&nbsp;
-</span><a
-href="http://csrc.nist.gov/publications/nistpubs/800-38a/sp800-38a.pdf">Dworkin,
-Morris: “Recommendation for Block Cipher Modes of Operation—Methods and
-Techniques,” NIST Special Publication 800-38A, December 2001.</a><a
-name="_Ref151269073"></a></p>
-
-</div>
-
-</body>
-
-</html>
diff --git a/drm/libdrmframework/plugins/forward-lock/internal-format/doc/images/image001.gif b/drm/libdrmframework/plugins/forward-lock/internal-format/doc/images/image001.gif
deleted file mode 100644
index ee94513..0000000
--- a/drm/libdrmframework/plugins/forward-lock/internal-format/doc/images/image001.gif
+++ /dev/null
Binary files differ
diff --git a/drm/libdrmframework/plugins/forward-lock/internal-format/doc/images/image002.gif b/drm/libdrmframework/plugins/forward-lock/internal-format/doc/images/image002.gif
deleted file mode 100644
index 8c12f46..0000000
--- a/drm/libdrmframework/plugins/forward-lock/internal-format/doc/images/image002.gif
+++ /dev/null
Binary files differ
diff --git a/drm/libdrmframework/plugins/forward-lock/internal-format/doc/images/image003.gif b/drm/libdrmframework/plugins/forward-lock/internal-format/doc/images/image003.gif
deleted file mode 100644
index 9e019ca..0000000
--- a/drm/libdrmframework/plugins/forward-lock/internal-format/doc/images/image003.gif
+++ /dev/null
Binary files differ
diff --git a/drm/libdrmframework/plugins/forward-lock/internal-format/doc/images/image004.gif b/drm/libdrmframework/plugins/forward-lock/internal-format/doc/images/image004.gif
deleted file mode 100644
index cae1d01..0000000
--- a/drm/libdrmframework/plugins/forward-lock/internal-format/doc/images/image004.gif
+++ /dev/null
Binary files differ
diff --git a/drm/libdrmframework/plugins/forward-lock/internal-format/doc/images/image005.gif b/drm/libdrmframework/plugins/forward-lock/internal-format/doc/images/image005.gif
deleted file mode 100644
index 0d87be9..0000000
--- a/drm/libdrmframework/plugins/forward-lock/internal-format/doc/images/image005.gif
+++ /dev/null
Binary files differ
diff --git a/drm/libdrmframework/plugins/forward-lock/internal-format/doc/images/image006.gif b/drm/libdrmframework/plugins/forward-lock/internal-format/doc/images/image006.gif
deleted file mode 100644
index 9445b6b..0000000
--- a/drm/libdrmframework/plugins/forward-lock/internal-format/doc/images/image006.gif
+++ /dev/null
Binary files differ
diff --git a/drm/libdrmframework/plugins/passthru/Android.mk b/drm/libdrmframework/plugins/passthru/Android.mk
deleted file mode 100644
index d0d1439..0000000
--- a/drm/libdrmframework/plugins/passthru/Android.mk
+++ /dev/null
@@ -1,42 +0,0 @@
-#
-# Copyright (C) 2010 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.
-#
-LOCAL_PATH:= $(call my-dir)
-include $(CLEAR_VARS)
-
-LOCAL_SRC_FILES:= \
- src/DrmPassthruPlugIn.cpp
-
-LOCAL_MODULE := libdrmpassthruplugin
-
-LOCAL_STATIC_LIBRARIES := libdrmframeworkcommon
-
-LOCAL_SHARED_LIBRARIES := \
- libutils \
- libdl
-
-
-LOCAL_C_INCLUDES += \
- $(TOP)/frameworks/base/drm/libdrmframework/include \
- $(TOP)/frameworks/base/drm/libdrmframework/plugins/passthru/include \
- $(TOP)/frameworks/base/drm/libdrmframework/plugins/common/include \
- $(TOP)/frameworks/base/include
-
-# Set the following flag to enable the decryption passthru flow
-#LOCAL_CFLAGS += -DENABLE_PASSTHRU_DECRYPTION
-
-LOCAL_MODULE_TAGS := optional
-
-include $(BUILD_SHARED_LIBRARY)
diff --git a/drm/libdrmframework/plugins/passthru/include/DrmPassthruPlugIn.h b/drm/libdrmframework/plugins/passthru/include/DrmPassthruPlugIn.h
deleted file mode 100644
index f941f70..0000000
--- a/drm/libdrmframework/plugins/passthru/include/DrmPassthruPlugIn.h
+++ /dev/null
@@ -1,102 +0,0 @@
-/*
- * Copyright (C) 2010 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.
- */
-
-#ifndef __DRM_PASSTHRU_PLUGIN_H__
-#define __DRM_PASSTHRU_PLUGIN_H__
-
-#include <DrmEngineBase.h>
-
-namespace android {
-
-class DrmPassthruPlugIn : public DrmEngineBase {
-
-public:
- DrmPassthruPlugIn();
- virtual ~DrmPassthruPlugIn();
-
-protected:
- DrmConstraints* onGetConstraints(int uniqueId, const String8* path, int action);
-
- DrmMetadata* onGetMetadata(int uniqueId, const String8* path);
-
- status_t onInitialize(int uniqueId);
-
- status_t onSetOnInfoListener(int uniqueId, const IDrmEngine::OnInfoListener* infoListener);
-
- status_t onTerminate(int uniqueId);
-
- bool onCanHandle(int uniqueId, const String8& path);
-
- DrmInfoStatus* onProcessDrmInfo(int uniqueId, const DrmInfo* drmInfo);
-
- status_t onSaveRights(int uniqueId, const DrmRights& drmRights,
- const String8& rightsPath, const String8& contentPath);
-
- DrmInfo* onAcquireDrmInfo(int uniqueId, const DrmInfoRequest* drmInfoRequest);
-
- String8 onGetOriginalMimeType(int uniqueId, const String8& path);
-
- int onGetDrmObjectType(int uniqueId, const String8& path, const String8& mimeType);
-
- int onCheckRightsStatus(int uniqueId, const String8& path, int action);
-
- status_t onConsumeRights(int uniqueId, DecryptHandle* decryptHandle, int action, bool reserve);
-
- status_t onSetPlaybackStatus(
- int uniqueId, DecryptHandle* decryptHandle, int playbackStatus, int64_t position);
-
- bool onValidateAction(
- int uniqueId, const String8& path, int action, const ActionDescription& description);
-
- status_t onRemoveRights(int uniqueId, const String8& path);
-
- status_t onRemoveAllRights(int uniqueId);
-
- status_t onOpenConvertSession(int uniqueId, int convertId);
-
- DrmConvertedStatus* onConvertData(int uniqueId, int convertId, const DrmBuffer* inputData);
-
- DrmConvertedStatus* onCloseConvertSession(int uniqueId, int convertId);
-
- DrmSupportInfo* onGetSupportInfo(int uniqueId);
-
- status_t onOpenDecryptSession(
- int uniqueId, DecryptHandle* decryptHandle, int fd, off64_t offset, off64_t length);
-
- status_t onOpenDecryptSession(
- int uniqueId, DecryptHandle* decryptHandle, const char* uri);
-
- status_t onCloseDecryptSession(int uniqueId, DecryptHandle* decryptHandle);
-
- status_t onInitializeDecryptUnit(int uniqueId, DecryptHandle* decryptHandle,
- int decryptUnitId, const DrmBuffer* headerInfo);
-
- status_t onDecrypt(int uniqueId, DecryptHandle* decryptHandle, int decryptUnitId,
- const DrmBuffer* encBuffer, DrmBuffer** decBuffer, DrmBuffer* IV);
-
- status_t onFinalizeDecryptUnit(int uniqueId, DecryptHandle* decryptHandle, int decryptUnitId);
-
- ssize_t onPread(int uniqueId, DecryptHandle* decryptHandle,
- void* buffer, ssize_t numBytes, off64_t offset);
-
-private:
- DecryptHandle* openDecryptSessionImpl();
-};
-
-};
-
-#endif /* __DRM_PASSTHRU_PLUGIN_H__ */
-
diff --git a/drm/libdrmframework/plugins/passthru/src/DrmPassthruPlugIn.cpp b/drm/libdrmframework/plugins/passthru/src/DrmPassthruPlugIn.cpp
deleted file mode 100644
index 0ffc0a7..0000000
--- a/drm/libdrmframework/plugins/passthru/src/DrmPassthruPlugIn.cpp
+++ /dev/null
@@ -1,299 +0,0 @@
-/*
- * Copyright (C) 2010 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.
- */
-
-#define LOG_NDEBUG 0
-#define LOG_TAG "DrmPassthruPlugIn"
-#include <utils/Log.h>
-
-#include <drm/DrmRights.h>
-#include <drm/DrmConstraints.h>
-#include <drm/DrmMetadata.h>
-#include <drm/DrmInfo.h>
-#include <drm/DrmInfoEvent.h>
-#include <drm/DrmInfoStatus.h>
-#include <drm/DrmConvertedStatus.h>
-#include <drm/DrmInfoRequest.h>
-#include <drm/DrmSupportInfo.h>
-#include <DrmPassthruPlugIn.h>
-
-using namespace android;
-
-
-// This extern "C" is mandatory to be managed by TPlugInManager
-extern "C" IDrmEngine* create() {
- return new DrmPassthruPlugIn();
-}
-
-// This extern "C" is mandatory to be managed by TPlugInManager
-extern "C" void destroy(IDrmEngine* pPlugIn) {
- delete pPlugIn;
- pPlugIn = NULL;
-}
-
-DrmPassthruPlugIn::DrmPassthruPlugIn()
- : DrmEngineBase() {
-
-}
-
-DrmPassthruPlugIn::~DrmPassthruPlugIn() {
-
-}
-
-DrmMetadata* DrmPassthruPlugIn::onGetMetadata(int uniqueId, const String8* path) {
- return NULL;
-}
-
-DrmConstraints* DrmPassthruPlugIn::onGetConstraints(
- int uniqueId, const String8* path, int action) {
- ALOGD("DrmPassthruPlugIn::onGetConstraints From Path: %d", uniqueId);
- DrmConstraints* drmConstraints = new DrmConstraints();
-
- String8 value("dummy_available_time");
- char* charValue = NULL;
- charValue = new char[value.length() + 1];
- strncpy(charValue, value.string(), value.length());
-
- //Just add dummy available time for verification
- drmConstraints->put(&(DrmConstraints::LICENSE_AVAILABLE_TIME), charValue);
-
- return drmConstraints;
-}
-
-DrmInfoStatus* DrmPassthruPlugIn::onProcessDrmInfo(int uniqueId, const DrmInfo* drmInfo) {
- ALOGD("DrmPassthruPlugIn::onProcessDrmInfo - Enter : %d", uniqueId);
- DrmInfoStatus* drmInfoStatus = NULL;
- if (NULL != drmInfo) {
- switch (drmInfo->getInfoType()) {
- case DrmInfoRequest::TYPE_REGISTRATION_INFO: {
- const DrmBuffer* emptyBuffer = new DrmBuffer();
- drmInfoStatus = new DrmInfoStatus(DrmInfoStatus::STATUS_OK,
- DrmInfoRequest::TYPE_REGISTRATION_INFO, emptyBuffer, drmInfo->getMimeType());
- break;
- }
- case DrmInfoRequest::TYPE_UNREGISTRATION_INFO: {
- const DrmBuffer* emptyBuffer = new DrmBuffer();
- drmInfoStatus = new DrmInfoStatus(DrmInfoStatus::STATUS_OK,
- DrmInfoRequest::TYPE_UNREGISTRATION_INFO, emptyBuffer, drmInfo->getMimeType());
- break;
- }
- case DrmInfoRequest::TYPE_RIGHTS_ACQUISITION_INFO: {
- String8 licenseString("dummy_license_string");
- const int bufferSize = licenseString.size();
- char* data = NULL;
- data = new char[bufferSize];
- memcpy(data, licenseString.string(), bufferSize);
- const DrmBuffer* buffer = new DrmBuffer(data, bufferSize);
- drmInfoStatus = new DrmInfoStatus(DrmInfoStatus::STATUS_OK,
- DrmInfoRequest::TYPE_RIGHTS_ACQUISITION_INFO, buffer, drmInfo->getMimeType());
- break;
- }
- }
- }
- ALOGD("DrmPassthruPlugIn::onProcessDrmInfo - Exit");
- return drmInfoStatus;
-}
-
-status_t DrmPassthruPlugIn::onSetOnInfoListener(
- int uniqueId, const IDrmEngine::OnInfoListener* infoListener) {
- ALOGD("DrmPassthruPlugIn::onSetOnInfoListener : %d", uniqueId);
- return DRM_NO_ERROR;
-}
-
-status_t DrmPassthruPlugIn::onInitialize(int uniqueId) {
- ALOGD("DrmPassthruPlugIn::onInitialize : %d", uniqueId);
- return DRM_NO_ERROR;
-}
-
-status_t DrmPassthruPlugIn::onTerminate(int uniqueId) {
- ALOGD("DrmPassthruPlugIn::onTerminate : %d", uniqueId);
- return DRM_NO_ERROR;
-}
-
-DrmSupportInfo* DrmPassthruPlugIn::onGetSupportInfo(int uniqueId) {
- ALOGD("DrmPassthruPlugIn::onGetSupportInfo : %d", uniqueId);
- DrmSupportInfo* drmSupportInfo = new DrmSupportInfo();
- // Add mimetype's
- drmSupportInfo->addMimeType(String8("application/vnd.passthru.drm"));
- // Add File Suffixes
- drmSupportInfo->addFileSuffix(String8(".passthru"));
- // Add plug-in description
- drmSupportInfo->setDescription(String8("Passthru plug-in"));
- return drmSupportInfo;
-}
-
-status_t DrmPassthruPlugIn::onSaveRights(int uniqueId, const DrmRights& drmRights,
- const String8& rightsPath, const String8& contentPath) {
- ALOGD("DrmPassthruPlugIn::onSaveRights : %d", uniqueId);
- return DRM_NO_ERROR;
-}
-
-DrmInfo* DrmPassthruPlugIn::onAcquireDrmInfo(int uniqueId, const DrmInfoRequest* drmInfoRequest) {
- ALOGD("DrmPassthruPlugIn::onAcquireDrmInfo : %d", uniqueId);
- DrmInfo* drmInfo = NULL;
-
- if (NULL != drmInfoRequest) {
- String8 dataString("dummy_acquistion_string");
- int length = dataString.length();
- char* data = NULL;
- data = new char[length];
- memcpy(data, dataString.string(), length);
- drmInfo = new DrmInfo(drmInfoRequest->getInfoType(),
- DrmBuffer(data, length), drmInfoRequest->getMimeType());
- }
- return drmInfo;
-}
-
-bool DrmPassthruPlugIn::onCanHandle(int uniqueId, const String8& path) {
- ALOGD("DrmPassthruPlugIn::canHandle: %s ", path.string());
- String8 extension = path.getPathExtension();
- extension.toLower();
- return (String8(".passthru") == extension);
-}
-
-String8 DrmPassthruPlugIn::onGetOriginalMimeType(int uniqueId, const String8& path) {
- ALOGD("DrmPassthruPlugIn::onGetOriginalMimeType() : %d", uniqueId);
- return String8("video/passthru");
-}
-
-int DrmPassthruPlugIn::onGetDrmObjectType(
- int uniqueId, const String8& path, const String8& mimeType) {
- ALOGD("DrmPassthruPlugIn::onGetDrmObjectType() : %d", uniqueId);
- return DrmObjectType::UNKNOWN;
-}
-
-int DrmPassthruPlugIn::onCheckRightsStatus(int uniqueId, const String8& path, int action) {
- ALOGD("DrmPassthruPlugIn::onCheckRightsStatus() : %d", uniqueId);
- int rightsStatus = RightsStatus::RIGHTS_VALID;
- return rightsStatus;
-}
-
-status_t DrmPassthruPlugIn::onConsumeRights(int uniqueId, DecryptHandle* decryptHandle,
- int action, bool reserve) {
- ALOGD("DrmPassthruPlugIn::onConsumeRights() : %d", uniqueId);
- return DRM_NO_ERROR;
-}
-
-status_t DrmPassthruPlugIn::onSetPlaybackStatus(int uniqueId, DecryptHandle* decryptHandle,
- int playbackStatus, int64_t position) {
- ALOGD("DrmPassthruPlugIn::onSetPlaybackStatus() : %d", uniqueId);
- return DRM_NO_ERROR;
-}
-
-bool DrmPassthruPlugIn::onValidateAction(int uniqueId, const String8& path,
- int action, const ActionDescription& description) {
- ALOGD("DrmPassthruPlugIn::onValidateAction() : %d", uniqueId);
- return true;
-}
-
-status_t DrmPassthruPlugIn::onRemoveRights(int uniqueId, const String8& path) {
- ALOGD("DrmPassthruPlugIn::onRemoveRights() : %d", uniqueId);
- return DRM_NO_ERROR;
-}
-
-status_t DrmPassthruPlugIn::onRemoveAllRights(int uniqueId) {
- ALOGD("DrmPassthruPlugIn::onRemoveAllRights() : %d", uniqueId);
- return DRM_NO_ERROR;
-}
-
-status_t DrmPassthruPlugIn::onOpenConvertSession(int uniqueId, int convertId) {
- ALOGD("DrmPassthruPlugIn::onOpenConvertSession() : %d", uniqueId);
- return DRM_NO_ERROR;
-}
-
-DrmConvertedStatus* DrmPassthruPlugIn::onConvertData(
- int uniqueId, int convertId, const DrmBuffer* inputData) {
- ALOGD("DrmPassthruPlugIn::onConvertData() : %d", uniqueId);
- DrmBuffer* convertedData = NULL;
-
- if (NULL != inputData && 0 < inputData->length) {
- int length = inputData->length;
- char* data = NULL;
- data = new char[length];
- convertedData = new DrmBuffer(data, length);
- memcpy(convertedData->data, inputData->data, length);
- }
- return new DrmConvertedStatus(DrmConvertedStatus::STATUS_OK, convertedData, 0 /*offset*/);
-}
-
-DrmConvertedStatus* DrmPassthruPlugIn::onCloseConvertSession(int uniqueId, int convertId) {
- ALOGD("DrmPassthruPlugIn::onCloseConvertSession() : %d", uniqueId);
- return new DrmConvertedStatus(DrmConvertedStatus::STATUS_OK, NULL, 0 /*offset*/);
-}
-
-status_t DrmPassthruPlugIn::onOpenDecryptSession(
- int uniqueId, DecryptHandle* decryptHandle, int fd, off64_t offset, off64_t length) {
- ALOGD("DrmPassthruPlugIn::onOpenDecryptSession() : %d", uniqueId);
-
-#ifdef ENABLE_PASSTHRU_DECRYPTION
- decryptHandle->mimeType = String8("video/passthru");
- decryptHandle->decryptApiType = DecryptApiType::ELEMENTARY_STREAM_BASED;
- decryptHandle->status = DRM_NO_ERROR;
- decryptHandle->decryptInfo = NULL;
- return DRM_NO_ERROR;
-#endif
-
- return DRM_ERROR_CANNOT_HANDLE;
-}
-
-status_t DrmPassthruPlugIn::onOpenDecryptSession(
- int uniqueId, DecryptHandle* decryptHandle, const char* uri) {
- return DRM_ERROR_CANNOT_HANDLE;
-}
-
-status_t DrmPassthruPlugIn::onCloseDecryptSession(int uniqueId, DecryptHandle* decryptHandle) {
- ALOGD("DrmPassthruPlugIn::onCloseDecryptSession() : %d", uniqueId);
- if (NULL != decryptHandle) {
- if (NULL != decryptHandle->decryptInfo) {
- delete decryptHandle->decryptInfo; decryptHandle->decryptInfo = NULL;
- }
- delete decryptHandle; decryptHandle = NULL;
- }
- return DRM_NO_ERROR;
-}
-
-status_t DrmPassthruPlugIn::onInitializeDecryptUnit(int uniqueId, DecryptHandle* decryptHandle,
- int decryptUnitId, const DrmBuffer* headerInfo) {
- ALOGD("DrmPassthruPlugIn::onInitializeDecryptUnit() : %d", uniqueId);
- return DRM_NO_ERROR;
-}
-
-status_t DrmPassthruPlugIn::onDecrypt(int uniqueId, DecryptHandle* decryptHandle,
- int decryptUnitId, const DrmBuffer* encBuffer, DrmBuffer** decBuffer, DrmBuffer* IV) {
- ALOGD("DrmPassthruPlugIn::onDecrypt() : %d", uniqueId);
- /**
- * As a workaround implementation passthru would copy the given
- * encrypted buffer as it is to decrypted buffer. Note, decBuffer
- * memory has to be allocated by the caller.
- */
- if (NULL != (*decBuffer) && 0 < (*decBuffer)->length) {
- memcpy((*decBuffer)->data, encBuffer->data, encBuffer->length);
- (*decBuffer)->length = encBuffer->length;
- }
- return DRM_NO_ERROR;
-}
-
-status_t DrmPassthruPlugIn::onFinalizeDecryptUnit(
- int uniqueId, DecryptHandle* decryptHandle, int decryptUnitId) {
- ALOGD("DrmPassthruPlugIn::onFinalizeDecryptUnit() : %d", uniqueId);
- return DRM_NO_ERROR;
-}
-
-ssize_t DrmPassthruPlugIn::onPread(int uniqueId, DecryptHandle* decryptHandle,
- void* buffer, ssize_t numBytes, off64_t offset) {
- ALOGD("DrmPassthruPlugIn::onPread() : %d", uniqueId);
- return 0;
-}
-