This client enables to perform actions on Escrow contracts and obtain information from both the contracts and subgraph.
Internally, the SDK will use one network or another according to the network ID of the web3. To use this client, you need to create Web3 instance, and configure default account, as well as some middlewares.
- With Signer
from eth_typing import URI
from web3 import Web3
from web3.middleware import construct_sign_and_send_raw_middleware
from web3.providers.auto import load_provider_from_uri
from human_protocol_sdk.escrow import EscrowClient
def get_w3_with_priv_key(priv_key: str):
w3 = Web3(load_provider_from_uri(URI("http://localhost:8545")))
gas_payer = w3.eth.account.from_key(priv_key)
w3.eth.default_account = gas_payer.address
w3.middleware_onion.add(
construct_sign_and_send_raw_middleware(gas_payer),
"construct_sign_and_send_raw_middleware",
)
return (w3, gas_payer)
(w3, gas_payer) = get_w3_with_priv_key('YOUR_PRIVATE_KEY')
escrow_client = EscrowClient(w3)
- Without Signer (For read operations only)
from eth_typing import URI
from web3 import Web3
from web3.providers.auto import load_provider_from_uri
from human_protocol_sdk.escrow import EscrowClient
w3 = Web3(load_provider_from_uri(URI("http://localhost:8545")))
escrow_client = EscrowClient(w3)
Bases: object
Represents the result of an escrow cancellation transaction. Args:
tx_hash (str): The hash of the transaction that cancelled the escrow. amount_refunded (Any): The amount refunded during the escrow cancellation.
Bases: object
A class used to manage escrow on the HUMAN network.
Initializes a Escrow instance.
- Parameters:
web3 (
Web3
) – The Web3 object
Cancels the specified escrow, sends the balance to the canceler and selfdestructs the escrow contract.
- Parameters:
- escrow_address (
str
) – Address of the escrow to abort - tx_options (
Optional
[TxParams
]) – (Optional) Additional transaction parameters
- escrow_address (
- Return type:
None
- Returns: None
- Raises: EscrowClientError – If an error occurs while checking the parameters
- Example:
from eth_typing import URI from web3 import Web3 from web3.middleware import construct_sign_and_send_raw_middleware from web3.providers.auto import load_provider_from_uri from human_protocol_sdk.escrow import EscrowClient def get_w3_with_priv_key(priv_key: str): w3 = Web3(load_provider_from_uri(URI("http://localhost:8545"))) gas_payer = w3.eth.account.from_key(priv_key) w3.eth.default_account = gas_payer.address w3.middleware_onion.add( construct_sign_and_send_raw_middleware(gas_payer), "construct_sign_and_send_raw_middleware", ) return (w3, gas_payer) (w3, gas_payer) = get_w3_with_priv_key('YOUR_PRIVATE_KEY') escrow_client = EscrowClient(w3) escrow_client.abort("0x62dD51230A30401C455c8398d06F85e4EaB6309f")
Adds an array of addresses to the trusted handlers list.
- Parameters:
- escrow_address (
str
) – Address of the escrow - handlers (
List
[str
]) – Array of trusted handler addresses - tx_options (
Optional
[TxParams
]) – (Optional) Additional transaction parameters
- escrow_address (
- Return type:
None
- Returns: None
- Raises: EscrowClientError – If an error occurs while checking the parameters
- Example:
from eth_typing import URI from web3 import Web3 from web3.middleware import construct_sign_and_send_raw_middleware from web3.providers.auto import load_provider_from_uri from human_protocol_sdk.escrow import EscrowClient def get_w3_with_priv_key(priv_key: str): w3 = Web3(load_provider_from_uri(URI("http://localhost:8545"))) gas_payer = w3.eth.account.from_key(priv_key) w3.eth.default_account = gas_payer.address w3.middleware_onion.add( construct_sign_and_send_raw_middleware(gas_payer), "construct_sign_and_send_raw_middleware", ) return (w3, gas_payer) (w3, gas_payer) = get_w3_with_priv_key('YOUR_PRIVATE_KEY') escrow_client = EscrowClient(w3) trusted_handlers = [ '0xf39Fd6e51aad88F6F4ce6aB8827279cffFb92266', '0xf39Fd6e51aad88F6F4ce6aB8827279cffFb92266' ] escrow_client.add_trusted_handlers( "0x62dD51230A30401C455c8398d06F85e4EaB6309f", trusted_handlers )
bulk_payout(escrow_address, recipients, amounts, final_results_url, final_results_hash, txId, tx_options=None)
Pays out the amounts specified to the workers and sets the URL of the final results file.
- Parameters:
- escrow_address (
str
) – Address of the escrow - recipients (
List
[str
]) – Array of recipient addresses - amounts (
List
[Decimal
]) – Array of amounts the recipients will receive - final_results_url (
str
) – Final results file url - final_results_hash (
str
) – Final results file hash - txId (
Decimal
) – Serial number of the bulks - tx_options (
Optional
[TxParams
]) – (Optional) Additional transaction parameters
- escrow_address (
- Return type:
None
- Returns: None
- Raises: EscrowClientError – If an error occurs while checking the parameters
- Example:
from eth_typing import URI from web3 import Web3 from web3.middleware import construct_sign_and_send_raw_middleware from web3.providers.auto import load_provider_from_uri from human_protocol_sdk.escrow import EscrowClient def get_w3_with_priv_key(priv_key: str): w3 = Web3(load_provider_from_uri(URI("http://localhost:8545"))) gas_payer = w3.eth.account.from_key(priv_key) w3.eth.default_account = gas_payer.address w3.middleware_onion.add( construct_sign_and_send_raw_middleware(gas_payer), "construct_sign_and_send_raw_middleware", ) return (w3, gas_payer) (w3, gas_payer) = get_w3_with_priv_key('YOUR_PRIVATE_KEY') escrow_client = EscrowClient(w3) recipients = [ '0xf39Fd6e51aad88F6F4ce6aB8827279cffFb92266', '0xf39Fd6e51aad88F6F4ce6aB8827279cffFb92267' ] amounts = [ Web3.to_wei(5, 'ether'), Web3.to_wei(10, 'ether') ] results_url = 'http://localhost/results.json' results_hash = 'b5dad76bf6772c0f07fd5e048f6e75a5f86ee079' escrow_client.bulk_payout( "0x62dD51230A30401C455c8398d06F85e4EaB6309f", recipients, amounts, results_url, results_hash, 1 )
Cancels the specified escrow and sends the balance to the canceler.
- Parameters:
- escrow_address (
str
) – Address of the escrow to cancel - tx_options (
Optional
[TxParams
]) – (Optional) Additional transaction parameters
- escrow_address (
- Return type:
EscrowCancel
- Returns: EscrowCancel: An instance of the EscrowCancel class containing details of the cancellation transaction, including the transaction hash and the amount refunded.
- Raises:
- EscrowClientError – If an error occurs while checking the parameters
- EscrowClientError – If the transfer event associated with the cancellation is not found in the transaction logs
- Example:
from eth_typing import URI from web3 import Web3 from web3.middleware import construct_sign_and_send_raw_middleware from web3.providers.auto import load_provider_from_uri from human_protocol_sdk.escrow import EscrowClient def get_w3_with_priv_key(priv_key: str): w3 = Web3(load_provider_from_uri(URI("http://localhost:8545"))) gas_payer = w3.eth.account.from_key(priv_key) w3.eth.default_account = gas_payer.address w3.middleware_onion.add( construct_sign_and_send_raw_middleware(gas_payer), "construct_sign_and_send_raw_middleware", ) return (w3, gas_payer) (w3, gas_payer) = get_w3_with_priv_key('YOUR_PRIVATE_KEY') escrow_client = EscrowClient(w3) escrow_cancel_data = escrow_client.cancel( "0x62dD51230A30401C455c8398d06F85e4EaB6309f" )
Sets the status of an escrow to completed.
- Parameters:
- escrow_address (
str
) – Address of the escrow to complete - tx_options (
Optional
[TxParams
]) – (Optional) Additional transaction parameters
- escrow_address (
- Return type:
None
- Returns: None
- Raises: EscrowClientError – If an error occurs while checking the parameters
- Example:
from eth_typing import URI from web3 import Web3 from web3.middleware import construct_sign_and_send_raw_middleware from web3.providers.auto import load_provider_from_uri from human_protocol_sdk.escrow import EscrowClient def get_w3_with_priv_key(priv_key: str): w3 = Web3(load_provider_from_uri(URI("http://localhost:8545"))) gas_payer = w3.eth.account.from_key(priv_key) w3.eth.default_account = gas_payer.address w3.middleware_onion.add( construct_sign_and_send_raw_middleware(gas_payer), "construct_sign_and_send_raw_middleware", ) return (w3, gas_payer) (w3, gas_payer) = get_w3_with_priv_key('YOUR_PRIVATE_KEY') escrow_client = EscrowClient(w3) escrow_client.complete("0x62dD51230A30401C455c8398d06F85e4EaB6309f")
Creates and sets up an escrow.
- Parameters:
- token_address (
str
) – Token to use for pay outs - trusted_handlers (
List
[str
]) – Array of addresses that can perform actions on the contract - job_requester_id (
str
) – The id of the job requester - escrow_config (
EscrowConfig
) – Object containing all the necessary information to setup an escrow
- token_address (
- Return type:
str
- Returns: The address of the escrow created
- Raises: EscrowClientError – If an error occurs while checking the parameters
- Example:
from eth_typing import URI from web3 import Web3 from web3.middleware import construct_sign_and_send_raw_middleware from web3.providers.auto import load_provider_from_uri from human_protocol_sdk.escrow import EscrowClient def get_w3_with_priv_key(priv_key: str): w3 = Web3(load_provider_from_uri(URI("http://localhost:8545"))) gas_payer = w3.eth.account.from_key(priv_key) w3.eth.default_account = gas_payer.address w3.middleware_onion.add( construct_sign_and_send_raw_middleware(gas_payer), "construct_sign_and_send_raw_middleware", ) return (w3, gas_payer) (w3, gas_payer) = get_w3_with_priv_key('YOUR_PRIVATE_KEY') escrow_client = EscrowClient(w3) token_address = '0x0376D26246Eb35FF4F9924cF13E6C05fd0bD7Fb4' trusted_handlers = [ '0xf39Fd6e51aad88F6F4ce6aB8827279cffFb92266', '0xf39Fd6e51aad88F6F4ce6aB8827279cffFb92266' ] job_requester_id = 'job-requester' escrow_config = EscrowConfig( "0xf39Fd6e51aad88F6F4ce6aB8827279cffFb92266", "0xf39Fd6e51aad88F6F4ce6aB8827279cffFb92266", "0xf39Fd6e51aad88F6F4ce6aB8827279cffFb92266", 10, 10, 10, "htttp://localhost/manifest.json", "b5dad76bf6772c0f07fd5e048f6e75a5f86ee079", ) escrow_address = escrow_client.create_and_setup_escrow( token_address, trusted_handlers, job_requester_id, escrow_config )
Creates an escrow contract that uses the token passed to pay oracle fees and reward workers.
- Parameters:
- tokenAddress – The address of the token to use for payouts
- trusted_handlers (
List
[str
]) – Array of addresses that can perform actions on the contract - job_requester_id (
str
) – The id of the job requester - tx_options (
Optional
[TxParams
]) – (Optional) Additional transaction parameters
- Return type:
str
- Returns: The address of the escrow created
- Raises: EscrowClientError – If an error occurs while checking the parameters
- Example:
from eth_typing import URI from web3 import Web3 from web3.middleware import construct_sign_and_send_raw_middleware from web3.providers.auto import load_provider_from_uri from human_protocol_sdk.escrow import EscrowClient def get_w3_with_priv_key(priv_key: str): w3 = Web3(load_provider_from_uri(URI("http://localhost:8545"))) gas_payer = w3.eth.account.from_key(priv_key) w3.eth.default_account = gas_payer.address w3.middleware_onion.add( construct_sign_and_send_raw_middleware(gas_payer), "construct_sign_and_send_raw_middleware", ) return (w3, gas_payer) (w3, gas_payer) = get_w3_with_priv_key('YOUR_PRIVATE_KEY') escrow_client = EscrowClient(w3) token_address = '0x0376D26246Eb35FF4F9924cF13E6C05fd0bD7Fb4' trusted_handlers = [ '0xf39Fd6e51aad88F6F4ce6aB8827279cffFb92266', '0xf39Fd6e51aad88F6F4ce6aB8827279cffFb92266' ] job_requester_id = 'job-requester' escrow_address = escrow_client.create_escrow( token_address, trusted_handlers, job_requester_id )
Adds funds to the escrow.
- Parameters:
- escrow_address (
str
) – Address of the escrow to setup - amount (
Decimal
) – Amount to be added as funds - tx_options (
Optional
[TxParams
]) – (Optional) Additional transaction parameters
- escrow_address (
- Return type:
None
- Returns: None
- Raises: EscrowClientError – If an error occurs while checking the parameters
- Example:
from eth_typing import URI from web3 import Web3 from web3.middleware import construct_sign_and_send_raw_middleware from web3.providers.auto import load_provider_from_uri from human_protocol_sdk.escrow import EscrowClient def get_w3_with_priv_key(priv_key: str): w3 = Web3(load_provider_from_uri(URI("http://localhost:8545"))) gas_payer = w3.eth.account.from_key(priv_key) w3.eth.default_account = gas_payer.address w3.middleware_onion.add( construct_sign_and_send_raw_middleware(gas_payer), "construct_sign_and_send_raw_middleware", ) return (w3, gas_payer) (w3, gas_payer) = get_w3_with_priv_key('YOUR_PRIVATE_KEY') escrow_client = EscrowClient(w3) amount = Web3.to_wei(5, 'ether') # convert from ETH to WEI escrow_client.fund("0x62dD51230A30401C455c8398d06F85e4EaB6309f", amount)
Gets the balance for a specified escrow address.
- Parameters:
escrow_address (
str
) – Address of the escrow - Return type:
Decimal
- Returns: Value of the balance
- Raises: EscrowClientError – If an error occurs while checking the parameters
- Example:
from eth_typing import URI from web3 import Web3 from web3.providers.auto import load_provider_from_uri from human_protocol_sdk.escrow import EscrowClient w3 = Web3(load_provider_from_uri(URI("http://localhost:8545"))) escrow_client = EscrowClient(w3) balance = escrow_client.get_balance( "0x62dD51230A30401C455c8398d06F85e4EaB6309f" )
Gets the exchange oracle address of the escrow.
- Parameters:
escrow_address (
str
) – Address of the escrow - Return type:
str
- Returns: Exchange oracle address
- Raises: EscrowClientError – If an error occurs while checking the parameters
- Example:
from eth_typing import URI from web3 import Web3 from web3.providers.auto import load_provider_from_uri from human_protocol_sdk.escrow import EscrowClient w3 = Web3(load_provider_from_uri(URI("http://localhost:8545"))) escrow_client = EscrowClient(w3) exchange_oracle = escrow_client.get_exchange_oracle_address( "0x62dD51230A30401C455c8398d06F85e4EaB6309f" )
Gets the escrow factory address of the escrow.
- Parameters:
escrow_address (
str
) – Address of the escrow - Return type:
str
- Returns: Escrow factory address
- Raises: EscrowClientError – If an error occurs while checking the parameters
- Example:
from eth_typing import URI from web3 import Web3 from web3.providers.auto import load_provider_from_uri from human_protocol_sdk.escrow import EscrowClient w3 = Web3(load_provider_from_uri(URI("http://localhost:8545"))) escrow_client = EscrowClient(w3) escrow_factory = escrow_client.get_factory_address( "0x62dD51230A30401C455c8398d06F85e4EaB6309f" )
Gets the intermediate results file URL.
- Parameters:
escrow_address (
str
) – Address of the escrow - Return type:
str
- Returns: Intermediate results file url
- Raises: EscrowClientError – If an error occurs while checking the parameters
- Example:
from eth_typing import URI from web3 import Web3 from web3.providers.auto import load_provider_from_uri from human_protocol_sdk.escrow import EscrowClient w3 = Web3(load_provider_from_uri(URI("http://localhost:8545"))) escrow_client = EscrowClient(w3) url = escrow_client.get_intermediate_results_url( "0x62dD51230A30401C455c8398d06F85e4EaB6309f" )
Gets the job launcher address of the escrow.
- Parameters:
escrow_address (
str
) – Address of the escrow - Return type:
str
- Returns: Job launcher address
- Raises: EscrowClientError – If an error occurs while checking the parameters
- Example:
from eth_typing import URI from web3 import Web3 from web3.providers.auto import load_provider_from_uri from human_protocol_sdk.escrow import EscrowClient w3 = Web3(load_provider_from_uri(URI("http://localhost:8545"))) escrow_client = EscrowClient(w3) job_launcher = escrow_client.get_job_launcher_address( "0x62dD51230A30401C455c8398d06F85e4EaB6309f" )
Gets the manifest file hash.
- Parameters:
escrow_address (
str
) – Address of the escrow - Return type:
str
- Returns: Manifest file hash
- Raises: EscrowClientError – If an error occurs while checking the parameters
- Example:
from eth_typing import URI from web3 import Web3 from web3.providers.auto import load_provider_from_uri from human_protocol_sdk.escrow import EscrowClient w3 = Web3(load_provider_from_uri(URI("http://localhost:8545"))) escrow_client = EscrowClient(w3) manifest_hash = escrow_client.get_manifest_hash( "0x62dD51230A30401C455c8398d06F85e4EaB6309f" )
Gets the manifest file URL.
- Parameters:
escrow_address (
str
) – Address of the escrow - Return str: Manifest file url
- Raises: EscrowClientError – If an error occurs while checking the parameters
- Example:
from eth_typing import URI from web3 import Web3 from web3.providers.auto import load_provider_from_uri from human_protocol_sdk.escrow import EscrowClient w3 = Web3(load_provider_from_uri(URI("http://localhost:8545"))) escrow_client = EscrowClient(w3) url = escrow_client.get_manifest_url( "0x62dD51230A30401C455c8398d06F85e4EaB6309f" )
- Return type:
str
Gets the recording oracle address of the escrow.
- Parameters:
escrow_address (
str
) – Address of the escrow - Return type:
str
- Returns: Recording oracle address
- Raises: EscrowClientError – If an error occurs while checking the parameters
- Example:
from eth_typing import URI from web3 import Web3 from web3.providers.auto import load_provider_from_uri from human_protocol_sdk.escrow import EscrowClient w3 = Web3(load_provider_from_uri(URI("http://localhost:8545"))) escrow_client = EscrowClient(w3) recording_oracle = escrow_client.get_recording_oracle_address( "0x62dD51230A30401C455c8398d06F85e4EaB6309f" )
Gets the reputation oracle address of the escrow.
- Parameters:
escrow_address (
str
) – Address of the escrow - Return type:
str
- Returns: Reputation oracle address
- Raises: EscrowClientError – If an error occurs while checking the parameters
- Example:
from eth_typing import URI from web3 import Web3 from web3.providers.auto import load_provider_from_uri from human_protocol_sdk.escrow import EscrowClient w3 = Web3(load_provider_from_uri(URI("http://localhost:8545"))) escrow_client = EscrowClient(w3) reputation_oracle = escrow_client.get_reputation_oracle_address( "0x62dD51230A30401C455c8398d06F85e4EaB6309f" )
Gets the results file URL.
- Parameters:
escrow_address (
str
) – Address of the escrow - Return type:
str
- Returns: Results file url
- Raises: EscrowClientError – If an error occurs while checking the parameters
- Example:
from eth_typing import URI from web3 import Web3 from web3.providers.auto import load_provider_from_uri from human_protocol_sdk.escrow import EscrowClient w3 = Web3(load_provider_from_uri(URI("http://localhost:8545"))) escrow_client = EscrowClient(w3) url = escrow_client.get_results_url( "0x62dD51230A30401C455c8398d06F85e4EaB6309f" )
Gets the current status of the escrow.
- Parameters:
escrow_address (
str
) – Address of the escrow - Return type:
Status
- Returns: Current escrow status
- Raises: EscrowClientError – If an error occurs while checking the parameters
- Example:
from eth_typing import URI from web3 import Web3 from web3.providers.auto import load_provider_from_uri from human_protocol_sdk.escrow import EscrowClient w3 = Web3(load_provider_from_uri(URI("http://localhost:8545"))) escrow_client = EscrowClient(w3) status = escrow_client.get_status( "0x62dD51230A30401C455c8398d06F85e4EaB6309f" )
Gets the address of the token used to fund the escrow.
- Parameters:
escrow_address (
str
) – Address of the escrow - Return type:
str
- Returns: Address of the token
- Raises: EscrowClientError – If an error occurs while checking the parameters
- Example:
from eth_typing import URI from web3 import Web3 from web3.providers.auto import load_provider_from_uri from human_protocol_sdk.escrow import EscrowClient w3 = Web3(load_provider_from_uri(URI("http://localhost:8545"))) escrow_client = EscrowClient(w3) token_address = escrow_client.get_token_address( "0x62dD51230A30401C455c8398d06F85e4EaB6309f" )
Sets up the parameters of the escrow.
- Parameters:
- escrow_address (
str
) – Address of the escrow to setup - escrow_config (
EscrowConfig
) – Object containing all the necessary information to setup an escrow - tx_options (
Optional
[TxParams
]) – (Optional) Additional transaction parameters
- escrow_address (
- Return type:
None
- Returns: None
- Raises: EscrowClientError – If an error occurs while checking the parameters
- Example:
from eth_typing import URI from web3 import Web3 from web3.middleware import construct_sign_and_send_raw_middleware from web3.providers.auto import load_provider_from_uri from human_protocol_sdk.escrow import EscrowClient def get_w3_with_priv_key(priv_key: str): w3 = Web3(load_provider_from_uri(URI("http://localhost:8545"))) gas_payer = w3.eth.account.from_key(priv_key) w3.eth.default_account = gas_payer.address w3.middleware_onion.add( construct_sign_and_send_raw_middleware(gas_payer), "construct_sign_and_send_raw_middleware", ) return (w3, gas_payer) (w3, gas_payer) = get_w3_with_priv_key('YOUR_PRIVATE_KEY') escrow_client = EscrowClient(w3) escrow_address = "0x62dD51230A30401C455c8398d06F85e4EaB6309f" escrow_config = EscrowConfig( "0xf39Fd6e51aad88F6F4ce6aB8827279cffFb92266", "0xf39Fd6e51aad88F6F4ce6aB8827279cffFb92266", "0xf39Fd6e51aad88F6F4ce6aB8827279cffFb92266", 10, 10, 10, "htttp://localhost/manifest.json", "b5dad76bf6772c0f07fd5e048f6e75a5f86ee079", ) escrow_client.setup(escrow_address, escrow_config)
Stores the results url.
- Parameters:
- escrow_address (
str
) – Address of the escrow - url (
str
) – Results file url - hash (
str
) – Results file hash - tx_options (
Optional
[TxParams
]) – (Optional) Additional transaction parameters
- escrow_address (
- Return type:
None
- Returns: None
- Raises: EscrowClientError – If an error occurs while checking the parameters
- Example:
from eth_typing import URI from web3 import Web3 from web3.middleware import construct_sign_and_send_raw_middleware from web3.providers.auto import load_provider_from_uri from human_protocol_sdk.escrow import EscrowClient def get_w3_with_priv_key(priv_key: str): w3 = Web3(load_provider_from_uri(URI("http://localhost:8545"))) gas_payer = w3.eth.account.from_key(priv_key) w3.eth.default_account = gas_payer.address w3.middleware_onion.add( construct_sign_and_send_raw_middleware(gas_payer), "construct_sign_and_send_raw_middleware", ) return (w3, gas_payer) (w3, gas_payer) = get_w3_with_priv_key('YOUR_PRIVATE_KEY') escrow_client = EscrowClient(w3) escrow_client.store_results( "0x62dD51230A30401C455c8398d06F85e4EaB6309f", "http://localhost/results.json", "b5dad76bf6772c0f07fd5e048f6e75a5f86ee079" )
Bases: Exception
Raises when some error happens when interacting with escrow.
class human_protocol_sdk.escrow.escrow_client.EscrowConfig(recording_oracle_address, reputation_oracle_address, exchange_oracle_address, recording_oracle_fee, reputation_oracle_fee, exchange_oracle_fee, manifest_url, hash)
Bases: object
A class used to manage escrow parameters.
__init__(recording_oracle_address, reputation_oracle_address, exchange_oracle_address, recording_oracle_fee, reputation_oracle_fee, exchange_oracle_fee, manifest_url, hash)
Initializes a Escrow instance.
- Parameters:
- recording_oracle_address (
str
) – Address of the Recording Oracle - reputation_oracle_address (
str
) – Address of the Reputation Oracle - recording_oracle_fee (
Decimal
) – Fee percentage of the Recording Oracle - reputation_oracle_fee (
Decimal
) – Fee percentage of the Reputation Oracle - manifest_url (
str
) – Manifest file url - hash (
str
) – Manifest file hash
- recording_oracle_address (