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


Python wallet.CBitcoinAddress方法代碼示例

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


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

示例1: getreceivedbyaddress

# 需要導入模塊: from bitcoin import wallet [as 別名]
# 或者: from bitcoin.wallet import CBitcoinAddress [as 別名]
def getreceivedbyaddress(self, addr, minconf=1):
        """Return total amount received by given a (wallet) address

        Get the amount received by <address> in transactions with at least
        [minconf] confirmations.

        Works only for addresses in the local wallet; other addresses will
        always show zero.

        addr    - The address. (CBitcoinAddress instance)

        minconf - Only include transactions confirmed at least this many times.
        (default=1)
        """
        r = self._call('getreceivedbyaddress', str(addr), minconf)
        return int(r * COIN) 
開發者ID:petertodd,項目名稱:checklocktimeverify-demos,代碼行數:18,代碼來源:rpc.py

示例2: listunspent

# 需要導入模塊: from bitcoin import wallet [as 別名]
# 或者: from bitcoin.wallet import CBitcoinAddress [as 別名]
def listunspent(self, minconf=0, maxconf=9999999, addrs=None):
        """Return unspent transaction outputs in wallet

        Outputs will have between minconf and maxconf (inclusive)
        confirmations, optionally filtered to only include txouts paid to
        addresses in addrs.
        """
        r = None
        if addrs is None:
            r = self._call('listunspent', minconf, maxconf)
        else:
            addrs = [str(addr) for addr in addrs]
            r = self._call('listunspent', minconf, maxconf, addrs)

        r2 = []
        for unspent in r:
            unspent['outpoint'] = COutPoint(lx(unspent['txid']), unspent['vout'])
            del unspent['txid']
            del unspent['vout']

            unspent['address'] = CBitcoinAddress(unspent['address'])
            unspent['scriptPubKey'] = CScript(unhexlify(unspent['scriptPubKey']))
            unspent['amount'] = int(unspent['amount'] * COIN)
            r2.append(unspent)
        return r2 
開發者ID:petertodd,項目名稱:checklocktimeverify-demos,代碼行數:27,代碼來源:rpc.py

示例3: getaccountaddress

# 需要導入模塊: from bitcoin import wallet [as 別名]
# 或者: from bitcoin.wallet import CBitcoinAddress [as 別名]
def getaccountaddress(self, account=None):
        """Return the current Bitcoin address for receiving payments to this
        account."""
        r = self._call('getaccountaddress', account)
        return CBitcoinAddress(r) 
開發者ID:petertodd,項目名稱:checklocktimeverify-demos,代碼行數:7,代碼來源:rpc.py

示例4: getnewaddress

# 需要導入模塊: from bitcoin import wallet [as 別名]
# 或者: from bitcoin.wallet import CBitcoinAddress [as 別名]
def getnewaddress(self, account=None):
        """Return a new Bitcoin address for receiving payments.

        If account is not None, it is added to the address book so payments
        received with the address will be credited to account.
        """
        r = None
        if account is not None:
            r = self._call('getnewaddress', account)
        else:
            r = self._call('getnewaddress')

        return CBitcoinAddress(r) 
開發者ID:petertodd,項目名稱:checklocktimeverify-demos,代碼行數:15,代碼來源:rpc.py

示例5: getrawchangeaddress

# 需要導入模塊: from bitcoin import wallet [as 別名]
# 或者: from bitcoin.wallet import CBitcoinAddress [as 別名]
def getrawchangeaddress(self):
        """Returns a new Bitcoin address, for receiving change.

        This is for use with raw transactions, NOT normal use.
        """
        r = self._call('getrawchangeaddress')
        return CBitcoinAddress(r) 
開發者ID:petertodd,項目名稱:checklocktimeverify-demos,代碼行數:9,代碼來源:rpc.py

示例6: validateaddress

# 需要導入模塊: from bitcoin import wallet [as 別名]
# 或者: from bitcoin.wallet import CBitcoinAddress [as 別名]
def validateaddress(self, address):
        """Return information about an address"""
        r = self._call('validateaddress', str(address))
        if r['isvalid']:
            r['address'] = CBitcoinAddress(r['address'])
        if 'pubkey' in r:
            r['pubkey'] = unhexlify(r['pubkey'])
        return r 
開發者ID:petertodd,項目名稱:checklocktimeverify-demos,代碼行數:10,代碼來源:rpc.py

示例7: create_transaction_output

# 需要導入模塊: from bitcoin import wallet [as 別名]
# 或者: from bitcoin.wallet import CBitcoinAddress [as 別名]
def create_transaction_output(address, output_value):
    """
    Create a single transaction output
    :param address:
    :param output_value:
    :return:
    """
    bitcoin_address = CBitcoinAddress(address)
    tx_out = CMutableTxOut(output_value, bitcoin_address.to_scriptPubKey())
    return tx_out 
開發者ID:blockchain-certificates,項目名稱:cert-issuer,代碼行數:12,代碼來源:tx_utils.py

示例8: spend_command

# 需要導入模塊: from bitcoin import wallet [as 別名]
# 或者: from bitcoin.wallet import CBitcoinAddress [as 別名]
def spend_command(args):
    args.addr = CBitcoinAddress(args.addr)

    redeemScript = hodl_redeemScript(args.privkey, args.nLockTime)
    scriptPubKey = redeemScript.to_p2sh_scriptPubKey()

    proxy = bitcoin.rpc.Proxy()

    prevouts = []
    for prevout in args.prevouts:
        try:
            txid,n = prevout.split(':')

            txid = lx(txid)
            n = int(n)

            outpoint = COutPoint(txid, n)
        except ValueError:
            args.parser.error('Invalid output: %s' % prevout)


        try:
            prevout = proxy.gettxout(outpoint)
        except IndexError:
            args.parser.error('Outpoint %s not found' % outpoint)

        prevout = prevout['txout']
        if prevout.scriptPubKey != scriptPubKey:
            args.parser.error('Outpoint not correct scriptPubKey')

        prevouts.append((outpoint, prevout))

    sum_in = sum(prev_txout.nValue for outpoint,prev_txout in prevouts)

    tx_size = (4                   + # version field
               2                   + # # of txins
               len(prevouts) * 153 + # txins, including sigs
               1                   + # # of txouts
               34                  + # txout
               4                     # nLockTime field
              )

    feerate = int(proxy._call('estimatefee', 1) * COIN) # satoshi's per KB
    if feerate <= 0:
        feerate = 10000
    fees = int(tx_size / 1000 * feerate)

    unsigned_tx = CTransaction([CTxIn(outpoint, nSequence=0) for outpoint, prevout in prevouts],
                               [CTxOut(sum_in - fees,
                                       args.addr.to_scriptPubKey())],
                               args.nLockTime)

    signed_tx = CTransaction(
        [CTxIn(txin.prevout,
               spend_hodl_redeemScript(args.privkey, args.nLockTime, unsigned_tx, i),
               nSequence=0)
            for i, txin in enumerate(unsigned_tx.vin)],
        unsigned_tx.vout,
        unsigned_tx.nLockTime)

    print(b2x(signed_tx.serialize())) 
開發者ID:petertodd,項目名稱:checklocktimeverify-demos,代碼行數:63,代碼來源:hodl.py

示例9: check_order_for_payment

# 需要導入模塊: from bitcoin import wallet [as 別名]
# 或者: from bitcoin.wallet import CBitcoinAddress [as 別名]
def check_order_for_payment(order_id, db, libbitcoin_client, notification_listener, testnet=False):
    try:
        if os.path.exists(os.path.join(DATA_FOLDER, "purchases", "unfunded", order_id + ".json")):
            file_path = os.path.join(DATA_FOLDER, "purchases", "unfunded", order_id + ".json")
            is_purchase = True
        elif os.path.exists(os.path.join(DATA_FOLDER, "store", "contracts", "unfunded", order_id + ".json")):
            file_path = os.path.join(DATA_FOLDER, "store", "contracts", "unfunded", order_id + ".json")
            is_purchase = False
        with open(file_path, 'r') as filename:
            order = json.load(filename, object_pairs_hook=OrderedDict)
        c = Contract(db, contract=order, testnet=testnet)
        c.blockchain = libbitcoin_client
        c.notification_listener = notification_listener
        c.is_purchase = is_purchase
        addr = c.contract["buyer_order"]["order"]["payment"]["address"]
        SelectParams("testnet" if testnet else "mainnet")
        script_pubkey = CBitcoinAddress(addr).to_scriptPubKey().encode("hex")

        def history_fetched(ec, history):
            if not ec:
                # pylint: disable=W0612
                # pylint: disable=W0640
                amount_funded = 0
                outpoints = []
                for objid, txhash, index, height, value in history:
                    amount_funded += value
                    o = {
                        "txid": txhash.encode("hex"),
                        "vout": index,
                        "value": value,
                        "scriptPubKey": script_pubkey
                    }
                    outpoints.append(o)

                # get the amount (in satoshi) the user is expected to pay
                amount_to_pay = int(float(c.contract["buyer_order"]["order"]["payment"]["amount"]) * 100000000)
                if amount_funded >= amount_to_pay:
                    c.outpoints = outpoints
                    c.payment_received()

        libbitcoin_client.fetch_history2(addr, history_fetched)
    except Exception:
        pass 
開發者ID:OpenBazaar,項目名稱:OpenBazaar-Server,代碼行數:45,代碼來源:contracts.py

示例10: do_mesh_sendtoaddress

# 需要導入模塊: from bitcoin import wallet [as 別名]
# 或者: from bitcoin.wallet import CBitcoinAddress [as 別名]
def do_mesh_sendtoaddress(self, rem) :
        """ 
        Create a signed transaction and broadcast it over the connected mesh device. The transaction 
        spends some amount of satoshis to the specified address from the local bitcoind wallet and selected network. 

        Usage: mesh_sendtoaddress ADDRESS SATS NETWORK(m|t)

        eg. txTenna> mesh_sendtoaddress 2N4BtwKZBU3kXkWT7ZBEcQLQ451AuDWiau2 13371337 t
        """
        try:

            proxy = bitcoin.rpc.Proxy()
            (addr, sats, network) = rem.split()

            # Create the txout. This time we create the scriptPubKey from a Bitcoin
            # address.
            txout = CMutableTxOut(sats, CBitcoinAddress(addr).to_scriptPubKey())

            # Create the unsigned transaction.
            unfunded_transaction = CMutableTransaction([], [txout])
            funded_transaction = proxy.fundrawtransaction(unfunded_transaction)
            signed_transaction = proxy.signrawtransaction(funded_transaction["tx"])
            txhex = b2x(signed_transaction["tx"].serialize())
            txid = b2lx(signed_transaction["tx"].GetTxid())
            print("sendtoaddress_mesh (tx, txid, network): " + txhex + ", " + txid, ", " + network)

            # broadcast over mesh
            self.do_mesh_broadcast_rawtx( txhex + " " + txid + " " + network)

        except Exception: # pylint: disable=broad-except
            traceback.print_exc()

        try :
            # lock UTXOs used to fund the tx if broadcast successful
            vin_outpoints = set()
            for txin in funded_transaction["tx"].vin:
                vin_outpoints.add(txin.prevout)
            ## json_outpoints = [{'txid':b2lx(outpoint.hash), 'vout':outpoint.n}
            ##              for outpoint in vin_outpoints]
            ## print(str(json_outpoints))
            proxy.lockunspent(False, vin_outpoints)
            
        except Exception: # pylint: disable=broad-except
            ## TODO: figure out why this is happening
            print("RPC timeout after calling lockunspent") 
開發者ID:remyers,項目名稱:txtenna-python,代碼行數:47,代碼來源:txtenna.py


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