Merge branch 'percent-40' of https://github.com/wmhilton-contrib/unpkg.com into wmhilton-contrib-percent-40
This commit is contained in:
commit
59e402a41e
|
@ -2,20 +2,14 @@ import url from 'url';
|
||||||
|
|
||||||
const packageURLFormat = /^\/((?:@[^/@]+\/)?[^/@]+)(?:@([^/]+))?(\/.*)?$/;
|
const packageURLFormat = /^\/((?:@[^/@]+\/)?[^/@]+)(?:@([^/]+))?(\/.*)?$/;
|
||||||
|
|
||||||
function decodeParam(param) {
|
|
||||||
if (param) {
|
|
||||||
try {
|
|
||||||
return decodeURIComponent(param);
|
|
||||||
} catch (error) {
|
|
||||||
// Ignore invalid params.
|
|
||||||
}
|
|
||||||
}
|
|
||||||
|
|
||||||
return '';
|
|
||||||
}
|
|
||||||
|
|
||||||
export default function parsePackageURL(originalURL) {
|
export default function parsePackageURL(originalURL) {
|
||||||
const { pathname, search, query } = url.parse(originalURL, true);
|
let { pathname, search, query } = url.parse(originalURL, true);
|
||||||
|
try {
|
||||||
|
pathname = decodeURIComponent(pathname);
|
||||||
|
} catch (error) {
|
||||||
|
return null;
|
||||||
|
}
|
||||||
|
|
||||||
const match = packageURLFormat.exec(pathname);
|
const match = packageURLFormat.exec(pathname);
|
||||||
|
|
||||||
// Disallow invalid URL formats.
|
// Disallow invalid URL formats.
|
||||||
|
@ -24,8 +18,8 @@ export default function parsePackageURL(originalURL) {
|
||||||
}
|
}
|
||||||
|
|
||||||
const packageName = match[1];
|
const packageName = match[1];
|
||||||
const packageVersion = decodeParam(match[2]) || 'latest';
|
const packageVersion = match[2] || 'latest';
|
||||||
const filename = decodeParam(match[3]);
|
const filename = match[3] || '';
|
||||||
|
|
||||||
return {
|
return {
|
||||||
// If the URL is /@scope/name@version/file.js?main=browser:
|
// If the URL is /@scope/name@version/file.js?main=browser:
|
||||||
|
|
Loading…
Reference in New Issue