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
use serde::{Deserialize, Serialize};
/// Hyperlink to enable Hypermedia Access
#[serde_with::skip_serializing_none]
#[derive(Serialize, Deserialize, Debug, PartialEq, Eq, Clone)]
pub struct Link {
/// Supplies the URI to a remote resource (or resource fragment).
pub href: String,
/// The type or semantics of the relation.
pub rel: String,
/// A hint indicating what the media type of the result of dereferencing
/// the link should be.
pub r#type: Option<String>,
/// A hint indicating what the language of the result of dereferencing the
/// link should be.
pub hreflang: Option<String>,
/// Used to label the destination of a link such that it can be used as a
/// human-readable identifier.
pub title: Option<String>,
pub length: Option<i64>,
}
impl Link {
/// Constructs a new Link with the given href and link relation
pub fn new(href: impl ToString, rel: impl ToString) -> Link {
Link {
href: href.to_string(),
rel: rel.to_string(),
r#type: None,
hreflang: None,
title: None,
length: None,
}
}
/// Sets the media type of the Link and returns the Value
pub fn mediatype(mut self, mime: impl ToString) -> Link {
self.r#type = Some(mime.to_string());
self
}
/// Sets the language of the Link and returns the Value
pub fn language(mut self, language: impl ToString) -> Link {
self.hreflang = Some(language.to_string());
self
}
/// Sets the title of the Link and returns the Value
pub fn title(mut self, title: impl ToString) -> Link {
self.title = Some(title.to_string());
self
}
/// Sets the length of the reference resource by the Link and returns the Value
pub fn length(mut self, length: i64) -> Link {
self.length = Some(length);
self
}
}