Skip to content

Commit

Permalink
fix: Replace Loader.getResponseHeader() with Loader.getCacheAge().
Browse files Browse the repository at this point in the history
  • Loading branch information
jwalton committed Apr 1, 2021
1 parent f20e155 commit d520008
Show file tree
Hide file tree
Showing 5 changed files with 49 additions and 16 deletions.
5 changes: 3 additions & 2 deletions api-extractor/report/hls.js.api.md
Original file line number Diff line number Diff line change
Expand Up @@ -1555,8 +1555,9 @@ export interface Loader<T extends LoaderContext> {
context: T;
// (undocumented)
destroy(): void;
// (undocumented)
getResponseHeader(name: string): string | null;
getCacheAge?: () => number;
// @deprecated
getResponseHeader?: (name: 'age') => string | null;
// (undocumented)
load(context: LoaderContext, config: LoaderConfiguration, callbacks: LoaderCallbacks<T>): void;
// (undocumented)
Expand Down
10 changes: 8 additions & 2 deletions src/loader/playlist-loader.ts
Original file line number Diff line number Diff line change
Expand Up @@ -684,8 +684,14 @@ class PlaylistLoader {
}

if (levelDetails.live) {
const ageHeader = loader.getResponseHeader('age');
levelDetails.ageHeader = ageHeader ? parseFloat(ageHeader) : 0;
if (loader.getCacheAge) {
levelDetails.ageHeader = loader.getCacheAge();
} else if (loader.getResponseHeader) {
const ageHeaderStr = loader.getResponseHeader('age');
levelDetails.ageHeader = ageHeaderStr ? parseFloat(ageHeaderStr) : 0;
} else {
levelDetails.ageHeader = 0;
}
}

switch (type) {
Expand Down
25 changes: 24 additions & 1 deletion src/types/loader.ts
Original file line number Diff line number Diff line change
Expand Up @@ -120,7 +120,30 @@ export interface Loader<T extends LoaderContext> {
config: LoaderConfiguration,
callbacks: LoaderCallbacks<T>
): void;
getResponseHeader(name: string): string | null;
/**
* `getCacheAge()` is called by hls.js to get the duration that a given object
* has been sitting in a cache proxy when playing live. If implemented,
* this should return a value in seconds.
*
* For HTTP based loaders, this should return the contents of the "age" header.
*
* @returns time object being lodaded
*/
getCacheAge?: () => number;
/**
* `getResponseHeader()` is called by hls.js to get the duration that a given
* object has been sitting in a proxy cache when playing live.
*
* For HTTP based loaders, this should just return the "age" header. For
* non-HTTP based loaders, if the retrieved object has been cached, this
* should return the time the object has been in a cache, as a string, possibly
* with a decimal point. Otherwise implementers should return "0" or null.
*
* Note that HLS.js will never call this for a header other than "age".
*
* @deprecated - Implement `getCacheAge()` instead.
*/
getResponseHeader?: (name: 'age') => string | null;
context: T;
loader: any;
stats: LoaderStats;
Expand Down
12 changes: 5 additions & 7 deletions src/utils/fetch-loader.ts
Original file line number Diff line number Diff line change
Expand Up @@ -160,15 +160,13 @@ class FetchLoader implements Loader<LoaderContext> {
});
}

getResponseHeader(name: string): string | null {
getCacheAge(): number {
let result: number = 0;
if (this.response) {
try {
return this.response.headers.get(name);
} catch (error) {
/* Could not get header */
}
const ageHeader = this.response.headers.get('age');
result = ageHeader ? parseFloat(ageHeader) : 0;
}
return null;
return result;
}

private loadProgressively(
Expand Down
13 changes: 9 additions & 4 deletions src/utils/xhr-loader.ts
Original file line number Diff line number Diff line change
Expand Up @@ -249,11 +249,16 @@ class XhrLoader implements Loader<LoaderContext> {
}
}

getResponseHeader(name: string): string | null {
if (this.loader && this.loader.getAllResponseHeaders().indexOf(name) >= 0) {
return this.loader.getResponseHeader(name);
getCacheAge(): number {
let result: number = 0;
if (
this.loader &&
this.loader.getAllResponseHeaders().indexOf('age') >= 0
) {
const ageHeader = this.loader.getResponseHeader('age');
result = ageHeader ? parseFloat(ageHeader) : 0;
}
return null;
return result;
}
}

Expand Down

0 comments on commit d520008

Please sign in to comment.