@version 1 condition triggered_by: transaction, on: provision(_evm_contract, _endpoints, _signature, _evm_pool), as: [ previous_public_key: ( # 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) == 0x0000EC74226E85766FE5ADE9FFEA53D453F569799142F9FF248DCF532CEBFF4B3D32 ) ] actions triggered_by: transaction, on: provision(evm_contract, endpoints, signature, evm_pool) do endpoints = Json.to_string(endpoints) Contract.set_code """ @version 1 condition triggered_by: transaction, on: refund(), as: [ content: ( valid? = false abi_data = Evm.abi_encode("status()") tx = [to: "#{evm_contract}", data: "0x\#{abi_data}"] request = [jsonrpc: "2.0", id: "1", method: "eth_call", params: [tx, "latest"]] headers = ["Content-Type": "application/json"] body = Json.to_string(request) evm_responses = query_evm_apis(#{endpoints}, "POST", headers, body) for res in evm_responses do if !valid? && res.status == 200 && Json.is_valid?(res.body) do response = Json.parse(res.body) result = Map.get(response, "result") if result != nil do decoded_abi = Evm.abi_decode("(uint)", result) # Refund status is 2 valid? = List.at(decoded_abi, 0) == 2 end end end valid? ) ] actions triggered_by: transaction, on: refund() do Contract.set_type "transfer" # Burn the non withdrawed tokens Contract.add_token_transfer to: 0x00000000000000000000000000000000000000000000000000000000000000000000, amount: 0.1, token_address: 0x0000457EACA7FBAA96DB4A8D506A0B69684F546166FBF3C55391B1461907EFA58EAF Contract.set_code \""" @version 1 export fun info() do [ evm_contract: #{evm_contract}, evm_pool: #{evm_pool}, ae_pool: 0x0000EC74226E85766FE5ADE9FFEA53D453F569799142F9FF248DCF532CEBFF4B3D32, status: 2 # REFUNDED ] end \""" end condition triggered_by: transaction, on: reveal_secret(secret), as: [ content: Crypto.hash(String.to_hex(secret)) == 0x8C07A3097BCF68D996F00995DA2C7ED1396FC5807209D3C30132769BCB6DC6EE, address: ( valid? = false abi_data = Evm.abi_encode("status()") tx = [to: "#{evm_contract}", data: "0x\#{abi_data}"] request = [jsonrpc: "2.0", id: "1", method: "eth_call", params: [tx, "latest"]] headers = ["Content-Type": "application/json"] body = Json.to_string(request) responses = query_evm_apis(#{endpoints}, "POST", headers, body) for res in responses do if !valid? && res.status == 200 && Json.is_valid?(res.body) do response = Json.parse(res.body) result = Map.get(response, "result") if result != nil do decoded_abi = Evm.abi_decode("(uint)", result) # Withdrawn status is 1 valid? = List.at(decoded_abi, 0) == 1 end end end valid? ) ] actions triggered_by: transaction, on: reveal_secret(secret) do Contract.set_type "transfer" Contract.add_token_transfer to: 0x00001AB23786C12BAB4DA5AB19F34ECCC403D503B992B984C23EB6E20ED70E6F98E6, amount: 0.1, token_address: 0x0000457EACA7FBAA96DB4A8D506A0B69684F546166FBF3C55391B1461907EFA58EAF Contract.set_code \""" @version 1 export fun info() do [ evm_contract: #{evm_contract}, evm_pool: #{evm_pool}, ae_pool: 0x0000EC74226E85766FE5ADE9FFEA53D453F569799142F9FF248DCF532CEBFF4B3D32, status: 1 # WITHDRAWN ] end \""" end fun query_evm_apis(endpoints, method, headers, body) do requests = [] for endpoint in endpoints do requests = List.append(requests, url: endpoint, method: method, headers: headers, body: body) end Http.request_many(requests, false) end export fun get_provision_signature() do [ r: 0x#{signature.r}, s: 0x#{signature.s}, v: #{signature.v} ] end export fun info() do [ evm_contract: #{evm_contract}, evm_pool: #{evm_pool}, ae_pool: 0x0000EC74226E85766FE5ADE9FFEA53D453F569799142F9FF248DCF532CEBFF4B3D32, status: 0 # PENDING ] end """ end export fun info() do [ ae_pool: 0x0000EC74226E85766FE5ADE9FFEA53D453F569799142F9FF248DCF532CEBFF4B3D32, status: 0 # PENDING ] end
Content (0 B)
State (0 B)
-
Secret shared with 1 key
Encoded secret
CF4BEB0CFB07D2D8F34EA35525C8BC8A2B1366E3CE857C2D9AFCDB9F308A00DE65E8C276D98FC8B14CEEFEF98C12DDF4D4CF4485CC7D0B9816AF1ACE
Authorized keys
- 000122A6CD9ED07E46835D6E88E5BD0BEE84C3F5E5DBF8E916AD9B2EC912C44AFEC2
-
Resolved 0000EC74...3D32request_funds
[ 1743449280, 0.1, "00001ab23786c12bab4da5ab19f34eccc403d503b992b984c23eb6e20ed70e6f98e6", "8c07a3097bcf68d996f00995da2c7ed1396fc5807209d3c30132769bcb6dc6ee", "0x9ea7cd3ce866042d67c4ab77c7becbe008ddbc76ea0925745c54d8aa5b0ae5b3", "0x0CC472F10376933325A0F5EE2eC434Da229616E3", 137 ]
Inputs (0)
Contract inputs (0)
Unspent outputs (0)
Previous public key
0001AB7B143F084D2DE4C15D806C2EA3338F0AD9016D54619EF70A45A2B06FF90ACC
Previous signature
89C567C580BA588F667299B5C4486B2D366B2CB1BF5394EF913C207EF2F3664DF0D6FD48699E41D2762B149A0CD2C64FB222684DC63B75B77A46479B0E6BF108
Origin signature
304402202EA228BB559AEDCFDEA67EDC59EA16B7BC7335F103DBD15E020AD44D4D17C6F602202C9A246E9D7C8C412A216985A283ED12837E9D42C863C25937181501E4F90AD4
Proof of work
010104AB41291F847A601055AEDD1AF24FF76FA970D6441E2DCA3818A8319B004C96B27B8FEB1DA31A044BA0A4800B4353359735719EBB3A05F98393A9CC599C3FAFD6
Proof of integrity
004D99334614AA2A4FA64DC9F539BFC44F5A6B0FFEB76201C0A12660A928B3E683
Coordinator signature
DA8B88F8653A3EE48C6A94827A0D660D8D8078AF1B5E8F3A40DF884D00355908EBCDC05845895F972BB0748859C7260CA566CB00158DC35086247B02091ABC0A
Validator #1 public key
0001172FBEC021CA921A9A771C312FCAD74E84CF0A466F5F662630C70E7BD8699587
Validator #1 signature
F12C867C82710A1441D46F2948E685B556906D8F64D9481F014EAC110D18BEDE66E80D60715163EB636880121EA426EB1C308FC0F4BB2B8554AEC95400BED102
Validator #2 public key
0001E3ED277E4F00BBE1F2B7E7AECD69B6E29FC8801BB8BB91DD36DE2F110A6D092A
Validator #2 signature
DC1D6AF2206A3591113D8416AC4420606B5BA06D10F0E3BD60CA5C2EF9F5124DA1CA6E1D11441E3D461DFBA95151595A74AC0638F81F36666E25D07E9E251C02