Skip to content

Commit

Permalink
Ulm demo contracts - DAIMock.rs (#184)
Browse files Browse the repository at this point in the history
* DAIMock.rs, translated from solidity version. WIP.

* Bug fix and renaming.

* Bug fix in transfer.

* Bug fixes - debug session Roberto, Theo, Maria.

* Replaced hex number with large int (2^64-1). Largest possible number TDB.

* Typo.

* Update DAIMock.rs to use Hexdecimal and fixing if statement

* Copy of DAIMock.rs. V2, to have names as needed.

* Added events to DAIMock*.

---------

Co-authored-by: Roberto Rosmaninho <[email protected]>
  • Loading branch information
2 people authored and virgil-serbanuta committed Nov 8, 2024
1 parent 966945f commit 84e2e72
Show file tree
Hide file tree
Showing 2 changed files with 212 additions and 0 deletions.
106 changes: 106 additions & 0 deletions tests/ulm-contracts/DAIMock.rs
Original file line number Diff line number Diff line change
@@ -0,0 +1,106 @@
// This contract is a translation of https://github.com/Pi-Squared-Inc/solidity-demo-semantics/blob/f1204ebfed3b3c133735efe5186bcc02cf288074/test/demo-contracts/UniswapV2SwapRenamed.DAI.sol

// The main differences are
// - we include an init method
// - we do not include events emission

#![no_std]

#[allow(unused_imports)]
use ulm::*;

#[ulm::contract]
pub trait DAIMock {
#[storage_mapper("total_supply")]
fn s_total_supply(&self) -> ::single_value_mapper::SingleValueMapper<u256>;

#[storage_mapper("balances")]
fn s_balances(&self, address: u160) -> ::single_value_mapper::SingleValueMapper<u256>;

#[storage_mapper("balances")]
fn s_allowances(&self, account: u160, spender: u160) -> ::single_value_mapper::SingleValueMapper<u256>;

#[event("Transfer")]
fn transfer_event(&self, #[indexed] from: u160, #[indexed] to: u160, value: u256);

#[event("Approval")]
fn approval_event(&self, #[indexed] owner: u160, #[indexed] spender: u160, value: u256);

#[view(totalSupply)]
fn total_supply(&self) -> u256 {
self.s_total_supply().get()
}

#[view(balanceOf)]
fn balance_of(&self, account: u160) -> u256 {
self.s_balances(account).get()
}

#[view(allowance)]
fn allowance(&self, owner: u160, spender: u160) -> u256 {
self.s_allowances(owner, spender).get()
}

#[init]
fn init(&self) {
}

#[view(decimals)]
fn decimals(&self) -> u8 {
18
}

#[endpoint(mint)]
fn mint(&self, account: u160, value: u256) {
self.s_balances(account).set(self.s_balances(account).get() + value);
self.s_total_supply().set(self.s_total_supply().get() + value);
self.transfer_event(0_u160, account, value);
}

#[endpoint(mintOnDeposit)]
fn mintOnDeposit(&self, account: u160, value: u256) {
self.mint(account, value);
}

#[endpoint(burn)]
fn burn(&self, account: u160, value: u256) {
if self.s_balances(account).get() >= value {
self.s_balances(account).set(self.s_balances(account).get() - value);
self.s_total_supply().set(self.s_total_supply().get() - value);
}
}

#[endpoint(approve)]
fn approve(&self, spender: u160, value: u256) -> bool {
let owner = ::ulm::Caller();
self.s_allowances(owner, spender).set(value);
self.approval_event(owner, spender, value);
true
}

#[endpoint(transfer)]
fn transfer(&self, to: u160, value: u256) -> bool {
let owner = ::ulm::Caller();
self.transferFrom(&owner, to, &value)
}

#[endpoint(transferFrom)]
fn transferFrom(&self, from: u160, to: u160, value: u256) -> bool {
::helpers::require(self.s_balances(from).get() >= value, "Dai/insufficient-balance");
let spender = ::ulm::Caller();
if from != spender && self.s_allowances(from, spender).get() != 0xffffffffffffffffffffffffffffffffffffffffffffffffffffffffffffffff_u256 {
::helpers::require(self.s_allowances(from, spender).get() >= value, "Dai/insufficient-allowance");
self.s_allowances(from, spender).set(self.s_allowances(from, spender).get() - value);
};
self.s_balances(from).set(self.s_balances(from).get() - value);
self.s_balances(to).set(self.s_balances(to).get() + value);
self.transfer_event(from, to, value);
true
}

#[endpoint(safeTransferFrom)]
fn safeTransferFrom(&self, from: u160, to: u160, value: u256) -> bool {
self.transferFrom(from, to, &value);
}

}
106 changes: 106 additions & 0 deletions tests/ulm-contracts/DAIMockWBTC.rs
Original file line number Diff line number Diff line change
@@ -0,0 +1,106 @@
// This contract is a translation of https://github.com/Pi-Squared-Inc/solidity-demo-semantics/blob/f1204ebfed3b3c133735efe5186bcc02cf288074/test/demo-contracts/UniswapV2SwapRenamed.DAI.sol

// The main differences are
// - we include an init method
// - we do not include events emission

#![no_std]

#[allow(unused_imports)]
use ulm::*;

#[ulm::contract]
pub trait DAIMock {
#[storage_mapper("total_supply")]
fn s_total_supply(&self) -> ::single_value_mapper::SingleValueMapper<u256>;

#[storage_mapper("balances")]
fn s_balances(&self, address: u160) -> ::single_value_mapper::SingleValueMapper<u256>;

#[storage_mapper("balances")]
fn s_allowances(&self, account: u160, spender: u160) -> ::single_value_mapper::SingleValueMapper<u256>;

#[event("Transfer")]
fn transfer_event(&self, #[indexed] from: u160, #[indexed] to: u160, value: u256);

#[event("Approval")]
fn approval_event(&self, #[indexed] owner: u160, #[indexed] spender: u160, value: u256);

#[view(totalSupply)]
fn total_supply(&self) -> u256 {
self.s_total_supply().get()
}

#[view(balanceOf)]
fn balance_of(&self, account: u160) -> u256 {
self.s_balances(account).get()
}

#[view(allowance)]
fn allowance(&self, owner: u160, spender: u160) -> u256 {
self.s_allowances(owner, spender).get()
}

#[init]
fn init(&self) {
}

#[view(decimals)]
fn decimals(&self) -> u8 {
18
}

#[endpoint(mint)]
fn mint(&self, account: u160, value: u256) {
self.s_balances(account).set(self.s_balances(account).get() + value);
self.s_total_supply().set(self.s_total_supply().get() + value);
self.transfer_event(0_u160, account, value);
}

#[endpoint(mintOnDeposit)]
fn mintOnDeposit(&self, account: u160, value: u256) {
self.mint(account, value);
}

#[endpoint(burn)]
fn burn(&self, account: u160, value: u256) {
if self.s_balances(account).get() >= value {
self.s_balances(account).set(self.s_balances(account).get() - value);
self.s_total_supply().set(self.s_total_supply().get() - value);
}
}

#[endpoint(approve)]
fn approve(&self, spender: u160, value: u256) -> bool {
let owner = ::ulm::Caller();
self.s_allowances(owner, spender).set(value);
self.approval_event(owner, spender, value);
true
}

#[endpoint(transfer)]
fn transfer(&self, to: u160, value: u256) -> bool {
let owner = ::ulm::Caller();
self.transferFrom(&owner, to, &value)
}

#[endpoint(transferFrom)]
fn transferFrom(&self, from: u160, to: u160, value: u256) -> bool {
::helpers::require(self.s_balances(from).get() >= value, "Dai/insufficient-balance");
let spender = ::ulm::Caller();
if from != spender && self.s_allowances(from, spender).get() != 0xffffffffffffffffffffffffffffffffffffffffffffffffffffffffffffffff_u256 {
::helpers::require(self.s_allowances(from, spender).get() >= value, "Dai/insufficient-allowance");
self.s_allowances(from, spender).set(self.s_allowances(from, spender).get() - value);
};
self.s_balances(from).set(self.s_balances(from).get() - value);
self.s_balances(to).set(self.s_balances(to).get() + value);
self.transfer_event(from, to, value);
true
}

#[endpoint(safeTransferFrom)]
fn safeTransferFrom(&self, from: u160, to: u160, value: u256) -> bool {
self.transferFrom(from, to, &value);
}

}

0 comments on commit 84e2e72

Please sign in to comment.