Skip to content

Commit

Permalink
fix: penumbra view db filepath
Browse files Browse the repository at this point in the history
The config option `view_service_storage_dir` for Penumbra chains was
honored, but was incorrectly expecting a filepath, not a parent
directory. Fixed the path handling so that a view db file is created
within the dir specified by the config option.
  • Loading branch information
conorsch committed Jun 18, 2024
1 parent ef80465 commit 8848bf8
Showing 1 changed file with 22 additions and 1 deletion.
23 changes: 22 additions & 1 deletion crates/relayer/src/chain/penumbra/chain.rs
Original file line number Diff line number Diff line change
Expand Up @@ -79,6 +79,8 @@ use tokio::runtime::Runtime as TokioRuntime;
use tokio::sync::Mutex;
use tonic::IntoRequest;

use std::path::PathBuf;

use crate::{
chain::{
endpoint::{ChainEndpoint, HealthCheck},
Expand Down Expand Up @@ -501,9 +503,28 @@ impl ChainEndpoint for PenumbraChain {

let fvk = config.kms_config.spend_key.full_viewing_key();

// Identify filepath for storing Penumbra view database locally.
// The directory might not be specified, in which case we'll preserve None,
// which causes the ViewServiceClient to use an in-memory database.
let view_file: Option<String> = match config.view_service_storage_dir {
Some(ref dir_string) => {
let p = PathBuf::from(dir_string)
.join("relayer-view.sqlite")
.to_str()
.ok_or_else(|| Error::temp_penumbra_error("Non-UTF8 view path".to_owned()))?
.to_owned();
tracing::info!("using view database at {}", p);
Some(p)
}
None => {
tracing::warn!("using in-memory view database for penumbra; consider setting 'view_service_storage_dir'");
None
}
};

let svc = rt
.block_on(ViewServer::load_or_initialize(
config.view_service_storage_dir.clone(),
view_file,
fvk,
config.grpc_addr.clone().into(),
))
Expand Down

0 comments on commit 8848bf8

Please sign in to comment.