use md5::{Digest as Md5Digest, Md5};
use sha1::Sha1;
use sha2::Sha256;
pub fn calculate_sha1(content: &[u8]) -> String {
let digest = Sha1::digest(content);
hex::encode(digest)
}
pub fn calculate_md5(content: &[u8]) -> String {
let digest = Md5::digest(content);
hex::encode(digest)
}
pub fn calculate_sha256(content: &[u8]) -> String {
let digest = Sha256::digest(content);
hex::encode(digest)
}
pub fn calculate_sha1_git(content: &[u8]) -> String {
let mut payload = Vec::with_capacity(content.len() + 32);
payload.extend_from_slice(format!("blob {}\0", content.len()).as_bytes());
payload.extend_from_slice(content);
calculate_sha1(&payload)
}