feat(tvix/castore): set user-agent for object_store blob/directorysvc

Change-Id: I9fcebffb19174cba2e9001398419d3041266400c
Reviewed-on: https://cl.tvl.fyi/c/depot/+/12850
Reviewed-by: Vladimir Kryachko <v.kryachko@gmail.com>
Tested-by: BuildkiteCI
Autosubmit: flokli <flokli@flokli.de>
Reviewed-by: flokli <flokli@flokli.de>
This commit is contained in:
Florian Klink 2024-11-28 21:20:10 +02:00 committed by clbot
parent fa305dea90
commit 9fabf8a1b5
3 changed files with 41 additions and 9 deletions

View file

@ -1,5 +1,5 @@
use std::{ use std::{
collections::HashMap, collections::{hash_map, HashMap},
io::{self, Cursor}, io::{self, Cursor},
pin::pin, pin::pin,
sync::Arc, sync::Arc,
@ -298,10 +298,24 @@ impl ServiceBuilder for ObjectStoreBlobServiceConfig {
instance_name: &str, instance_name: &str,
_context: &CompositionContext, _context: &CompositionContext,
) -> Result<Arc<dyn BlobService>, Box<dyn std::error::Error + Send + Sync + 'static>> { ) -> Result<Arc<dyn BlobService>, Box<dyn std::error::Error + Send + Sync + 'static>> {
let (object_store, path) = object_store::parse_url_opts( let opts = {
&self.object_store_url.parse()?, let mut opts: HashMap<&str, _> = self
&self.object_store_options, .object_store_options
)?; .iter()
.map(|(k, v)| (k.as_str(), v.as_str()))
.collect();
if let hash_map::Entry::Vacant(e) =
opts.entry(object_store::ClientConfigKey::UserAgent.as_ref())
{
e.insert(crate::USER_AGENT);
}
opts
};
let (object_store, path) =
object_store::parse_url_opts(&self.object_store_url.parse()?, opts)?;
Ok(Arc::new(ObjectStoreBlobService { Ok(Arc::new(ObjectStoreBlobService {
instance_name: instance_name.to_string(), instance_name: instance_name.to_string(),
object_store: Arc::new(object_store), object_store: Arc::new(object_store),

View file

@ -1,3 +1,4 @@
use std::collections::hash_map;
use std::collections::HashMap; use std::collections::HashMap;
use std::sync::Arc; use std::sync::Arc;
@ -232,10 +233,24 @@ impl ServiceBuilder for ObjectStoreDirectoryServiceConfig {
instance_name: &str, instance_name: &str,
_context: &CompositionContext, _context: &CompositionContext,
) -> Result<Arc<dyn DirectoryService>, Box<dyn std::error::Error + Send + Sync + 'static>> { ) -> Result<Arc<dyn DirectoryService>, Box<dyn std::error::Error + Send + Sync + 'static>> {
let (object_store, path) = object_store::parse_url_opts( let opts = {
&self.object_store_url.parse()?, let mut opts: HashMap<&str, _> = self
&self.object_store_options, .object_store_options
)?; .iter()
.map(|(k, v)| (k.as_str(), v.as_str()))
.collect();
if let hash_map::Entry::Vacant(e) =
opts.entry(object_store::ClientConfigKey::UserAgent.as_ref())
{
e.insert(crate::USER_AGENT);
}
opts
};
let (object_store, path) =
object_store::parse_url_opts(&self.object_store_url.parse()?, opts)?;
Ok(Arc::new(ObjectStoreDirectoryService::new( Ok(Arc::new(ObjectStoreDirectoryService::new(
instance_name.to_string(), instance_name.to_string(),
Arc::new(object_store), Arc::new(object_store),

View file

@ -21,6 +21,9 @@ pub mod import;
pub mod proto; pub mod proto;
pub mod tonic; pub mod tonic;
// Used as user agent in various HTTP Clients
const USER_AGENT: &str = concat!(env!("CARGO_PKG_NAME"), "/", env!("CARGO_PKG_VERSION"));
pub use digests::{B3Digest, B3_LEN}; pub use digests::{B3Digest, B3_LEN};
pub use errors::{DirectoryError, Error, ValidateNodeError}; pub use errors::{DirectoryError, Error, ValidateNodeError};
pub use hashing_reader::{B3HashingReader, HashingReader}; pub use hashing_reader::{B3HashingReader, HashingReader};