* . * . * . * . * refactor client keys * . * . * refactor * . * . * . * update new account
63 lines
1.5 KiB
Rust
63 lines
1.5 KiB
Rust
use std::collections::HashSet;
|
|
use std::hash::{DefaultHasher, Hash, Hasher};
|
|
use std::sync::Arc;
|
|
|
|
use gpui::{Image, ImageFormat};
|
|
use itertools::Itertools;
|
|
use nostr_sdk::prelude::*;
|
|
use qrcode_generator::QrCodeEcc;
|
|
|
|
pub mod debounced_delay;
|
|
pub mod handle_auth;
|
|
pub mod profile;
|
|
|
|
pub async fn nip96_upload(
|
|
client: &Client,
|
|
upload_to: Url,
|
|
file: Vec<u8>,
|
|
) -> anyhow::Result<Url, anyhow::Error> {
|
|
let signer = client.signer().await?;
|
|
|
|
let config: ServerConfig = nip96::get_server_config(upload_to.to_owned(), None).await?;
|
|
let url = nip96::upload_data(&signer, &config, file, None, None).await?;
|
|
|
|
Ok(url)
|
|
}
|
|
|
|
pub fn room_hash(event: &Event) -> u64 {
|
|
let mut hasher = DefaultHasher::new();
|
|
let mut pubkeys: Vec<&PublicKey> = vec![];
|
|
|
|
// Add all public keys from event
|
|
pubkeys.push(&event.pubkey);
|
|
pubkeys.extend(event.tags.public_keys().collect::<Vec<_>>());
|
|
|
|
// Generate unique hash
|
|
pubkeys
|
|
.into_iter()
|
|
.unique()
|
|
.sorted()
|
|
.collect::<Vec<_>>()
|
|
.hash(&mut hasher);
|
|
|
|
hasher.finish()
|
|
}
|
|
|
|
pub fn string_to_qr(data: &str) -> Option<Arc<Image>> {
|
|
let Ok(bytes) = qrcode_generator::to_png_to_vec_from_str(data, QrCodeEcc::Medium, 256) else {
|
|
return None;
|
|
};
|
|
|
|
Some(Arc::new(Image::from_bytes(ImageFormat::Png, bytes)))
|
|
}
|
|
|
|
pub fn compare<T>(a: &[T], b: &[T]) -> bool
|
|
where
|
|
T: Eq + Hash,
|
|
{
|
|
let a: HashSet<_> = a.iter().collect();
|
|
let b: HashSet<_> = b.iter().collect();
|
|
|
|
a == b
|
|
}
|