Skip to content

Commit

Permalink
refactor: handle optionality outside of parsers
Browse files Browse the repository at this point in the history
kespinola committed Feb 29, 2024
1 parent 6c883b6 commit cbf6ca5
Showing 3 changed files with 19 additions and 24 deletions.
2 changes: 1 addition & 1 deletion Cargo.lock

Some generated files are not rendered by default. Learn more about how customized files appear on GitHub.

2 changes: 1 addition & 1 deletion plerkle_serialization/Cargo.toml
Original file line number Diff line number Diff line change
@@ -1,7 +1,7 @@
[package]
name = "plerkle_serialization"
description = "Metaplex Flatbuffers Plerkle Serialization for Geyser plugin producer/consumer patterns."
version = "1.7.0"
version = "1.8.0"
authors = ["Metaplex Developers <dev@metaplex.com>"]
repository = "https://github.com/metaplex-foundation/digital-asset-validator-plugin"
license = "AGPL-3.0"
39 changes: 17 additions & 22 deletions plerkle_serialization/src/deserializer/solana.rs
Original file line number Diff line number Diff line change
@@ -19,31 +19,24 @@ pub enum SolanaDeserializerError {

pub type SolanaDeserializeResult<T> = Result<T, SolanaDeserializerError>;

pub fn parse_pubkey(pubkey: Option<&FBPubkey>) -> SolanaDeserializeResult<Pubkey> {
Pubkey::try_from(
pubkey
.ok_or(SolanaDeserializerError::NotFound)?
.0
.as_slice(),
)
.map_err(|_error| SolanaDeserializerError::InvalidFlatBufferKey)
pub fn parse_pubkey(pubkey: &FBPubkey) -> SolanaDeserializeResult<Pubkey> {
Pubkey::try_from(pubkey.0.as_slice())
.map_err(|_error| SolanaDeserializerError::InvalidFlatBufferKey)
}

pub fn parse_slice(data: Option<Vector<'_, u8>>) -> SolanaDeserializeResult<&[u8]> {
data.map(|data| data.bytes())
.ok_or(SolanaDeserializerError::NotFound)
pub fn parse_slice(data: Vector<'_, u8>) -> SolanaDeserializeResult<&[u8]> {
Ok(data.bytes())
}

pub fn parse_signature(data: Option<&str>) -> SolanaDeserializeResult<Signature> {
data.ok_or(SolanaDeserializerError::NotFound)?
.parse()
pub fn parse_signature(data: &str) -> SolanaDeserializeResult<Signature> {
data.parse()
.map_err(|_error| SolanaDeserializerError::DeserializationError)
}

pub fn parse_account_keys(
keys: Option<Vector<'_, FBPubkey>>,
public_keys: Vector<'_, FBPubkey>,
) -> SolanaDeserializeResult<Vec<Pubkey>> {
keys.ok_or(SolanaDeserializerError::NotFound)?
public_keys
.iter()
.map(|key| {
Pubkey::try_from(key.0.as_slice())
@@ -53,10 +46,11 @@ pub fn parse_account_keys(
}

pub fn parse_compiled_instructions(
vec_cix: Option<Vector<'_, ForwardsUOffset<FBCompiledInstruction>>>,
vec_cix: Vector<'_, ForwardsUOffset<FBCompiledInstruction>>,
) -> SolanaDeserializeResult<Vec<CompiledInstruction>> {
let mut message_instructions = vec![];
for cix in vec_cix.ok_or(SolanaDeserializerError::NotFound)? {

for cix in vec_cix {
message_instructions.push(CompiledInstruction {
program_id_index: cix.program_id_index(),
accounts: cix
@@ -76,10 +70,11 @@ pub fn parse_compiled_instructions(
}

pub fn parse_compiled_inner_instructions(
vec_ixs: Option<Vector<'_, ForwardsUOffset<FBCompiledInnerInstructions>>>,
vec_ixs: Vector<'_, ForwardsUOffset<FBCompiledInnerInstructions>>,
) -> SolanaDeserializeResult<Vec<InnerInstructions>> {
let mut meta_inner_instructions = vec![];
for ixs in vec_ixs.ok_or(SolanaDeserializerError::NotFound)? {

for ixs in vec_ixs {
let mut instructions = vec![];
for ix in ixs
.instructions()
@@ -110,14 +105,14 @@ pub fn parse_compiled_inner_instructions(
instructions,
})
}

Ok(meta_inner_instructions)
}

pub fn parse_inner_instructions(
vec_ixs: Option<Vector<'_, ForwardsUOffset<FBInnerInstructions>>>,
vec_ixs: Vector<'_, ForwardsUOffset<FBInnerInstructions>>,
) -> SolanaDeserializeResult<Vec<InnerInstructions>> {
vec_ixs
.ok_or(SolanaDeserializerError::NotFound)?
.iter()
.map(|iixs| {
let instructions = iixs

0 comments on commit cbf6ca5

Please sign in to comment.