index.js.map
18.1 KB
{"version":3,"file":"index.js","sources":["../src/format.js","../third_party/format.js","../src/constants.js","../src/parse.js","../src/resolve.js"],"sourcesContent":["/*\n * Copyright 2019 Google LLC\n *\n * Licensed under the Apache License, Version 2.0 (the 'License');\n * you may not use this file except in compliance with the License.\n * You may obtain a copy of the License at\n *\n * https://www.apache.org/licenses/LICENSE-2.0\n *\n * Unless required by applicable law or agreed to in writing, software\n * distributed under the License is distributed on an 'AS IS' BASIS,\n * WITHOUT WARRANTIES OR CONDITIONS OF ANY KIND, either express or implied.\n * See the License for the specific language governing permissions and\n * limitations under the License.\n */\n\nimport qs from 'querystring';\nimport parse from './parse';\nimport format from '../third_party/format';\n\nconst slashedProtocols = /https?|ftp|gopher|file/;\n\nexport default function(urlObj) {\n if (typeof urlObj === 'string') {\n urlObj = parse(urlObj);\n }\n\n const { protocol, host, pathname, search, hash } = format(\n urlObj,\n qs,\n slashedProtocols\n );\n\n return `${protocol}${host}${pathname}${search}${hash}`;\n}\n","// Format function modified from nodejs\n// Copyright Joyent, Inc. and other Node contributors.\n//\n// Permission is hereby granted, free of charge, to any person obtaining a\n// copy of this software and associated documentation files (the\n// \"Software\"), to deal in the Software without restriction, including\n// without limitation the rights to use, copy, modify, merge, publish,\n// distribute, sublicense, and/or sell copies of the Software, and to permit\n// persons to whom the Software is furnished to do so, subject to the\n// following conditions:\n//\n// The above copyright notice and this permission notice shall be included\n// in all copies or substantial portions of the Software.\n//\n// THE SOFTWARE IS PROVIDED \"AS IS\", WITHOUT WARRANTY OF ANY KIND, EXPRESS\n// OR IMPLIED, INCLUDING BUT NOT LIMITED TO THE WARRANTIES OF\n// MERCHANTABILITY, FITNESS FOR A PARTICULAR PURPOSE AND NONINFRINGEMENT. IN\n// NO EVENT SHALL THE AUTHORS OR COPYRIGHT HOLDERS BE LIABLE FOR ANY CLAIM,\n// DAMAGES OR OTHER LIABILITY, WHETHER IN AN ACTION OF CONTRACT, TORT OR\n// OTHERWISE, ARISING FROM, OUT OF OR IN CONNECTION WITH THE SOFTWARE OR THE\n// USE OR OTHER DEALINGS IN THE SOFTWARE.\n\nexport default function(urlObj, qs, slashedProtocols) {\n let { auth, hostname } = urlObj;\n let protocol = urlObj.protocol || '';\n let pathname = urlObj.pathname || '';\n let hash = urlObj.hash || '';\n let query = urlObj.query || '';\n let host = false;\n\n auth = auth ? encodeURIComponent(auth).replace(/%3A/i, ':') + '@' : '';\n\n if (urlObj.host) {\n host = auth + urlObj.host;\n } else if (hostname) {\n host = auth + (~hostname.indexOf(':') ? `[${hostname}]` : hostname);\n if (urlObj.port) {\n host += ':' + urlObj.port;\n }\n }\n\n if (query && typeof query === 'object') {\n // query = '' + new URLSearchParams(query);\n query = qs.encode(query);\n }\n\n let search = urlObj.search || (query && `?${query}`) || '';\n\n if (protocol && protocol.substr(-1) !== ':') protocol += ':';\n\n if (\n urlObj.slashes ||\n ((!protocol || slashedProtocols.test(protocol)) && host !== false)\n ) {\n host = '//' + (host || '');\n if (pathname && pathname[0] !== '/') pathname = '/' + pathname;\n } else if (!host) {\n host = '';\n }\n\n if (hash && hash[0] !== '#') hash = '#' + hash;\n if (search && search[0] !== '?') search = '?' + search;\n\n pathname = pathname.replace(/[?#]/g, encodeURIComponent);\n search = search.replace('#', '%23');\n\n return {\n protocol,\n host,\n pathname,\n search,\n hash\n };\n}\n","/*\n * Copyright 2019 Google LLC\n *\n * Licensed under the Apache License, Version 2.0 (the 'License');\n * you may not use this file except in compliance with the License.\n * You may obtain a copy of the License at\n *\n * https://www.apache.org/licenses/LICENSE-2.0\n *\n * Unless required by applicable law or agreed to in writing, software\n * distributed under the License is distributed on an 'AS IS' BASIS,\n * WITHOUT WARRANTIES OR CONDITIONS OF ANY KIND, either express or implied.\n * See the License for the specific language governing permissions and\n * limitations under the License.\n */\n\nexport const PROTOCOL = 'http://';\nexport const HOST = 'w.w';\nexport const BASE_URL = PROTOCOL + HOST;\n","/*\n * Copyright 2019 Google LLC\n *\n * Licensed under the Apache License, Version 2.0 (the 'License');\n * you may not use this file except in compliance with the License.\n * You may obtain a copy of the License at\n *\n * https://www.apache.org/licenses/LICENSE-2.0\n *\n * Unless required by applicable law or agreed to in writing, software\n * distributed under the License is distributed on an 'AS IS' BASIS,\n * WITHOUT WARRANTIES OR CONDITIONS OF ANY KIND, either express or implied.\n * See the License for the specific language governing permissions and\n * limitations under the License.\n */\n\nimport qs from 'querystring';\nimport format from './format';\nimport { BASE_URL, HOST } from './constants';\n\nconst slashedProtocols = /^https?|ftp|gopher|file/;\nconst urlRegex = /^(.*?)([#?].*)/;\nconst protocolRegex = /^([a-z0-9.+-]*:)(\\/{0,3})(.*)/i;\nconst slashesRegex = /^([a-z0-9.+-]*:)?\\/\\/\\/*/i;\nconst ipv6Regex = /^([a-z0-9.+-]*:)(\\/{0,2})\\[(.*)\\]$/i;\n\nfunction safeDecode(url) {\n try {\n return decodeURI(url);\n } catch (_) {\n return url;\n }\n}\n\nexport default function(urlStr, parseQs = false, slashesDenoteHost = false) {\n urlStr = urlStr.trim();\n\n const slashesMatch = urlStr.match(urlRegex);\n if (slashesMatch) {\n urlStr = safeDecode(slashesMatch[1]).replace(/\\\\/g, '/') + slashesMatch[2];\n } else {\n urlStr = safeDecode(urlStr).replace(/\\\\/g, '/');\n }\n\n // IPv6 check\n if (ipv6Regex.test(urlStr)) {\n // Add trailing slash to IPV6 urls to match parsing\n if (urlStr.slice(-1) !== '/') urlStr += '/';\n }\n\n const protocolMatch =\n !/(^javascript)/.test(urlStr) && urlStr.match(protocolRegex);\n let slashes = slashesRegex.test(urlStr);\n let protocolPrefix = '';\n\n if (protocolMatch) {\n if (!slashedProtocols.test(protocolMatch[1])) {\n // Replace invalid protocol with a valid one for correct parsing\n protocolPrefix = protocolMatch[1].toLowerCase();\n urlStr = `${protocolMatch[2]}${protocolMatch[3]}`;\n }\n\n if (!protocolMatch[2]) {\n slashes = false;\n if (slashedProtocols.test(protocolMatch[1])) {\n protocolPrefix = protocolMatch[1];\n urlStr = `${protocolMatch[3]}`;\n } else {\n urlStr = `//${protocolMatch[3]}`;\n }\n }\n\n // Handle '///' in url Eg: http:///s//a/b/c\n // TODO: file:/some/dir/# should become file:///some/dir/# according to the url module in node\n if (protocolMatch[2].length === 3 || protocolMatch[2].length === 1) {\n protocolPrefix = protocolMatch[1];\n urlStr = `/${protocolMatch[3]}`;\n }\n }\n\n // If port is 80 we change it to 8000 and undo it later\n let portMatch = urlStr.match(/(:[0-9]+)/);\n let portSuffix = '';\n\n if (portMatch && portMatch[1] && portMatch[1].length === 3) {\n portSuffix = portMatch[1];\n urlStr = urlStr.replace(portSuffix, `${portSuffix}00`);\n }\n\n let url;\n let res = {};\n let err = '';\n let preSlash = '';\n\n try {\n url = new URL(urlStr);\n } catch (e) {\n err = e;\n\n // Handle url with slashes - Eg: //some_url\n if (\n !protocolPrefix &&\n !slashesDenoteHost &&\n /^\\/\\//.test(urlStr) &&\n !/^\\/\\/.+[@.]/.test(urlStr)\n ) {\n preSlash = '/';\n urlStr = urlStr.substr(1);\n }\n\n try {\n url = new URL(urlStr, BASE_URL);\n } catch (_) {\n // Unable to parse the url\n // If the URL has only the protocol - Eg: \"foo:\"\n res.protocol = protocolPrefix;\n res.href = protocolPrefix;\n return res;\n }\n }\n\n res.slashes = slashes && !preSlash;\n res.host = url.host === HOST ? '' : url.host;\n res.hostname =\n url.hostname === HOST ? '' : url.hostname.replace(/(\\[|\\])/g, '');\n res.protocol = err ? protocolPrefix || null : url.protocol;\n\n res.search = url.search.replace(/\\\\/g, '%5C');\n res.hash = url.hash.replace(/\\\\/g, '%5C');\n\n const hashSplit = urlStr.split('#');\n // Handle case when there is a lone '?' in url\n // Eg: http://example.com/?\n if (!res.search && ~hashSplit[0].indexOf('?')) {\n res.search = '?';\n }\n // Similarly handle lone '#' Eg: http://example.com/#\n if (!res.hash && hashSplit[1] === '') {\n res.hash = '#';\n }\n\n // URLSearchParams is not supported in Edge 16\n // res.query = res.searchParams;\n res.query = parseQs ? qs.decode(url.search.substr(1)) : res.search.substr(1);\n\n res.pathname = preSlash + safeDecode(url.pathname).replace(/\"/g, '%22');\n\n // Chrome parses \"#abc\" as \"about:blank#abc\"\n if (res.protocol === 'about:' && res.pathname === 'blank') {\n res.protocol = '';\n res.pathname = '';\n }\n\n // Partial url that does not start with a /\n // example www.example.com\n if (err && urlStr[0] !== '/') res.pathname = res.pathname.substr(1);\n\n // Remove additional trailing slashes added by URL\n if (\n protocolPrefix &&\n !slashedProtocols.test(protocolPrefix) &&\n urlStr.slice(-1) !== '/' &&\n res.pathname === '/'\n ) {\n res.pathname = '';\n }\n\n res.path = res.pathname + res.search;\n\n res.auth = [url.username, url.password]\n .map(decodeURIComponent)\n .filter(Boolean)\n .join(':');\n res.port = url.port;\n\n // Undo port to its original value, 8000 -> 80\n if (portSuffix) {\n res.host = res.host.replace(`${portSuffix}00`, portSuffix);\n res.port = res.port.slice(0, -2);\n }\n\n res.href = preSlash ? `${res.pathname}${res.search}${res.hash}` : format(res);\n\n const excludedKeys = /^(file)/.test(res.href) ? ['host', 'hostname'] : [];\n Object.keys(res).forEach(k => {\n if (!~excludedKeys.indexOf(k)) res[k] = res[k] || null;\n });\n\n return res;\n}\n","/*\n * Copyright 2019 Google LLC\n *\n * Licensed under the Apache License, Version 2.0 (the 'License');\n * you may not use this file except in compliance with the License.\n * You may obtain a copy of the License at\n *\n * https://www.apache.org/licenses/LICENSE-2.0\n *\n * Unless required by applicable law or agreed to in writing, software\n * distributed under the License is distributed on an 'AS IS' BASIS,\n * WITHOUT WARRANTIES OR CONDITIONS OF ANY KIND, either express or implied.\n * See the License for the specific language governing permissions and\n * limitations under the License.\n */\n\nimport parse from './parse';\nimport format from './format';\nimport { BASE_URL, PROTOCOL, HOST } from './constants';\n\nconst resolveProtocolRegex = /^([a-z0-9.+-]*:\\/\\/\\/)([a-z0-9.+-]:\\/*)?/i;\nconst slashedProtocols = /https?|ftp|gopher|file/;\n\nexport function resolve(fromUrl, toUrl) {\n let parsedFrom = typeof fromUrl === 'string' ? parse(fromUrl) : fromUrl;\n fromUrl = typeof fromUrl === 'object' ? format(fromUrl) : fromUrl;\n let parsedTo = parse(toUrl);\n let prefix = '';\n\n // Handle incomplete urls without slashes Eg: foo:a/b\n if (parsedFrom.protocol && !parsedFrom.slashes) {\n prefix = parsedFrom.protocol;\n\n fromUrl = fromUrl.replace(parsedFrom.protocol, '');\n prefix += toUrl[0] === '/' || fromUrl[0] === '/' ? '/' : '';\n }\n\n if (prefix && parsedTo.protocol) {\n prefix = '';\n if (!parsedTo.slashes) {\n prefix = parsedTo.protocol;\n toUrl = toUrl.replace(parsedTo.protocol, '');\n }\n }\n\n // Handle http:///xyz urls\n const protocolMatch = fromUrl.match(resolveProtocolRegex);\n if (protocolMatch && !parsedTo.protocol) {\n // protocolMatch[2] handles - file:///C:/DEV/Haskell/lib/HXmlToolbox-3.01/examples/\n prefix = protocolMatch[1] + (protocolMatch[2] || '');\n fromUrl = fromUrl.substr(prefix.length);\n\n // :/// -> :// If toUrl is of the form //xyz\n if (/^\\/\\/[^/]/.test(toUrl)) prefix = prefix.slice(0, -1);\n }\n\n const normalizedFromUrl = new URL(fromUrl, BASE_URL + '/');\n let resolved = new URL(toUrl, normalizedFromUrl)\n .toString()\n .replace(BASE_URL, '');\n\n // Remove/replace the protocol if the URL class has added it\n let actualProtocol = parsedTo.protocol || parsedFrom.protocol;\n actualProtocol += parsedFrom.slashes || parsedTo.slashes ? '//' : '';\n if (!prefix && actualProtocol) {\n resolved = resolved.replace(PROTOCOL, actualProtocol);\n } else if (prefix) {\n resolved = resolved.replace(PROTOCOL, '');\n }\n\n // Remove unwanted trailing slash\n if (\n !slashedProtocols.test(resolved) &&\n !~toUrl.indexOf('.') &&\n fromUrl.slice(-1) !== '/' &&\n toUrl.slice(-1) !== '/' &&\n resolved.slice(-1) === '/'\n ) {\n resolved = resolved.slice(0, -1);\n }\n\n // If prefix remove the leading slash\n if (prefix) {\n resolved = prefix + (resolved[0] === '/' ? resolved.substr(1) : resolved);\n }\n\n return resolved;\n}\n\nexport function resolveObject(fromUrl, toUrl) {\n return parse(resolve(fromUrl, toUrl));\n}\n"],"names":["slashedProtocols","urlObj","parse","qs","protocol","pathname","hash","query","host","auth","encodeURIComponent","replace","hostname","indexOf","port","encode","search","substr","slashes","test","format","const","PROTOCOL","HOST","BASE_URL","urlRegex","protocolRegex","slashesRegex","ipv6Regex","safeDecode","url","decodeURI","_","urlStr","parseQs","slashesDenoteHost","slashesMatch","trim","match","slice","protocolMatch","protocolPrefix","toLowerCase","length","portMatch","portSuffix","res","err","preSlash","URL","e","href","hashSplit","split","decode","path","username","password","map","decodeURIComponent","filter","Boolean","join","excludedKeys","Object","keys","forEach","k","resolveProtocolRegex","resolve","fromUrl","toUrl","parsedFrom","parsedTo","prefix","normalizedFromUrl","resolved","toString","actualProtocol"],"mappings":"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"}