Skip to content

Commit

Permalink
Fix: Add support to file type in mediaCapabilities implementation (#3570
Browse files Browse the repository at this point in the history
)

If it's srcEquals, the 'type' element of the input object when querying mediaCapabilities should be 'file'. Otherwise it should be 'media-source' .
Issue: #3530

Change-Id: I8d54f5215f27c663ffdcfef0ec41182139d7f5d7
  • Loading branch information
Álvaro Velad Galván authored and joeyparrish committed Oct 12, 2021
1 parent c43c37d commit a44e9ab
Show file tree
Hide file tree
Showing 4 changed files with 39 additions and 8 deletions.
13 changes: 12 additions & 1 deletion lib/media/drm_engine.js
Original file line number Diff line number Diff line change
Expand Up @@ -126,6 +126,9 @@ shaka.media.DrmEngine = class {

/** @const {!shaka.util.Destroyer} */
this.destroyer_ = new shaka.util.Destroyer(() => this.destroyNow_());

/** @private {boolean} */
this.srcEquals_ = false;
}

/** @override */
Expand Down Expand Up @@ -181,6 +184,7 @@ shaka.media.DrmEngine = class {
this.config_ = null;
this.onError_ = () => {};
this.playerInterface_ = null;
this.srcEquals_ = false;
}

/**
Expand All @@ -194,6 +198,13 @@ shaka.media.DrmEngine = class {
this.config_ = config;
}

/**
* @param {!boolean} value
*/
setSrcEquals(value) {
this.srcEquals_ = value;
}

/**
* Initialize the drm engine for storing and deleting stored content.
*
Expand Down Expand Up @@ -356,7 +367,7 @@ shaka.media.DrmEngine = class {
// in the drm infos, and before queryMediaKeys_().
if (useMediaCapabilities) {
await shaka.util.StreamUtils.getDecodingInfosForVariants(variants,
this.usePersistentLicenses_);
this.usePersistentLicenses_, this.srcEquals_);
} else {
configsByKeySystem =
this.prepareMediaKeyConfigsForVariants_(variants);
Expand Down
1 change: 1 addition & 0 deletions lib/player.js
Original file line number Diff line number Diff line change
Expand Up @@ -2069,6 +2069,7 @@ shaka.Player = class extends shaka.util.FakeEventTarget {
decodingInfos: [],
};

this.drmEngine_.setSrcEquals(/* srcEquals= */ true);
await this.drmEngine_.initForPlayback(
[variant], /* offlineSessionIds= */ []);
await this.drmEngine_.attach(has.mediaElement);
Expand Down
13 changes: 8 additions & 5 deletions lib/util/stream_utils.js
Original file line number Diff line number Diff line change
Expand Up @@ -337,7 +337,7 @@ shaka.util.StreamUtils = class {
'MediaCapabilities should be valid.');

await shaka.util.StreamUtils.getDecodingInfosForVariants(
manifest.variants, usePersistentLicenses);
manifest.variants, usePersistentLicenses, /* srcEquals= */ false);
manifest.variants = manifest.variants.filter((variant) => {
const video = variant.video;
// See: https://github.com/google/shaka-player/issues/3380
Expand Down Expand Up @@ -410,9 +410,11 @@ shaka.util.StreamUtils = class {
*
* @param {!Array.<shaka.extern.Variant>} variants
* @param {boolean} usePersistentLicenses
* @param {boolean} srcEquals
* @exportDoc
*/
static async getDecodingInfosForVariants(variants, usePersistentLicenses) {
static async getDecodingInfosForVariants(variants, usePersistentLicenses,
srcEquals) {
const gotDecodingInfo = variants.some((variant) =>
variant.decodingInfos.length);
if (gotDecodingInfo) {
Expand All @@ -436,7 +438,7 @@ shaka.util.StreamUtils = class {
for (const variant of variants) {
/** @type {!Array.<!MediaDecodingConfiguration>} */
const decodingConfigs = shaka.util.StreamUtils.getDecodingConfigs_(
variant, usePersistentLicenses);
variant, usePersistentLicenses, srcEquals);

for (const config of decodingConfigs) {
operations.push(getVariantDecodingInfos(variant, config));
Expand All @@ -451,17 +453,18 @@ shaka.util.StreamUtils = class {
* results for each variant.
* @param {!shaka.extern.Variant} variant
* @param {boolean} usePersistentLicenses
* @param {boolean} srcEquals
* @return {!Array.<!MediaDecodingConfiguration>}
* @private
*/
static getDecodingConfigs_(variant, usePersistentLicenses) {
static getDecodingConfigs_(variant, usePersistentLicenses, srcEquals) {
const audio = variant.audio;
const video = variant.video;
const ContentType = shaka.util.ManifestParserUtils.ContentType;

/** @type {!MediaDecodingConfiguration} */
const mediaDecodingConfig = {
type: 'media-source',
type: srcEquals ? 'file' : 'media-source',
};

if (video) {
Expand Down
20 changes: 18 additions & 2 deletions test/util/stream_utils_unit.js
Original file line number Diff line number Diff line change
Expand Up @@ -488,7 +488,23 @@ describe('StreamUtils', () => {
});

await StreamUtils.getDecodingInfosForVariants(manifest.variants,
/* usePersistentLicenses= */false);
/* usePersistentLicenses= */false, /* srcEquals= */ false);
expect(manifest.variants.length).toBeTruthy();
expect(manifest.variants[0].decodingInfos.length).toBe(1);
expect(manifest.variants[0].decodingInfos[0].supported).toBeTruthy();
});

it('for srcEquals content', async () => {
manifest = shaka.test.ManifestGenerator.generate((manifest) => {
manifest.addVariant(0, (variant) => {
variant.addVideo(1, (stream) => {
stream.mime('video/mp4', 'avc1.4d400d');
});
});
});

await StreamUtils.getDecodingInfosForVariants(manifest.variants,
/* usePersistentLicenses= */false, /* srcEquals= */ true);
expect(manifest.variants.length).toBeTruthy();
expect(manifest.variants[0].decodingInfos.length).toBe(1);
expect(manifest.variants[0].decodingInfos[0].supported).toBeTruthy();
Expand Down Expand Up @@ -517,7 +533,7 @@ describe('StreamUtils', () => {
});

await StreamUtils.getDecodingInfosForVariants(manifest.variants,
/* usePersistentLicenses= */false);
/* usePersistentLicenses= */false, /* srcEquals= */ false);
expect(manifest.variants.length).toBe(1);
expect(manifest.variants[0].decodingInfos.length).toBe(0);
});
Expand Down

0 comments on commit a44e9ab

Please sign in to comment.