public interface

ContentMetadata

 androidx.media3.datasource.cache.ContentMetadata

Subclasses:

DefaultContentMetadata

Gradle dependencies

compile group: 'androidx.media3', name: 'media3-datasource', version: '1.5.0-alpha01'

  • groupId: androidx.media3
  • artifactId: media3-datasource
  • version: 1.5.0-alpha01

Artifact androidx.media3:media3-datasource:1.5.0-alpha01 it located at Google repository (https://maven.google.com/)

Overview

Interface for an immutable snapshot of keyed metadata.

Summary

Fields
public static final java.lang.StringKEY_CONTENT_LENGTH

Key for content length in bytes (type: long).

public static final java.lang.StringKEY_CUSTOM_PREFIX

Prefix for custom metadata keys.

public static final java.lang.StringKEY_REDIRECTED_URI

Key for redirected uri (type: String).

Methods
public booleancontains(java.lang.String key)

Returns whether the metadata is available.

public byte[]get(java.lang.String key, byte[] defaultValue[])

Returns a metadata value.

public longget(java.lang.String key, long defaultValue)

Returns a metadata value.

public java.lang.Stringget(java.lang.String key, java.lang.String defaultValue)

Returns a metadata value.

public static longgetContentLength(ContentMetadata contentMetadata)

Returns the value stored under ContentMetadata.KEY_CONTENT_LENGTH, or C.LENGTH_UNSET if not set.

public static UrigetRedirectedUri(ContentMetadata contentMetadata)

Returns the value stored under ContentMetadata.KEY_REDIRECTED_URI as a , or {code null} if not set.

Fields

public static final java.lang.String KEY_CUSTOM_PREFIX

Prefix for custom metadata keys. Applications can use keys starting with this prefix without any risk of their keys colliding with ones defined by the ExoPlayer library.

public static final java.lang.String KEY_REDIRECTED_URI

Key for redirected uri (type: String).

public static final java.lang.String KEY_CONTENT_LENGTH

Key for content length in bytes (type: long).

Methods

public byte[] get(java.lang.String key, byte[] defaultValue[])

Returns a metadata value.

Parameters:

key: Key of the metadata to be returned.
defaultValue: Value to return if the metadata doesn't exist.

Returns:

The metadata value.

public java.lang.String get(java.lang.String key, java.lang.String defaultValue)

Returns a metadata value.

Parameters:

key: Key of the metadata to be returned.
defaultValue: Value to return if the metadata doesn't exist.

Returns:

The metadata value.

public long get(java.lang.String key, long defaultValue)

Returns a metadata value.

Parameters:

key: Key of the metadata to be returned.
defaultValue: Value to return if the metadata doesn't exist.

Returns:

The metadata value.

public boolean contains(java.lang.String key)

Returns whether the metadata is available.

public static long getContentLength(ContentMetadata contentMetadata)

Returns the value stored under ContentMetadata.KEY_CONTENT_LENGTH, or C.LENGTH_UNSET if not set.

public static Uri getRedirectedUri(ContentMetadata contentMetadata)

Returns the value stored under ContentMetadata.KEY_REDIRECTED_URI as a , or {code null} if not set.

Source

/*
 * Copyright (C) 2018 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 androidx.media3.datasource.cache;

import android.net.Uri;
import androidx.annotation.Nullable;
import androidx.media3.common.C;
import androidx.media3.common.util.UnstableApi;

/** Interface for an immutable snapshot of keyed metadata. */
@UnstableApi
public interface ContentMetadata {

  /**
   * Prefix for custom metadata keys. Applications can use keys starting with this prefix without
   * any risk of their keys colliding with ones defined by the ExoPlayer library.
   */
  @SuppressWarnings("unused")
  String KEY_CUSTOM_PREFIX = "custom_";

  /** Key for redirected uri (type: String). */
  String KEY_REDIRECTED_URI = "exo_redir";

  /** Key for content length in bytes (type: long). */
  String KEY_CONTENT_LENGTH = "exo_len";

  /**
   * Returns a metadata value.
   *
   * @param key Key of the metadata to be returned.
   * @param defaultValue Value to return if the metadata doesn't exist.
   * @return The metadata value.
   */
  @Nullable
  byte[] get(String key, @Nullable byte[] defaultValue);

  /**
   * Returns a metadata value.
   *
   * @param key Key of the metadata to be returned.
   * @param defaultValue Value to return if the metadata doesn't exist.
   * @return The metadata value.
   */
  @Nullable
  String get(String key, @Nullable String defaultValue);

  /**
   * Returns a metadata value.
   *
   * @param key Key of the metadata to be returned.
   * @param defaultValue Value to return if the metadata doesn't exist.
   * @return The metadata value.
   */
  long get(String key, long defaultValue);

  /** Returns whether the metadata is available. */
  boolean contains(String key);

  /**
   * Returns the value stored under {@link #KEY_CONTENT_LENGTH}, or {@link C#LENGTH_UNSET} if not
   * set.
   */
  static long getContentLength(ContentMetadata contentMetadata) {
    return contentMetadata.get(KEY_CONTENT_LENGTH, C.LENGTH_UNSET);
  }

  /**
   * Returns the value stored under {@link #KEY_REDIRECTED_URI} as a {@link Uri}, or {code null} if
   * not set.
   */
  @Nullable
  static Uri getRedirectedUri(ContentMetadata contentMetadata) {
    @Nullable String redirectedUri = contentMetadata.get(KEY_REDIRECTED_URI, (String) null);
    return redirectedUri == null ? null : Uri.parse(redirectedUri);
  }
}