/drm/java/android/drm/DrmInfoRequest.java
http://github.com/CyanogenMod/android_frameworks_base · Java · 163 lines · 57 code · 17 blank · 89 comment · 7 complexity · 9523bd19636a2231320944dbc9126912 MD5 · raw 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.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 {@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.
- */
- public static final int TYPE_REGISTRATION_INFO = 1;
- /**
- * Acquires information for unregistering the DRM server.
- */
- public static final int TYPE_UNREGISTRATION_INFO = 2;
- /**
- * Acquires rights information.
- */
- public static final int TYPE_RIGHTS_ACQUISITION_INFO = 3;
- /**
- * 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.
- */
- public static final String ACCOUNT_ID = "account_id";
- /**
- * 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 <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.
- *
- * @return The MIME type.
- */
- public String getMimeType() {
- return mMimeType;
- }
- /**
- * 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.
- *
- * @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.
- *
- * @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 <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 <code>DrmInfoRequest</code> object.
- *
- * @return The iterator object.
- */
- public Iterator<Object> iterator() {
- return mRequestInformation.values().iterator();
- }
- /**
- * 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;
- }
- }