mirror of
https://github.com/Xahau/xahaud.git
synced 2025-12-06 17:27:52 +00:00
99 lines
3.0 KiB
C++
99 lines
3.0 KiB
C++
//------------------------------------------------------------------------------
|
|
/*
|
|
This file is part of rippled: https://github.com/ripple/rippled
|
|
Copyright (c) 2012, 2013 Ripple Labs Inc.
|
|
|
|
Permission to use, copy, modify, and/or distribute this software for any
|
|
purpose with or without fee is hereby granted, provided that the above
|
|
copyright notice and this permission notice appear in all copies.
|
|
|
|
THE SOFTWARE IS PROVIDED "AS IS" AND THE AUTHOR DISCLAIMS ALL WARRANTIES
|
|
WITH REGARD TO THIS SOFTWARE INCLUDING ALL IMPLIED WARRANTIES OF
|
|
MERCHANTABILITY AND FITNESS. IN NO EVENT SHALL THE AUTHOR BE LIABLE FOR
|
|
ANY SPECIAL , DIRECT, INDIRECT, OR CONSEQUENTIAL DAMAGES OR ANY DAMAGES
|
|
WHATSOEVER RESULTING FROM LOSS OF USE, DATA OR PROFITS, WHETHER IN AN
|
|
ACTION OF CONTRACT, NEGLIGENCE OR OTHER TORTIOUS ACTION, ARISING OUT OF
|
|
OR IN CONNECTION WITH THE USE OR PERFORMANCE OF THIS SOFTWARE.
|
|
*/
|
|
//==============================================================================
|
|
|
|
// This is the primary interface into the "client" portion of the program.
|
|
// Code that wants to do normal operations on the network such as
|
|
// creating and monitoring accounts, creating transactions, and so on
|
|
// should use this interface. The RPC code will primarily be a light wrapper
|
|
// over this code.
|
|
|
|
// Eventually, it will check the node's operating mode (synched, unsynched,
|
|
// etectera) and defer to the correct means of processing. The current
|
|
// code assumes this node is synched (and will continue to do so until
|
|
// there's a functional network.
|
|
|
|
//------------------------------------------------------------------------------
|
|
|
|
InfoSub::Source::Source (char const* name, Stoppable& parent)
|
|
: Stoppable (name, parent)
|
|
{
|
|
}
|
|
|
|
//------------------------------------------------------------------------------
|
|
|
|
InfoSub::InfoSub (Source& source, Consumer consumer)
|
|
: mLock (this, "InfoSub", __FILE__, __LINE__)
|
|
, m_consumer (consumer)
|
|
, m_source (source)
|
|
{
|
|
static Atomic <int> s_seq_id;
|
|
mSeq = ++s_seq_id;
|
|
}
|
|
|
|
InfoSub::~InfoSub ()
|
|
{
|
|
m_source.unsubTransactions (mSeq);
|
|
m_source.unsubRTTransactions (mSeq);
|
|
m_source.unsubLedger (mSeq);
|
|
m_source.unsubServer (mSeq);
|
|
m_source.unsubAccount (mSeq, mSubAccountInfo, true);
|
|
m_source.unsubAccount (mSeq, mSubAccountInfo, false);
|
|
}
|
|
|
|
Resource::Consumer& InfoSub::getConsumer()
|
|
{
|
|
return m_consumer;
|
|
}
|
|
|
|
void InfoSub::send (const Json::Value& jvObj, const std::string& sObj, bool broadcast)
|
|
{
|
|
send (jvObj, broadcast);
|
|
}
|
|
|
|
uint64 InfoSub::getSeq ()
|
|
{
|
|
return mSeq;
|
|
}
|
|
|
|
void InfoSub::onSendEmpty ()
|
|
{
|
|
}
|
|
|
|
void InfoSub::insertSubAccountInfo (RippleAddress addr, uint32 uLedgerIndex)
|
|
{
|
|
ScopedLockType sl (mLock, __FILE__, __LINE__);
|
|
|
|
mSubAccountInfo.insert (addr);
|
|
}
|
|
|
|
void InfoSub::clearPathRequest ()
|
|
{
|
|
mPathRequest.reset ();
|
|
}
|
|
|
|
void InfoSub::setPathRequest (const boost::shared_ptr<PathRequest>& req)
|
|
{
|
|
mPathRequest = req;
|
|
}
|
|
|
|
const boost::shared_ptr<PathRequest>& InfoSub::getPathRequest ()
|
|
{
|
|
return mPathRequest;
|
|
}
|