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

An entity class that is used to pass information to an online DRM server. An instance of this class is passed to the acquireDrmInfo() method to get an instance of a DrmInfo.
/** * An entity class that is used to pass information to an online DRM server. An instance of this * class is passed to the {@link DrmManagerClient#acquireDrmInfo acquireDrmInfo()} method to get an * instance of a {@link DrmInfo}. * */
public class DrmInfoRequest { // Changes in following constants should be in sync with DrmInfoRequest.h
Acquires DRM server registration information.
/** * Acquires DRM server registration information. */
public static final int TYPE_REGISTRATION_INFO = 1;
Acquires information for unregistering the DRM server.
/** * Acquires information for unregistering the DRM server. */
public static final int TYPE_UNREGISTRATION_INFO = 2;
Acquires rights information.
/** * Acquires rights information. */
public static final int TYPE_RIGHTS_ACQUISITION_INFO = 3;
Acquires the progress of the rights acquisition.
/** * Acquires the progress of the rights acquisition. */
public static final int TYPE_RIGHTS_ACQUISITION_PROGRESS_INFO = 4;
Key that is used to pass the unique session ID for the account or the user.
/** * Key that is used to pass the unique session ID for the account or the user. */
public static final String ACCOUNT_ID = "account_id";
Key that is used to pass the unique session ID for the subscription.
/** * Key that is used to pass the unique session ID for the subscription. */
public static final String SUBSCRIPTION_ID = "subscription_id"; private final int mInfoType; private final String mMimeType; private final HashMap<String, Object> mRequestInformation = new HashMap<String, Object>();
Creates a DrmInfoRequest object with type and MIME type.
Params:
  • infoType – Type of information.
  • mimeType – MIME type.
/** * Creates a <code>DrmInfoRequest</code> object with type and MIME type. * * @param infoType Type of information. * @param mimeType MIME type. */
public DrmInfoRequest(int infoType, String mimeType) { mInfoType = infoType; mMimeType = mimeType; if (!isValid()) { final String msg = "infoType: " + infoType + "," + "mimeType: " + mimeType; throw new IllegalArgumentException(msg); } }
Retrieves the MIME type associated with this object.
Returns:The MIME type.
/** * Retrieves the MIME type associated with this object. * * @return The MIME type. */
public String getMimeType() { return mMimeType; }
Retrieves the information type associated with this object.
Returns:The information type.
/** * Retrieves the information type associated with this object. * * @return The information type. */
public int getInfoType() { return mInfoType; }
Adds optional information as key-value pairs to this object.
Params:
  • key – The key to add.
  • value – The value to add.
/** * Adds optional information as key-value pairs to this object. * * @param key The key to add. * @param value The value to add. */
public void put(String key, Object value) { mRequestInformation.put(key, value); }
Retrieves the value of a given key.
Params:
  • key – The key whose value is being retrieved.
Returns:The value of the key that is being retrieved. Returns null if the key cannot be found.
/** * Retrieves the value of a given key. * * @param key The key whose value is being retrieved. * * @return The value of the key that is being retrieved. Returns null if the key cannot be * found. */
public Object get(String key) { return mRequestInformation.get(key); }
Retrieves an iterator object that you can use to iterate over the keys associated with this DrmInfoRequest object.
Returns:The iterator object.
/** * Retrieves an iterator object that you can use to iterate over the keys associated with * this <code>DrmInfoRequest</code> object. * * @return The iterator object. */
public Iterator<String> keyIterator() { return mRequestInformation.keySet().iterator(); }
Retrieves an iterator object that you can use to iterate over the values associated with this DrmInfoRequest object.
Returns:The iterator object.
/** * Retrieves an iterator object that you can use to iterate over the values associated with * this <code>DrmInfoRequest</code> object. * * @return The iterator object. */
public Iterator<Object> iterator() { return mRequestInformation.values().iterator(); }
Returns whether this instance is valid or not
Returns: true if valid false if invalid
/** * Returns whether this instance is valid or not * * @return * true if valid * false if invalid */
boolean isValid() { return (null != mMimeType && !mMimeType.equals("") && null != mRequestInformation && isValidType(mInfoType)); } /* package */ static boolean isValidType(int infoType) { boolean isValid = false; switch (infoType) { case TYPE_REGISTRATION_INFO: case TYPE_UNREGISTRATION_INFO: case TYPE_RIGHTS_ACQUISITION_INFO: case TYPE_RIGHTS_ACQUISITION_PROGRESS_INFO: isValid = true; break; } return isValid; } }