Skip to content

Commit

Permalink
Merge pull request #2 from cryptogarageinc/add-assetid-bitcoin-tx-add…
Browse files Browse the repository at this point in the history
…outdata

Utils: Add Asset parameter to MutateTxAddOutData
  • Loading branch information
instagibbs authored Nov 14, 2018
2 parents 078d20f + b985f31 commit 931196c
Showing 1 changed file with 36 additions and 16 deletions.
52 changes: 36 additions & 16 deletions src/bitcoin-tx.cpp
Original file line number Diff line number Diff line change
Expand Up @@ -395,27 +395,47 @@ static void MutateTxAddOutMultiSig(CMutableTransaction& tx, const std::string& s
static void MutateTxAddOutData(CMutableTransaction& tx, const std::string& strInput)
{
CAmount value = 0;

// separate [VALUE:]DATA[:ASSET] in string
std::vector<std::string> vStrInputParts;
boost::split(vStrInputParts, strInput, boost::is_any_of(":"));

// separate [VALUE:]DATA in string
size_t pos = strInput.find(':');

if (pos==0)
// Check that there are enough parameters
if (vStrInputParts[0].empty())
throw std::runtime_error("TX output value not specified");

if (pos != std::string::npos) {
// Extract and validate VALUE
value = ExtractAndValidateValue(strInput.substr(0, pos));
}

// extract and validate DATA
std::string strData = strInput.substr(pos + 1, std::string::npos);

if (!IsHex(strData))
throw std::runtime_error("invalid TX output data");
if (vStrInputParts.size()>3)
throw std::runtime_error("too many separators");

std::vector<unsigned char> data;
CAsset asset(Params().GetConsensus().pegged_asset);

if (vStrInputParts.size()==1) {
std::string strData = vStrInputParts[0];
if (!IsHex(strData))
throw std::runtime_error("invalid TX output data");
data = ParseHex(strData);

std::vector<unsigned char> data = ParseHex(strData);
} else {
value = ExtractAndValidateValue(vStrInputParts[0]);
std::string strData = vStrInputParts[1];
if (!IsHex(strData))
throw std::runtime_error("invalid TX output data");
data = ParseHex(strData);

if (vStrInputParts.size()==3) {
std::string strAsset = vStrInputParts[2];
if (!IsHex(strAsset))
throw std::runtime_error("invalid TX output asset type");

asset.SetHex(strAsset);
if (asset.IsNull()) {
throw std::runtime_error("invalid TX output asset type");
}
}
}

CTxOut txout(Params().GetConsensus().pegged_asset, value, CScript() << OP_RETURN << data);
CTxOut txout(asset, value, CScript() << OP_RETURN << data);
tx.vout.push_back(txout);
}

Expand Down

0 comments on commit 931196c

Please sign in to comment.