mirror of
https://github.com/videojs/video.js.git
synced 2025-01-06 06:50:51 +02:00
refactor: use URL API (#8716)
* refactor: use URL API * add relative test * remove old jsdoc comment * Corrected test description
This commit is contained in:
parent
3e697e942f
commit
992af3b3ee
@ -5,80 +5,18 @@
|
|||||||
import document from 'global/document';
|
import document from 'global/document';
|
||||||
import window from 'global/window';
|
import window from 'global/window';
|
||||||
|
|
||||||
/**
|
|
||||||
* @typedef {Object} url:URLObject
|
|
||||||
*
|
|
||||||
* @property {string} protocol
|
|
||||||
* The protocol of the url that was parsed.
|
|
||||||
*
|
|
||||||
* @property {string} hostname
|
|
||||||
* The hostname of the url that was parsed.
|
|
||||||
*
|
|
||||||
* @property {string} port
|
|
||||||
* The port of the url that was parsed.
|
|
||||||
*
|
|
||||||
* @property {string} pathname
|
|
||||||
* The pathname of the url that was parsed.
|
|
||||||
*
|
|
||||||
* @property {string} search
|
|
||||||
* The search query of the url that was parsed.
|
|
||||||
*
|
|
||||||
* @property {string} hash
|
|
||||||
* The hash of the url that was parsed.
|
|
||||||
*
|
|
||||||
* @property {string} host
|
|
||||||
* The host of the url that was parsed.
|
|
||||||
*/
|
|
||||||
|
|
||||||
/**
|
/**
|
||||||
* Resolve and parse the elements of a URL.
|
* Resolve and parse the elements of a URL.
|
||||||
*
|
*
|
||||||
* @function
|
* @function
|
||||||
* @param {String} url
|
* @param {string} url
|
||||||
* The url to parse
|
* The url to parse
|
||||||
*
|
*
|
||||||
* @return {url:URLObject}
|
* @return {URL}
|
||||||
* An object of url details
|
* An object of url details
|
||||||
*/
|
*/
|
||||||
export const parseUrl = function(url) {
|
export const parseUrl = function(url) {
|
||||||
// This entire method can be replace with URL once we are able to drop IE11
|
return new URL(url, document.baseURI);
|
||||||
|
|
||||||
const props = ['protocol', 'hostname', 'port', 'pathname', 'search', 'hash', 'host'];
|
|
||||||
|
|
||||||
// add the url to an anchor and let the browser parse the URL
|
|
||||||
const a = document.createElement('a');
|
|
||||||
|
|
||||||
a.href = url;
|
|
||||||
|
|
||||||
// Copy the specific URL properties to a new object
|
|
||||||
// This is also needed for IE because the anchor loses its
|
|
||||||
// properties when it's removed from the dom
|
|
||||||
const details = {};
|
|
||||||
|
|
||||||
for (let i = 0; i < props.length; i++) {
|
|
||||||
details[props[i]] = a[props[i]];
|
|
||||||
}
|
|
||||||
|
|
||||||
// IE adds the port to the host property unlike everyone else. If
|
|
||||||
// a port identifier is added for standard ports, strip it.
|
|
||||||
if (details.protocol === 'http:') {
|
|
||||||
details.host = details.host.replace(/:80$/, '');
|
|
||||||
}
|
|
||||||
|
|
||||||
if (details.protocol === 'https:') {
|
|
||||||
details.host = details.host.replace(/:443$/, '');
|
|
||||||
}
|
|
||||||
|
|
||||||
if (!details.protocol) {
|
|
||||||
details.protocol = window.location.protocol;
|
|
||||||
}
|
|
||||||
|
|
||||||
/* istanbul ignore if */
|
|
||||||
if (!details.host) {
|
|
||||||
details.host = window.location.host;
|
|
||||||
}
|
|
||||||
|
|
||||||
return details;
|
|
||||||
};
|
};
|
||||||
|
|
||||||
/**
|
/**
|
||||||
@ -90,21 +28,9 @@ export const parseUrl = function(url) {
|
|||||||
*
|
*
|
||||||
* @return {string}
|
* @return {string}
|
||||||
* Absolute URL
|
* Absolute URL
|
||||||
*
|
|
||||||
* @see http://stackoverflow.com/questions/470832/getting-an-absolute-url-from-a-relative-one-ie6-issue
|
|
||||||
*/
|
*/
|
||||||
export const getAbsoluteURL = function(url) {
|
export const getAbsoluteURL = function(url) {
|
||||||
// Check if absolute URL
|
return (new URL(url, document.baseURI)).href;
|
||||||
if (!url.match(/^https?:\/\//)) {
|
|
||||||
// Add the url to an anchor and let the browser parse it to convert to an absolute url
|
|
||||||
const a = document.createElement('a');
|
|
||||||
|
|
||||||
a.href = url;
|
|
||||||
|
|
||||||
url = a.href;
|
|
||||||
}
|
|
||||||
|
|
||||||
return url;
|
|
||||||
};
|
};
|
||||||
|
|
||||||
/**
|
/**
|
||||||
@ -139,27 +65,12 @@ export const getFileExtension = function(path) {
|
|||||||
* @param {string} url
|
* @param {string} url
|
||||||
* The url to check.
|
* The url to check.
|
||||||
*
|
*
|
||||||
* @param {Object} [winLoc]
|
* @param {URL} [winLoc]
|
||||||
* the domain to check the url against, defaults to window.location
|
* the domain to check the url against, defaults to window.location
|
||||||
*
|
*
|
||||||
* @param {string} [winLoc.protocol]
|
|
||||||
* The window location protocol defaults to window.location.protocol
|
|
||||||
*
|
|
||||||
* @param {string} [winLoc.host]
|
|
||||||
* The window location host defaults to window.location.host
|
|
||||||
*
|
|
||||||
* @return {boolean}
|
* @return {boolean}
|
||||||
* Whether it is a cross domain request or not.
|
* Whether it is a cross domain request or not.
|
||||||
*/
|
*/
|
||||||
export const isCrossOrigin = function(url, winLoc = window.location) {
|
export const isCrossOrigin = function(url, winLoc = window.location) {
|
||||||
const urlInfo = parseUrl(url);
|
return parseUrl(url).origin !== winLoc.origin;
|
||||||
|
|
||||||
// IE8 protocol relative urls will return ':' for protocol
|
|
||||||
const srcProtocol = urlInfo.protocol === ':' ? winLoc.protocol : urlInfo.protocol;
|
|
||||||
|
|
||||||
// Check if url is for another domain/origin
|
|
||||||
// IE8 doesn't know location.origin, so we won't rely on it here
|
|
||||||
const crossOrigin = (srcProtocol + urlInfo.host) !== (winLoc.protocol + winLoc.host);
|
|
||||||
|
|
||||||
return crossOrigin;
|
|
||||||
};
|
};
|
||||||
|
@ -41,9 +41,8 @@ QUnit.test('should strip port from hosts using http or https', function(assert)
|
|||||||
});
|
});
|
||||||
|
|
||||||
QUnit.test('should get an absolute URL', function(assert) {
|
QUnit.test('should get an absolute URL', function(assert) {
|
||||||
// Errors on compiled tests that don't use unit.html. Need a better solution.
|
assert.ok(Url.getAbsoluteURL(window.location.pathname + window.location.search) === window.location.href);
|
||||||
// assert.ok(Url.getAbsoluteURL('unit.html') === window.location.href);
|
assert.ok(Url.getAbsoluteURL('http://asdf.com') === 'http://asdf.com/');
|
||||||
assert.ok(Url.getAbsoluteURL('http://asdf.com') === 'http://asdf.com');
|
|
||||||
assert.ok(Url.getAbsoluteURL('https://asdf.com/index.html') === 'https://asdf.com/index.html');
|
assert.ok(Url.getAbsoluteURL('https://asdf.com/index.html') === 'https://asdf.com/index.html');
|
||||||
});
|
});
|
||||||
|
|
||||||
@ -81,12 +80,9 @@ QUnit.test('isCrossOrigin can identify cross origin urls', function(assert) {
|
|||||||
// we cannot test that relative urls work on https, though
|
// we cannot test that relative urls work on https, though
|
||||||
assert.ok(!Url.isCrossOrigin('example.vtt'), 'relative url is not cross origin');
|
assert.ok(!Url.isCrossOrigin('example.vtt'), 'relative url is not cross origin');
|
||||||
|
|
||||||
const location = {
|
const location = new URL('https:/google.com');
|
||||||
protocol: 'https:',
|
|
||||||
host: 'google.com'
|
|
||||||
};
|
|
||||||
|
|
||||||
assert.ok(!Url.isCrossOrigin('https://google.com/example.vtt', location), 'http://google.com from https://google.com is not cross origin');
|
assert.ok(!Url.isCrossOrigin('https://google.com/example.vtt', location), 'https://google.com from https://google.com is not cross origin');
|
||||||
assert.ok(Url.isCrossOrigin('http://google.com/example.vtt', location), 'http://google.com from https://google.com is cross origin');
|
assert.ok(Url.isCrossOrigin('http://google.com/example.vtt', location), 'http://google.com from https://google.com is cross origin');
|
||||||
assert.ok(Url.isCrossOrigin('http://example.com/example.vtt', location), 'http://example.com from https://google.com is cross origin');
|
assert.ok(Url.isCrossOrigin('http://example.com/example.vtt', location), 'http://example.com from https://google.com is cross origin');
|
||||||
assert.ok(Url.isCrossOrigin('https://example.com/example.vtt', location), 'https://example.com from https://google.com is cross origin');
|
assert.ok(Url.isCrossOrigin('https://example.com/example.vtt', location), 'https://example.com from https://google.com is cross origin');
|
||||||
|
Loading…
Reference in New Issue
Block a user