/*
 * 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;
import java.util.Arrays;

An entity class that wraps the license information retrieved from the online DRM server.

A caller can instantiate a DrmRights object by first invoking the DrmManagerClient.processDrmInfo(DrmInfo) method and then using the resulting ProcessedData object to invoke the DrmRights(ProcessedData, String) constructor.

A caller can also instantiate a DrmRights object by using the DrmRights(String, String) constructor, which takes a path to a file containing rights information instead of a ProcessedData.

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.

/** * 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>. *<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; private String mSubscriptionId;
Creates a DrmRights object with the given parameters.
Params:
  • rightsFilePath – Path to the file containing rights information.
  • mimeType – MIME type. Must not be null or an empty string.
/** * Creates a <code>DrmRights</code> object with the given parameters. * * @param rightsFilePath Path to the file containing rights information. * @param mimeType MIME type. Must not be null or an empty string. */
public DrmRights(String rightsFilePath, String mimeType) { File file = new File(rightsFilePath); instantiate(file, mimeType); }
Creates a DrmRights object with the given parameters.
Params:
  • rightsFilePath – Path to the file containing rights information.
  • mimeType – MIME type. Must not be null or an empty string.
  • accountId – Account ID of the user.
/** * Creates a <code>DrmRights</code> object with the given parameters. * * @param rightsFilePath Path to the file containing rights information. * @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); mAccountId = accountId; }
Creates a DrmRights object with the given parameters.
Params:
  • rightsFilePath – Path to the file containing rights information.
  • mimeType – MIME type. Must not be null or an empty string.
  • accountId – Account ID of the user.
  • subscriptionId – Subscription ID of the user.
/** * Creates a <code>DrmRights</code> object with the given parameters. * * @param rightsFilePath Path to the file containing rights information. * @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. */
public DrmRights( String rightsFilePath, String mimeType, String accountId, String subscriptionId) { this(rightsFilePath, mimeType); mAccountId = accountId; mSubscriptionId = subscriptionId; }
Creates a DrmRights object with the given parameters.
Params:
  • rightsFile – File containing rights information.
  • mimeType – MIME type. Must not be null or an empty string.
/** * Creates a <code>DrmRights</code> object with the given parameters. * * @param rightsFile File containing rights information. * @param mimeType MIME type. Must not be null or an empty string. */
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; if (!isValid()) { final String msg = "mimeType: " + mMimeType + "," + "data: " + Arrays.toString(mData); throw new IllegalArgumentException(msg); } }
Creates a DrmRights object with the given parameters.
Params:
  • data – A ProcessedData object containing rights information. Must not be null.
  • mimeType – The MIME type. It must not be null or an empty string.
/** * Creates a <code>DrmRights</code> object with the given parameters. * * @param data A {@link ProcessedData} object containing rights information. * 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) { 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: " + Arrays.toString(mData); throw new IllegalArgumentException(msg); } }
Retrieves the rights data associated with this DrmRights object.
Returns:A byte array representing the rights data.
/** * 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 DrmRights object.
Returns:The MIME type.
/** * 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 DrmRights object.
Returns:The account ID.
/** * 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 DrmRights object.
Returns:The subscription ID.
/** * 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.
Returns:True if valid; false if invalid.
/** * 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); } }