Skip to content

Commit

Permalink
add documentation
Browse files Browse the repository at this point in the history
  • Loading branch information
rtso committed Oct 9, 2024
1 parent 4cc90a3 commit 92bbf80
Show file tree
Hide file tree
Showing 3 changed files with 10 additions and 7 deletions.
Original file line number Diff line number Diff line change
Expand Up @@ -394,6 +394,7 @@ impl FungibleAssetBalance {
last_transaction_timestamp: txn_timestamp,
token_standard: TokenStandard::V1.to_string(),
};
// What is this for?
let event_to_coin_mapping: EventToCoinType = AHashMap::from([
(
inner.withdraw_events.guid.id.get_standardized(),
Expand Down
15 changes: 8 additions & 7 deletions rust/processor/src/processors/fungible_asset_processor.rs
Original file line number Diff line number Diff line change
Expand Up @@ -476,7 +476,7 @@ pub async fn parse_v2_coin(
let mut current_fungible_asset_balances: CurrentFungibleAssetMapping = AHashMap::new();
let mut fungible_asset_metadata: FungibleAssetMetadataMapping = AHashMap::new();

// Get Metadata for fungible assets by object
// Get Metadata for fungible assets by object address
let mut fungible_asset_object_helper: ObjectAggregatedDataMapping = AHashMap::new();

let txn_version = txn.version as i64;
Expand Down Expand Up @@ -523,8 +523,8 @@ pub async fn parse_v2_coin(
// the event to the resource using the event guid
let mut event_to_v1_coin_type: EventToCoinType = AHashMap::new();

// First loop to get all objects
// Need to do a first pass to get all the objects
// Loop 1: to get all object addresses
// Need to do a first pass to get all the object addresses and insert them into the helper
for wsc in transaction_info.changes.iter() {
if let Change::WriteResource(wr) = wsc.change.as_ref().unwrap() {
if let Some(object) =
Expand All @@ -540,7 +540,7 @@ pub async fn parse_v2_coin(
}
}
}
// Loop to get the metadata relevant to parse v1 and v2.
// Loop 2: Get the metadata relevant to parse v1 coin and v2 fungible asset.
// As an optimization, we also handle v1 balances in the process
for (index, wsc) in transaction_info.changes.iter().enumerate() {
if let Change::WriteResource(write_resource) = wsc.change.as_ref().unwrap() {
Expand All @@ -558,7 +558,8 @@ pub async fn parse_v2_coin(
.insert(current_balance.storage_id.clone(), current_balance.clone());
event_to_v1_coin_type.extend(event_to_coin);
}
// Fill the v2 object metadata
// Fill the v2 fungible_asset_object_helper. This is used to track which objects exist at each object address.
// The data will be used to reconstruct the full data in Loop 4.
let address = standardize_address(&write_resource.address.to_string());
if let Some(aggregated_data) = fungible_asset_object_helper.get_mut(&address) {
if let Some(fungible_asset_metadata) =
Expand Down Expand Up @@ -643,7 +644,7 @@ pub async fn parse_v2_coin(
fungible_asset_activities.push(gas_event);
}

// Loop to handle events and collect additional metadata from events for v2
// Loop 3 to handle events and collect additional metadata from events for v2
for (index, event) in events.iter().enumerate() {
if let Some(v1_activity) = FungibleAssetActivity::get_v1_from_event(
event,
Expand Down Expand Up @@ -685,7 +686,7 @@ pub async fn parse_v2_coin(
}
}

// Loop to handle all the other changes
// Loop 4 to handle write set changes for metadata, balance, and v1 supply
for (index, wsc) in transaction_info.changes.iter().enumerate() {
match wsc.change.as_ref().unwrap() {
Change::WriteResource(write_resource) => {
Expand Down
Original file line number Diff line number Diff line change
Expand Up @@ -20,6 +20,7 @@ use processor::{
processors::fungible_asset_processor::parse_v2_coin,
};

/// Extracts fungible asset events, metadata, balances, and v1 supply from transactions
pub struct FungibleAssetExtractor
where
Self: Sized + Send + 'static, {}
Expand Down

0 comments on commit 92bbf80

Please sign in to comment.