8 releases
new 0.2.1 | Apr 29, 2025 |
---|---|
0.2.0 | Apr 26, 2025 |
0.1.7 | Jun 7, 2022 |
#358 in Data structures
205 downloads per month
34KB
531 lines
jCard (vCard in JSON format) serde serialization and deserialization.
About
Our CCTLD-developed system uses the jCard format to communicate with ICANN services. Unfortunately, since there is no jCard serde crate available, we developed our own library and used this library to create an RDAP system that makes the .uz TLD domains in Uzbekistan both fast and robust.
[!NOTE] This library is developed according to the RFC 7483 standard.
While the crate should be fully RFC compliant, please open an issue if you spot anything wrong.
Using Vicardi
use vicardi::*;
use serde_json::json;
fn main() -> anyhow::Result<()> {
let mut vcard = Vcard::default();
vcard.push(Property::new_fn("John Doe", None));
let json = json!([
"vcard",
[
["version", {}, "text", "4.0"],
["fn", {}, "text", "John Doe"]
]
]);
let parsed: Vcard = serde_json::from_value(json.clone())?;
assert_eq!(serde_json::to_value(&vcard)?, json);
assert_eq!(parsed, vcard);
Ok(())
}
See the documentation for more details.
License
This library is distributed under the GPL-3.0 license. See the LICENSE for more information!
Dependencies
~0.9–1.5MB
~33K SLoC