本文整理汇总了C#中NBitcoin.Transaction类的典型用法代码示例。如果您正苦于以下问题:C# Transaction类的具体用法?C# Transaction怎么用?C# Transaction使用的例子?那么, 这里精选的类代码示例或许可以为您提供帮助。
Transaction类属于NBitcoin命名空间,在下文中一共展示了Transaction类的15个代码示例,这些例子默认根据受欢迎程度排序。您可以为喜欢或者感觉有用的代码点赞,您的评价将有助于系统推荐出更棒的C#代码示例。
示例1: GetPayments
public static StealthPayment[] GetPayments(Transaction transaction, PubKey[] spendKeys, BitField bitField, Key scan)
{
List<StealthPayment> result = new List<StealthPayment>();
for(int i = 0 ; i < transaction.Outputs.Count ; i++)
{
var metadata = StealthMetadata.TryParse(transaction.Outputs[i].ScriptPubKey);
if(metadata != null && bitField.Match(metadata.BitField))
{
var payment = new StealthPayment(transaction.Outputs[i + 1].ScriptPubKey, metadata);
if(scan != null && spendKeys != null)
{
if(payment.StealthKeys.Length != spendKeys.Length)
continue;
var expectedStealth = spendKeys.Select(s => s.UncoverReceiver(scan, metadata.EphemKey)).ToList();
foreach(var stealth in payment.StealthKeys)
{
var match = expectedStealth.FirstOrDefault(expected => expected.ID == stealth.ID);
if(match != null)
expectedStealth.Remove(match);
}
if(expectedStealth.Count != 0)
continue;
}
result.Add(payment);
}
}
return result.ToArray();
}
示例2: Check
public bool Check(PubKey pubKey, Script scriptPubKey, Transaction tx, uint nIndex, ScriptVerify verify = ScriptVerify.Standard)
{
return new ScriptEvaluationContext()
{
ScriptVerify = verify,
SigHash = SigHash
}.CheckSig(this, pubKey, scriptPubKey, tx, nIndex);
}
示例3: AddFromTransaction
public void AddFromTransaction(Transaction transaction)
{
var hash = transaction.GetHash();
for(int i = 0 ; i < transaction.Outputs.Count; i++)
{
AddTxOut(new OutPoint(hash, i), transaction.Outputs[i]);
}
}
示例4: Coins
public Coins(Transaction tx, Func<TxOut, bool> belongsToCoins, int height)
{
if(belongsToCoins == null)
belongsToCoins = o => !o.ScriptPubKey.IsUnspendable;
fCoinBase = tx.IsCoinBase;
vout = tx.Outputs.ToList();
nVersion = tx.Version;
nHeight = (uint)height;
ClearUnused(belongsToCoins);
UpdateValue();
}
示例5: PutAsync
public Task PutAsync(uint256 txId, Transaction tx)
{
using(@lock.LockWrite())
{
if(!_Transactions.ContainsKey(txId))
_Transactions.AddOrReplace(txId, tx);
else
_Transactions[txId] = tx;
}
return _Inner.PutAsync(txId, tx);
}
示例6: Put
public static void Put(this ITransactionRepository repo, uint256 txId, Transaction tx)
{
try
{
repo.PutAsync(txId, tx).Wait();
}
catch(AggregateException aex)
{
ExceptionDispatchInfo.Capture(aex.InnerException).Throw();
}
}
示例7: SendTransaction
public static void SendTransaction(Transaction tx)
{
AddressManager nodeParams = new AddressManager();
IPEndPoint endPoint = TranslateHostNameToIP("http://btcnode.placefullcloud.com", 8333);
nodeParams.Add(new NetworkAddress(endPoint), endPoint.Address);
using (var node = Node.Connect(Network, nodeParams))
{
node.VersionHandshake();
node.SendMessage(new InvPayload(InventoryType.MSG_TX, tx.GetHash()));
node.SendMessage(new TxPayload(tx));
}
}
示例8: OnBroadcastTransaction
internal void OnBroadcastTransaction(Transaction transaction)
{
var hash = transaction.GetHash();
var nodes = Nodes
.Select(n => n.Key.Behaviors.Find<BroadcastHubBehavior>())
.Where(n => n != null)
.ToArray();
foreach(var node in nodes)
{
node.BroadcastTransactionCore(transaction);
}
}
示例9: CreateTransactionFeeCoin
static Coin CreateTransactionFeeCoin(PubKey destination, NoSqlTransactionRepository txRepo)
{
var bitcoinProviderTransaction = new Transaction()
{
Outputs =
{
new TxOut("0.0001" , destination)
}
};
txRepo.Put(bitcoinProviderTransaction.GetHash(), bitcoinProviderTransaction);
return new Coin(new OutPoint(bitcoinProviderTransaction, 0),
bitcoinProviderTransaction.Outputs[0]);
}
示例10: AreInputsStandard
//
// Check transaction inputs, and make sure any
// pay-to-script-hash transactions are evaluating IsStandard scripts
//
// Why bother? To avoid denial-of-service attacks; an attacker
// can submit a standard HASH... OP_EQUAL transaction,
// which will get accepted into blocks. The redemption
// script can be anything; an attacker could use a very
// expensive-to-check-upon-redemption script like:
// DUP CHECKSIG DROP ... repeated 100 times... OP_1
//
public static bool AreInputsStandard(Transaction tx, CoinsView coinsView)
{
if(tx.IsCoinBase)
return true; // Coinbases don't use vin normally
for(int i = 0 ; i < tx.Inputs.Count ; i++)
{
TxOut prev = coinsView.GetOutputFor(tx.Inputs[i]);
if(prev == null)
return false;
if(!IsStandardScriptSig(tx.Inputs[i].ScriptSig, prev.ScriptPubKey))
return false;
}
return true;
}
示例11: GetTrustedInput
public TrustedInput GetTrustedInput(Transaction transaction, int outputIndex)
{
using(Transport.Lock())
{
if(outputIndex >= transaction.Outputs.Count)
throw new ArgumentOutOfRangeException("outputIndex is bigger than the number of outputs in the transaction", "outputIndex");
MemoryStream data = new MemoryStream();
// Header
BufferUtils.WriteUint32BE(data, outputIndex);
BufferUtils.WriteBuffer(data, transaction.Version);
VarintUtils.write(data, transaction.Inputs.Count);
ExchangeApdu(LedgerWalletConstants.LedgerWallet_CLA, LedgerWalletConstants.LedgerWallet_INS_GET_TRUSTED_INPUT, (byte)0x00, (byte)0x00, data.ToArray(), OK);
// Each input
foreach(var input in transaction.Inputs)
{
data = new MemoryStream();
BufferUtils.WriteBuffer(data, input.PrevOut);
VarintUtils.write(data, input.ScriptSig.Length);
ExchangeApdu(LedgerWalletConstants.LedgerWallet_CLA, LedgerWalletConstants.LedgerWallet_INS_GET_TRUSTED_INPUT, (byte)0x80, (byte)0x00, data.ToArray(), OK);
data = new MemoryStream();
BufferUtils.WriteBuffer(data, input.ScriptSig.ToBytes());
ExchangeApduSplit2(LedgerWalletConstants.LedgerWallet_CLA, LedgerWalletConstants.LedgerWallet_INS_GET_TRUSTED_INPUT, (byte)0x80, (byte)0x00, data.ToArray(), Utils.ToBytes(input.Sequence, true), OK);
}
// Number of outputs
data = new MemoryStream();
VarintUtils.write(data, transaction.Outputs.Count);
ExchangeApdu(LedgerWalletConstants.LedgerWallet_CLA, LedgerWalletConstants.LedgerWallet_INS_GET_TRUSTED_INPUT, (byte)0x80, (byte)0x00, data.ToArray(), OK);
// Each output
foreach(var output in transaction.Outputs)
{
data = new MemoryStream();
BufferUtils.WriteBuffer(data, Utils.ToBytes((ulong)output.Value.Satoshi, true));
VarintUtils.write(data, output.ScriptPubKey.Length);
ExchangeApdu(LedgerWalletConstants.LedgerWallet_CLA, LedgerWalletConstants.LedgerWallet_INS_GET_TRUSTED_INPUT, (byte)0x80, (byte)0x00, data.ToArray(), OK);
data = new MemoryStream();
BufferUtils.WriteBuffer(data, output.ScriptPubKey.ToBytes());
ExchangeApduSplit(LedgerWalletConstants.LedgerWallet_CLA, LedgerWalletConstants.LedgerWallet_INS_GET_TRUSTED_INPUT, (byte)0x80, (byte)0x00, data.ToArray(), OK);
}
// Locktime
byte[] response = ExchangeApdu(LedgerWalletConstants.LedgerWallet_CLA, LedgerWalletConstants.LedgerWallet_INS_GET_TRUSTED_INPUT, (byte)0x80, (byte)0x00, transaction.LockTime.ToBytes(), OK);
return new TrustedInput(response);
}
}
示例12: PutAsync
public Task PutAsync(uint256 txId, Transaction tx)
{
if(WriteThrough)
{
using(@lock.LockWrite())
{
if(!_Transactions.ContainsKey(txId))
{
_Transactions.AddOrReplace(txId, tx);
EvictIfNecessary(txId);
}
else
_Transactions[txId] = tx;
}
}
return _Inner.PutAsync(txId, tx);
}
示例13: Submit
public static void Submit(Transaction tx)
{
//SOME TEST NET NODES
//54.149.133.4:18333
//52.69.206.155:18333
//93.114.160.222:18333
string url = "93.114.160.222:18333";
using(var node = NBitcoin.Protocol.Node.Connect(NBitcoin.Network.TestNet, url))
{
node.VersionHandshake();
//System.Threading.Thread.Sleep(1000);
NBitcoin.Transaction[] transactions = new Transaction[1];
transactions[0] = tx;
node.SendMessage(new NBitcoin.Protocol.InvPayload(transactions));
node.SendMessage(new NBitcoin.Protocol.TxPayload(tx));
}
}
示例14: GetAsync
public async Task<Transaction> GetAsync(uint256 txId)
{
while(true)
{
using(HttpClient client = new HttpClient())
{
var response = await client.GetAsync(BlockrAddress + "tx/raw/" + txId).ConfigureAwait(false);
if(response.StatusCode == HttpStatusCode.NotFound)
return null;
var result = await response.Content.ReadAsStringAsync().ConfigureAwait(false);
var json = JObject.Parse(result);
var status = json["status"];
var code = json["code"];
if(status != null && status.ToString() == "error")
{
throw new BlockrException(json);
}
var tx = new Transaction(json["data"]["tx"]["hex"].ToString());
return tx;
}
}
}
示例15: GetHexSignedTransaction
public static string GetHexSignedTransaction(TransactionToSign txToSign)
{
var walletPrivateKey = ConfigurationManager.AppSettings[METACO_ENV_WALLET_PRIVATE_KEY_HEX_NAME];
var key = new Key(Encoders.Hex.DecodeData(walletPrivateKey));
var scriptPubKey = PayToPubkeyHashTemplate.Instance.GenerateScriptPubKey(key.PubKey);
var tx = new Transaction(Encoders.Hex.DecodeData(txToSign.Raw));
foreach(var inputsToSign in txToSign.InputsToSign)
{
var sigHash = tx.GetSignatureHash(scriptPubKey, inputsToSign.Index);
var sig = key.Sign(sigHash);
var txSign = new TransactionSignature(sig, SigHash.All);
var inputScript = PayToPubkeyHashTemplate.Instance.GenerateScriptSig(txSign, key.PubKey);
tx.Inputs[inputsToSign.Index].ScriptSig = inputScript;
Assert.True(Script.VerifyScript(scriptPubKey, tx, inputsToSign.Index));
}
return tx.ToHex();
}