Skip to content

Commit

Permalink
modules/consensus_accounts: handle incoming message tokens
Browse files Browse the repository at this point in the history
  • Loading branch information
pro-wh committed Mar 15, 2022
1 parent 5c9abe3 commit b5b3ba5
Show file tree
Hide file tree
Showing 3 changed files with 68 additions and 2 deletions.
20 changes: 20 additions & 0 deletions runtime-sdk/src/modules/accounts/mod.rs
Original file line number Diff line number Diff line change
Expand Up @@ -212,6 +212,11 @@ pub trait API {
amount: &token::BaseUnits,
) -> Result<(), modules::core::Error>;

fn mint_into_fee_accumulator<C: Context>(
ctx: &mut C,
amount: &token::BaseUnits,
) -> Result<(), modules::core::Error>;

/// Move amount from fee accumulator into address.
fn move_from_fee_accumulator<C: Context>(
ctx: &mut C,
Expand Down Expand Up @@ -587,6 +592,21 @@ impl API for Module {
Ok(())
}

fn mint_into_fee_accumulator<C: Context>(
ctx: &mut C,
amount: &token::BaseUnits,
) -> Result<(), modules::core::Error> {
if ctx.is_simulation() {
return Ok(());
}

ctx.value::<FeeAccumulator>(CONTEXT_KEY_FEE_ACCUMULATOR)
.or_default()
.add(amount);

Ok(())
}

fn move_from_fee_accumulator<C: Context>(
ctx: &mut C,
to: Address,
Expand Down
44 changes: 42 additions & 2 deletions runtime-sdk/src/modules/consensus_accounts/mod.rs
Original file line number Diff line number Diff line change
Expand Up @@ -4,10 +4,16 @@
//! while keeping track of amount deposited per account.
use std::{collections::BTreeSet, convert::TryInto};

use num_traits::Zero;
use once_cell::sync::Lazy;
use thiserror::Error;

use oasis_core_runtime::consensus::staking::Account as ConsensusAccount;
use oasis_core_runtime::{
consensus::{
staking::Account as ConsensusAccount,
roothash,
},
};
use oasis_runtime_sdk_macros::{handler, sdk_derive};

use crate::{
Expand All @@ -20,9 +26,10 @@ use crate::{
storage::Prefix,
types::{
address::Address,
in_msg::IncomingMessageData,
message::{MessageEvent, MessageEventHookInvocation},
token,
transaction::AuthInfo,
transaction::{AuthInfo, Transaction},
},
};

Expand Down Expand Up @@ -416,6 +423,39 @@ impl<Accounts: modules::accounts::API, Consensus: modules::consensus::API>
{
}

impl<Accounts: modules::accounts::API, Consensus: modules::consensus::API>
module::IncomingMessageHandler for Module<Accounts, Consensus>
{
fn prefetch_in_msg(
_prefixes: &mut BTreeSet<Prefix>,
_in_msg: &roothash::IncomingMessage,
_data: &IncomingMessageData,
_tx: &Option<Transaction>,
) -> Result<(), error::RuntimeError> {
// todo: their account
Ok(())
}

fn execute_in_msg<C: Context>(
ctx: &mut C,
in_msg: &roothash::IncomingMessage,
_data: &IncomingMessageData,
_tx: &Option<Transaction>,
) -> Result<(), error::RuntimeError> {
if !in_msg.fee.is_zero() {
let amount = token::BaseUnits(Consensus::amount_from_consensus(ctx, (&in_msg.fee).try_into().unwrap()).unwrap(), Consensus::consensus_denomination(ctx).unwrap());
Accounts::mint_into_fee_accumulator(ctx, &amount).unwrap();
// TODO: Emit event that fee has been paid.
}
if !in_msg.tokens.is_zero() {
let amount = token::BaseUnits(Consensus::amount_from_consensus(ctx, (&in_msg.tokens).try_into().unwrap()).unwrap(), Consensus::consensus_denomination(ctx).unwrap());
Accounts::mint(ctx, (&in_msg.caller).into(), &amount).unwrap();
// TODO: Emit event.
}
Ok(())
}
}

impl<Accounts: modules::accounts::API, Consensus: modules::consensus::API> module::BlockHandler
for Module<Accounts, Consensus>
{
Expand Down
6 changes: 6 additions & 0 deletions runtime-sdk/src/types/address.rs
Original file line number Diff line number Diff line change
Expand Up @@ -250,6 +250,12 @@ impl From<Address> for ConsensusAddress {
}
}

impl From<&ConsensusAddress> for Address {
fn from(addr: &ConsensusAddress) -> Address {
Address::from_bytes(addr.as_ref()).unwrap()
}
}

#[cfg(test)]
mod test {
use super::*;
Expand Down

0 comments on commit b5b3ba5

Please sign in to comment.