@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) == 0x00002075E9FB5329C7F5149802EB75F925D79B5FEC5BFCF09DC81993CB9C39FEAF5D
)
]
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"
# Send back UCO to bridge pool
Contract.add_uco_transfer to: 0x00002075E9FB5329C7F5149802EB75F925D79B5FEC5BFCF09DC81993CB9C39FEAF5D, amount: 100
Contract.set_code \"""
@version 1
export fun info() do
[
evm_contract: #{evm_contract},
evm_pool: #{evm_pool},
ae_pool: 0x00002075E9FB5329C7F5149802EB75F925D79B5FEC5BFCF09DC81993CB9C39FEAF5D,
status: 2 # REFUNDED
]
end
\"""
end
condition triggered_by: transaction, on: reveal_secret(secret), as: [
content: Crypto.hash(String.to_hex(secret)) == 0xB3B03974347895A2EE2FE2804EE125BB303C2B4158B3CC2752F5FD8AB7836D44,
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_uco_transfer to: 0x0000E9F9DAF9D5892AA9FF6890A27B8A83E8D37FA466C4950C4A1802A439383E849E, amount: 100
Contract.set_code \"""
@version 1
export fun info() do
[
evm_contract: #{evm_contract},
evm_pool: #{evm_pool},
ae_pool: 0x00002075E9FB5329C7F5149802EB75F925D79B5FEC5BFCF09DC81993CB9C39FEAF5D,
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: 0x00002075E9FB5329C7F5149802EB75F925D79B5FEC5BFCF09DC81993CB9C39FEAF5D,
status: 0 # PENDING
]
end
"""
end
export fun info() do
[
ae_pool: 0x00002075E9FB5329C7F5149802EB75F925D79B5FEC5BFCF09DC81993CB9C39FEAF5D,
status: 0 # PENDING
]
end
Content (0 B)
State (0 B)
-
Secret shared with 1 key
Encoded secret
ADE4DE515B832D3DDAB8F02B5468872611434D46A95598359C15218B76D2742ABEB0C9FA30EAD1CB096E186ED963A2DAAF021373A7FF9B0992BC6F69
Authorized keys
- 000122A6CD9ED07E46835D6E88E5BD0BEE84C3F5E5DBF8E916AD9B2EC912C44AFEC2
-
Resolved 00002075...AF5Drequest_funds
[ 1743459840, 100, "0000e9f9daf9d5892aa9ff6890a27b8a83e8d37fa466c4950c4a1802a439383e849e", "b3b03974347895a2ee2fe2804ee125bb303c2b4158b3cc2752f5fd8ab7836d44", "0xa16327e81b27ca6a900176a3df04bd4d96ad0db3d849816f9c9c3c68866118de", "0xf47809579603370bAC40EE60D7d55B60D3D0dFBb", 137 ]
Inputs (0)
Contract inputs (0)
Unspent outputs (0)
Previous public key
000137E3E870E48FFAAE10373B7C345F575F140900403301AA4C6E5BB2710514C5FC
Previous signature
480A36E4EEE608DAFC279A66D885A99EB96D39331D8433D82764C85431B8AC86ABE0148891FEF773281054F0F14D613A26FD185CFFD2DE84CED6CC2CAF394A08
Origin signature
3045022100F1F45A8BBED1C50E06D23DC77567E7BE6AE5ED2574201AC73802C3651F35879102205F55BA8740AB3BC19562342F924BD344021BB7E7DFD3CCFB205720032AD61472
Proof of work
010104AB41291F847A601055AEDD1AF24FF76FA970D6441E2DCA3818A8319B004C96B27B8FEB1DA31A044BA0A4800B4353359735719EBB3A05F98393A9CC599C3FAFD6
Proof of integrity
0070F39161FFC390429D200EE257AF13FB295EDF155F5449601B5D6C395E20B051
Coordinator signature
3CF4D8EEDEC868AA52D08D24A17A4EA031E05B32FECD9B361D63427BE24B2CD55C180306227271818A19BF7D92DB47BC011EE5BCF37FCE01D463D8C22CA1140A
Validator #1 public key
00011518CD02E2B0009F828843512538A3F44A9CB493EB5E288376E4E45AD727AB3E
Validator #1 signature
8EB683B898DFC5E42A6AE3FFC8E25796EBEF4C68B9D865B85D9CFC2B4DB3E774EFF3DFE445CCF0F501B3D6B8CEAF451DEAC3CB9CA378F819F41F3F4931F67B08
Validator #2 public key
000105B4FDF46B9FE90C30A471DCE4D296CCCDC27242C6CDA6E48622F4330C646100
Validator #2 signature
E04B09808DCE2BFC655B8AB64453064540B110BF542EAA8C4CE00E2ED4908F0A5CADEBC61656AD1D24514103FC72CC57C491DCC6D482E31669356D2BA328D50E