hats-finance / SeeR-PM-0x899bc13919880db76edf4ccd72bdfa5dfa666fb7

1 stars 0 forks source link

wrapped1155 is not approved to be unwrapped by wrapped1155Factory contract #90

Open hats-bug-reporter[bot] opened 1 month ago

hats-bug-reporter[bot] commented 1 month ago

Github username: @cpp-phoenix Twitter username: 0xrochimaru Submission hash (on-chain): 0xd3b947b574497463ce79ccf434f28752c63998c4f24975cf0272b369ecd7c9d1 Severity: high

Description: Description\ In methods _splitPosition(), mergePositions() & _redeemPositions() wrapped1155Factory.unwrap() is used to unwrap a wrapped1155 token. But it doesn't approve the wrapped1155Factory contract with the amount to be unwrapped.

Attack Scenario\ Because of the insufficient approval the transaction will fail as the Router.sol token should approve wrapped1155Factory contract to use x amount of wrapped1155 tokens.

Recommendations\

    wrapped1155.transferFrom(msg.sender, address(this), amount);

@>  wrapped1155.approve(wrapped1155Factory, amount);
    wrapped1155Factory.unwrap(address(conditionalTokens), tokenId, amount, address(this), data);        
xyzseer commented 1 month ago

that approval is not needed, you can test the deployed smart contracts on the frontend and check that split/merge/redeem work as expected

clesaege commented 1 month ago

The router holds the token during this call. So no approval is needed.