1 2 3 4 5 6 7 8 9 10 11 12 13 14 15 16 17 18 19 20 21 22 23 24 25 26 27 28 29 30 31 32 33 34 35 36 37 38 39 40 41 42 43 44 45 46 47 48 49 50 51 52 53 54 55 56 57 58 59 60 61 62 63 64 65
//! Resources (enums, structs) for processing the _Time Zone API_ response from //! the Google Maps Platform. Look in here for more information about the data //! returned from Google's server and how to parse it with your program. pub mod status; use crate::time_zone::response::status::Status; use serde::{Serialize, Deserialize}; /// The response from the Google Maps Time Zone API will be stored in this /// structure. /// /// [Time Zone Responses](https://developers.google.com/maps/documentation/timezone/intro#Responses) /// ------------------------------------------------------------------------------------------------ /// For each valid request, the time zone service will return a response in the /// format indicated within the request URI. /// /// [Calculating the Local Time](https://developers.google.com/maps/documentation/timezone/intro#CalculatingTime) /// /// The local time of a given location is the sum of the timestamp parameter, /// and the dstOffset and rawOffset fields from the result. #[derive(Clone, Debug, Eq, Hash, Ord, PartialEq, PartialOrd, Serialize, Deserialize)] pub struct Response { /// The offset for daylight-savings time in seconds. This will be zero if /// the time zone is not in Daylight Savings Time during the specified /// `time`. #[serde(alias = "dstOffset")] pub dst_offset: Option<i16>, /// More detailed information about the reasons behind the given status /// code, if other than `OK`. /// /// **Note**: This field is not guaranteed to be always present, and its /// content is subject to change. #[serde(alias = "errorMessage")] pub error_message: Option<String>, /// The offset from UTC (in seconds) for the given location. This does not /// take into effect daylight savings. #[serde(alias = "rawOffset")] pub raw_offset: Option<i16>, /// The status of the response. pub status: Status, /// A string containing the ID of the time zone, such as /// "America/Los_Angeles" or "Australia/Sydney". These IDs are defined by /// Unicode [Common Locale Data Repository (CLDR) /// project](http://cldr.unicode.org/), and currently available in file /// [timezone.xml](http://unicode.org/repos/cldr/trunk/common/bcp47/timezone.xml). /// When a timezone has several IDs, the canonical one is returned. In /// timezone.xml, this is the first alias of each timezone. For example, /// "Asia/Calcutta" is returned, not "Asia/Kolkata". #[serde(alias = "timeZoneId")] pub time_zone_id: Option<String>, /// A string containing the long form name of the time zone. This field will /// be localized if the language parameter is set. eg. "Pacific Daylight /// Time" or "Australian Eastern Daylight Time" #[serde(alias = "timeZoneName")] pub time_zone_name: Option<String>, } // struct