@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)
{
"deposits": {
"0000834AD179A291856494A6ECA9AA855AAE0F28E5F221666CBD11D2FF96B2A0FE19": {
"amount": 100.0,
"reward_amount": 0
}
},
"lp_token_deposited": 100.0,
"reward_token_balance": 1000000.00225862
}
-
Secret shared with 1 key
Encoded secret
6BEABAAA6D6924008A89BFC5A6D3CF32B8109B3D0E412369A2922D67FD168899400B7D157C0738B8BFA241E5A846D24204F798F347864413D02F5F82
Authorized keys
- 00017877BCF4122095926A49489009649603AB129822A19EF9D573B8FD714911ED7F
Contract recipients (0)
Inputs (0)
Contract inputs (0)
Unspent outputs (2)
-
From 00007277...7F76At 2024-01-31 15:23:55 UTCAmount 1,000,000.00225862 UCO
-
From 0000C490...7D80At 2024-01-31 15:23:45 UTCAmount 100 00006394...DEAF
Previous public key
00016981D640066DA857A7201A401504F4F29D5879ED10E258623785746C82D0AE1A
Previous signature
F8E4EBCC8355A544CFAF6374F9D24C34703944AB8AEAF8E05EEA9EC801CC2E63585A2FEA6F4547DEB0FFFCD6C48C70705D760612E7ECEAF984B4AE84F5EBC204
Origin signature
3045022100C4D369127D2BB673FEC857E0FA14C964F52014653F6166F787EAEFE4FD2E8C130220339B29A3A16E77FEBF8337711C3575704E40AE679C4FCEEEA6406526DD2E4F2D
Proof of work
010204B3B2A53580086B9F36919CF40ABC55904729F78BF43673E216FAC1EB2451DD1E521879C6588F0CB09B150A103A39A73E2816B5ADF51F0721348BA3A66C33023B
Proof of integrity
00FF8F2464B3F29C89712B9EFF70045476AEF636E167E675076CE66275A462194A
Coordinator signature
5520B3969A679DC444B87F518D94F842B4527C33FE594DFF97E292CD4A50F2FB87047BC6D1DE75114B70DAC859AFC0D9FAFCAEA28E4F3DD11391FF3104F5A80E
Validator #1 public key
00010F2A0E4C424582A94BD90E05FE6931628F91988ABBE387D365994F1F3FCF5A12
Validator #1 signature
AA6030CF72FB986DB33F4B397BE4A9B86EF4FBA4BC05DA5C7EB541670CA599F8D346898FA4352CCCC04EE120D4EAED2F18AF2159F8C7E521DF7EB5A472B2600A
Validator #2 public key
000162E6ADFF9FBBBC4BDBB3CD56A5A13A1E8576C3619ADC58A189F7E9A3A77FF95D
Validator #2 signature
F60D88502A8514BD0011D4AA65C82A5ACC73A7D3549B78B985B49F1323979E158CE8C819A0747731999A6207D459DFD4826A613D71713BC87AF0D508924D1E03