934858bebf
- Add repo_path parameter to cached_response and cached_vec_response functions - Implement structured cache key format with namespace, repo_path, and request proto - Replace global cache with Moka in-memory cache using weight-based eviction - Set 256MB memory cap with 10-minute TTL and 2-minute TTI policy - Add metrics collection for cache operations and evictions - Implement efficient repo-scoped invalidation using key structure - Add detailed documentation comments explaining cache architecture - Remove outdated dependencies and update dependency versions - Add error handling for encoding failures in cache operations - Optimize Vec responses with length-delimited encoding and pre-allocation
37 lines
1.1 KiB
Rust
37 lines
1.1 KiB
Rust
use crate::bare::GitBare;
|
|
use crate::error::GitResult;
|
|
use crate::pb::{VerifiedSignature, VerifyTagRequest};
|
|
|
|
impl GitBare {
|
|
pub fn verify_tag(&self, request: VerifyTagRequest) -> GitResult<VerifiedSignature> {
|
|
crate::sanitize::validate_ref_name(&request.name)?;
|
|
let result = duct::cmd(
|
|
"git",
|
|
[
|
|
"--git-dir",
|
|
self.bare_dir.to_string_lossy().as_ref(),
|
|
"tag",
|
|
"-v",
|
|
&request.name,
|
|
],
|
|
)
|
|
.stdout_capture()
|
|
.stderr_capture()
|
|
.unchecked()
|
|
.run()?;
|
|
let verified = result.status.success();
|
|
Ok(VerifiedSignature {
|
|
verified,
|
|
reason: if verified {
|
|
crate::pb::verified_signature::Reason::Valid as i32
|
|
} else {
|
|
crate::pb::verified_signature::Reason::GpgverifyError as i32
|
|
},
|
|
signature: String::new(),
|
|
payload: String::new(),
|
|
key_fingerprint: String::new(),
|
|
signer: String::new(),
|
|
})
|
|
}
|
|
}
|