Skip to content
New issue

Have a question about this project? Sign up for a free GitHub account to open an issue and contact its maintainers and the community.

By clicking “Sign up for GitHub”, you agree to our terms of service and privacy statement. We’ll occasionally send you account related emails.

Already on GitHub? Sign in to your account

Draft #1980

Closed
wants to merge 191 commits into from
Closed

Draft #1980

Changes from 1 commit
Commits
Show all changes
191 commits
Select commit Hold shift + click to select a range
4f89775
refactor `Epoched` for past epochs
brentstone Sep 26, 2023
d8a29ef
cleaning: remove unused code + improve docstrings
brentstone Sep 26, 2023
cd64eff
Test vector formatting changes.
murisi Sep 11, 2023
4d0d333
Added a changelog record.
murisi Sep 22, 2023
1783a94
transfer and query with trace-path
yito88 Sep 27, 2023
4f45b81
Inner tx signer also signs tx header
grarco Aug 28, 2023
ee31f47
Adds `raw_header_hash` method for `Tx`
grarco Aug 28, 2023
8c7bdf0
query balances for IbcToken
yito88 Sep 27, 2023
1b79599
add changelog
yito88 Sep 28, 2023
0613ac2
benches: move bench lib code to apps crate and feature guard it
tzemanovic Sep 28, 2023
4dc0304
benches: update docs
tzemanovic Sep 28, 2023
5aaa83e
benches: rm unused deps
tzemanovic Sep 28, 2023
bc2e285
changelog: add #1955
tzemanovic Sep 28, 2023
f015005
Moves signatures verification gas in `Signature`
grarco Sep 28, 2023
6fba21a
changelog: add #1954
grarco Sep 28, 2023
8416f0b
test/eth: init storage with PoS params where needed
tzemanovic Sep 28, 2023
f5d4544
test/PoS/epoched: init PoS params and fix `PastEpochs` type param
tzemanovic Sep 28, 2023
d3f1eb3
changelog: add #1943
brentstone Sep 28, 2023
812b2c2
[ci] wasm checksums update
github-actions[bot] Sep 28, 2023
bfd91f9
WIP want to pass `max_proposal_period` from gov params into PoS
brentstone Sep 26, 2023
053fffb
add PosParams type with added gov param
tzemanovic Sep 27, 2023
bfe4c97
pos/types: configure number of past epochs kept for PoS data
brentstone Sep 28, 2023
eaed189
new impl for purging old validator sets
brentstone Sep 28, 2023
85bf4aa
docstring cleanup
brentstone Sep 28, 2023
6364cc0
Apply suggestions from code review
tzemanovic Sep 28, 2023
1ddd82b
fixup! Apply suggestions from code review
tzemanovic Sep 28, 2023
f1bc264
fix PoS crate standalone build
tzemanovic Sep 28, 2023
f40bd26
replace direct storage read of PosParams with an RPC fn
tzemanovic Sep 28, 2023
41d3838
fixup! replace direct storage read of PosParams with an RPC fn
tzemanovic Sep 28, 2023
620e4e2
core/types/storage:m ore flexible fn checked_sub param
tzemanovic Sep 28, 2023
856130e
PoS: refactor usages of `Epoch::checked_sub`
tzemanovic Sep 28, 2023
20180c4
changelog: add #1944
brentstone Sep 28, 2023
3fa8d38
[ci] wasm checksums update
github-actions[bot] Sep 28, 2023
c65a6d0
fixed `epoched` tests and `test_validator_sets`
brentstone Sep 28, 2023
9971497
fixup! pos/types: configure number of past epochs kept for PoS data
tzemanovic Sep 29, 2023
fe6c3eb
Combined construction of signing data with transaction construction.
murisi Sep 19, 2023
16425d5
Created builders and constructors for each type of transaction.
murisi Sep 20, 2023
d10ba96
Allow the prototypical Tx builder to be modified in NamadaImpl instan…
murisi Sep 25, 2023
b874ffa
remove trace-path
yito88 Oct 2, 2023
4cf16cb
WIP: receive to a shielded address
yito88 Sep 19, 2023
f35b779
add gen_ibc_shielded_transfer
yito88 Sep 20, 2023
0e18507
WIP: add e2e test for receiving to payment address
yito88 Sep 20, 2023
94e6c2d
workaround for decoding asset types for IbcToken
yito88 Sep 22, 2023
c8f8426
fix after merge
yito88 Sep 29, 2023
27f4e0a
fix get_shielded_action
yito88 Sep 29, 2023
6806410
remove Address::Foreign
yito88 Sep 29, 2023
7c7ee02
keep validator eth keys for max proposal period
brentstone Oct 2, 2023
85770be
clear old enqueued slashes when processing slashes
brentstone Oct 2, 2023
59d8465
keep `total_deltas` for same period of time as `validator_deltas`
brentstone Oct 2, 2023
6656f1b
fix get_ibc_event
yito88 Oct 2, 2023
e471b6c
Moved FsShieldedUtils into the SDK behind a feature flag.
murisi Sep 27, 2023
1142e64
Adding saving and loading function to Wallet.
murisi Sep 28, 2023
f99eaa3
Made the ShieldedUtils trait similar to the WalletStorage trait.
murisi Oct 1, 2023
79f006a
Added function to construct DenominatedAmounts from Amounts.
murisi Oct 1, 2023
c775ec7
Removed unnecessary requirement for mutable references in Namada trait.
murisi Oct 1, 2023
9f06a4b
Enabled parallel usage of the Namada trait using read and write locks.
murisi Oct 1, 2023
64e817b
move protocol keys into epoched PoS data
brentstone Oct 3, 2023
b38e6f4
deps: switch to use libseck256k1 to k256
tzemanovic Sep 29, 2023
7e4e922
changelog: add #1958
tzemanovic Sep 29, 2023
609e70d
Implement ZeroizeOnDrop on ed25519 keys
sug0 Sep 28, 2023
5d7c951
Changelog for #1956
sug0 Oct 4, 2023
2a141f1
Update to upstream borsh v1.0.0-alpha.4
sug0 Sep 14, 2023
f542fa2
Add borsh-ext dependency
sug0 Sep 15, 2023
b5076f6
Update color-eyre
sug0 Sep 15, 2023
e93e97e
Update borsh on heliaxdev deps
sug0 Sep 25, 2023
7eb80b1
Fix compilation errors
sug0 Sep 15, 2023
134798e
Add Cargo lock files
sug0 Sep 15, 2023
bbe3a67
Fix unit test
sug0 Sep 25, 2023
f0a9720
Changelog for #1930
sug0 Sep 25, 2023
ac2535a
add changelog
yito88 Oct 6, 2023
b1bc845
Reintegrated generic IO support.
murisi Oct 4, 2023
68a3393
add checks and simplify code
brentstone Oct 6, 2023
2e84ddc
changelog: add #1973
brentstone Oct 6, 2023
615ebc8
SDK can now query for the native token address from the network. Also…
murisi Oct 9, 2023
9aa1d45
Fix transmitting protocol txs if validator node
sug0 Oct 3, 2023
25ffc67
Allow shutting off the Ethereum oracle in tests
sug0 Oct 3, 2023
9d5b454
Add test_broadcast_valset_upd_inspite_oracle_off() unit test
sug0 Oct 3, 2023
2368969
Changelog for #1964
sug0 Oct 3, 2023
af011f6
fix error handling
yito88 Oct 9, 2023
66a7567
check if rate > 1 in lib code
brentstone Oct 11, 2023
78ccf42
Writes the result of a governance proposal in storage
grarco Oct 11, 2023
464d93a
Client first looks for governance proposal result in storage
grarco Oct 11, 2023
79c85cb
Changelog #1979
grarco Oct 11, 2023
17c3e6c
Separated an SDK crate out of the shared crate.
murisi Oct 11, 2023
f892ab4
Changes to enable better usage of the SDK in the absence of wallet or…
murisi Oct 12, 2023
94b2d4b
Added a change log entry.
murisi Oct 12, 2023
3cd3970
Merge branch 'murisi/sdk-refactor-rebased' (#1963)
murisi Oct 12, 2023
0c006ec
Add new SDK errors
sug0 Sep 26, 2023
abb6710
core/lazy_map+set: avoid calling delete when given key is not present
tzemanovic Oct 13, 2023
027a920
Phase out Halt and its cousins from the SDK
sug0 Sep 26, 2023
cff47a2
Remove halt abstraction from the SDK
sug0 Sep 27, 2023
e986bcf
Apply suggestions from code review
sug0 Sep 29, 2023
1831e8e
Internal macros SDK module
sug0 Oct 9, 2023
f338ae3
Echo SDK errors to stdout
sug0 Oct 9, 2023
af1fa0e
Changelog for #1953
sug0 Sep 28, 2023
79af00e
Implemented compounding inflation for native tokens.
murisi Oct 13, 2023
88a3961
Factor out submit_bridge_pool_tx()
sug0 Sep 28, 2023
5aeabd8
Factor out validate_bridge_pool_tx()
sug0 Sep 28, 2023
601ada8
Add new SDK error types
sug0 Sep 28, 2023
a025cfc
Check ERC20 token caps
sug0 Sep 28, 2023
3b3e6e9
Make ERC20 flow control fields public
sug0 Sep 28, 2023
3525f01
Validate Bridge pool client transfers
sug0 Sep 28, 2023
bbab1c4
Changelog for #1957
sug0 Sep 29, 2023
7ae503f
Merge branch 'tiago/phase-out-try-halt' (#1953)
sug0 Oct 13, 2023
bf3f7aa
Merge branch 'tiago/bp-client-validation' (#1957)
sug0 Oct 13, 2023
fb72c6e
Merge branch 'tiago/fix-protocol-txs' (#1964)
sug0 Oct 13, 2023
21c5e58
Merge branch 'tomas/k256' (#1958)
sug0 Oct 13, 2023
03b1856
Merge branch 'tiago/zeroize-secret-keys' (#1956)
sug0 Oct 13, 2023
2e95338
Merge branch 'tiago/update-borsh' (#1930)
sug0 Oct 13, 2023
672e153
changelog: add #1984
tzemanovic Oct 13, 2023
0bad247
update ibc-rs for ibc-rs/#911
yito88 Oct 13, 2023
6bb2bb0
add changelog
yito88 Oct 13, 2023
68b5704
SQUASHED redelegation
brentstone Jun 23, 2023
2e407e4
Replay protection column family and related methods in `DB` trait and…
grarco Oct 4, 2023
58b424e
Writes replay protection keys under separate storage root
grarco Oct 5, 2023
935e55f
Removes hacky solution for replay protection merkle tree
grarco Oct 5, 2023
61724b4
Renames replay protection storage key getter
grarco Oct 5, 2023
7caac7f
Removes replay protecion internal address and vp
grarco Oct 5, 2023
60f0014
Updates `DB` and `DBIter` traits for replay protection
grarco Oct 6, 2023
77dfccb
Refactors replay protection helper functions
grarco Oct 6, 2023
2eddc70
New field in `WriteLog` for replay protection changes
grarco Oct 6, 2023
daeae3e
Improves replay protection `WriteLog` API
grarco Oct 9, 2023
2661d86
Fixes unit tests
grarco Oct 9, 2023
b2ec6a3
Renames `finalize_tx_hashes`
grarco Oct 9, 2023
4a7ec74
Removes wrapper hash when committed inner tx
grarco Oct 10, 2023
1e06990
Writes only one hash at a time for replay protection
grarco Oct 10, 2023
37a6602
Fixes check for replay protection keys
grarco Oct 13, 2023
914b6f5
Reworks replay protection check
grarco Oct 13, 2023
673c99a
Removes useless checks on decrypted tx, error codes and unit tests
grarco Aug 28, 2023
39c9b43
Adds raw header signature in tests
grarco Aug 29, 2023
3dbd59a
Client signs the raw transaction header
grarco Aug 29, 2023
64a42d6
Merge branch 'brent/pos-redelegation' (#1612)
brentstone Oct 14, 2023
bf5ca7a
Mock ledger services in integration tests
sug0 Oct 6, 2023
aed3c8f
Improve reading flow of mock node service defs
sug0 Oct 16, 2023
9c69e4b
Changelog for #1976
sug0 Oct 16, 2023
a77cb5c
Expose replay protection methods from `WlStorage`
grarco Oct 16, 2023
4fca277
Changelog #1977
grarco Oct 11, 2023
d19e365
evil make: skip pos_state_machine_test in CI
tzemanovic Oct 16, 2023
d4fc717
evil bench/vps: credit source before bond tx
tzemanovic Oct 16, 2023
ed55676
evil test/e2e/slashing: fix flakiness
tzemanovic Oct 16, 2023
5218ec6
Merge branch 'brent/refactor-past-epoch-offsets' (#1943)
brentstone Oct 16, 2023
07af16f
Merge branch 'brent/tune-storage-past-epochs' (#1944)
brentstone Oct 16, 2023
296fde2
Merge branch 'tomas/rm-redundant-writes' (#1984)
brentstone Oct 16, 2023
bcd7557
remove dbg prints
tzemanovic Oct 17, 2023
ca1ebc2
Merge branch 'brent/pos-redelegation' (#1612)
tzemanovic Oct 17, 2023
c38d822
make: skip pos_state_machine_test in CI
tzemanovic Oct 16, 2023
efeebfd
bench/vps: credit source before bond tx
tzemanovic Oct 16, 2023
2075e8e
test/e2e/slashing: fix flakiness
tzemanovic Oct 16, 2023
a9964d6
Integrated PD controller support.
murisi Oct 16, 2023
b301581
Merge branch 'yuji/ibc-balance-query' (#1951)
yito88 Oct 17, 2023
b0f988f
evil: fix queries for new sdk
yito88 Oct 17, 2023
4262206
Merge branch 'yuji/ibc-shielded-actions' (#1917)
yito88 Oct 17, 2023
a5a82dc
evil: move GenIbcShieldedTransafer
yito88 Oct 17, 2023
9eb62e9
Merge branch 'yuji/fix-ibc-client-validation' (#1989)
yito88 Oct 18, 2023
c8f3a7d
PoS: comment out unused code
tzemanovic Oct 18, 2023
c273d0b
Merge branch 'brent/pos-redelegation' (#1612)
tzemanovic Oct 18, 2023
8bd09aa
Merge branch 'brent/refine-commission-tx' (#1973)
tzemanovic Oct 18, 2023
e4b415a
evil: moved PoS error type to sub-module
tzemanovic Oct 18, 2023
b2ed599
evil: sdk IO changes and missing arg deref
tzemanovic Oct 18, 2023
65751c2
Merge branch 'tomas/avoid-testing-feature-in-workspace' (#1955)
tzemanovic Oct 18, 2023
ce20a15
Increased the precision of MASP rewards.
murisi Oct 17, 2023
7eaf2f3
Merge branch 'tiago/int-test-services' (#1976)
Fraccaman Oct 18, 2023
d4da00b
Fixes pgf inflation
grarco Oct 18, 2023
ab20766
make token amounts in `RewardsController` of `Uint` type
brentstone Oct 18, 2023
2e58240
process_slashes: fix critical bug
brentstone Oct 19, 2023
37798a8
Merge branch 'brent/pos-redelegation' (#1612)
brentstone Oct 19, 2023
05fbe1f
Changelog #1999
grarco Oct 19, 2023
b6b376d
fix bug in SMv1 test
brentstone Oct 19, 2023
fce7325
Merge branch 'brent/pos-redelegation' (#1612)
brentstone Oct 19, 2023
7877a13
Implemented a mul_div operation for Uints and reduced overflow risks …
murisi Oct 20, 2023
2e3e640
Added changelog entry.
murisi Oct 20, 2023
8c14123
Merge branch 'murisi/compounding-rewards' (#1985)
murisi Oct 20, 2023
b4b0525
Merge branch 'aleks+murisi/ledger-test-vector-generator-fix-0.22.0' (…
murisi Oct 20, 2023
ed12b23
Merge branch 'grarco/proposal-result-in-storage' (#1979)
grarco Oct 20, 2023
cf1db81
evil: client from context in rpc
grarco Oct 20, 2023
329591a
Merge branch 'grarco/gas-in-sig-ver' (#1954)
grarco Oct 20, 2023
4dfa8bc
Merge branch 'grarco/replay-protection-storage' (#1977)
grarco Oct 20, 2023
454b3f6
evil: fixes missing test import and `dry_run` parameter
grarco Oct 20, 2023
738fb61
Merge branch 'grarco/fix-pgf-stewards-funding' (#1999)
grarco Oct 20, 2023
44633e2
Removes redundant signature on `Code` and `Data`
grarco Aug 30, 2023
ca14bfc
Fixes raw header hash in compressed signature
grarco Oct 23, 2023
c40cbc1
Changelog #1867
grarco Oct 12, 2023
f4b94dc
Merge branch 'grarco/fix-replay-protection' (#1867)
grarco Oct 23, 2023
7e01122
evil: updates calls to `raw_header_hash`
grarco Oct 23, 2023
b0e45ab
evil: updates lock files
grarco Oct 23, 2023
adbc185
Now re-export crates that may be needed to use the SDK.
murisi Oct 23, 2023
abc49d6
Added changelog entry.
murisi Oct 23, 2023
7f3fc5e
Reintroduced a dummy field in order to achieve compatability with har…
murisi Sep 27, 2023
696c8be
Added changelog entry.
murisi Sep 27, 2023
a27b984
Merge branch 'murisi/pow-solution-fix' (#1949)
murisi Oct 23, 2023
15f35b2
Merge branch 'murisi/sdk-re-exports' (#2033)
murisi Oct 23, 2023
File filter

Filter by extension

Filter by extension

Conversations
Failed to load comments.
Loading
Jump to
Jump to file
Failed to load files.
Loading
Diff view
Diff view
Prev Previous commit
Next Next commit
WIP: add e2e test for receiving to payment address
yito88 committed Oct 2, 2023

Verified

This commit was signed with the committer’s verified signature.
yito88 Yuji Ito
commit 0e1850739aaf2fc8562d02863b59f82dee13fcbc
17 changes: 8 additions & 9 deletions apps/src/lib/cli.rs
Original file line number Diff line number Diff line change
@@ -2687,7 +2687,7 @@ pub mod args {
pub const HD_WALLET_DERIVATION_PATH_OPT: ArgOpt<String> =
HD_WALLET_DERIVATION_PATH.opt();
pub const HISTORIC: ArgFlag = flag("historic");
pub const IBC_TRANSFER_MEMO: ArgOpt<String> = arg_opt("memo");
pub const IBC_TRANSFER_MEMO_PATH: ArgOpt<PathBuf> = arg_opt("memo-path");
pub const LEDGER_ADDRESS_ABOUT: &str =
"Address of a ledger node as \"{scheme}://{host}:{port}\". If the \
scheme is not supplied, it is assumed to be TCP.";
@@ -3603,7 +3603,10 @@ pub mod args {
let channel_id = CHANNEL_ID.parse(matches);
let timeout_height = TIMEOUT_HEIGHT.parse(matches);
let timeout_sec_offset = TIMEOUT_SEC_OFFSET.parse(matches);
let memo = IBC_TRANSFER_MEMO.parse(matches);
let memo = IBC_TRANSFER_MEMO_PATH.parse(matches).map(|path| {
std::fs::read_to_string(path)
.expect("Expected a file at given path")
});
let tx_code_path = PathBuf::from(TX_IBC_WASM);
Self {
tx,
@@ -3640,9 +3643,9 @@ pub mod args {
)
.arg(TIMEOUT_SEC_OFFSET.def().help("The timeout as seconds."))
.arg(
IBC_TRANSFER_MEMO
IBC_TRANSFER_MEMO_PATH
.def()
.help("Memo field of ICS20 transfer."),
.help("The path for the memo field of ICS20 transfer."),
)
}
}
@@ -4773,7 +4776,6 @@ pub mod args {
sender: self.sender,
target: ctx.get(&self.target),
token: ctx.get(&self.token),
trace_path: self.trace_path,
amount: self.amount,
port_id: self.port_id,
channel_id: self.channel_id,
@@ -4788,7 +4790,6 @@ pub mod args {
let sender = SENDER.parse(matches);
let target = TRANSFER_TARGET.parse(matches);
let token = TOKEN.parse(matches);
let trace_path = TRACE_PATH.parse(matches);
let amount = InputAmount::Unvalidated(AMOUNT.parse(matches));
let port_id = PORT_ID.parse(matches);
let channel_id = CHANNEL_ID.parse(matches);
@@ -4798,22 +4799,20 @@ pub mod args {
sender,
target,
token,
trace_path,
amount,
port_id,
channel_id,
}
}

fn def(app: App) -> App {
app.add_args::<Tx<CliTypes>>()
app.add_args::<Query<CliTypes>>()
.arg(OUTPUT_FOLDER_PATH.def().help(
"The output folder path where the artifact will be stored.",
))
.arg(SENDER.def().help("The foreign sender address."))
.arg(TRANSFER_TARGET.def().help("The target address."))
.arg(TOKEN.def().help("The transfer token."))
.arg(TRACE_PATH.def().help("The IBC trace path of the token."))
.arg(AMOUNT.def().help("The amount to transfer in decimal."))
.arg(
PORT_ID
10 changes: 7 additions & 3 deletions apps/src/lib/client/tx.rs
Original file line number Diff line number Diff line change
@@ -1625,15 +1625,19 @@ where
.await?
{
let tx_id = shielded_transfer.masp_tx.txid().to_string();
let filename = format!("ibc_shielded_transfer_{}.memo", tx_id,);
let filename = format!("ibc_shielded_transfer_{}.memo", tx_id);
let output_path = match &args.output_folder {
Some(path) => path.join(filename),
None => filename.into(),
};
let out = File::create(&output_path)
let mut out = File::create(&output_path)
.expect("Should be able to create the out file.");
serde_json::to_writer_pretty(out, &Memo::from(shielded_transfer))
out.write_all(Memo::from(shielded_transfer).as_ref().as_bytes())
.expect("IBC memo should be deserializable.");
println!(
"Output IBC shielded transfer for {tx_id} to {}",
output_path.to_string_lossy()
);
} else {
eprintln!("No shielded transfer for this IBC transfer.")
}
1 change: 0 additions & 1 deletion benches/lib.rs
Original file line number Diff line number Diff line change
@@ -71,7 +71,6 @@ use namada::ledger::queries::{
use namada::ledger::storage_api::StorageRead;
use namada::proof_of_stake;
use namada::proto::{Code, Data, Section, Signature, Tx};
use namada::sdk::args::InputAmount;
use namada::sdk::masp::{
self, ShieldedContext, ShieldedTransfer, ShieldedUtils,
};
65 changes: 31 additions & 34 deletions core/src/ledger/ibc/mod.rs
Original file line number Diff line number Diff line change
@@ -20,7 +20,7 @@ use crate::ibc::applications::transfer::error::TokenTransferError;
use crate::ibc::applications::transfer::msgs::transfer::MsgTransfer;
use crate::ibc::applications::transfer::{
is_receiver_chain_source, send_transfer_execute, send_transfer_validate,
BaseDenom, PrefixedDenom, TracePath, TracePrefix,
PrefixedDenom, TracePrefix,
};
use crate::ibc::core::ics04_channel::msgs::PacketMsg;
use crate::ibc::core::ics23_commitment::specs::ProofSpecs;
@@ -30,12 +30,13 @@ use crate::ibc::core::ics24_host::identifier::{
use crate::ibc::core::router::{Module, ModuleId, Router};
use crate::ibc::core::{execute, validate, MsgEnvelope, RouterError};
use crate::ibc_proto::google::protobuf::Any;
use crate::types::address::Address;
use crate::types::address::{masp, Address};
use crate::types::chain::ChainId;
use crate::types::ibc::{
get_shielded_transfer, is_ibc_denom, EVENT_TYPE_DENOM_TRACE,
EVENT_TYPE_PACKET,
};
use crate::types::masp::PaymentAddress;

#[allow(missing_docs)]
#[derive(Error, Debug)]
@@ -211,14 +212,20 @@ where
.as_ref()
.and_then(|event| event.attributes.get("receiver"))
{
Some(receiver) => {
Some(Address::decode(receiver).map_err(|_| {
Error::Denom(format!(
"Decoding the receiver address failed: {:?}",
receive_event
))
})?)
}
Some(receiver) => Some(
Address::decode(receiver)
.or_else(|_| {
// Replace it with MASP address when the receiver is a
// payment address
PaymentAddress::from_str(receiver).map(|_| masp())
})
.map_err(|_| {
Error::Denom(format!(
"Decoding the receiver address failed: {:?}",
receive_event
))
})?,
),
None => None,
};
let denom_event = self
@@ -306,35 +313,25 @@ pub struct ValidationParams {

/// Get the IbcToken from the source/destination ports and channels
pub fn received_ibc_token(
token: &Address,
trace_path: Option<TracePath>,
ibc_denom: &PrefixedDenom,
src_port_id: &PortId,
src_channel_id: &ChannelId,
dest_port_id: &PortId,
dest_channel_id: &ChannelId,
) -> Result<Address, Error> {
if let Some(trace_path) = trace_path {
let mut ibc_denom = PrefixedDenom {
trace_path,
base_denom: BaseDenom::from_str(&token.to_string()).map_err(
|e| Error::Denom(format!("Trace path is invalid: error {e}")),
)?,
};
if is_receiver_chain_source(
src_port_id.clone(),
src_channel_id.clone(),
&ibc_denom,
) {
let prefix =
TracePrefix::new(src_port_id.clone(), src_channel_id.clone());
ibc_denom.remove_trace_prefix(&prefix);
} else {
let prefix =
TracePrefix::new(dest_port_id.clone(), dest_channel_id.clone());
ibc_denom.add_trace_prefix(prefix);
}
Ok(storage::ibc_token(&ibc_denom.to_string()))
let mut ibc_denom = ibc_denom.clone();
if is_receiver_chain_source(
src_port_id.clone(),
src_channel_id.clone(),
&ibc_denom,
) {
let prefix =
TracePrefix::new(src_port_id.clone(), src_channel_id.clone());
ibc_denom.remove_trace_prefix(&prefix);
} else {
Ok(token.clone())
let prefix =
TracePrefix::new(dest_port_id.clone(), dest_channel_id.clone());
ibc_denom.add_trace_prefix(prefix);
}
Ok(storage::ibc_token(ibc_denom.to_string()))
}
8 changes: 4 additions & 4 deletions core/src/types/ibc.rs
Original file line number Diff line number Diff line change
@@ -65,7 +65,7 @@ mod ibc_rs_conversion {
use std::str::FromStr;

use borsh::{BorshDeserialize, BorshSerialize};
use data_encoding::HEXLOWER;
use data_encoding::HEXUPPER;
use thiserror::Error;

use super::{IbcEvent, IbcShieldedTransfer};
@@ -126,15 +126,15 @@ mod ibc_rs_conversion {
fn from(shielded: IbcShieldedTransfer) -> Self {
let bytes =
shielded.try_to_vec().expect("Encoding shouldn't failed");
HEXLOWER.encode(&bytes).into()
HEXUPPER.encode(&bytes).into()
}
}

impl TryFrom<Memo> for IbcShieldedTransfer {
type Error = Error;

fn try_from(memo: Memo) -> Result<Self> {
let bytes = HEXLOWER
let bytes = HEXUPPER
.decode(memo.as_ref().as_bytes())
.map_err(Error::DecodingHex)?;
Self::try_from_slice(&bytes)
@@ -154,7 +154,7 @@ mod ibc_rs_conversion {
event.attributes.get("success") == Some(&"true".to_string());
let receiver = event.attributes.get("receiver");
let is_shielded = if let Some(receiver) = receiver {
PaymentAddress::from_str(&receiver).is_ok()
PaymentAddress::from_str(receiver).is_ok()
} else {
false
};
2 changes: 0 additions & 2 deletions shared/src/sdk/args.rs
Original file line number Diff line number Diff line change
@@ -899,8 +899,6 @@ pub struct GenIbcShieldedTransafer<C: NamadaTypes = SdkTypes> {
pub target: C::TransferTarget,
/// The token address
pub token: C::Address,
/// The trace path of the token
pub trace_path: Option<TracePath>,
/// Transferred token amount
pub amount: InputAmount,
/// Port ID via which the token is received
5 changes: 3 additions & 2 deletions shared/src/sdk/tx.rs
Original file line number Diff line number Diff line change
@@ -2025,9 +2025,10 @@ pub async fn gen_ibc_shielded_transfer<
let (src_port_id, src_channel_id) =
get_ibc_src_port_channel(client, &args.port_id, &args.channel_id)
.await?;
let ibc_denom =
rpc::query_ibc_denom::<_, IO>(client, &args.token, Some(&source)).await;
let token = namada_core::ledger::ibc::received_ibc_token(
&args.token,
args.trace_path,
&ibc_denom.parse().expect("Invalid IBC denom"),
&src_port_id,
&src_channel_id,
&args.port_id,
212 changes: 186 additions & 26 deletions tests/src/e2e/ibc_tests.rs

Large diffs are not rendered by default.