本文整理匯總了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)
示例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
示例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)
示例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)
示例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)
示例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
示例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
示例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()))
示例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
示例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")