0e092f806b
This change contains information contributed by Sony Corporation. Bug: 4119363 Change-Id: I6f565c15d512d675993dc65f7fee19bd3d0bc0fa
187 lines
5.7 KiB
Java
Executable File
187 lines
5.7 KiB
Java
Executable File
/*
|
|
* 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.
|
|
*/
|
|
|
|
package android.drm;
|
|
|
|
import java.io.File;
|
|
import java.io.IOException;
|
|
|
|
/**
|
|
* An entity class that wraps the license information retrieved from the online DRM server.
|
|
*<p>
|
|
* A caller can instantiate a {@link DrmRights} object by first invoking the
|
|
* {@link DrmManagerClient#processDrmInfo(DrmInfo)} method and then using the resulting
|
|
* {@link ProcessedData} object to invoke the {@link DrmRights#DrmRights(ProcessedData, String)}
|
|
* constructor.
|
|
*<p>
|
|
* 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>.
|
|
*
|
|
*/
|
|
public class DrmRights {
|
|
private byte[] mData;
|
|
private String mMimeType;
|
|
private String mAccountId = "_NO_USER";
|
|
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.
|
|
*/
|
|
public DrmRights(String rightsFilePath, String mimeType) {
|
|
File file = new File(rightsFilePath);
|
|
instantiate(file, mimeType);
|
|
}
|
|
|
|
/**
|
|
* Creates a <code>DrmRights</code> object with the given parameters.
|
|
*
|
|
* @param rightsFilePath Path to the file containing rights information.
|
|
* @param mimeType MIME type.
|
|
* @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;
|
|
}
|
|
}
|
|
|
|
/**
|
|
* Creates a <code>DrmRights</code> object with the given parameters.
|
|
*
|
|
* @param rightsFilePath Path to the file containing rights information.
|
|
* @param mimeType MIME type.
|
|
* @param accountId Account ID of the user.
|
|
* @param subscriptionId Subscription ID of the user.
|
|
*/
|
|
public 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;
|
|
}
|
|
}
|
|
|
|
/**
|
|
* Creates a <code>DrmRights</code> object with the given parameters.
|
|
*
|
|
* @param rightsFile File containing rights information.
|
|
* @param mimeType MIME type.
|
|
*/
|
|
public DrmRights(File rightsFile, String mimeType) {
|
|
instantiate(rightsFile, mimeType);
|
|
}
|
|
|
|
private void instantiate(File rightsFile, String mimeType) {
|
|
try {
|
|
mData = DrmUtils.readBytes(rightsFile);
|
|
} catch (IOException e) {
|
|
e.printStackTrace();
|
|
}
|
|
|
|
mMimeType = mimeType;
|
|
}
|
|
|
|
/**
|
|
* Creates a <code>DrmRights</code> object with the given parameters.
|
|
*<p>
|
|
* The application can pass the processed data as a <code>String</code> or as binary data.
|
|
*<p>
|
|
* The following code snippet shows how to pass the processed data as a <code>String</code>:
|
|
*<p>
|
|
* new DrmRights(data.getBytes(), mimeType)
|
|
*<p>
|
|
* The following code snippet shows how to pass the processed data as binary data:
|
|
*<p>
|
|
* new DrmRights(binaryData[], mimeType)
|
|
*
|
|
* @param data A {@link ProcessedData} object.
|
|
* @param mimeType The MIME type.
|
|
*/
|
|
public DrmRights(ProcessedData data, String mimeType) {
|
|
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;
|
|
}
|
|
|
|
mMimeType = mimeType;
|
|
}
|
|
|
|
/**
|
|
* Retrieves the rights data associated with this <code>DrmRights</code> object.
|
|
*
|
|
* @return A <code>byte</code> array representing the rights data.
|
|
*/
|
|
public byte[] getData() {
|
|
return mData;
|
|
}
|
|
|
|
/**
|
|
* Retrieves the MIME type associated with this <code>DrmRights</code> object.
|
|
*
|
|
* @return The MIME type.
|
|
*/
|
|
public String getMimeType() {
|
|
return mMimeType;
|
|
}
|
|
|
|
/**
|
|
* Retrieves the account ID associated with this <code>DrmRights</code> object.
|
|
*
|
|
* @return The account ID.
|
|
*/
|
|
public String getAccountId() {
|
|
return mAccountId;
|
|
}
|
|
|
|
/**
|
|
* Retrieves the subscription ID associated with this <code>DrmRights</code> object.
|
|
*
|
|
* @return The subscription ID.
|
|
*/
|
|
public String getSubscriptionId() {
|
|
return mSubscriptionId;
|
|
}
|
|
|
|
/**
|
|
* Determines whether this instance is valid or not.
|
|
*
|
|
* @return True if valid; false if invalid.
|
|
*/
|
|
/*package*/ boolean isValid() {
|
|
return (null != mMimeType && !mMimeType.equals("")
|
|
&& null != mData && mData.length > 0);
|
|
}
|
|
}
|
|
|