mirror of
https://github.com/hinto-janai/cuprate.git
synced 2025-01-18 16:54:32 +00:00
finished read block
This commit is contained in:
parent
95b3d0417f
commit
f56d7231af
2 changed files with 50 additions and 9 deletions
|
@ -60,7 +60,7 @@ pub enum Value<T: Table> {
|
||||||
/// variant of Value you should receive. But be careful on your code, or it might crash.
|
/// variant of Value you should receive. But be careful on your code, or it might crash.
|
||||||
impl<'a, T: Table> Value<T> {
|
impl<'a, T: Table> Value<T> {
|
||||||
|
|
||||||
pub fn as_type(&'a self) -> &'a <T as Table>::Value {
|
pub fn as_type(self) -> <T as Table>::Value {
|
||||||
assert!(matches!(self, Value::Type(_))); // Hint for the compiler to check the boundaries
|
assert!(matches!(self, Value::Type(_))); // Hint for the compiler to check the boundaries
|
||||||
if let Value::Type(value) = self {
|
if let Value::Type(value) = self {
|
||||||
value
|
value
|
||||||
|
|
|
@ -3,7 +3,7 @@
|
||||||
use monero::{Hash, BlockHeader, Block};
|
use monero::{Hash, BlockHeader, Block};
|
||||||
use monero::blockdata::transaction::KeyImage;
|
use monero::blockdata::transaction::KeyImage;
|
||||||
|
|
||||||
use crate::database::transaction::DupCursor;
|
use crate::database::transaction::{DupCursor, Cursor};
|
||||||
use crate::{encoding::Value, database::{Interface, Database, transaction::Transaction}, error::DBException, interface::{ReadInterface, WriteInterface}, table, types::{AltBlock, TransactionPruned}};
|
use crate::{encoding::Value, database::{Interface, Database, transaction::Transaction}, error::DBException, interface::{ReadInterface, WriteInterface}, table, types::{AltBlock, TransactionPruned}};
|
||||||
|
|
||||||
impl<'thread, D: Database<'thread>> ReadInterface<'thread> for Interface<'thread, D> {
|
impl<'thread, D: Database<'thread>> ReadInterface<'thread> for Interface<'thread, D> {
|
||||||
|
@ -43,7 +43,7 @@ impl<'thread, D: Database<'thread>> ReadInterface<'thread> for Interface<'thread
|
||||||
cursor_blockhash
|
cursor_blockhash
|
||||||
.get_dup::<false>(&(), hash)?
|
.get_dup::<false>(&(), hash)?
|
||||||
.ok_or(DBException::NotFound(format!("Failed to find height of block: {}", hash)))
|
.ok_or(DBException::NotFound(format!("Failed to find height of block: {}", hash)))
|
||||||
.map(|res| *res.as_type())
|
.map(|res| res.as_type())
|
||||||
}
|
}
|
||||||
|
|
||||||
fn get_block_weight(&'thread self, height: &u64) -> Result<u64, DBException> {
|
fn get_block_weight(&'thread self, height: &u64) -> Result<u64, DBException> {
|
||||||
|
@ -132,32 +132,73 @@ impl<'thread, D: Database<'thread>> ReadInterface<'thread> for Interface<'thread
|
||||||
|
|
||||||
fn get_block<const B: bool>(&'thread self, hash: &Hash) -> Result<Block, DBException> {
|
fn get_block<const B: bool>(&'thread self, hash: &Hash) -> Result<Block, DBException> {
|
||||||
let ro_tx = self.db.tx().map_err(Into::into)?;
|
let ro_tx = self.db.tx().map_err(Into::into)?;
|
||||||
todo!()
|
let mut cursor_blockhash = ro_tx.cursor_dup::<table::blockhash>()?;
|
||||||
|
|
||||||
|
let blk_height = cursor_blockhash
|
||||||
|
.get_dup::<false>(&(), hash)?
|
||||||
|
.ok_or(DBException::NotFound(format!("Can't height of block: {}", hash)))
|
||||||
|
.map(|res| res.as_type())?;
|
||||||
|
|
||||||
|
ro_tx
|
||||||
|
.get::<false, table::blocks>(&blk_height)?
|
||||||
|
.ok_or(DBException::NotFound(format!("Can't find block at height: {}", blk_height)))
|
||||||
|
.map(|res| res.as_type().0)
|
||||||
}
|
}
|
||||||
|
|
||||||
fn get_block_from_height<const B: bool>(&'thread self, height: &u64) -> Result<Block, DBException> {
|
fn get_block_from_height<const B: bool>(&'thread self, height: &u64) -> Result<Block, DBException> {
|
||||||
let ro_tx = self.db.tx().map_err(Into::into)?;
|
let ro_tx = self.db.tx().map_err(Into::into)?;
|
||||||
todo!()
|
|
||||||
|
ro_tx
|
||||||
|
.get::<false, table::blocks>(height)?
|
||||||
|
.ok_or(DBException::NotFound(format!("Can't find block at height: {}", height)))
|
||||||
|
.map(|res| res.as_type().0)
|
||||||
}
|
}
|
||||||
|
|
||||||
fn get_block_header(&'thread self, hash: &Hash) -> Result<BlockHeader, DBException> {
|
fn get_block_header(&'thread self, hash: &Hash) -> Result<BlockHeader, DBException> {
|
||||||
let ro_tx = self.db.tx().map_err(Into::into)?;
|
let ro_tx = self.db.tx().map_err(Into::into)?;
|
||||||
todo!()
|
let mut cursor_blockhash = ro_tx.cursor_dup::<table::blockhash>()?;
|
||||||
|
|
||||||
|
let blk_height = cursor_blockhash
|
||||||
|
.get_dup::<false>(&(), hash)?
|
||||||
|
.ok_or(DBException::NotFound(format!("Can't height of block: {}", hash)))
|
||||||
|
.map(|res| res.as_type())?;
|
||||||
|
|
||||||
|
ro_tx
|
||||||
|
.get::<false, table::blocks>(&blk_height)?
|
||||||
|
.ok_or(DBException::NotFound(format!("Can't find block at height: {}", &blk_height)))
|
||||||
|
.map(|res| res.as_type().0.header)
|
||||||
}
|
}
|
||||||
|
|
||||||
fn get_block_header_from_height(&'thread self, height: &u64) -> Result<BlockHeader, DBException> {
|
fn get_block_header_from_height(&'thread self, height: &u64) -> Result<BlockHeader, DBException> {
|
||||||
let ro_tx = self.db.tx().map_err(Into::into)?;
|
let ro_tx = self.db.tx().map_err(Into::into)?;
|
||||||
todo!()
|
|
||||||
|
ro_tx
|
||||||
|
.get::<false, table::blocks>(height)?
|
||||||
|
.ok_or(DBException::NotFound(format!("Can't find block at height: {}", height)))
|
||||||
|
.map(|res| res.as_type().0.header)
|
||||||
}
|
}
|
||||||
|
|
||||||
fn get_top_block(&'thread self) -> Result<Block, DBException> {
|
fn get_top_block(&'thread self) -> Result<Block, DBException> {
|
||||||
let ro_tx = self.db.tx().map_err(Into::into)?;
|
let ro_tx = self.db.tx().map_err(Into::into)?;
|
||||||
todo!()
|
|
||||||
|
let height = self.height()?;
|
||||||
|
|
||||||
|
ro_tx
|
||||||
|
.get::<false, table::blocks>(&height)?
|
||||||
|
.ok_or(DBException::NotFound(format!("Can't find block at height: {}", height)))
|
||||||
|
.map(|res| res.as_type().0)
|
||||||
}
|
}
|
||||||
|
|
||||||
fn get_top_block_hash(&'thread self) -> Result<Hash, DBException> {
|
fn get_top_block_hash(&'thread self) -> Result<Hash, DBException> {
|
||||||
let ro_tx = self.db.tx().map_err(Into::into)?;
|
let ro_tx = self.db.tx().map_err(Into::into)?;
|
||||||
todo!()
|
let mut cursor_blockmetadata = ro_tx.cursor_dup::<table::blockmetadata>()?;
|
||||||
|
|
||||||
|
let height = self.height()?;
|
||||||
|
let metadata = cursor_blockmetadata
|
||||||
|
.get_dup::<false>(&(), &height)?
|
||||||
|
.ok_or(DBException::NotFound(format!("Failed to find block's metadata at height : {}", height)))?;
|
||||||
|
|
||||||
|
Ok(metadata.as_type().block_hash)
|
||||||
}
|
}
|
||||||
|
|
||||||
// ------------------------------| Transactions |-----------------------------
|
// ------------------------------| Transactions |-----------------------------
|
||||||
|
|
Loading…
Reference in a new issue