當前位置: 首頁>>代碼示例>>Python>>正文


Python eth_utils.encode_hex方法代碼示例

本文整理匯總了Python中eth_utils.encode_hex方法的典型用法代碼示例。如果您正苦於以下問題:Python eth_utils.encode_hex方法的具體用法?Python eth_utils.encode_hex怎麽用?Python eth_utils.encode_hex使用的例子?那麽, 這裏精選的方法代碼示例或許可以為您提供幫助。您也可以進一步了解該方法所在eth_utils的用法示例。


在下文中一共展示了eth_utils.encode_hex方法的15個代碼示例,這些例子默認根據受歡迎程度排序。您可以為喜歡或者感覺有用的代碼點讚,您的評價將有助於係統推薦出更棒的Python代碼示例。

示例1: main

# 需要導入模塊: import eth_utils [as 別名]
# 或者: from eth_utils import encode_hex [as 別名]
def main(rpc_url: URI, private_key: Path, token_address: ChecksumAddress, amount: int) -> None:
    web3 = Web3(HTTPProvider(rpc_url))
    privkey = get_private_key(private_key)
    assert privkey is not None
    owner = private_key_to_address(privkey)
    web3.middleware_onion.add(construct_sign_and_send_raw_middleware(privkey))
    token_code = web3.eth.getCode(token_address, "latest")
    assert token_code != HexBytes("")
    token_contract = ContractManager(contracts_precompiled_path()).get_contract(
        CONTRACT_CUSTOM_TOKEN
    )
    token_proxy = web3.eth.contract(address=token_address, abi=token_contract["abi"])
    tx_hash = token_proxy.functions.mint(amount).transact({"from": owner})
    print(f"Minting tokens for address {owner}")
    print(f"Transaction hash {encode_hex(tx_hash)}")
    balance = token_proxy.functions.balanceOf(owner).call()
    print(f"Balance of {owner}: {balance}") 
開發者ID:raiden-network,項目名稱:raiden-contracts,代碼行數:19,代碼來源:mint_tokens.py

示例2: package

# 需要導入模塊: import eth_utils [as 別名]
# 或者: from eth_utils import encode_hex [as 別名]
def package(self, eth_address):
        try:
            try: 
                package = self.functions.packages(eth_address).call()
            except NameNotFound:
                # try tacking an .eth on to the address
                package = self.functions.packages(eth_address + '.eth').call()
        
            uri = package[1]
            checksum = encode_hex(package[0])
        except (ValidationError, NameNotFound):
            raise DappNotFound

        if uri == '' or checksum == '0000000000000000000000000000000000000000000000000000000000000000':
            raise DappNotFound

        return uri, checksum.replace('0x','') 
開發者ID:kayagoban,項目名稱:shadowlands,代碼行數:19,代碼來源:sloader.py

示例3: upsert_channel

# 需要導入模塊: import eth_utils [as 別名]
# 或者: from eth_utils import encode_hex [as 別名]
def upsert_channel(self, channel: Channel) -> None:
        values = [
            to_checksum_address(channel.token_network_address),
            hex256(channel.identifier),
            to_checksum_address(channel.participant1),
            to_checksum_address(channel.participant2),
            hex256(channel.settle_timeout),
            channel.state,
            hex256(channel.closing_block) if channel.closing_block else None,
            channel.closing_participant,
            encode_hex(channel.monitor_tx_hash) if channel.monitor_tx_hash else None,
            encode_hex(channel.claim_tx_hash) if channel.claim_tx_hash else None,
        ]
        if channel.update_status:
            values += [
                to_checksum_address(channel.update_status.update_sender_address),
                hex256(channel.update_status.nonce),
            ]
        else:
            values += [None, None]

        upsert_sql = "INSERT OR REPLACE INTO channel VALUES ({})".format(
            ", ".join("?" * len(values))
        )
        self.conn.execute(upsert_sql, values) 
開發者ID:raiden-network,項目名稱:raiden-services,代碼行數:27,代碼來源:database.py

示例4: request_monitoring_message

# 需要導入模塊: import eth_utils [as 別名]
# 或者: from eth_utils import encode_hex [as 別名]
def request_monitoring_message(token_network, get_accounts, get_private_key) -> RequestMonitoring:
    c1, c2 = get_accounts(2)

    balance_proof_c2 = HashedBalanceProof(
        channel_identifier=ChannelID(1),
        token_network_address=TokenNetworkAddress(to_canonical_address(token_network.address)),
        chain_id=ChainID(61),
        nonce=Nonce(2),
        additional_hash="0x%064x" % 0,
        transferred_amount=TokenAmount(1),
        locked_amount=TokenAmount(0),
        locksroot=encode_hex(LOCKSROOT_OF_NO_LOCKS),
        priv_key=get_private_key(c2),
    )

    return balance_proof_c2.get_request_monitoring(
        privkey=get_private_key(c1),
        reward_amount=TokenAmount(1),
        monitoring_service_contract_address=MonitoringServiceAddress(bytes([11] * 20)),
    ) 
開發者ID:raiden-network,項目名稱:raiden-services,代碼行數:22,代碼來源:test_matrix.py

示例5: _generate_protocol_info

# 需要導入模塊: import eth_utils [as 別名]
# 或者: from eth_utils import encode_hex [as 別名]
def _generate_protocol_info(
            self,
            protocols: Capabilities) -> Dict[str, RpcProtocolResponse]:

        head = await self.chain.coro_get_canonical_head()
        total_difficulty = await self.chain.coro_get_score(head.hash)
        genesis_header = await self.chain.coro_get_canonical_block_header_by_number(
            BlockNumber(GENESIS_BLOCK_NUMBER)
        )
        chain_config = self.trinity_config.get_app_config(Eth1AppConfig).get_chain_config()

        return {
            protocol: {
                'version': f'{protocol}/{version}',
                'difficulty': total_difficulty,
                'genesis': encode_hex(genesis_header.hash),
                'head': encode_hex(head.hash),
                'network': self.trinity_config.network_id,
                'config': generate_chain_config(chain_config)
            }
            for protocol, version in protocols
        } 
開發者ID:ethereum,項目名稱:trinity,代碼行數:24,代碼來源:admin.py

示例6: validate_base_receipt

# 需要導入模塊: import eth_utils [as 別名]
# 或者: from eth_utils import encode_hex [as 別名]
def validate_base_receipt(remote: NodeAPI,
                          receipt: Union[ETHV63HandshakeReceipt, ETHHandshakeReceipt],
                          handshake_params: Union[StatusV63Payload, StatusPayload]) -> None:
    if receipt.handshake_params.network_id != handshake_params.network_id:
        raise WrongNetworkFailure(
            f"{remote} network "
            f"({receipt.handshake_params.network_id}) does not match ours "
            f"({handshake_params.network_id}), disconnecting"
        )

    if receipt.handshake_params.genesis_hash != handshake_params.genesis_hash:
        raise WrongGenesisFailure(
            f"{remote} genesis "
            f"({encode_hex(receipt.handshake_params.genesis_hash)}) does "
            f"not match ours ({encode_hex(handshake_params.genesis_hash)}), "
            f"disconnecting"
        ) 
開發者ID:ethereum,項目名稱:trinity,代碼行數:19,代碼來源:handshaker.py

示例7: get_beacon_shell_context

# 需要導入模塊: import eth_utils [as 別名]
# 或者: from eth_utils import encode_hex [as 別名]
def get_beacon_shell_context(database_dir: Path,
                             trinity_config: TrinityConfig) -> Iterator[Dict[str, Any]]:
    app_config = trinity_config.get_app_config(BeaconAppConfig)
    ipc_path = trinity_config.database_ipc_path
    trinity_already_running = ipc_path.exists()

    with _get_base_db(database_dir, ipc_path) as db:
        chain_config = app_config.get_chain_config()
        chaindb = BeaconChainDB(db)
        chain = chain_config.beacon_chain_class(
            chaindb,
        )

        head = chaindb.get_canonical_head(BeaconBlock)
        yield {
            'db': db,
            'chaindb': chaindb,
            'trinity_config': trinity_config,
            'chain_config': chain_config,
            'chain': chain,
            'block_number': head.slot,
            'hex_hash': head.hash_tree_root.hex(),
            'state_root_hex': encode_hex(head.state_root),
            'trinity_already_running': trinity_already_running
        } 
開發者ID:ethereum,項目名稱:trinity,代碼行數:27,代碼來源:console.py

示例8: _get_attestation_from_beacon_node

# 需要導入模塊: import eth_utils [as 別名]
# 或者: from eth_utils import encode_hex [as 別名]
def _get_attestation_from_beacon_node(
    session: Session,
    url: str,
    public_key: BLSPubkey,
    slot: Slot,
    committee_index: CommitteeIndex,
) -> Optional[Attestation]:
    attestation_response = await _get_json(
        session,
        url,
        {
            "validator_pubkey": encode_hex(public_key),
            "slot": slot,
            "committee_index": committee_index,
        },
    )
    try:
        return from_formatted_dict(attestation_response, Attestation)
    except Exception as e:
        logger.exception(e)
        return None 
開發者ID:ethereum,項目名稱:trinity,代碼行數:23,代碼來源:beacon_node.py

示例9: update_genesis_config_with_time

# 需要導入模塊: import eth_utils [as 別名]
# 或者: from eth_utils import encode_hex [as 別名]
def update_genesis_config_with_time(
    config: Dict[str, Any], genesis_time: Timestamp
) -> Dict[str, Any]:
    config_profile = config["profile"]
    eth2_config = _get_eth2_config(config_profile)
    override_lengths(eth2_config)

    existing_state = from_formatted_dict(config["genesis_state"], BeaconState)

    genesis_state = existing_state.set("genesis_time", genesis_time)

    updates = {
        "genesis_state_root": encode_hex(genesis_state.hash_tree_root),
        "genesis_state": to_formatted_dict(genesis_state),
    }
    return {**config, **updates} 
開發者ID:ethereum,項目名稱:trinity,代碼行數:18,代碼來源:genesis.py

示例10: validate_deposit_proof

# 需要導入模塊: import eth_utils [as 別名]
# 或者: from eth_utils import encode_hex [as 別名]
def validate_deposit_proof(
    state: BeaconState, deposit: Deposit, deposit_contract_tree_depth: int
) -> None:
    """
    Validate if deposit branch proof is valid.
    """
    is_valid_proof = verify_merkle_branch(
        leaf=deposit.data.hash_tree_root,
        proof=deposit.proof,
        depth=deposit_contract_tree_depth + 1,
        index=state.eth1_deposit_index,
        root=state.eth1_data.deposit_root,
    )
    if not is_valid_proof:
        raise ValidationError(
            f"deposit.proof ({list(map(encode_hex, deposit.proof))}) is invalid against "
            f"leaf={encode_hex(deposit.data.hash_tree_root)}, "
            f"deposit_contract_tree_depth={deposit_contract_tree_depth}, "
            f"deposit.index (via state) = {state.eth1_deposit_index} "
            f"state.eth1_data.deposit_root={state.eth1_data.deposit_root.hex()}"
        ) 
開發者ID:ethereum,項目名稱:trinity,代碼行數:23,代碼來源:deposit_helpers.py

示例11: _get_state_by_root

# 需要導入模塊: import eth_utils [as 別名]
# 或者: from eth_utils import encode_hex [as 別名]
def _get_state_by_root(
        db: DatabaseAPI, state_root: Hash32, state_class: Type[BeaconState]
    ) -> BeaconState:
        """
        Return the requested beacon state as specified by state hash.

        Raises StateNotFound if it is not present in the db.
        """
        # TODO: validate_state_root
        if state_root in state_cache and state_root in db:
            return state_cache[state_root]

        try:
            state_ssz = db[state_root]
        except KeyError:
            raise StateNotFound(f"No state with root {encode_hex(state_root)} found")

        state = ssz.decode(state_ssz, state_class)
        state_cache[state] = state
        return state 
開發者ID:ethereum,項目名稱:trinity,代碼行數:22,代碼來源:chain.py

示例12: cmd

# 需要導入模塊: import eth_utils [as 別名]
# 或者: from eth_utils import encode_hex [as 別名]
def cmd(self) -> str:
        _cmds = [
            "trinity-beacon",
            f"--port={self.port}",
            f"--trinity-root-dir={self.root_dir}",
            f"--beacon-nodekey={remove_0x_prefix(encode_hex(self.node_privkey.to_bytes()))}",
            f"--preferred_nodes={','.join(str(node.maddr) for node in self.preferred_nodes)}",
            f"--http-port={self.http_port}",
            "--enable-http",
            "--enable-metrics",
            "--enable-api",
            f"--api-port={self.api_port}",
            f"--metrics-port={self.metrics_port}",
            "--disable-discovery",
            "-l debug",
            "interop",
            f"--validators={','.join(str(v) for v in self.validators)}",
            f"--start-time={self.start_time}",
            "--wipedb",
        ]
        _cmd = " ".join(_cmds)
        return _cmd 
開發者ID:ethereum,項目名稱:trinity,代碼行數:24,代碼來源:run_beacon_nodes.py

示例13: decode_int

# 需要導入模塊: import eth_utils [as 別名]
# 或者: from eth_utils import encode_hex [as 別名]
def decode_int(s):
    return int(encode_hex(s[::-1]), 16) if s else 0 
開發者ID:QuarkChain,項目名稱:pyquarkchain,代碼行數:4,代碼來源:ethash_utils.py

示例14: test_ecdh

# 需要導入模塊: import eth_utils [as 別名]
# 或者: from eth_utils import encode_hex [as 別名]
def test_ecdh(privkey_hex, pubkey_hex, ecdh_expected):
    privkey = keys.PrivateKey(decode_hex(privkey_hex))
    pubkey = keys.PublicKey(decode_hex(pubkey_hex))
    assert ecdh_expected == encode_hex(ecies.ecdh_agree(privkey, pubkey))


# FIXME: Document those values; this test was lifted from pydevp2p:
# https://github.com/ethereum/pydevp2p/blob/e1ef07a782b9369d18a8441c3b9bcf12456e0608/devp2p/tests/test_ecies.py#L31 
開發者ID:QuarkChain,項目名稱:pyquarkchain,代碼行數:10,代碼來源:test_ecies.py

示例15: default

# 需要導入模塊: import eth_utils [as 別名]
# 或者: from eth_utils import encode_hex [as 別名]
def default(self, obj):
        if isinstance(obj, HexBytes):
            return obj.hex()
        elif isinstance(obj, AttributeDict):
            return dict(obj)
        elif isinstance(obj, bytes):
            return encode_hex(obj)
        return super().default(obj) 
開發者ID:artemistomaras,項目名稱:django-ethereum-events,代碼行數:10,代碼來源:utils.py


注:本文中的eth_utils.encode_hex方法示例由純淨天空整理自Github/MSDocs等開源代碼及文檔管理平台,相關代碼片段篩選自各路編程大神貢獻的開源項目,源碼版權歸原作者所有,傳播和使用請參考對應項目的License;未經允許,請勿轉載。