mirror of
https://github.com/twisterarmy/twister-core.git
synced 2025-01-25 05:54:19 +00:00
205 lines
6.1 KiB
C++
205 lines
6.1 KiB
C++
// Copyright (c) 2009-2010 Satoshi Nakamoto
|
|
// Copyright (c) 2009-2012 The Bitcoin developers
|
|
// Distributed under the MIT/X11 software license, see the accompanying
|
|
// file COPYING or http://www.opensource.org/licenses/mit-license.php.
|
|
|
|
#include "init.h"
|
|
#include "bitcoinrpc.h"
|
|
#include <boost/algorithm/string/predicate.hpp>
|
|
|
|
void DetectShutdownThread(boost::thread_group* threadGroup)
|
|
{
|
|
bool shutdown = ShutdownRequested();
|
|
// Tell the main threads to shutdown.
|
|
while (!shutdown)
|
|
{
|
|
MilliSleep(200);
|
|
shutdown = ShutdownRequested();
|
|
}
|
|
if (threadGroup)
|
|
threadGroup->interrupt_all();
|
|
}
|
|
|
|
//////////////////////////////////////////////////////////////////////////////
|
|
//
|
|
// Start
|
|
//
|
|
bool AppInit(int argc, char* argv[])
|
|
{
|
|
boost::thread_group threadGroup;
|
|
boost::thread* detectShutdownThread = NULL;
|
|
|
|
bool fRet = false;
|
|
try
|
|
{
|
|
//
|
|
// Parameters
|
|
//
|
|
// If Qt is used, parameters/bitcoin.conf are parsed in qt/bitcoin.cpp's main()
|
|
ParseParameters(argc, argv);
|
|
if (!boost::filesystem::is_directory(GetDataDir(false)))
|
|
{
|
|
fprintf(stderr, "Error: Specified directory does not exist\n");
|
|
Shutdown();
|
|
}
|
|
ReadConfigFile(mapArgs, mapMultiArgs);
|
|
|
|
if (mapArgs.count("-?") || mapArgs.count("--help"))
|
|
{
|
|
// First part of help message is specific to bitcoind / RPC client
|
|
std::string strUsage = _("Bitcoin version") + " " + FormatFullVersion() + "\n\n" +
|
|
_("Usage:") + "\n" +
|
|
" bitcoind [options] " + "\n" +
|
|
" bitcoind [options] <command> [params] " + _("Send command to -server or bitcoind") + "\n" +
|
|
" bitcoind [options] help " + _("List commands") + "\n" +
|
|
" bitcoind [options] help <command> " + _("Get help for a command") + "\n";
|
|
|
|
strUsage += "\n" + HelpMessage();
|
|
|
|
fprintf(stdout, "%s", strUsage.c_str());
|
|
return false;
|
|
}
|
|
|
|
// Command-line RPC
|
|
for (int i = 1; i < argc; i++)
|
|
if (!IsSwitchChar(argv[i][0]) && !boost::algorithm::istarts_with(argv[i], "bitcoin:"))
|
|
fCommandLine = true;
|
|
|
|
if (fCommandLine)
|
|
{
|
|
if (!SelectParamsFromCommandLine()) {
|
|
fprintf(stderr, "Error: invalid combination of -regtest and -testnet.\n");
|
|
return false;
|
|
}
|
|
int ret = CommandLineRPC(argc, argv);
|
|
exit(ret);
|
|
}
|
|
#if !defined(WIN32)
|
|
fDaemon = GetBoolArg("-daemon", false);
|
|
if (fDaemon)
|
|
{
|
|
// Daemonize
|
|
pid_t pid = fork();
|
|
if (pid < 0)
|
|
{
|
|
fprintf(stderr, "Error: fork() returned %d errno %d\n", pid, errno);
|
|
return false;
|
|
}
|
|
if (pid > 0) // Parent process, pid is child process id
|
|
{
|
|
CreatePidFile(GetPidFile(), pid);
|
|
return true;
|
|
}
|
|
// Child process falls through to rest of initialization
|
|
|
|
pid_t sid = setsid();
|
|
if (sid < 0)
|
|
fprintf(stderr, "Error: setsid() returned %d errno %d\n", sid, errno);
|
|
}
|
|
#endif
|
|
|
|
detectShutdownThread = new boost::thread(boost::bind(&DetectShutdownThread, &threadGroup));
|
|
fRet = AppInit2(threadGroup);
|
|
}
|
|
catch (std::exception& e) {
|
|
PrintExceptionContinue(&e, "AppInit()");
|
|
} catch (...) {
|
|
PrintExceptionContinue(NULL, "AppInit()");
|
|
}
|
|
if (!fRet) {
|
|
if (detectShutdownThread)
|
|
detectShutdownThread->interrupt();
|
|
threadGroup.interrupt_all();
|
|
}
|
|
|
|
if (detectShutdownThread)
|
|
{
|
|
detectShutdownThread->join();
|
|
delete detectShutdownThread;
|
|
detectShutdownThread = NULL;
|
|
}
|
|
Shutdown();
|
|
|
|
return fRet;
|
|
}
|
|
|
|
|
|
static const string strSecret1C ("Kwr371tjA9u2rFSMZjTNun2PXXP3WPZu2afRHTcta6KxEUdm1vEw");
|
|
|
|
static bool TestCreateSpamMsgTx()
|
|
{
|
|
CTransaction txNew;
|
|
|
|
txNew.message = CScript() << strSpamMessage;
|
|
|
|
CBitcoinSecret bsecret1;
|
|
bsecret1.SetString (strSecret1C);
|
|
|
|
CKey key;
|
|
key.MakeNewKey(true);
|
|
//CKey key = bsecret1.GetKey();
|
|
CPubKey pubkey( key.GetPubKey() );
|
|
|
|
printf("key valid: %d compressed: %d\n", key.IsValid(), key.IsCompressed());
|
|
printf("pubkey: %s\n", EncodeBase64(&pubkey[0], pubkey.size()).c_str() );
|
|
|
|
// compute message hash and sign it
|
|
CHashWriter ss(SER_GETHASH, PROTOCOL_VERSION);
|
|
ss << txNew.message;
|
|
uint256 hashMsg = ss.GetHash();
|
|
|
|
// vchSig is sig(hash(message))
|
|
vector<unsigned char> vchSig;
|
|
if (!key.Sign(hashMsg, vchSig)) {
|
|
printf("CreateNewBlock: Failed to sign SpamMessage\n");
|
|
return false;
|
|
}
|
|
|
|
/*
|
|
vector<unsigned char> vchSigCompact;
|
|
if (!key.SignCompact(hashMsg, vchSigCompact)) {
|
|
printf("CreateNewBlock: Failed to sign SpamMessage2\n");
|
|
return false;
|
|
}
|
|
printf("sign size: %zu signCompact size: %zu\n", vchSig.size(), vchSigCompact.size());
|
|
printf("signCompact: %s\n", EncodeBase64(&vchSigCompact[0], vchSigCompact.size()).c_str());
|
|
*/
|
|
|
|
printf("CreateSpamMsgTx: msg = %s user = %s hash = %s signedhash = %s\n", txNew.message.ToString().c_str(), strSpamUser.c_str(),
|
|
hashMsg.ToString().c_str(), EncodeBase64(&vchSig[0], vchSig.size()).c_str() );
|
|
|
|
// add username and signature
|
|
txNew.userName = CScript() << strSpamUser;
|
|
txNew.userName += CScript() << vchSig;
|
|
txNew.pubKey.clear(); // pubKey will be updated to include extranonce
|
|
txNew.nNonce = 0; // no update needed for spamMessage's nonce.
|
|
|
|
std::vector< std::vector<unsigned char> > vData;
|
|
txNew.userName.ExtractPushData(vData);
|
|
|
|
printf("Verify: %d\n", pubkey.Verify(hashMsg,vData[1]));
|
|
|
|
exit(1);
|
|
}
|
|
|
|
extern void GenesisMiner();
|
|
extern void noui_connect();
|
|
int main(int argc, char* argv[])
|
|
{
|
|
bool fRet = false;
|
|
fHaveGUI = false;
|
|
|
|
//GenesisMiner();
|
|
//TestCreateSpamMsgTx();
|
|
|
|
// Connect bitcoind signal handlers
|
|
noui_connect();
|
|
|
|
fRet = AppInit(argc, argv);
|
|
|
|
if (fRet && fDaemon)
|
|
return 0;
|
|
|
|
return (fRet ? 0 : 1);
|
|
}
|