mirror of
https://github.com/twisterarmy/twister-core.git
synced 2025-01-25 14:04:27 +00:00
spam message queue
This commit is contained in:
parent
73dc8acc72
commit
831ae233e4
18
src/main.cpp
18
src/main.cpp
@ -71,7 +71,8 @@ int64 nHPSTimerStart = 0;
|
|||||||
// Settings
|
// Settings
|
||||||
int64 nTransactionFee = 0;
|
int64 nTransactionFee = 0;
|
||||||
|
|
||||||
string strSpamMessage = "Promoted posts are needed to run the network infrastructure. If you want to help, start generating blocks and advertise. [en]";
|
CCriticalSection cs_spamMessages;
|
||||||
|
list<string> spamMessages;
|
||||||
string strSpamUser = "nobody";
|
string strSpamUser = "nobody";
|
||||||
|
|
||||||
|
|
||||||
@ -3681,7 +3682,13 @@ public:
|
|||||||
|
|
||||||
static bool CreateSpamMsgTx(CTransaction &txNew, std::vector<unsigned char> &salt)
|
static bool CreateSpamMsgTx(CTransaction &txNew, std::vector<unsigned char> &salt)
|
||||||
{
|
{
|
||||||
txNew.message = CScript() << strSpamMessage;
|
if (spamMessages.size())
|
||||||
|
{
|
||||||
|
LOCK(cs_spamMessages);
|
||||||
|
txNew.message = CScript() << spamMessages.front();
|
||||||
|
}
|
||||||
|
else
|
||||||
|
txNew.message = CScript() << strSpamMessage;
|
||||||
std::string strUsername = strSpamUser;
|
std::string strUsername = strSpamUser;
|
||||||
|
|
||||||
CKeyID keyID;
|
CKeyID keyID;
|
||||||
@ -3941,6 +3948,13 @@ bool CheckWork(CBlock* pblock, CWallet& wallet)
|
|||||||
CValidationState state;
|
CValidationState state;
|
||||||
if (!ProcessBlock(state, NULL, pblock))
|
if (!ProcessBlock(state, NULL, pblock))
|
||||||
return error("BitcoinMiner : ProcessBlock, block not accepted");
|
return error("BitcoinMiner : ProcessBlock, block not accepted");
|
||||||
|
else
|
||||||
|
{
|
||||||
|
//after finding a block, change spam messages order..
|
||||||
|
LOCK(cs_spamMessages);
|
||||||
|
spamMessages.push_back(spamMessages.front());
|
||||||
|
spamMessages.pop_front();
|
||||||
|
}
|
||||||
}
|
}
|
||||||
|
|
||||||
return true;
|
return true;
|
||||||
|
@ -96,7 +96,9 @@ extern bool fHaveGUI;
|
|||||||
// Settings
|
// Settings
|
||||||
extern int64 nTransactionFee;
|
extern int64 nTransactionFee;
|
||||||
|
|
||||||
extern string strSpamMessage;
|
extern CCriticalSection cs_spamMessages;
|
||||||
|
static const string strSpamMessage = "Promoted posts are needed to run the network infrastructure. If you want to help, start generating blocks and advertise. [en]";
|
||||||
|
extern std::list<string> spamMessages;
|
||||||
extern string strSpamUser;
|
extern string strSpamUser;
|
||||||
|
|
||||||
// Minimum disk space required - used in CheckDiskSpace()
|
// Minimum disk space required - used in CheckDiskSpace()
|
||||||
|
@ -64,6 +64,7 @@ static CCriticalSection cs_spamMsg;
|
|||||||
static std::string m_preferredSpamLang = "[en]";
|
static std::string m_preferredSpamLang = "[en]";
|
||||||
static std::string m_receivedSpamMsgStr;
|
static std::string m_receivedSpamMsgStr;
|
||||||
static std::string m_receivedSpamUserStr;
|
static std::string m_receivedSpamUserStr;
|
||||||
|
static int m_receivedSpamHeight;
|
||||||
static int64 m_lastSpamTime = 0;
|
static int64 m_lastSpamTime = 0;
|
||||||
static std::map<std::string,UserData> m_users;
|
static std::map<std::string,UserData> m_users;
|
||||||
static std::map<std::string,GroupChat> m_groups;
|
static std::map<std::string,GroupChat> m_groups;
|
||||||
@ -213,8 +214,16 @@ int saveGlobalData(std::string const& filename)
|
|||||||
globalDict["preferredSpamLang"] = m_preferredSpamLang;
|
globalDict["preferredSpamLang"] = m_preferredSpamLang;
|
||||||
globalDict["receivedSpamMsg"] = m_receivedSpamMsgStr;
|
globalDict["receivedSpamMsg"] = m_receivedSpamMsgStr;
|
||||||
globalDict["receivedSpamUser"] = m_receivedSpamUserStr;
|
globalDict["receivedSpamUser"] = m_receivedSpamUserStr;
|
||||||
|
globalDict["receivedSpamHeight"]= m_receivedSpamHeight;
|
||||||
globalDict["lastSpamTime"] = m_lastSpamTime;
|
globalDict["lastSpamTime"] = m_lastSpamTime;
|
||||||
globalDict["sendSpamMsg"] = strSpamMessage;
|
|
||||||
|
entry spams(entry::list_t);
|
||||||
|
{
|
||||||
|
LOCK(cs_spamMessages);
|
||||||
|
BOOST_FOREACH(string msg, spamMessages)
|
||||||
|
spams.list().push_back(msg);
|
||||||
|
}
|
||||||
|
globalDict["sendSpamMsg"] = spams;
|
||||||
globalDict["sendSpamUser"] = strSpamUser;
|
globalDict["sendSpamUser"] = strSpamUser;
|
||||||
globalDict["generate"] = GetBoolArg("-gen", false);
|
globalDict["generate"] = GetBoolArg("-gen", false);
|
||||||
int genproclimit = GetArg("-genproclimit", -1);
|
int genproclimit = GetArg("-genproclimit", -1);
|
||||||
@ -240,9 +249,24 @@ int loadGlobalData(std::string const& filename)
|
|||||||
m_preferredSpamLang = userDict.dict_find_string_value("preferredSpamLang");
|
m_preferredSpamLang = userDict.dict_find_string_value("preferredSpamLang");
|
||||||
m_receivedSpamMsgStr = userDict.dict_find_string_value("receivedSpamMsg");
|
m_receivedSpamMsgStr = userDict.dict_find_string_value("receivedSpamMsg");
|
||||||
m_receivedSpamUserStr = userDict.dict_find_string_value("receivedSpamUser");
|
m_receivedSpamUserStr = userDict.dict_find_string_value("receivedSpamUser");
|
||||||
|
m_receivedSpamHeight = userDict.dict_find_int_value("receivedSpamHeight");
|
||||||
m_lastSpamTime = userDict.dict_find_int_value("lastSpamTime");
|
m_lastSpamTime = userDict.dict_find_int_value("lastSpamTime");
|
||||||
string sendSpamMsg = userDict.dict_find_string_value("sendSpamMsg");
|
|
||||||
if( sendSpamMsg.size() ) strSpamMessage = sendSpamMsg;
|
const lazy_entry *sendSpamMsg = userDict.dict_find_list("sendSpamMsg");
|
||||||
|
if (sendSpamMsg)
|
||||||
|
{
|
||||||
|
LOCK(cs_spamMessages);
|
||||||
|
for (int i = 0; i < sendSpamMsg->list_size(); i++)
|
||||||
|
spamMessages.push_back(sendSpamMsg->list_string_value_at(i));
|
||||||
|
}
|
||||||
|
else
|
||||||
|
{
|
||||||
|
string strSSM = userDict.dict_find_string_value("sendSpamMsg");
|
||||||
|
LOCK(cs_spamMessages);
|
||||||
|
if(strSSM.size() && strSSM != strSpamMessage)
|
||||||
|
spamMessages.push_back(strSSM);
|
||||||
|
}
|
||||||
|
|
||||||
string sendSpamUser = userDict.dict_find_string_value("sendSpamUser");
|
string sendSpamUser = userDict.dict_find_string_value("sendSpamUser");
|
||||||
if( sendSpamUser.size() ) strSpamUser = sendSpamUser;
|
if( sendSpamUser.size() ) strSpamUser = sendSpamUser;
|
||||||
generateOpt = userDict.dict_find_int_value("generate");
|
generateOpt = userDict.dict_find_int_value("generate");
|
||||||
@ -1791,6 +1815,7 @@ void receivedSpamMessage(std::string const &message, std::string const &user)
|
|||||||
if( currentlyEmpty || (isSameLang && rand() < (RAND_MAX/2)) ) {
|
if( currentlyEmpty || (isSameLang && rand() < (RAND_MAX/2)) ) {
|
||||||
m_receivedSpamMsgStr = message;
|
m_receivedSpamMsgStr = message;
|
||||||
m_receivedSpamUserStr = user;
|
m_receivedSpamUserStr = user;
|
||||||
|
m_receivedSpamHeight = nBestHeight;
|
||||||
}
|
}
|
||||||
}
|
}
|
||||||
|
|
||||||
@ -2528,7 +2553,7 @@ Value getposts(const Array& params, bool fHelp)
|
|||||||
if( m_receivedSpamMsgStr.length() && GetAdjustedTime() > m_lastSpamTime + (8*3600) ) {
|
if( m_receivedSpamMsgStr.length() && GetAdjustedTime() > m_lastSpamTime + (8*3600) ) {
|
||||||
m_lastSpamTime = GetAdjustedTime();
|
m_lastSpamTime = GetAdjustedTime();
|
||||||
|
|
||||||
entry v = formatSpamPost(m_receivedSpamMsgStr, m_receivedSpamUserStr);
|
entry v = formatSpamPost(m_receivedSpamMsgStr, m_receivedSpamUserStr, 0, m_receivedSpamHeight);
|
||||||
ret.insert(ret.begin(),entryToJson(v));
|
ret.insert(ret.begin(),entryToJson(v));
|
||||||
|
|
||||||
m_receivedSpamMsgStr = "";
|
m_receivedSpamMsgStr = "";
|
||||||
@ -2756,13 +2781,15 @@ Value getfavs(const Array& params, bool fHelp)
|
|||||||
|
|
||||||
Value setspammsg(const Array& params, bool fHelp)
|
Value setspammsg(const Array& params, bool fHelp)
|
||||||
{
|
{
|
||||||
if (fHelp || (params.size() != 2))
|
if (fHelp || params.size() < 2 || params.size() > 3)
|
||||||
throw runtime_error(
|
throw runtime_error(
|
||||||
"setspammsg <username> <msg>\n"
|
"setspammsg <username> <msg> [add|remove|replace]\n"
|
||||||
"Set spam message attached to generated blocks");
|
"Set spam message attached to generated blocks\n"
|
||||||
|
"replace is default operation.");
|
||||||
|
|
||||||
string strUsername = params[0].get_str();
|
string strUsername = params[0].get_str();
|
||||||
string strMsg = params[1].get_str();
|
string strMsg = params[1].get_str();
|
||||||
|
string strOp = params.size() == 3 ? params[2].get_str() : "replace";
|
||||||
|
|
||||||
int spamMsgUtf8Size = utf8::num_characters(strMsg.begin(), strMsg.end());
|
int spamMsgUtf8Size = utf8::num_characters(strMsg.begin(), strMsg.end());
|
||||||
if (spamMsgUtf8Size < 0)
|
if (spamMsgUtf8Size < 0)
|
||||||
@ -2772,10 +2799,30 @@ Value setspammsg(const Array& params, bool fHelp)
|
|||||||
if (spamMsgUtf8Size > MAX_SPAM_MSG_SIZE)
|
if (spamMsgUtf8Size > MAX_SPAM_MSG_SIZE)
|
||||||
throw JSONRPCError(RPC_INTERNAL_ERROR, "spam message too big");
|
throw JSONRPCError(RPC_INTERNAL_ERROR, "spam message too big");
|
||||||
|
|
||||||
strSpamUser = strUsername;
|
Array ret;
|
||||||
strSpamMessage = strMsg;
|
{
|
||||||
|
LOCK(cs_spamMessages);
|
||||||
|
strSpamUser = strUsername;
|
||||||
|
if (strOp == "add")
|
||||||
|
{
|
||||||
|
spamMessages.push_back(strMsg);
|
||||||
|
spamMessages.unique();
|
||||||
|
}
|
||||||
|
else if (strOp == "remove")
|
||||||
|
spamMessages.remove(strMsg);
|
||||||
|
else if (strOp == "replace")
|
||||||
|
{
|
||||||
|
spamMessages.clear();
|
||||||
|
spamMessages.push_back(strMsg);
|
||||||
|
}
|
||||||
|
else
|
||||||
|
throw JSONRPCError(RPC_INVALID_PARAMETER, "unknown operation");
|
||||||
|
|
||||||
return Value();
|
BOOST_FOREACH(string msg, spamMessages)
|
||||||
|
ret.push_back(msg);
|
||||||
|
}
|
||||||
|
|
||||||
|
return ret;
|
||||||
}
|
}
|
||||||
|
|
||||||
Value getspammsg(const Array& params, bool fHelp)
|
Value getspammsg(const Array& params, bool fHelp)
|
||||||
@ -2787,7 +2834,15 @@ Value getspammsg(const Array& params, bool fHelp)
|
|||||||
|
|
||||||
Array ret;
|
Array ret;
|
||||||
ret.push_back(strSpamUser);
|
ret.push_back(strSpamUser);
|
||||||
ret.push_back(strSpamMessage);
|
|
||||||
|
{
|
||||||
|
LOCK(cs_spamMessages);
|
||||||
|
BOOST_FOREACH(string msg, spamMessages)
|
||||||
|
ret.push_back(msg);
|
||||||
|
}
|
||||||
|
//if spamMessages is empty, use default message...
|
||||||
|
if (ret.size() == 1)
|
||||||
|
ret.push_back(strSpamMessage);
|
||||||
|
|
||||||
return ret;
|
return ret;
|
||||||
}
|
}
|
||||||
|
Loading…
x
Reference in New Issue
Block a user