Add "Created at" attribute to IPFS representation of a post
This commit is contained in:
parent
1de82674aa
commit
1d089d4b35
2 changed files with 27 additions and 1 deletions
|
@ -1,15 +1,29 @@
|
||||||
|
use chrono::{DateTime, Utc};
|
||||||
use serde::Serialize;
|
use serde::Serialize;
|
||||||
|
use serde_json::{json, Value};
|
||||||
use uuid::Uuid;
|
use uuid::Uuid;
|
||||||
|
|
||||||
use super::utils::get_ipfs_url;
|
use super::utils::get_ipfs_url;
|
||||||
|
|
||||||
// https://docs.opensea.io/docs/metadata-standards
|
/// ERC-721 custom attribute as defined by OpenSea guidelines.
|
||||||
|
#[derive(Serialize)]
|
||||||
|
struct Attribute {
|
||||||
|
trait_type: String,
|
||||||
|
value: Value,
|
||||||
|
display_type: String,
|
||||||
|
}
|
||||||
|
|
||||||
|
/// JSON representation of a post. Compatible with ERC-721 metadata standard.
|
||||||
|
/// https://docs.opensea.io/docs/metadata-standards
|
||||||
#[derive(Serialize)]
|
#[derive(Serialize)]
|
||||||
pub struct PostMetadata {
|
pub struct PostMetadata {
|
||||||
|
// Fields required by ERC-721
|
||||||
name: String,
|
name: String,
|
||||||
description: String,
|
description: String,
|
||||||
image: String,
|
image: String,
|
||||||
|
// OpenSea custom fields
|
||||||
external_url: String,
|
external_url: String,
|
||||||
|
attributes: Vec<Attribute>,
|
||||||
}
|
}
|
||||||
|
|
||||||
impl PostMetadata {
|
impl PostMetadata {
|
||||||
|
@ -17,13 +31,20 @@ impl PostMetadata {
|
||||||
post_id: &Uuid,
|
post_id: &Uuid,
|
||||||
post_url: &str,
|
post_url: &str,
|
||||||
content: &str,
|
content: &str,
|
||||||
|
created_at: &DateTime<Utc>,
|
||||||
image_cid: &str,
|
image_cid: &str,
|
||||||
) -> Self {
|
) -> Self {
|
||||||
|
let created_at_attr = Attribute {
|
||||||
|
trait_type: "Created at".to_string(),
|
||||||
|
value: json!(created_at.timestamp()),
|
||||||
|
display_type: "date".to_string(),
|
||||||
|
};
|
||||||
Self {
|
Self {
|
||||||
name: format!("Post {}", post_id),
|
name: format!("Post {}", post_id),
|
||||||
description: content.to_string(),
|
description: content.to_string(),
|
||||||
image: get_ipfs_url(image_cid),
|
image: get_ipfs_url(image_cid),
|
||||||
external_url: post_url.to_string(),
|
external_url: post_url.to_string(),
|
||||||
|
attributes: vec![created_at_attr],
|
||||||
}
|
}
|
||||||
}
|
}
|
||||||
}
|
}
|
||||||
|
@ -45,6 +66,7 @@ mod tests {
|
||||||
&post.id,
|
&post.id,
|
||||||
post_url,
|
post_url,
|
||||||
&post.content,
|
&post.content,
|
||||||
|
&post.created_at,
|
||||||
image_cid,
|
image_cid,
|
||||||
);
|
);
|
||||||
|
|
||||||
|
@ -52,5 +74,8 @@ mod tests {
|
||||||
assert_eq!(post_metadata.description, post.content);
|
assert_eq!(post_metadata.description, post.content);
|
||||||
assert_eq!(post_metadata.image, format!("ipfs://{}", image_cid));
|
assert_eq!(post_metadata.image, format!("ipfs://{}", image_cid));
|
||||||
assert_eq!(post_metadata.external_url, post_url);
|
assert_eq!(post_metadata.external_url, post_url);
|
||||||
|
let created_at_attr = &post_metadata.attributes[0];
|
||||||
|
assert_eq!(created_at_attr.display_type, "date");
|
||||||
|
assert_eq!(created_at_attr.value.as_i64().is_some(), true);
|
||||||
}
|
}
|
||||||
}
|
}
|
||||||
|
|
|
@ -402,6 +402,7 @@ async fn make_permanent(
|
||||||
&post.id,
|
&post.id,
|
||||||
&post_url,
|
&post_url,
|
||||||
&post.content,
|
&post.content,
|
||||||
|
&post.created_at,
|
||||||
&post_image_cid,
|
&post_image_cid,
|
||||||
);
|
);
|
||||||
let post_metadata_json = serde_json::to_string(&post_metadata)
|
let post_metadata_json = serde_json::to_string(&post_metadata)
|
||||||
|
|
Loading…
Reference in a new issue