4 releases (2 breaking)

0.6.2 Aug 26, 2022
0.6.1 Aug 22, 2022
0.5.0 Aug 22, 2022
0.4.0 Aug 22, 2022

#482 in HTTP client

Download history 91/week @ 2024-07-22 52/week @ 2024-07-29 33/week @ 2024-08-05 6/week @ 2024-08-26 18/week @ 2024-09-02 27/week @ 2024-09-23 16/week @ 2024-09-30 2/week @ 2024-10-07 16/week @ 2024-10-14 6/week @ 2024-10-21 14/week @ 2024-10-28 18/week @ 2024-11-04

54 downloads per month

MIT license

9KB
171 lines

Format URLs for fetch requests using templates and substitution values.

Usage

use format_url::FormatUrl;

let url = FormatUrl::new("https://api.example.com/")
    .with_path_template("/user/:name")
    .with_substitutes(vec![("name", "alex")])
    .with_query_params(vec![("active", "true")])
    .format_url();

assert_eq!(url, "https://api.example.com/user/alex?active=true");

Wishlist

  • Support for lists and nested values. (serde_urlencoded -> serde_qs)
  • Support receiving query params as any value serde_urlencoded or serde_qs can serialize.
  • Support receiving path template substitutes as a (Hash)Map, perhaps even a struct with matching fields.

lib.rs:

Format URLs for fetch requests using templates and substitution values.

Usage

use format_url::FormatUrl;

let url = FormatUrl::new("https://api.example.com/")
    .with_path_template("/user/:name")
    .with_substitutes(vec![("name", "alex")])
    .with_query_params(vec![("active", "true")])
    .format_url();

assert_eq!(url, "https://api.example.com/user/alex?active=true");

Wishlist

  • Support for lists and nested values. (serde_urlencoded -> serde_qs)
  • Support receiving query params as any value serde_urlencoded or serde_qs can serialize.
  • Support receiving path template substitutes as a (Hash)Map, perhaps even a struct with matching fields.

Dependencies

~13KB