Test contact extraction
This commit is contained in:
		
							parent
							
								
									1311f92b6c
								
							
						
					
					
						commit
						2479c2b39d
					
				
					 1 changed files with 24 additions and 35 deletions
				
			
		|  | @ -33,45 +33,33 @@ impl QueryContact { | |||
|             .fetch::<AcceptedActors>(self.contact_id.as_str()) | ||||
|             .await?; | ||||
| 
 | ||||
|         let username = contact.preferred_username(); | ||||
|         let display_name = contact | ||||
|             .name() | ||||
|             .and_then(|name| name.as_one().and_then(|s| s.as_xsd_string())); | ||||
|         let url = contact.url().and_then(|url| url.as_single_id()); | ||||
|         let avatar = contact | ||||
|             .icon() | ||||
|             .and_then(|one_or_many| one_or_many.as_one()) | ||||
|             .and_then(|any_base| Image::from_any_base(any_base.clone()).ok()?) | ||||
|             .and_then(|image| { | ||||
|                 image | ||||
|                     .url() | ||||
|                     .and_then(|url| url.as_single_id()) | ||||
|                     .map(|url| url.to_owned()) | ||||
|             }); | ||||
| 
 | ||||
|         let optioned = || { | ||||
|             let username = username?; | ||||
|             let display_name = display_name?; | ||||
|             let url = url?; | ||||
|             let avatar = avatar?; | ||||
| 
 | ||||
|             Some(state.node_cache.set_contact( | ||||
|                 self.actor_id.clone(), | ||||
|                 username.to_owned(), | ||||
|                 display_name.to_owned(), | ||||
|                 url.to_owned(), | ||||
|                 avatar.to_owned(), | ||||
|             )) | ||||
|         }; | ||||
| 
 | ||||
|         if let Some(fut) = (optioned)() { | ||||
|             fut.await?; | ||||
|         if let Some((username, display_name, url, avatar)) = to_contact(contact) { | ||||
|             state | ||||
|                 .node_cache | ||||
|                 .set_contact(self.actor_id, username, display_name, url, avatar) | ||||
|                 .await?; | ||||
|         } | ||||
| 
 | ||||
|         Ok(()) | ||||
|     } | ||||
| } | ||||
| 
 | ||||
| fn to_contact(contact: AcceptedActors) -> Option<(String, String, Url, Url)> { | ||||
|     let username = contact.preferred_username()?.to_owned(); | ||||
|     let display_name = contact.name()?.as_one()?.as_xsd_string()?.to_owned(); | ||||
| 
 | ||||
|     let url = contact.url()?.as_single_id()?.to_owned(); | ||||
|     let any_base = contact.icon()?.as_one()?; | ||||
| 
 | ||||
|     let avatar = Image::from_any_base(any_base.clone()) | ||||
|         .ok()?? | ||||
|         .url()? | ||||
|         .as_single_id()? | ||||
|         .to_owned(); | ||||
| 
 | ||||
|     Some((username, display_name, url, avatar)) | ||||
| } | ||||
| 
 | ||||
| impl ActixJob for QueryContact { | ||||
|     type State = JobState; | ||||
|     type Future = Pin<Box<dyn Future<Output = Result<(), Error>>>>; | ||||
|  | @ -85,12 +73,13 @@ impl ActixJob for QueryContact { | |||
| 
 | ||||
| #[cfg(test)] | ||||
| mod tests { | ||||
|     use crate::apub::AcceptedActors; | ||||
|     use super::to_contact; | ||||
| 
 | ||||
|     const HYNET_ADMIN: &'static str = r#"{"@context":["https://www.w3.org/ns/activitystreams","https://soc.hyena.network/schemas/litepub-0.1.jsonld",{"@language":"und"}],"alsoKnownAs":[],"attachment":[{"name":"Website","type":"PropertyValue","value":"https://hyena.network/"},{"name":"Services","type":"PropertyValue","value":"Pleroma, Invidious, SearX, XMPP"},{"name":"CW","type":"PropertyValue","value":"all long posts"}],"capabilities":{"acceptsChatMessages":true},"discoverable":true,"endpoints":{"oauthAuthorizationEndpoint":"https://soc.hyena.network/oauth/authorize","oauthRegistrationEndpoint":"https://soc.hyena.network/api/v1/apps","oauthTokenEndpoint":"https://soc.hyena.network/oauth/token","sharedInbox":"https://soc.hyena.network/inbox","uploadMedia":"https://soc.hyena.network/api/ap/upload_media"},"followers":"https://soc.hyena.network/users/HyNET/followers","following":"https://soc.hyena.network/users/HyNET/following","icon":{"type":"Image","url":"https://soc.hyena.network/media/ab149b1e0196ffdbecc6830c7f6f1a14dd8d8408ec7db0f1e8ad9d40e600ea73.gif"},"id":"https://soc.hyena.network/users/HyNET","image":{"type":"Image","url":"https://soc.hyena.network/media/12ba78d3015e13aa65ac4e106e574dd7bf959614585f10ce85de40e0148da677.png"},"inbox":"https://soc.hyena.network/users/HyNET/inbox","manuallyApprovesFollowers":false,"name":"HyNET Announcement System :glider:","outbox":"https://soc.hyena.network/users/HyNET/outbox","preferredUsername":"HyNET","publicKey":{"id":"https://soc.hyena.network/users/HyNET#main-key","owner":"https://soc.hyena.network/users/HyNET","publicKeyPem":"-----BEGIN PUBLIC KEY-----\nMIIBIjANBgkqhkiG9w0BAQEFAAOCAQ8AMIIBCgKCAQEAyF74womumWRhR7RW4Q6a\n2+Av/Ue8QHiKwjQARJEakbKnKgkI5FRFVVOfMiYVJp/juNt4GLgK15panBqJa9Yt\nWACiHQjBd2yVI5tIHiae0uBj5SdUVuduoycVLG0lpJsg12p8m/vL1oaeLqehTqa6\nsYplQh1GCLet0cUdn/66Cj2pAPD3V7Bz3VnG+oyXIsGQbBB8RHnWhFH8b0qQOyur\nJRAB8aye6QAL2sQbfISM2lycWzNeIHkqsUb7FdqdhQ+Ze0rETRGDkOO2Qvpg0hQm\n6owMsHnHA/DzyOHLy6Yf+I3OUlBC/P1SSAKwORsifFDXL322AEqoDi5ZpwzG9m5z\nAQIDAQAB\n-----END PUBLIC KEY-----\n\n"},"summary":"Ran by <span class=\"h-card\"><a class=\"u-url mention\" data-user=\"9s8j4AHGt3ED0P0b6e\" href=\"https://soc.hyena.network/users/mel\" rel=\"ugc\">@<span>mel</span></a></span> :adm1::adm2: <br/>For direct help with the service, send <span class=\"h-card\"><a class=\"u-url mention\" data-user=\"9s8j4AHGt3ED0P0b6e\" href=\"https://soc.hyena.network/users/mel\" rel=\"ugc\">@<span>mel</span></a></span> a message.","tag":[{"icon":{"type":"Image","url":"https://soc.hyena.network/emoji/Signs/adm1.png"},"id":"https://soc.hyena.network/emoji/Signs/adm1.png","name":":adm1:","type":"Emoji","updated":"1970-01-01T00:00:00Z"},{"icon":{"type":"Image","url":"https://soc.hyena.network/emoji/Signs/adm2.png"},"id":"https://soc.hyena.network/emoji/Signs/adm2.png","name":":adm2:","type":"Emoji","updated":"1970-01-01T00:00:00Z"},{"icon":{"type":"Image","url":"https://soc.hyena.network/emoji/misc/glider.png"},"id":"https://soc.hyena.network/emoji/misc/glider.png","name":":glider:","type":"Emoji","updated":"1970-01-01T00:00:00Z"}],"type":"Service","url":"https://soc.hyena.network/users/HyNET"}"#; | ||||
| 
 | ||||
|     #[test] | ||||
|     fn parse_hynet() { | ||||
|         serde_json::from_str::<AcceptedActors>(HYNET_ADMIN).unwrap(); | ||||
|         let actor = serde_json::from_str(HYNET_ADMIN).unwrap(); | ||||
|         to_contact(actor).unwrap(); | ||||
|     } | ||||
| } | ||||
|  |  | |||
		Loading…
	
	Add table
		
		Reference in a new issue