@version 1
condition triggered_by: transaction, on: deposit(), as: [
timestamp: transaction.timestamp < 1710763200,
token_transfers: get_user_transfer_amount(transaction) > 0
]
actions triggered_by: transaction, on: deposit() do
transfer_amount = get_user_transfer_amount(transaction)
previous_address = Chain.get_previous_address(transaction)
user_genesis_address = Chain.get_genesis_address(previous_address)
State.set("reward_token_balance", get_reward_token_balance())
deposits = nil
if Time.now() > 1706720400 do
res = calculate_new_rewards()
deposits = res.deposits
State.set("rewards_reserved", res.rewards_reserved)
State.set("last_calculation_timestamp", res.last_calculation_timestamp)
else
deposits = State.get("deposits", Map.new())
end
user_deposit = Map.get(deposits, user_genesis_address, [amount: 0, reward_amount: 0])
user_deposit = Map.set(user_deposit, "amount", user_deposit.amount + transfer_amount)
deposits = Map.set(deposits, user_genesis_address, user_deposit)
State.set("deposits", deposits)
lp_token_deposited = State.get("lp_token_deposited", 0)
State.set("lp_token_deposited", lp_token_deposited + transfer_amount)
end
condition triggered_by: transaction, on: claim(), as: [
timestamp: transaction.timestamp > 1706720400,
previous_public_key: (
previous_address = Chain.get_previous_address()
genesis_address = Chain.get_genesis_address(previous_address)
deposits = State.get("deposits", Map.new())
Map.get(deposits, genesis_address) != nil
)
]
actions triggered_by: transaction, on: claim() do
previous_address = Chain.get_previous_address(transaction)
user_genesis_address = Chain.get_genesis_address(previous_address)
State.set("reward_token_balance", get_reward_token_balance())
res = calculate_new_rewards()
deposits = res.deposits
State.set("last_calculation_timestamp", res.last_calculation_timestamp)
user_deposit = Map.get(deposits, user_genesis_address)
if "UCO" == "UCO" do
Contract.add_uco_transfer(to: transaction.address, amount: user_deposit.reward_amount)
else
Contract.add_token_transfer(
to: transaction.address,
amount: user_deposit.reward_amount,
token_address: "UCO"
)
end
reward_distributed = State.get("reward_distributed", 0)
State.set("reward_distributed", reward_distributed + user_deposit.reward_amount)
State.set("rewards_reserved", res.rewards_reserved - user_deposit.reward_amount)
reward_token_balance = State.get("reward_token_balance")
State.set("reward_token_balance", reward_token_balance - user_deposit.reward_amount)
new_user_deposit = Map.set(user_deposit, "reward_amount", 0)
deposits = Map.set(deposits, user_genesis_address, new_user_deposit)
State.set("deposits", deposits)
end
condition triggered_by: transaction, on: withdraw(amount), as: [
previous_public_key: (
previous_address = Chain.get_previous_address()
genesis_address = Chain.get_genesis_address(previous_address)
deposits = State.get("deposits", Map.new())
user_deposit = Map.get(deposits, genesis_address)
user_deposit != nil && user_deposit.amount >= amount
)
]
actions triggered_by: transaction, on: withdraw(amount) do
previous_address = Chain.get_previous_address(transaction)
user_genesis_address = Chain.get_genesis_address(previous_address)
State.set("reward_token_balance", get_reward_token_balance())
deposits = nil
rewards_reserved = 0
if Time.now() > 1706720400 do
res = calculate_new_rewards()
deposits = res.deposits
rewards_reserved = res.rewards_reserved
State.set("last_calculation_timestamp", res.last_calculation_timestamp)
else
deposits = State.get("deposits", Map.new())
rewards_reserved = State.get("rewards_reserved", 0)
end
user_deposit = Map.get(deposits, user_genesis_address)
if "UCO" == "UCO" do
Contract.add_uco_transfer(to: transaction.address, amount: user_deposit.reward_amount)
else
Contract.add_token_transfer(
to: transaction.address,
amount: user_deposit.reward_amount,
token_address: "UCO"
)
end
Contract.add_token_transfer(
to: transaction.address,
amount: amount,
token_address: 0x00006394EF24DFDC6FDFC3642FDC83827591A485704BB997221C0B9F313A468BDEAF
)
reward_distributed = State.get("reward_distributed", 0)
State.set("reward_distributed", reward_distributed + user_deposit.reward_amount)
State.set("rewards_reserved", rewards_reserved - user_deposit.reward_amount)
reward_token_balance = State.get("reward_token_balance")
State.set("reward_token_balance", reward_token_balance - user_deposit.reward_amount)
lp_token_deposited = State.get("lp_token_deposited")
State.set("lp_token_deposited", lp_token_deposited - amount)
if amount == user_deposit.amount do
deposits = Map.delete(deposits, user_genesis_address)
else
new_deposit = Map.set(user_deposit, "reward_amount", 0)
new_deposit = Map.set(new_deposit, "amount", user_deposit.amount - amount)
deposits = Map.set(deposits, user_genesis_address, new_deposit)
end
State.set("deposits", deposits)
end
condition triggered_by: transaction, on: update_code(), as: [
previous_public_key: (
# Pool code can only be updated from the router contract of the dex
# Transaction is not yet validated so we need to use previous address
# to get the genesis address
previous_address = Chain.get_previous_address()
Chain.get_genesis_address(previous_address) == 0x000066CD867DA536A73D39CF05174387923358DC0009A29CC7162D4AED00675DAB55
)
]
actions triggered_by: transaction, on: update_code() do
params = [
0x00006394EF24DFDC6FDFC3642FDC83827591A485704BB997221C0B9F313A468BDEAF,
1706720400,
1710763200,
"UCO",
0x0000208a670b5590939174d65f88140c05dddba63c0c920582e12162b22f3985e510
]
new_code = Contract.call_function(0x000086E60124C986EBCAA5AFFB7A3DB8213072A132233FE61CF45651FDCF3C4CECEA, "get_farm_code", params)
if Code.is_valid?(new_code) && !Code.is_same?(new_code, contract.code) do
Contract.set_type("contract")
Contract.set_code(new_code)
end
end
fun get_reward_token_balance() do
if "UCO" == "UCO" do
Chain.get_uco_balance(contract.address)
else
Chain.get_token_balance(contract.address, "UCO")
end
end
fun get_user_transfer_amount(tx) do
transfers = Map.get(transaction.token_transfers, 0x0000208a670b5590939174d65f88140c05dddba63c0c920582e12162b22f3985e510, [])
transfer = List.at(transfers, 0)
if transfer != nil && transfer.token_address == 0x00006394EF24DFDC6FDFC3642FDC83827591A485704BB997221C0B9F313A468BDEAF do
transfer.amount
else
0
end
end
fun calculate_new_rewards() do
deposits = State.get("deposits", Map.new())
lp_token_deposited = State.get("lp_token_deposited", 0)
rewards_reserved = State.get("rewards_reserved", 0)
last_calculation_timestamp = State.get("last_calculation_timestamp", 1706720400)
now = Time.now()
if last_calculation_timestamp < now && last_calculation_timestamp < 1710763200 && lp_token_deposited > 0 do
rewards_balance = State.get("reward_token_balance", 0)
available_balance = rewards_balance - rewards_reserved
amount_to_allocate = 0
if now >= 1710763200 do
amount_to_allocate = available_balance
else
time_elapsed = now - last_calculation_timestamp
time_remaining = 1710763200 - last_calculation_timestamp
amount_to_allocate = available_balance * (time_elapsed / time_remaining)
end
if amount_to_allocate > 0 do
for address in Map.keys(deposits) do
deposit = Map.get(deposits, address)
new_reward_amount = amount_to_allocate * (deposit.amount / lp_token_deposited)
if new_reward_amount > 0 do
deposit = Map.set(deposit, "reward_amount", deposit.reward_amount + new_reward_amount)
deposits = Map.set(deposits, address, deposit)
rewards_reserved = rewards_reserved + new_reward_amount
last_calculation_timestamp = now
end
end
end
end
[
deposits: deposits,
rewards_reserved: rewards_reserved,
last_calculation_timestamp: last_calculation_timestamp
]
end
export fun get_farm_infos() do
reward_token_balance = State.get("reward_token_balance")
remaining_reward = nil
if reward_token_balance != nil do
remaining_reward = reward_token_balance - State.get("rewards_reserved", 0)
end
[
lp_token_address: 0x00006394EF24DFDC6FDFC3642FDC83827591A485704BB997221C0B9F313A468BDEAF,
reward_token: "UCO",
start_date: 1706720400,
end_date: 1710763200,
remaining_reward: remaining_reward,
lp_token_deposited: State.get("lp_token_deposited", 0),
nb_deposit: Map.size(State.get("deposits", Map.new())),
stats: [
reward_distributed: State.get("reward_distributed", 0)
]
]
end
export fun get_user_infos(user_genesis_address) do
user_genesis_address = String.to_hex(user_genesis_address)
deposits = State.get("deposits", Map.new())
user_deposit = Map.get(deposits, user_genesis_address)
if user_deposit != nil do
lp_token_deposited = State.get("lp_token_deposited", 0)
last_calculation_timestamp = State.get("last_calculation_timestamp", 1706720400)
now = Time.now()
if now > 1706720400 && last_calculation_timestamp < now && last_calculation_timestamp < 1710763200 && lp_token_deposited > 0 do
rewards_balance = State.get("reward_token_balance", 0)
rewards_reserved = State.get("rewards_reserved", 0)
available_balance = rewards_balance - rewards_reserved
amount_to_allocate = 0
if now >= 1710763200 do
amount_to_allocate = available_balance
else
time_elapsed = now - last_calculation_timestamp
time_remaining = 1710763200 - last_calculation_timestamp
amount_to_allocate = available_balance * (time_elapsed / time_remaining)
end
if amount_to_allocate > 0 do
new_reward_amount = amount_to_allocate * (user_deposit.amount / lp_token_deposited)
if new_reward_amount > 0 do
user_deposit = Map.set(user_deposit, "reward_amount", user_deposit.reward_amount + new_reward_amount)
end
end
end
[deposited_amount: user_deposit.amount, reward_amount: user_deposit.reward_amount]
else
[deposited_amount: 0, reward_amount: 0]
end
end
Content (0 B)
State (0 B)
-
Secret shared with 1 key
Encoded secret
C1725EB54D6D98049FCEC300235F50D104FD02423A4300FC4961CAFB66EC580D22E2DD094556964A80475468D3AEFE35ACFCC467B1AE2D1F25C56588
Authorized keys
- 00017877BCF4122095926A49489009649603AB129822A19EF9D573B8FD714911ED7F
Contract recipients (0)
Inputs (0)
Contract inputs (0)
Unspent outputs (1)
-
From 000063F9...60D6At 2024-01-31 14:39:26 UTCAmount 0.00225862 UCO
Previous public key
000185AC11E054CC9F8F8242B36EA838B23DDB3EC0EEE65FCC75C8FF007AE80CEF55
Previous signature
CFF022AB4F4080421F02A3CAE5C3639D975CAE11EB593A28EB09B5B7BF2AD7787AE7700CBE411756AF72291122C75166C92345D2B141DD31BA5E4B8B1807D70F
Origin signature
3044022079FA88D1D9BF87BED8BEAB980C13B3B7972921B39E806DE1EE817E3CE246F1FC0220360422BFAEEF2A445F5FEFF6951483131DD7A31221C3B11A1B8BE34898F3260B
Proof of work
010104AB41291F847A601055AEDD1AF24FF76FA970D6441E2DCA3818A8319B004C96B27B8FEB1DA31A044BA0A4800B4353359735719EBB3A05F98393A9CC599C3FAFD6
Proof of integrity
007005594C9CFCD71D1B0CDB92846B8B7B4C79F8AD52653BFA3EBC4EDFE16DF4A5
Coordinator signature
AFC3020E7DA878BB9731062275B0B4CBF6D77D23989B5592E80A5D974D4DCDD6FCD7482DC458633657B621BA7015C6A6A5940947624EF80E3F72DC2E17BA9D0F
Validator #1 public key
00018A312AFA617E98B343D09AD2E73F0AB661DB0A59FB986D5DB8CE7664E14C25FC
Validator #1 signature
C771E4248294620E097B61E2299E5DF020CBF53B4A188A8286A2A19894B212C1649410C2127E4B76EC26A19E17F6F43DF416469068026C93442C14F7743D0F0A
Validator #2 public key
00011ED0B570D680BE5ECD58D2D121689DA73C46DCB38A01C6E10D06286040ADE30A
Validator #2 signature
944DC8F35719999E923460B31829106FA2E197E3A5CB36B96BA29111B47AAFFE8D4747AC3470D1BB064E4C94D9F2D8CB2268582601BBD14E3E11B496F147040E