Files
gitks/tag/verify_tag.rs
T
zhenyi 934858bebf refactor(cache): redesign cache system with structured keys and improved performance
- 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
2026-06-12 12:53:23 +08:00

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(),
})
}
}