mirror of
https://github.com/Karaka-Management/jsOMS.git
synced 2026-02-16 09:18:42 +00:00
Fixed url parsing bugs
Introduced self url Removing double parameters
This commit is contained in:
parent
c820a8944f
commit
9d51b089aa
|
|
@ -50,7 +50,7 @@
|
||||||
loose: /^(?:(?![^:@]+:[^:@\/]*@)([^:\/?#.]+):)?(?:\/\/\/?)?((?:(([^:@]*):?([^:@]*))?@)?([^:\/?#]*)(?::(\d*))?)(((\/(?:[^?#](?![^?#\/]*\.[^?#\/.]+(?:[?#]|$)))*\/?)?([^?#\/]*))(?:\?([^#]*))?(?:#(.*))?)/ // Added one optional slash to post-scheme to catch file:/// (should restrict this)
|
loose: /^(?:(?![^:@]+:[^:@\/]*@)([^:\/?#.]+):)?(?:\/\/\/?)?((?:(([^:@]*):?([^:@]*))?@)?([^:\/?#]*)(?::(\d*))?)(((\/(?:[^?#](?![^?#\/]*\.[^?#\/.]+(?:[?#]|$)))*\/?)?([^?#\/]*))(?:\?([^#]*))?(?:#(.*))?)/ // Added one optional slash to post-scheme to catch file:/// (should restrict this)
|
||||||
};
|
};
|
||||||
|
|
||||||
if(!parser.hasOwnProperty(mode)) {
|
if (!parser.hasOwnProperty(mode)) {
|
||||||
throw new Error('Unexpected parsing mode.', 'UriFactory', 52);
|
throw new Error('Unexpected parsing mode.', 'UriFactory', 52);
|
||||||
}
|
}
|
||||||
|
|
||||||
|
|
@ -119,6 +119,49 @@
|
||||||
return false;
|
return false;
|
||||||
};
|
};
|
||||||
|
|
||||||
|
/**
|
||||||
|
* Remove multiple definitions of the same parameter
|
||||||
|
*
|
||||||
|
* The parameters will be recognized from right to left since it's easier to push at the end.
|
||||||
|
*
|
||||||
|
* @param {string} url Url
|
||||||
|
*
|
||||||
|
* @return {string}
|
||||||
|
*
|
||||||
|
* @function
|
||||||
|
*
|
||||||
|
* @since 1.0.0
|
||||||
|
* @author Dennis Eichhorn <d.eichhorn@oms.com>
|
||||||
|
*/
|
||||||
|
jsOMS.Uri.UriFactory.unique = function (url)
|
||||||
|
{
|
||||||
|
let parts = url.split('?');
|
||||||
|
|
||||||
|
if (parts.length >= 2) {
|
||||||
|
let full = parts[1],
|
||||||
|
pars = full.split('&'),
|
||||||
|
comps = {},
|
||||||
|
spl = null,
|
||||||
|
length = pars.length;
|
||||||
|
|
||||||
|
for (let i = 0; i < length; i++) {
|
||||||
|
spl = pars[i].split('=');
|
||||||
|
comps[spl[0]] = spl[1];
|
||||||
|
}
|
||||||
|
|
||||||
|
pars = [];
|
||||||
|
for (let a in comps) {
|
||||||
|
if (comps.hasOwnProperty(a)) {
|
||||||
|
pars.push(a + '=' + comps[a]);
|
||||||
|
}
|
||||||
|
}
|
||||||
|
|
||||||
|
url = parts[0] + '?' + pars.join('&');
|
||||||
|
}
|
||||||
|
|
||||||
|
return url;
|
||||||
|
};
|
||||||
|
|
||||||
/**
|
/**
|
||||||
* Build uri
|
* Build uri
|
||||||
*
|
*
|
||||||
|
|
@ -126,8 +169,9 @@
|
||||||
* . = DOM class
|
* . = DOM class
|
||||||
* / = Current path
|
* / = Current path
|
||||||
* ? = Current query
|
* ? = Current query
|
||||||
* @ =
|
* @ =
|
||||||
* $ = Other data
|
* $ = Other data
|
||||||
|
* % = Current url
|
||||||
*
|
*
|
||||||
* @param {string} uri Raw uri
|
* @param {string} uri Raw uri
|
||||||
* @param {Object} toMatch Key/value pair to replace in raw
|
* @param {Object} toMatch Key/value pair to replace in raw
|
||||||
|
|
@ -139,26 +183,35 @@
|
||||||
*/
|
*/
|
||||||
jsOMS.Uri.UriFactory.build = function (uri, toMatch)
|
jsOMS.Uri.UriFactory.build = function (uri, toMatch)
|
||||||
{
|
{
|
||||||
let current = jsOMS.Uri.UriFactory.parseUrl(window.location.href);
|
let current = jsOMS.Uri.UriFactory.parseUrl(window.location.href),
|
||||||
|
parsed = uri.replace(new RegExp('\{[\/#\?%@\.\$][a-zA-Z0-9\-]*\}', 'g'), function (match)
|
||||||
|
{
|
||||||
|
match = match.substr(1, match.length - 2);
|
||||||
|
|
||||||
return uri.replace(new RegExp('\{[\/#\?@\.\$][a-zA-Z0-9]*\}', 'g'), function (match)
|
if (typeof toMatch !== 'undefined' && toMatch.hasProperty(match)) {
|
||||||
{
|
return toMatch[match];
|
||||||
match = match.substr(1, match.length - 2);
|
} else if (typeof jsOMS.Uri.UriFactory.uri[match] !== 'undefined') {
|
||||||
|
return jsOMS.Uri.UriFactory.uri[match];
|
||||||
|
} else if (match.indexOf('#') === 0) {
|
||||||
|
return document.getElementById(match.substr(1)).value;
|
||||||
|
} else if (match.indexOf('?') === 0) {
|
||||||
|
return jsOMS.Uri.UriFactory.getUriQueryParameter(current.query, match.substr(1));
|
||||||
|
} else if (match.indexOf('/') === 0) {
|
||||||
|
// todo: second match should return second path
|
||||||
|
return 'ERROR PATH';
|
||||||
|
} else if (match === '%') {
|
||||||
|
return window.location.href;
|
||||||
|
} else {
|
||||||
|
return match;
|
||||||
|
}
|
||||||
|
});
|
||||||
|
|
||||||
if (typeof toMatch !== 'undefined' && toMatch.hasProperty(match)) {
|
if (parsed.indexOf('?') === -1) {
|
||||||
return toMatch[match];
|
parsed = parsed.replace('&', '?');
|
||||||
} else if (jsOMS.Uri.UriFactory.uri[match] !== 'undefined') {
|
}
|
||||||
return jsOMS.Uri.UriFactory.uri[match];
|
|
||||||
} else if (match.indexOf('#') === 0) {
|
parsed = jsOMS.Uri.UriFactory.unique(parsed);
|
||||||
return document.getElementById(match.substr(1)).value;
|
|
||||||
} else if (match.indexOf('?') === 0) {
|
return parsed;
|
||||||
return jsOMS.Uri.UriFactory.getUriQueryParameter(current.query, match.substr(1));
|
|
||||||
} else if (match.indexOf('/') === 0) {
|
|
||||||
// todo: second match should return second path
|
|
||||||
return 'ERROR PATH';
|
|
||||||
} else {
|
|
||||||
return match;
|
|
||||||
}
|
|
||||||
});
|
|
||||||
};
|
};
|
||||||
}(window.jsOMS = window.jsOMS || {}));
|
}(window.jsOMS = window.jsOMS || {}));
|
||||||
Loading…
Reference in New Issue
Block a user