@version 1 condition triggered_by: transaction, on: add_liquidity(token1_min_amount, token2_min_amount), as: [ token_transfers: ( user_amounts = get_user_transfers_amount(transaction) valid_transfers? = user_amounts.token1 > 0 && user_amounts.token2 > 0 valid_min? = user_amounts.token1 >= token1_min_amount && user_amounts.token2 >= token2_min_amount valid_transfers? && valid_min? ) ] actions triggered_by: transaction, on: add_liquidity(token1_min_amount, token2_min_amount) do pool_balances = get_pool_balances() user_amounts = get_user_transfers_amount(transaction) lp_token_supply = State.get("lp_token_supply", 0) reserves = State.get("reserves", [token1: 0, token2: 0]) final_amounts = get_final_amounts(user_amounts, reserves, token1_min_amount, token2_min_amount) token1_to_refund = user_amounts.token1 - final_amounts.token1 token2_to_refund = user_amounts.token2 - final_amounts.token2 token1_amount = user_amounts.token1 + pool_balances.token1 - reserves.token1 - token1_to_refund token2_amount = user_amounts.token2 + pool_balances.token2 - reserves.token2 - token2_to_refund lp_token_to_mint = get_lp_token_to_mint(token1_amount, token2_amount) # Handle invalid values and refund user valid_amounts? = final_amounts.token1 > 0 && final_amounts.token2 > 0 valid_liquidity? = lp_token_to_mint > 0 if valid_amounts? && valid_liquidity? do lp_token_to_mint_bigint = Math.trunc(lp_token_to_mint * 100_000_000) # Remove minimum liquidity if this is the first liquidity if the pool # First liquidity minted and burned on pool creation if lp_token_supply == 0 do lp_token_to_mint_bigint = lp_token_to_mint_bigint - 10 end token_specification = [ aeip: [8, 18, 19], supply: lp_token_to_mint_bigint, token_reference: 0x0000D1B4A0597A033F7DD0C8CA274745F850A990725B7B73B5E8CEBC7C4F9EA82954, recipients: [ [to: transaction.address, amount: lp_token_to_mint_bigint] ] ] new_token1_reserve = user_amounts.token1 + pool_balances.token1 - token1_to_refund new_token2_reserve = user_amounts.token2 + pool_balances.token2 - token2_to_refund State.set("lp_token_supply", lp_token_supply + lp_token_to_mint) State.set("reserves", [token1: new_token1_reserve, token2: new_token2_reserve]) if token1_to_refund > 0 do Contract.add_token_transfer(to: transaction.address, amount: token1_to_refund, token_address: "0000457EACA7FBAA96DB4A8D506A0B69684F546166FBF3C55391B1461907EFA58EAF") end if token2_to_refund > 0 do if "UCO" == "UCO" do Contract.add_uco_transfer(to: transaction.address, amount: token2_to_refund) else Contract.add_token_transfer(to: transaction.address, amount: token2_to_refund, token_address: "UCO") end end Contract.set_type("token") Contract.set_content(Json.to_string(token_specification)) else # Liquidity provision is invalid, refund user of it's tokens Contract.set_type("transfer") if "UCO" == "UCO" do Contract.add_uco_transfer(to: transaction.address, amount: user_amounts.token2) else Contract.add_token_transfer(to: transaction.address, amount: user_amounts.token2, token_address: "UCO") end Contract.add_token_transfer(to: transaction.address, amount: user_amounts.token1, token_address: "0000457EACA7FBAA96DB4A8D506A0B69684F546166FBF3C55391B1461907EFA58EAF") end end condition triggered_by: transaction, on: remove_liquidity(), as: [ token_transfers: ( user_amount = get_user_lp_amount(transaction.token_transfers) user_amount > 0 ) ] actions triggered_by: transaction, on: remove_liquidity() do return? = true user_amount = get_user_lp_amount(transaction.token_transfers) lp_token_supply = State.get("lp_token_supply", 0) if lp_token_supply > 0 do pool_balances = get_pool_balances() token1_to_remove = (user_amount * pool_balances.token1) / lp_token_supply token2_to_remove = (user_amount * pool_balances.token2) / lp_token_supply if token1_to_remove > 0 && token2_to_remove > 0 do return? = false new_token1_reserve = pool_balances.token1 - token1_to_remove new_token2_reserve = pool_balances.token2 - token2_to_remove State.set("lp_token_supply", lp_token_supply - user_amount) State.set("reserves", [token1: new_token1_reserve, token2: new_token2_reserve]) Contract.set_type("transfer") Contract.add_token_transfer(to: transaction.address, amount: token1_to_remove, token_address: "0000457EACA7FBAA96DB4A8D506A0B69684F546166FBF3C55391B1461907EFA58EAF") if "UCO" == "UCO" do Contract.add_uco_transfer(to: transaction.address, amount: token2_to_remove) else Contract.add_token_transfer(to: transaction.address, amount: token2_to_remove, token_address: "UCO") end end end if return? do # Refund is invalid, return LP tokens to user Contract.set_type("transfer") Contract.add_token_transfer(to: transaction.address, amount: user_amount, token_address: 0x0000D1B4A0597A033F7DD0C8CA274745F850A990725B7B73B5E8CEBC7C4F9EA82954) end end condition triggered_by: transaction, on: swap(_min_to_receive), as: [ token_transfers: ( transfer = get_user_transfer(transaction) transfer != nil ) ] actions triggered_by: transaction, on: swap(min_to_receive) do transfer = get_user_transfer(transaction) swap = get_output_swap_infos(transfer.token_address, transfer.amount) if swap.output_amount > 0 && swap.output_amount >= min_to_receive do pool_balances = get_pool_balances() token_to_send = nil token1_volume = 0 token2_volume = 0 token1_fee = 0 token2_fee = 0 token1_protocol_fee = 0 token2_protocol_fee = 0 if transfer.token_address == "0000457EACA7FBAA96DB4A8D506A0B69684F546166FBF3C55391B1461907EFA58EAF" do pool_balances = [ token1: pool_balances.token1 + transfer.amount - swap.protocol_fee, token2: pool_balances.token2 - swap.output_amount ] token_to_send = "UCO" token1_volume = transfer.amount token1_fee = swap.fee token1_protocol_fee = swap.protocol_fee else pool_balances = [ token1: pool_balances.token1 - swap.output_amount, token2: pool_balances.token2 + transfer.amount - swap.protocol_fee ] token_to_send = "0000457EACA7FBAA96DB4A8D506A0B69684F546166FBF3C55391B1461907EFA58EAF" token2_volume = transfer.amount token2_fee = swap.fee token2_protocol_fee = swap.protocol_fee end State.set("reserves", [token1: pool_balances.token1, token2: pool_balances.token2]) stats = State.get("stats", [ token1_total_fee: 0, token2_total_fee: 0, token1_total_volume: 0, token2_total_volume: 0, token1_total_protocol_fee: 0, token2_total_protocol_fee: 0, ]) token1_total_fee = Map.get(stats, "token1_total_fee") + token1_fee token2_total_fee = Map.get(stats, "token2_total_fee") + token2_fee token1_total_volume = Map.get(stats, "token1_total_volume") + token1_volume token2_total_volume = Map.get(stats, "token2_total_volume") + token2_volume token1_total_protocol_fee = Map.get(stats, "token1_total_protocol_fee") + token1_protocol_fee token2_total_protocol_fee = Map.get(stats, "token2_total_protocol_fee") + token2_protocol_fee stats = Map.set(stats, "token1_total_fee", token1_total_fee) stats = Map.set(stats, "token2_total_fee", token2_total_fee) stats = Map.set(stats, "token1_total_volume", token1_total_volume) stats = Map.set(stats, "token2_total_volume", token2_total_volume) stats = Map.set(stats, "token1_total_protocol_fee", token1_total_protocol_fee) stats = Map.set(stats, "token2_total_protocol_fee", token2_total_protocol_fee) State.set("stats", stats) Contract.set_type("transfer") if token_to_send == "UCO" do Contract.add_uco_transfer(to: transaction.address, amount: swap.output_amount) else Contract.add_token_transfer(to: transaction.address, amount: swap.output_amount, token_address: token_to_send) end if swap.protocol_fee > 0 do if transfer.token_address == "UCO" do Contract.add_uco_transfer(to: 0x0000CC1FADBD31B043947C016E09CCD59BC3C81E55AB8A4932A046236D5E0FEE9E45, amount: swap.protocol_fee) else Contract.add_token_transfer(to: 0x0000CC1FADBD31B043947C016E09CCD59BC3C81E55AB8A4932A046236D5E0FEE9E45, amount: swap.protocol_fee, token_address: transfer.token_address) end end else # Swap is invalid, return tokens to user Contract.set_type("transfer") if transfer.token_address == "0000457EACA7FBAA96DB4A8D506A0B69684F546166FBF3C55391B1461907EFA58EAF" do Contract.add_token_transfer(to: transaction.address, amount: transfer.amount, token_address: "0000457EACA7FBAA96DB4A8D506A0B69684F546166FBF3C55391B1461907EFA58EAF") else if transfer.token_address == "UCO" do Contract.add_uco_transfer(to: transaction.address, amount: transfer.amount) else Contract.add_token_transfer(to: transaction.address, amount: transfer.amount, token_address: "UCO") end end end 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) == 0x000077CEC9D9DBC0183CAF843CBB4828A932BB1457E382AC83B31AD6F9755DD50FFC ) ] actions triggered_by: transaction, on: update_code() do params = [ "0000457EACA7FBAA96DB4A8D506A0B69684F546166FBF3C55391B1461907EFA58EAF", "UCO", 0x000090C5AFCC97C2357E964E3DDF5BE9948477F7C1DE2C633CDFC95B202970AEA036, 0x0000D1B4A0597A033F7DD0C8CA274745F850A990725B7B73B5E8CEBC7C4F9EA82954 ] new_code = Contract.call_function(0x00004CE47B2828E923EB679FEF311DD458AA0571C67DB5CB46B4E0793CAC525AC791, "get_pool_code", params) if Code.is_valid?(new_code) do Contract.set_type("contract") Contract.set_code(new_code) end end condition triggered_by: transaction, on: set_protocol_fee(new_protocol_fee), as: [ content: new_protocol_fee <= 1 && new_protocol_fee >= 0, previous_public_key: ( previous_address = Chain.get_previous_address() Chain.get_genesis_address(previous_address) == 0x0000BE4D33FC48CD4791A58EF7296F6916F5A2032A4E66111CF10521D08FC660A4D3 ) ] actions triggered_by: transaction, on: set_protocol_fee(new_protocol_fee) do State.set("protocol_fee", new_protocol_fee) end condition triggered_by: transaction, on: set_lp_fee(new_lp_fee), as: [ content: new_lp_fee <= 1 && new_lp_fee >= 0, previous_public_key: ( previous_address = Chain.get_previous_address() Chain.get_genesis_address(previous_address) == 0x0000BE4D33FC48CD4791A58EF7296F6916F5A2032A4E66111CF10521D08FC660A4D3 ) ] actions triggered_by: transaction, on: set_lp_fee(new_lp_fee) do State.set("lp_fee", new_lp_fee) end export fun get_ratio(token_address) do reserves = State.get("reserves", [token1: 0, token2: 0]) ratio = 0 token_address = String.to_uppercase(token_address) if reserves.token1 > 0 && reserves.token2 > 0 do if token_address == "0000457EACA7FBAA96DB4A8D506A0B69684F546166FBF3C55391B1461907EFA58EAF" do ratio = reserves.token2 / reserves.token1 else ratio = reserves.token1 / reserves.token2 end end ratio end export fun get_equivalent_amount(token_address, amount) do reserves = State.get("reserves", [token1: 0, token2: 0]) ratio = 0 token_address = String.to_uppercase(token_address) if reserves.token1 > 0 && reserves.token2 > 0 do if token_address == "0000457EACA7FBAA96DB4A8D506A0B69684F546166FBF3C55391B1461907EFA58EAF" do ratio = reserves.token2 / reserves.token1 else ratio = reserves.token1 / reserves.token2 end end amount * ratio end export fun get_lp_token_to_mint(token1_amount, token2_amount) do lp_token_supply = State.get("lp_token_supply", 0) reserves = State.get("reserves", [token1: 0, token2: 0]) if lp_token_supply == 0 || reserves.token1 == 0 || reserves.token2 == 0 do # First liquidity Math.sqrt(token1_amount * token2_amount) else mint_amount1 = (token1_amount * lp_token_supply) / reserves.token1 mint_amount2 = (token2_amount * lp_token_supply) / reserves.token2 if mint_amount1 < mint_amount2 do mint_amount1 else mint_amount2 end end end export fun get_output_swap_infos(token_address, input_amount) do if input_amount <= 0 do throw code: 1, message: "input amount must be positive" end reserves = State.get("reserves", [token1: 0, token2: 0]) if reserves.token1 <= 0 || reserves.token2 <= 0 do throw code: 2, message: "Insufficient output liquidity" end output_amount = 0 price_impact = 0 market_price = 0 token_address = String.to_uppercase(token_address) fee = input_amount * State.get("lp_fee", 0.3) / 100 protocol_fee = input_amount * State.get("protocol_fee", 0) / 100 amount_with_fee = input_amount - fee - protocol_fee if token_address == "0000457EACA7FBAA96DB4A8D506A0B69684F546166FBF3C55391B1461907EFA58EAF" do market_price = reserves.token2 / reserves.token1 amount = (amount_with_fee * reserves.token2) / (amount_with_fee + reserves.token1) if amount < reserves.token2 do output_amount = amount else throw code: 2, message: "Insufficient output liquidity" end else market_price = reserves.token1 / reserves.token2 amount = (amount_with_fee * reserves.token1) / (amount_with_fee + reserves.token2) if amount < reserves.token1 do output_amount = amount else throw code: 2, message: "Insufficient output liquidity" end end # This check is necessary as there might be some approximation in small decimal calculation output_price = output_amount / input_amount if output_amount > 0 && market_price > output_price do price_impact = 100 - (output_price * 100 / market_price) end [ output_amount: output_amount, fee: fee, protocol_fee: protocol_fee, price_impact: price_impact ] end export fun get_input_swap_infos(token_address, output_amount) do if output_amount < 0 do throw code: 1, message: "output amount cannot be negative" end reserves = State.get("reserves", [token1: 0, token2: 0]) token_address = String.to_uppercase(token_address) if token_address == "0000457EACA7FBAA96DB4A8D506A0B69684F546166FBF3C55391B1461907EFA58EAF" && output_amount >= reserves.token1 do throw code: 2, message: "Insufficient output liquidity" end if token_address == "UCO" && output_amount >= reserves.token2 do throw code: 2, message: "Insufficient output liquidity" end input_amount = 0 market_price = 0 lp_fee = State.get("lp_fee", 0.3) / 100 protocol_fee = State.get("protocol_fee", 0) / 100 price_impact = 0 if token_address == "0000457EACA7FBAA96DB4A8D506A0B69684F546166FBF3C55391B1461907EFA58EAF" do market_price = reserves.token1 / reserves.token2 input_amount = (output_amount * reserves.token2) / ((reserves.token1 - output_amount) * (1 - lp_fee - protocol_fee)) else market_price = reserves.token2 / reserves.token1 input_amount = (output_amount * reserves.token1) / ((reserves.token2 - output_amount) * (1 - lp_fee - protocol_fee)) end if input_amount > 0 do # This check is necessary as there might be some approximation in small decimal calculation output_price = output_amount / input_amount if market_price > output_price do price_impact = 100 - (output_price * 100 / market_price) end end [ input_amount: input_amount, fee: input_amount * lp_fee, protocol_fee: input_amount * protocol_fee, price_impact: price_impact ] end export fun get_remove_amounts(lp_token_amount) do reserves = State.get("reserves", [token1: 0, token2: 0]) lp_token_supply = State.get("lp_token_supply", 0) token1_to_remove = 0 token2_to_remove = 0 if lp_token_supply > 0 && lp_token_amount < lp_token_supply do token1_to_remove = (lp_token_amount * reserves.token1) / lp_token_supply token2_to_remove = (lp_token_amount * reserves.token2) / lp_token_supply end [token1: token1_to_remove, token2: token2_to_remove] end export fun get_pool_infos() do reserves = State.get("reserves", [token1: 0, token2: 0]) stats = State.get("stats", [ token1_total_fee: 0, token2_total_fee: 0, token1_total_volume: 0, token2_total_volume: 0, token1_total_protocol_fee: 0, token2_total_protocol_fee: 0, ]) [ token1: [ address: "0000457EACA7FBAA96DB4A8D506A0B69684F546166FBF3C55391B1461907EFA58EAF", reserve: reserves.token1 ], token2: [ address: "UCO", reserve: reserves.token2 ], lp_token: [ address: 0x0000D1B4A0597A033F7DD0C8CA274745F850A990725B7B73B5E8CEBC7C4F9EA82954, supply: State.get("lp_token_supply", 0) ], fee: State.get("lp_fee", 0.3), protocol_fee: State.get("protocol_fee", 0), stats: stats ] end fun get_final_amounts(user_amounts, reserves, token1_min_amount, token2_min_amount) do final_token1_amount = 0 final_token2_amount = 0 if reserves.token1 > 0 && reserves.token2 > 0 do token2_ratio = reserves.token2 / reserves.token1 token2_equivalent_amount = user_amounts.token1 * token2_ratio if token2_equivalent_amount <= user_amounts.token2 && token2_equivalent_amount >= token2_min_amount do final_token1_amount = user_amounts.token1 final_token2_amount = token2_equivalent_amount else token1_ratio = reserves.token1 / reserves.token2 token1_equivalent_amount = user_amounts.token2 * token1_ratio if token1_equivalent_amount <= user_amounts.token1 && token1_equivalent_amount >= token1_min_amount do final_token1_amount = token1_equivalent_amount final_token2_amount = user_amounts.token2 end end else # No reserve final_token1_amount = user_amounts.token1 final_token2_amount = user_amounts.token2 end [token1: final_token1_amount, token2: final_token2_amount] end fun get_user_transfers_amount(tx) do contract_address = 0x000090C5AFCC97C2357E964E3DDF5BE9948477F7C1DE2C633CDFC95B202970AEA036 token1_amount = 0 token2_amount = 0 transfers = Map.get(tx.token_transfers, contract_address, []) uco_amount = Map.get(tx.uco_transfers, contract_address) if uco_amount != nil do transfers = List.prepend(transfers, [token_address: "UCO", amount: uco_amount]) end if List.size(transfers) == 2 do for transfer in transfers do if transfer.token_address == "0000457EACA7FBAA96DB4A8D506A0B69684F546166FBF3C55391B1461907EFA58EAF" do token1_amount = transfer.amount end if transfer.token_address == "UCO" do token2_amount = transfer.amount end end end [token1: token1_amount, token2: token2_amount] end fun get_user_transfer(tx) do contract_address = 0x000090C5AFCC97C2357E964E3DDF5BE9948477F7C1DE2C633CDFC95B202970AEA036 token_transfer = nil transfers = Map.get(tx.token_transfers, contract_address, []) uco_amount = Map.get(tx.uco_transfers, contract_address) if uco_amount != nil do transfers = List.prepend(transfers, [token_address: "UCO", amount: uco_amount]) end transfer = List.at(transfers, 0) tokens = [ "0000457EACA7FBAA96DB4A8D506A0B69684F546166FBF3C55391B1461907EFA58EAF", "UCO" ] if List.size(transfers) == 1 && List.in?(tokens, transfer.token_address) do token_transfer = transfer end token_transfer end fun get_user_lp_amount(token_transfers) do lp_token = 0x0000D1B4A0597A033F7DD0C8CA274745F850A990725B7B73B5E8CEBC7C4F9EA82954 lp_amount = 0 transfers = Map.get(token_transfers, Chain.get_burn_address(), []) for transfer in transfers do if transfer.token_address == lp_token do lp_amount = transfer.amount end end lp_amount end fun get_pool_balances() do token2_balance = 0 if "UCO" == "UCO" do token2_balance = contract.balance.uco else token2_id = [token_address: "UCO", token_id: 0] token2_balance = Map.get(contract.balance.tokens, token2_id, 0) end token1_id = [token_address: "0000457EACA7FBAA96DB4A8D506A0B69684F546166FBF3C55391B1461907EFA58EAF", token_id: 0] [ token1: Map.get(contract.balance.tokens, token1_id, 0), token2: token2_balance ] end
Content (0 B)
{ "lp_fee": 0, "lp_token_supply": 55053.87142628, "protocol_fee": 0.3, "reserves": { "token1": 115.5297582, "token2": 26489631.53591514 }, "stats": { "token1_total_fee": 0.22957848, "token1_total_protocol_fee": 1.70202898, "token1_total_volume": 621.43182567, "token2_total_fee": 51672.1377832, "token2_total_protocol_fee": 313427.76857741, "token2_total_volume": 116959957.2576905 } }
-
Secret shared with 1 key
Encoded secret
653AD42CEC582B2546D8B3EDE90F9EEBC0279D01E64A14A16341A76EBFB4D44D48E094EC54932DBDFC4A27D7FDBB09FF647D8C700F30FBB36F623BD1
Authorized keys
- 000122A6CD9ED07E46835D6E88E5BD0BEE84C3F5E5DBF8E916AD9B2EC912C44AFEC2
Contract recipients (0)
Inputs (0)
Contract inputs (0)
Unspent outputs (2)
-
From 0000D363...54D4At 2025-02-02 20:14:19 UTCAmount 26,489,631.53591514 UCO
-
From 0000D363...54D4At 2025-02-02 20:14:19 UTCAmount 115.5297582 0000457E...8EAF
Previous public key
0001D7FD7C179DBC0F44548849102B8EBE0D6438F67C18C5EC79F32072CDA88AE485
Previous signature
EEF80089435BF77BA789313A240B41E01F317C0D90DEC259F83130590F2F1F2379A786C47CCDD3152A2810E14DD0730FEB53179C85861F8E6AC42A1C2915EE03
Origin signature
304402205F178C561E73F3436370AD5920CEE522A1D34EA1ABA1D24E54C2271572B1C1A2022011DB6DB63C5127AC99CC8270C251B93F4695419C26F6F0B7908AA5FA33019470
Proof of work
010204E9BB401A767B0C92D5DB139379AAB18E1B449B455F49E3A44F3466B2D38E59F0516B79493A528A95E5A74CF46F79CF12DEB73293458F6A4403D2B3E57D697347
Proof of integrity
00108958ED2A48436F9027A6A099B36D98A856D7C0EA21ED043E63FA33F5688611
Coordinator signature
C0CDE182AC6A77DE14256925741B35B9D6628E378E4D4CCAE4E86CFEB74D0EEAAF3595FC9884A7078A70AEE66662BB29A87832DFC1E467A33B1DBE0E0F518401
Validator #1 public key
000106C25CB6B500CD3CD63D2880094D6415DB22328D43ED2E6F1C031D6C9E115E39
Validator #1 signature
78B0400083CAC959B661A5E2D8A26F5A82C1D48730C5441820C9F7F00BAD59BAFCC18E06AB650C32802FA2C478FA8B10488C9423007EB5D92C4834836E6F0202
Validator #2 public key
0001A47FA8573AE1E7DFD48036DAE2006E1E6A857701F280A55503DA34C6F3BC7759
Validator #2 signature
E3FE849BA10FA0EC38AB4624000C82C159BA297ECE1B4572F712C0BED0C9AFBCFD94BDC6F30772BF149E85E939A5213B1E96B90E1F7BA21261A31A60001C6B0D
Validator #3 public key
0001B8800415E75326411D65020B8E3E306F22CB1D72BC5FF5929B3EB58CDA511327
Validator #3 signature
92CFDA058A968A5C9D1481AE8419FA2AA586E6224771B9E3091CCF2B72078BD83F35747C5B309BD937F9756C1B0AD392E94E90921895CCE95901B3CE2BBBCB0C
Validator #4 public key
000198B33BEE362805F9024BC5BAF348421DCDC0AAB02A54F314D58954A9C9A275FB
Validator #4 signature
80FB382663A8E78BABCF72B00B8DF41E596D98D856D8DD3B6199B7A63CFAF1FA7032A07C08D3EA8EFDF005A3056E060C1BEC62127927A3D0EAE77F030C91D50B
Validator #5 public key
0001A5F6705AFE5C9103B4BE3307F94B3EC386283B77ABAA1D39C423EA4D6597F989
Validator #5 signature
64AD0780A810D997B7C4E7A9ECD9CC59051656ED335767D8C74439C74BA133832D86328DAECB31BEDDC43D048A6254DD1066DC114AAFED7258585A4958308505
Validator #6 public key
0001B4A7BDFB0343701C295C7F6113D538EA90C5BF6246E954B942CE645C30D45BCA
Validator #6 signature
B70081EDE3A19013CF0810E976E83328A84C8B49FC652AB85DC14F0627BCA0D4E56710EA2CC31271BF9CF30766F0CAFE15CBFDB013C3D08DB48C399D72AB4304