From 729d445b6885f69dd2c6355f38707bd42851c791 Mon Sep 17 00:00:00 2001 From: Jarred Sumner <709451+Jarred-Sumner@users.noreply.github.com> Date: Wed, 22 Jun 2022 23:21:48 -0700 Subject: change the directory structure --- src/bun.js/bindings/URLDecomposition.cpp | 257 +++++++++++++++++++++++++++++++ 1 file changed, 257 insertions(+) create mode 100644 src/bun.js/bindings/URLDecomposition.cpp (limited to 'src/bun.js/bindings/URLDecomposition.cpp') diff --git a/src/bun.js/bindings/URLDecomposition.cpp b/src/bun.js/bindings/URLDecomposition.cpp new file mode 100644 index 000000000..84e734528 --- /dev/null +++ b/src/bun.js/bindings/URLDecomposition.cpp @@ -0,0 +1,257 @@ +/* + * Copyright (C) 2014-2020 Apple Inc. All rights reserved. + * + * Redistribution and use in source and binary forms, with or without + * modification, are permitted provided that the following conditions + * are met: + * + * 1. Redistributions of source code must retain the above copyright + * notice, this list of conditions and the following disclaimer. + * 2. Redistributions in binary form must reproduce the above copyright + * notice, this list of conditions and the following disclaimer in the + * documentation and/or other materials provided with the distribution. + * + * THIS SOFTWARE IS PROVIDED BY APPLE AND ITS CONTRIBUTORS "AS IS" AND ANY + * EXPRESS OR IMPLIED WARRANTIES, INCLUDING, BUT NOT LIMITED TO, THE IMPLIED + * WARRANTIES OF MERCHANTABILITY AND FITNESS FOR A PARTICULAR PURPOSE ARE + * DISCLAIMED. IN NO EVENT SHALL APPLE OR ITS CONTRIBUTORS BE LIABLE FOR ANY + * DIRECT, INDIRECT, INCIDENTAL, SPECIAL, EXEMPLARY, OR CONSEQUENTIAL DAMAGES + * (INCLUDING, BUT NOT LIMITED TO, PROCUREMENT OF SUBSTITUTE GOODS OR SERVICES; + * LOSS OF USE, DATA, OR PROFITS; OR BUSINESS INTERRUPTION) HOWEVER CAUSED AND + * ON ANY THEORY OF LIABILITY, WHETHER IN CONTRACT, STRICT LIABILITY, OR TORT + * (INCLUDING NEGLIGENCE OR OTHERWISE) ARISING IN ANY WAY OUT OF THE USE OF + * THIS SOFTWARE, EVEN IF ADVISED OF THE POSSIBILITY OF SUCH DAMAGE. + */ + +#include "URLDecomposition.h" + +#include "wtf/text/StringToIntegerConversion.h" + +namespace WebCore { + +String URLDecomposition::origin() const +{ + return fullURL().hostAndPort(); +} + +String URLDecomposition::protocol() const +{ + auto fullURL = this->fullURL(); + if (WTF::protocolIsJavaScript(fullURL.string())) + return "javascript:"_s; + return makeString(fullURL.protocol(), ':'); +} + +void URLDecomposition::setProtocol(StringView value) +{ + URL copy = fullURL(); + copy.setProtocol(value); + setFullURL(copy); +} + +String URLDecomposition::username() const +{ + return fullURL().encodedUser().toString(); +} + +void URLDecomposition::setUsername(StringView user) +{ + auto fullURL = this->fullURL(); + if (fullURL.host().isEmpty() || fullURL.cannotBeABaseURL() || fullURL.protocolIs("file"_s)) + return; + fullURL.setUser(user); + setFullURL(fullURL); +} + +String URLDecomposition::password() const +{ + return fullURL().encodedPassword().toString(); +} + +void URLDecomposition::setPassword(StringView password) +{ + auto fullURL = this->fullURL(); + if (fullURL.host().isEmpty() || fullURL.cannotBeABaseURL() || fullURL.protocolIs("file"_s)) + return; + fullURL.setPassword(password); + setFullURL(fullURL); +} + +String URLDecomposition::host() const +{ + return fullURL().hostAndPort(); +} + +static unsigned countASCIIDigits(StringView string) +{ + unsigned length = string.length(); + for (unsigned count = 0; count < length; ++count) { + if (!isASCIIDigit(string[count])) + return count; + } + return length; +} + +void URLDecomposition::setHost(StringView value) +{ + auto fullURL = this->fullURL(); + if (value.isEmpty() && !fullURL.protocolIs("file"_s) && fullURL.hasSpecialScheme()) + return; + + size_t separator = value.reverseFind(':'); + if (!separator) + return; + + if (fullURL.cannotBeABaseURL() || !fullURL.canSetHostOrPort()) + return; + + // No port if no colon or rightmost colon is within the IPv6 section. + size_t ipv6Separator = value.reverseFind(']'); + if (separator == notFound || (ipv6Separator != notFound && ipv6Separator > separator)) + fullURL.setHost(value); + else { + // Multiple colons are acceptable only in case of IPv6. + if (value.find(':') != separator && ipv6Separator == notFound) + return; + unsigned portLength = countASCIIDigits(value.substring(separator + 1)); + if (!portLength) { + fullURL.setHost(value.substring(0, separator)); + } else { + auto portNumber = parseInteger(value.substring(separator + 1, portLength)); + if (portNumber && WTF::isDefaultPortForProtocol(*portNumber, fullURL.protocol())) + fullURL.setHostAndPort(value.substring(0, separator)); + else + fullURL.setHostAndPort(value.substring(0, separator + 1 + portLength)); + } + } + if (fullURL.isValid()) + setFullURL(fullURL); +} + +String URLDecomposition::hostname() const +{ + return fullURL().host().toString(); +} + +static StringView removeAllLeadingSolidusCharacters(StringView string) +{ + unsigned i; + unsigned length = string.length(); + for (i = 0; i < length; ++i) { + if (string[i] != '/') + break; + } + return string.substring(i); +} + +void URLDecomposition::setHostname(StringView value) +{ + auto fullURL = this->fullURL(); + auto host = removeAllLeadingSolidusCharacters(value); + if (host.isEmpty() && !fullURL.protocolIs("file"_s) && fullURL.hasSpecialScheme()) + return; + if (fullURL.cannotBeABaseURL() || !fullURL.canSetHostOrPort()) + return; + fullURL.setHost(host); + if (fullURL.isValid()) + setFullURL(fullURL); +} + +String URLDecomposition::port() const +{ + auto port = fullURL().port(); + if (!port) + return emptyString(); + return String::number(*port); +} + +// Outer optional is whether we could parse at all. Inner optional is "no port specified". +static std::optional> parsePort(StringView string, StringView protocol) +{ + // https://url.spec.whatwg.org/#port-state with state override given. + uint32_t port { 0 }; + bool foundDigit = false; + for (size_t i = 0; i < string.length(); ++i) { + auto c = string[i]; + // https://infra.spec.whatwg.org/#ascii-tab-or-newline + if (c == 0x0009 || c == 0x000A || c == 0x000D) + continue; + if (isASCIIDigit(c)) { + port = port * 10 + c - '0'; + foundDigit = true; + if (port > std::numeric_limits::max()) + return std::nullopt; + continue; + } + if (!foundDigit) + return std::nullopt; + break; + } + if (!foundDigit || WTF::isDefaultPortForProtocol(static_cast(port), protocol)) + return std::optional { std::nullopt }; + return { { static_cast(port) } }; +} + +void URLDecomposition::setPort(StringView value) +{ + auto fullURL = this->fullURL(); + if (fullURL.host().isEmpty() || fullURL.cannotBeABaseURL() || fullURL.protocolIs("file"_s) || !fullURL.canSetHostOrPort()) + return; + auto port = parsePort(value, fullURL.protocol()); + if (!port) + return; + fullURL.setPort(*port); + setFullURL(fullURL); +} + +String URLDecomposition::pathname() const +{ + return fullURL().path().toString(); +} + +void URLDecomposition::setPathname(StringView value) +{ + auto fullURL = this->fullURL(); + if (fullURL.cannotBeABaseURL() || !fullURL.canSetPathname()) + return; + fullURL.setPath(value); + setFullURL(fullURL); +} + +String URLDecomposition::search() const +{ + auto fullURL = this->fullURL(); + return fullURL.query().isEmpty() ? emptyString() : fullURL.queryWithLeadingQuestionMark().toString(); +} + +void URLDecomposition::setSearch(const String& value) +{ + auto fullURL = this->fullURL(); + if (value.isEmpty()) { + // If the given value is the empty string, set url's query to null. + fullURL.setQuery({}); + } else { + String newSearch = value; + // Make sure that '#' in the query does not leak to the hash. + fullURL.setQuery(makeStringByReplacingAll(value, '#', "%23"_s)); + } + setFullURL(fullURL); +} + +String URLDecomposition::hash() const +{ + auto fullURL = this->fullURL(); + return fullURL.fragmentIdentifier().isEmpty() ? emptyString() : fullURL.fragmentIdentifierWithLeadingNumberSign().toString(); +} + +void URLDecomposition::setHash(StringView value) +{ + auto fullURL = this->fullURL(); + if (value.isEmpty()) + fullURL.removeFragmentIdentifier(); + else + fullURL.setFragmentIdentifier(value.startsWith('#') ? value.substring(1) : value); + setFullURL(fullURL); +} + +} -- cgit v1.2.3 m'>jarred/no-more-npm Unnamed repository; edit this file 'description' to name the repository.
aboutsummaryrefslogtreecommitdiff
AgeCommit message (Collapse)AuthorFilesLines
2023-09-04Add zig changesGravatar Colin McDonnell 1-0/+29
2023-09-04chore: fix typo (#4476)Gravatar Ai Hoshino 1-1/+1
Close: #4377
2023-09-04fix(HTMLRewriter) buffer response before transform (#4418)Gravatar Ciro Spaciari 18-5941/+6655
* html rewriter response buffering * pipe the data when marked as used * fix empty response * add some fetch tests * deinit parent stream * fix decompression * keep byte_reader alive * update builds * remove nonsense * was not nonsense after all * protect tmp ret value from GC, fix readable strong ref deinit/init * fmt * if we detach the stream we cannot update the fetch stream * detach checking source * more tests, progress with javascript and Direct sink * drop support for pure readable stream for now * more fixes --------- Co-authored-by: Jarred Sumner <jarred@jarredsumner.com>
2023-09-03initialize JSC for macros from cliGravatar Dylan Conway 1-0/+4
2023-09-03fix(syscall): fix handling syscall errno (#4461)Gravatar Ai Hoshino 2-1/+22
* fix(syscall): fix handling syscall errno Close: #4198 * remove unused code * add more tests * remove unused code
2023-09-02workaround a zig bug (#4440)Gravatar dave caruso 1-3/+4
2023-09-01docs: fix http simple example log statement (#4320)Gravatar Karl Böhlmark 1-1/+1
Co-authored-by: Karl Böhlmark <karl.bohlmark@netinsight.net>
2023-09-01Fix typo (#4445)Gravatar Jorge Jiménez 1-1/+1
Replace `key: [Bun.file('./key1.pem'), Bun.file('./key2.pem']` with `key: [Bun.file('./key1.pem'), Bun.file('./key2.pem')]`
2023-09-01keep export star as (#4451)Gravatar Dylan Conway 1-14/+0
2023-09-01bun-vscode 0.0.8Gravatar Colin McDonnell 3-41/+39
2023-09-01Update commandsGravatar Colin McDonnell 3-4/+6
2023-09-01fix `Bun.serve` with tls and `Bun.file` (#4450)Gravatar Dylan Conway 3-14/+40
* check sendfile ctx * add test * undo blob check * undo undo and add assert
2023-09-01exclusive maxGravatar Dylan Conway 1-1/+1
2023-09-01Fix debug console from appears on startGravatar Ashcon Partovi 2-2/+5
2023-09-01Add configuration options to extensionGravatar Ashcon Partovi 5-5/+137
2023-09-01Fix run button starting cwd at /Gravatar Ashcon Partovi 1-0/+2
2023-09-01fix(runtime): fix dns_resolver crash (#4435)Gravatar dave caruso 3-17/+19
* fix incorrect c pointer * format * lets go * random other test case fixed * hanassagi patch * Update dns_resolver.zig * Revert "Update dns_resolver.zig" This reverts commit 53eb338048583a338e7c01d2b351f1c679db3e15. * See if the tests pass --------- Co-authored-by: Jarred Sumner <709451+Jarred-Sumner@users.noreply.github.com> Co-authored-by: Jarred Sumner <jarred@jarredsumner.com>
2023-09-01Fix background colorGravatar Ashcon Partovi 1-2/+3
2023-09-01Allow older versions of VSCodeGravatar Ashcon Partovi 2-6/+5
2023-09-01Fix README for extensionGravatar Ashcon Partovi 2-7/+12
2023-09-01Update VSCode extensionGravatar Ashcon Partovi 1-3/+4
2023-09-01Fix breakpoint on entry for extensionGravatar Ashcon Partovi 5-18/+15
2023-09-01Add Bun.canReload event to inspectorGravatar Ashcon Partovi 2-0/+17
2023-08-31JavaScript Debug Terminal == Bun TerminalGravatar Ashcon Partovi 1-0/+32
2023-08-31fix(runtime): `fs.cp` edge cases (#4439)Gravatar dave caruso 2-8/+44
* yippee * enable cpSync tests * much better * that doesnt actually do anything * lose
2023-08-31only set initial debugger breakpoint once (#4441)Gravatar Dylan Conway 1-2/+11
* unset `set_breakpoint_on_first_line` on reload * move to `module_loader.zig`
2023-08-31Make breakpoints faster in VSCode extensionGravatar Ashcon Partovi 1-241/+327
2023-08-31`bun install` correctly join dependency URLs (#4421)Gravatar Julian 6-64/+243
* use WTF to join registry strings * show dependency error messages, better join error We actually report errors when enqueuing dependencies now. I also made the join URLs error message read better. It'd be cleaner to handle it all in one place, but there's currently no way to propagate the data up. * starting on registry URL tests * added more registry URL tests * [install] prevent optional/peer deps from failing builds Couldn't get the peer dependency test to work, but the code is there. * ran prettier * changed error note to use realname, updated tests * ran prettier again...
2023-08-31get name if not provided in `FormData.append` (#4434)Gravatar Dylan Conway 4-5/+45
* get file name from blob if not provided * add test * another test * format
2023-08-31Fix vscode debug terminalGravatar Ashcon Partovi 1-21/+0