Skip to content
Snippets Groups Projects
Commit d3ee15fa authored by Éloïs's avatar Éloïs
Browse files

[ref] bc-db-writer: isolate CURRENT_META_DATAS update

parent af6eaaea
Branches
No related tags found
1 merge request!193Resolve "Migrate high-volume DBs to LMDB"
...@@ -17,19 +17,17 @@ ...@@ -17,19 +17,17 @@
pub mod fork_tree; pub mod fork_tree;
use crate::DbError;
use crate::*; use crate::*;
use dubp_block_doc::block::BlockDocumentTrait; use dubp_block_doc::block::BlockDocumentTrait;
use dubp_common_doc::traits::Document; use dubp_common_doc::traits::Document;
use durs_bc_db_reader::blocks::fork_tree::ForkTree; use durs_bc_db_reader::blocks::fork_tree::ForkTree;
use durs_bc_db_reader::blocks::DbBlock; use durs_bc_db_reader::blocks::DbBlock;
use durs_bc_db_reader::constants::*; use durs_bc_db_reader::constants::*;
use durs_bc_db_reader::current_meta_datas::CurrentMetaDataKey;
use durs_bc_db_reader::DbValue; use durs_bc_db_reader::DbValue;
use unwrap::unwrap; use unwrap::unwrap;
/// Insert new head Block in databases /// Insert new head Block in databases
/// Update MAIN_BLOCK and CURRENT_META_DATAS /// Update MAIN_BLOCK only
pub fn insert_new_head_block( pub fn insert_new_head_block(
db: &Db, db: &Db,
w: &mut DbWriter, w: &mut DbWriter,
...@@ -38,9 +36,7 @@ pub fn insert_new_head_block( ...@@ -38,9 +36,7 @@ pub fn insert_new_head_block(
) -> Result<(), DbError> { ) -> Result<(), DbError> {
// Serialize datas // Serialize datas
let bin_dal_block = durs_dbs_tools::to_bytes(&dal_block)?; let bin_dal_block = durs_dbs_tools::to_bytes(&dal_block)?;
let new_current_blockstamp_bytes: Vec<u8> = dal_block.blockstamp().into();
let current_meta_datas_store = db.get_int_store(CURRENT_METAS_DATAS);
let main_blocks_store = db.get_int_store(MAIN_BLOCKS); let main_blocks_store = db.get_int_store(MAIN_BLOCKS);
let fork_blocks_store = db.get_store(FORK_BLOCKS); let fork_blocks_store = db.get_store(FORK_BLOCKS);
...@@ -51,19 +47,6 @@ pub fn insert_new_head_block( ...@@ -51,19 +47,6 @@ pub fn insert_new_head_block(
&Db::db_value(&bin_dal_block)?, &Db::db_value(&bin_dal_block)?,
)?; )?;
// Update current blockstamp
current_meta_datas_store.put(
w.as_mut(),
CurrentMetaDataKey::CurrentBlockstamp.to_u32(),
&DbValue::Blob(&new_current_blockstamp_bytes),
)?;
// Update current common time (also named "blockchain time")
current_meta_datas_store.put(
w.as_mut(),
CurrentMetaDataKey::CurrentBlockchainTime.to_u32(),
&DbValue::U64(dal_block.block.common_time()),
)?;
if let Some(fork_tree) = fork_tree { if let Some(fork_tree) = fork_tree {
// Insert head block in fork tree // Insert head block in fork tree
let removed_blockstamps = let removed_blockstamps =
......
// Copyright (C) 2017-2019 The AXIOM TEAM Association.
//
// This program is free software: you can redistribute it and/or modify
// it under the terms of the GNU Affero General Public License as
// published by the Free Software Foundation, either version 3 of the
// License, or (at your option) any later version.
//
// This program is distributed in the hope that it will be useful,
// but WITHOUT ANY WARRANTY; without even the implied warranty of
// MERCHANTABILITY or FITNESS FOR A PARTICULAR PURPOSE. See the
// GNU Affero General Public License for more details.
//
// You should have received a copy of the GNU Affero General Public License
// along with this program. If not, see <https://www.gnu.org/licenses/>.
//! Curent meta datas storage: define write requests.
use crate::*;
use dubp_block_doc::block::BlockDocumentTrait;
use dubp_block_doc::BlockDocument;
use dubp_common_doc::traits::Document;
use durs_bc_db_reader::constants::CURRENT_METAS_DATAS;
use durs_bc_db_reader::current_meta_datas::CurrentMetaDataKey;
use durs_bc_db_reader::DbValue;
/// Update CURRENT_META_DATAS
pub fn update_current_meta_datas(
db: &Db,
w: &mut DbWriter,
new_current_block: &BlockDocument,
) -> Result<(), DbError> {
let new_current_blockstamp_bytes: Vec<u8> = new_current_block.blockstamp().into();
// Update current blockstamp
db.get_int_store(CURRENT_METAS_DATAS).put(
w.as_mut(),
CurrentMetaDataKey::CurrentBlockstamp.to_u32(),
&DbValue::Blob(&new_current_blockstamp_bytes),
)?;
// Update current common time (also named "blockchain time")
db.get_int_store(CURRENT_METAS_DATAS).put(
w.as_mut(),
CurrentMetaDataKey::CurrentBlockchainTime.to_u32(),
&DbValue::U64(new_current_block.common_time()),
)?;
Ok(())
}
...@@ -31,6 +31,7 @@ ...@@ -31,6 +31,7 @@
extern crate log; extern crate log;
pub mod blocks; pub mod blocks;
pub mod current_meta_datas;
pub mod indexes; pub mod indexes;
pub mod writers; pub mod writers;
......
...@@ -67,6 +67,7 @@ impl BlocksDBsWriteQuery { ...@@ -67,6 +67,7 @@ impl BlocksDBsWriteQuery {
BlocksDBsWriteQuery::WriteBlock(dal_block) => { BlocksDBsWriteQuery::WriteBlock(dal_block) => {
let dal_block: DbBlock = dal_block; let dal_block: DbBlock = dal_block;
trace!("BlocksDBsWriteQuery::WriteBlock..."); trace!("BlocksDBsWriteQuery::WriteBlock...");
crate::current_meta_datas::update_current_meta_datas(db, w, &dal_block.block)?;
if sync_target.is_none() if sync_target.is_none()
|| dal_block.blockstamp().id.0 + fork_window_size as u32 || dal_block.blockstamp().id.0 + fork_window_size as u32
>= sync_target.expect("safe unwrap").id.0 >= sync_target.expect("safe unwrap").id.0
......
...@@ -123,6 +123,9 @@ mod tests { ...@@ -123,6 +123,9 @@ mod tests {
// Insert mock blocks in forks_dbs // Insert mock blocks in forks_dbs
db.write(|mut w| { db.write(|mut w| {
for block in &main_branch { for block in &main_branch {
durs_bc_db_writer::current_meta_datas::update_current_meta_datas(
&db, &mut w, &block,
)?;
durs_bc_db_writer::blocks::insert_new_head_block( durs_bc_db_writer::blocks::insert_new_head_block(
&db, &db,
&mut w, &mut w,
......
...@@ -19,6 +19,7 @@ use dubp_block_doc::BlockDocument; ...@@ -19,6 +19,7 @@ use dubp_block_doc::BlockDocument;
use durs_bc_db_reader::blocks::fork_tree::ForkTree; use durs_bc_db_reader::blocks::fork_tree::ForkTree;
use durs_bc_db_reader::blocks::DbBlock; use durs_bc_db_reader::blocks::DbBlock;
use durs_bc_db_writer::blocks::{insert_new_fork_block, insert_new_head_block}; use durs_bc_db_writer::blocks::{insert_new_fork_block, insert_new_head_block};
use durs_bc_db_writer::current_meta_datas::update_current_meta_datas;
use durs_bc_db_writer::{Db, DbError}; use durs_bc_db_writer::{Db, DbError};
/// Warning : This function does not update the indexes and considers /// Warning : This function does not update the indexes and considers
...@@ -31,6 +32,7 @@ pub fn insert_main_block( ...@@ -31,6 +32,7 @@ pub fn insert_main_block(
fork_tree: Option<&mut ForkTree>, fork_tree: Option<&mut ForkTree>,
) -> Result<(), DbError> { ) -> Result<(), DbError> {
db_tmp.write(|mut w| { db_tmp.write(|mut w| {
update_current_meta_datas(db_tmp, &mut w, &block)?;
insert_new_head_block( insert_new_head_block(
&db_tmp, &db_tmp,
&mut w, &mut w,
......
0% Loading or .
You are about to add 0 people to the discussion. Proceed with caution.
Please register or to comment