本文整理汇总了C++中accountframe::pointer::getIsNew方法的典型用法代码示例。如果您正苦于以下问题:C++ pointer::getIsNew方法的具体用法?C++ pointer::getIsNew怎么用?C++ pointer::getIsNew使用的例子?那么, 这里精选的方法代码示例或许可以为您提供帮助。您也可以进一步了解该方法所在类accountframe::pointer
的用法示例。
在下文中一共展示了pointer::getIsNew方法的1个代码示例,这些例子默认根据受欢迎程度排序。您可以为喜欢或者感觉有用的代码点赞,您的评价将有助于系统推荐出更棒的C++代码示例。
示例1: getCachedEntry
AccountFrame::pointer
AccountFrame::loadAccount(AccountID const& accountID, Database& db)
{
LedgerKey key;
uint32_t sqlIsNew;
key.type(ACCOUNT);
key.account().accountID = accountID;
if (cachedEntryExists(key, db))
{
auto p = getCachedEntry(key, db);
return p ? std::make_shared<AccountFrame>(*p) : nullptr;
}
std::string actIDStrKey = PubKeyUtils::toStrKey(accountID);
std::string publicKey, inflationDest, creditAuthKey;
std::string homeDomain, thresholds;
soci::indicator inflationDestInd;
AccountFrame::pointer res = make_shared<AccountFrame>(accountID);
AccountEntry& account = res->getAccount();
CLOG(INFO, "Database") << "BEFORE getisnew is: " << res->getIsNew();
auto prep =
db.getPreparedStatement("SELECT "
"balance, seqnum, numsubentries, inflationdest, homedomain, thresholds, flags,lastmodified, 0 as isnew "
"FROM accounts WHERE accountid=:v1 "
"UNION SELECT "
"0 as balance, 0 as seqnum, 0 as numsubentries, null as inflationdest, '' as homedomain,'AQAAAA==' as thresholds,0 as flags,0 as lastmodified, 1 as isnew "
"WHERE NOT EXISTS (SELECT * FROM accounts WHERE accountid=:v1)");
auto& st = prep.statement();
st.exchange(into(account.balance));
st.exchange(into(account.seqNum));
st.exchange(into(account.numSubEntries));
st.exchange(into(inflationDest, inflationDestInd));
st.exchange(into(homeDomain));
st.exchange(into(thresholds));
st.exchange(into(account.flags));
st.exchange(into(res->getLastModified()));
st.exchange(into(sqlIsNew));
st.exchange(use(actIDStrKey, "v1"));
st.define_and_bind();
{
auto timer = db.getSelectTimer("account");
st.execute(true);
}
if (!st.got_data())
{
putCachedEntry(key, nullptr, db);
return nullptr;
}
if (sqlIsNew == 1) {
res->setIsNew();
}
CLOG(INFO, "Database") << actIDStrKey <<" sqlisnew is: " << sqlIsNew;
CLOG(INFO, "Database") << actIDStrKey <<" isnew is: " << res->isnew;
account.homeDomain = homeDomain;
bn::decode_b64(thresholds.begin(), thresholds.end(),
res->mAccountEntry.thresholds.begin());
if (inflationDestInd == soci::i_ok)
{
account.inflationDest.activate() =
PubKeyUtils::fromStrKey(inflationDest);
}
account.signers.clear();
if (account.numSubEntries != 0)
{
auto signers = loadSigners(db, actIDStrKey);
account.signers.insert(account.signers.begin(), signers.begin(),
signers.end());
}
res->normalize();
res->mUpdateSigners = false;
assert(res->isValid());
res->mKeyCalculated = false;
res->putCachedEntry(db);
return res;
}