Url
Url
It could be an absolute address, such as https://roc-lang.org/authors
or
a relative address, such as /authors
. You can create one using Url.from_str
.
reserve : Url, U64 -> Url
Reserve the given number of bytes as extra capacity. This can avoid reallocation when calling multiple functions that increase the length of the URL.
The following example reserves 50 bytes, then builds the url https://example.com/stuff?caf%C3%A9=du%20Monde&email=hi%40example.com
;
Url.from_str "https://example.com" |> Url.reserve 50 |> Url.append "stuff" |> Url.append_param "café" "du Monde" |> Url.append_param "email" "hi@example.com"
The Str.countUtf8Bytes function can be helpful in finding out how many bytes to reserve.
There is no Url.withCapacity
because it's better to reserve extra capacity
on a Str
first, and then pass that string to Url.from_str
. This function will make use
of the extra capacity.
from_str : Str -> Url
Create a Url
without validating or percent-encoding
anything.
Url.from_str "https://example.com#stuff"
URLs can be absolute, like https://example.com
, or they can be relative, like /blah
.
Url.from_str "/this/is#relative"
Since nothing is validated, this can return invalid URLs.
Url.from_str "https://this is not a valid URL, not at all!"
Naturally, passing invalid URLs to functions that need valid ones will tend to result in errors.
to_str : Url -> Str
Return a Str
representation of this URL.
# Gives "https://example.com/two%20words" Url.from_str "https://example.com" |> Url.append "two words" |> Url.to_str
append : Url, Str -> Url
Percent-encodes a path component and appends to the end of the URL's path.
This will be appended before any queries and fragments. If the given path string begins with /
and the URL already ends with /
, one
will be ignored. This avoids turning a single slash into a double slash. If either the given URL or the given string is empty, no /
will be added.
# Gives https://example.com/some%20stuff Url.from_str "https://example.com" |> Url.append "some stuff" # Gives https://example.com/stuff?search=blah#fragment Url.from_str "https://example.com?search=blah#fragment" |> Url.append "stuff" # Gives https://example.com/things/stuff/more/etc/" Url.from_str "https://example.com/things/" |> Url.append "/stuff/" |> Url.append "/more/etc/" # Gives https://example.com/things Url.from_str "https://example.com/things" |> Url.append ""
append_param :
Url,
Str,
Str
-> Url
Adds a Str
query parameter to the end of the Url
.
The key and value both get percent-encoded.
# Gives https://example.com?email=someone%40example.com Url.from_str "https://example.com" |> Url.append_param "email" "someone@example.com"
This can be called multiple times on the same URL.
# Gives https://example.com?caf%C3%A9=du%20Monde&email=hi%40example.com Url.from_str "https://example.com" |> Url.append_param "café" "du Monde" |> Url.append_param "email" "hi@example.com"
with_query : Url, Str -> Url
Replaces the URL's query—the part
after the ?
, if it has one, but before any #
it might have.
Passing ""
removes the ?
(if there was one).
# Gives https://example.com?newQuery=thisRightHere#stuff Url.from_str "https://example.com?key1=val1&key2=val2#stuff" |> Url.with_query "newQuery=thisRightHere" # Gives https://example.com#stuff Url.from_str "https://example.com?key1=val1&key2=val2#stuff" |> Url.with_query ""
query : Url -> Str
Returns the URL's query—the part after
the ?
, if it has one, but before any #
it might have.
Returns ""
if the URL has no query.
# Gives "key1=val1&key2=val2&key3=val3" Url.from_str "https://example.com?key1=val1&key2=val2&key3=val3#stuff" |> Url.query # Gives "" Url.from_str "https://example.com#stuff" |> Url.query
has_query : Url -> Bool
Returns Bool.true
if the URL has a ?
in it.
# Gives Bool.true Url.from_str "https://example.com?key=value#stuff" |> Url.has_query # Gives Bool.false Url.from_str "https://example.com#stuff" |> Url.has_query
fragment : Url -> Str
Returns the URL's fragment—the part after
the #
, if it has one.
Returns ""
if the URL has no fragment.
# Gives "stuff" Url.from_str "https://example.com#stuff" |> Url.fragment # Gives "" Url.from_str "https://example.com" |> Url.fragment
with_fragment : Url, Str -> Url
Replaces the URL's fragment.
If the URL didn't have a fragment, adds one. Passing ""
removes the fragment.
# Gives https://example.com#things Url.from_str "https://example.com#stuff" |> Url.with_fragment "things" # Gives https://example.com#things Url.from_str "https://example.com" |> Url.with_fragment "things" # Gives https://example.com Url.from_str "https://example.com#stuff" |> Url.with_fragment ""
has_fragment : Url -> Bool
Returns Bool.true
if the URL has a #
in it.
# Gives Bool.true Url.from_str "https://example.com?key=value#stuff" |> Url.has_fragment # Gives Bool.false Url.from_str "https://example.com?key=value" |> Url.has_fragment
query_params : Url -> Dict Str Str
path : Url -> Str
Returns the URL's path—the part after
the scheme and authority (e.g. https://
) but before any ?
or #
it might have.
Returns ""
if the URL has no path.
# Gives "example.com/" Url.fromStr "https://example.com/?key1=val1&key2=val2&key3=val3#stuff" |> Url.path
# Gives "/foo/" Url.fromStr "/foo/?key1=val1&key2=val2&key3=val3#stuff" |> Url.path