Url

Url

A Uniform Resource Locator.

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