worldtimeapi

Crates.ioworldtimeapi
lib.rsworldtimeapi
version0.5.2
sourcesrc
created_at2022-03-29 15:24:46.730134
updated_at2024-08-05 18:24:37.11216
descriptionA simple API for getting the current time in different timezones.
homepage
repositoryhttps://github.com/martial-plains/worldtimeapi-rs
max_upload_size
id558573
size57,928
Allister Isaiah Harvey (martial-plains)

documentation

README

World Time Wrapper

Rust

This is a simple wrapper for the World Time API. This crate is based on the WorldTimeAPI wrapper by Dulatr.

Usage

To use this crate, add worldtimeapi to your Cargo.toml:

[dependencies]
worldtimeapi = "0.5.1"

Then create a client for an endpoint (currently they only offer "ip" and "timezone"):

use std::collections::HashMap;

use worldtimeapi::service::{Client, Endpoint};

#[tokio::main]
async fn main() -> Result<(), reqwest::Error> {
   let client = Client::new(Endpoint::Timezone).await?;

   let mut payload = HashMap::new();
   payload.insert("area", "America");
   payload.insert("location", "New_York");

   let result = client.get(payload).await?;
   println!("{}", result.datetime());
   Ok(())
}

To get a list of regions and locations, use the regions method:

use worldtimeapi::service::{Client, Endpoint};

#[tokio::main]
async fn main() -> Result<(), reqwest::Error> {
   let client = Client::new(Endpoint::Timezone).await?;
   let regions = client.regions();
   println!("{:?}", regions);
   Ok(())
}
Commit count: 152

cargo fmt