diff options
Diffstat (limited to 'src')
-rw-r--r-- | src/login.rs | 8 | ||||
-rw-r--r-- | src/main.rs | 3 | ||||
-rw-r--r-- | src/media/storage/file.rs | 16 |
3 files changed, 16 insertions, 11 deletions
diff --git a/src/login.rs b/src/login.rs index 646c832..19bfaf7 100644 --- a/src/login.rs +++ b/src/login.rs @@ -332,7 +332,13 @@ async fn client_metadata<S: Storage + Send + Sync + 'static>( digest.update(b" "); digest.update(crate::OAUTH2_SOFTWARE_ID.as_bytes()); - let etag = String::from("W/") + &hex::encode(digest.finalize()); + let etag = { + let mut etag = String::with_capacity(66); + etag.push_str("W/"); + data_encoding::HEXLOWER.encode_append(&digest.finalize(), &mut etag); + + etag + }; axum_extra::headers::ETag::from_str(&etag).unwrap() }; if let Some(cached) = cached { diff --git a/src/main.rs b/src/main.rs index 3aee6c3..f57b0be 100644 --- a/src/main.rs +++ b/src/main.rs @@ -1,4 +1,3 @@ -use base64::Engine; use kittybox::{database::Storage, indieauth::backend::AuthBackend, media::storage::MediaStore, webmentions::Webmention, compose_kittybox}; use tokio::{sync::Mutex, task::JoinSet}; use std::{env, future::IntoFuture, sync::Arc}; @@ -82,7 +81,7 @@ async fn main() { // TODO: load from environment let cookie_key = axum_extra::extract::cookie::Key::from(&env::var("COOKIE_KEY") .as_deref() - .map(|s| base64::prelude::BASE64_STANDARD.decode(s.as_bytes()) + .map(|s| data_encoding::BASE64_MIME_PERMISSIVE.decode(s.as_bytes()) .expect("Invalid cookie key: must be base64 encoded") ) .unwrap() diff --git a/src/media/storage/file.rs b/src/media/storage/file.rs index 711b298..e432945 100644 --- a/src/media/storage/file.rs +++ b/src/media/storage/file.rs @@ -99,15 +99,15 @@ impl MediaStore for FileStore { tempfile.flush().await?; tempfile.into_inner().sync_all().await?; - let hash = hasher.finalize(); - debug!("Pending upload hash: {}", hex::encode(hash)); + let hash = data_encoding::HEXLOWER.encode(&hasher.finalize()); + debug!("Pending upload hash: {}", hash); let filename = format!( "{}/{}/{}/{}/{}", - hex::encode([hash[0]]), - hex::encode([hash[1]]), - hex::encode([hash[2]]), - hex::encode([hash[3]]), - hex::encode(&hash[4..32]) + &hash[0..2], + &hash[2..4], + &hash[4..6], + &hash[6..8], + &hash[8..] ); let domain_str = domain.to_string(); let filepath = self.base.join(domain_str.as_str()).join(&filename); @@ -115,7 +115,7 @@ impl MediaStore for FileStore { let metapath = self.base.join(domain_str.as_str()).join(&metafilename); let metatemppath = self.base.join(domain_str.as_str()).join(metafilename + ".tmp"); metadata.length = std::num::NonZeroUsize::new(length); - metadata.etag = Some(hex::encode(hash)); + metadata.etag = Some(hash); debug!("File path: {}, metadata: {}", filepath.display(), metapath.display()); { let parent = filepath.parent().unwrap(); |