diff options
author | kjj2 <github@jerviss.org> | 2012-11-03 09:58:41 -0500 |
---|---|---|
committer | kjj2 <github@jerviss.org> | 2012-11-03 10:07:57 -0500 |
commit | cae686d31e18a68826ef61931ae8379fe9461d7b (patch) | |
tree | 4615748a180ad35155eeb01d5577dc35a2dcf924 | |
parent | 6cbae37667f504d9ecd6173e1eff817d2b7aaf0c (diff) |
Add -walletnotify to call an external script on wallet transactions
-rw-r--r-- | src/init.cpp | 1 | ||||
-rw-r--r-- | src/wallet.cpp | 11 |
2 files changed, 12 insertions, 0 deletions
diff --git a/src/init.cpp b/src/init.cpp index dc425da644..ec32b62098 100644 --- a/src/init.cpp +++ b/src/init.cpp @@ -276,6 +276,7 @@ std::string HelpMessage() " -rpcallowip=<ip> " + _("Allow JSON-RPC connections from specified IP address") + "\n" + " -rpcconnect=<ip> " + _("Send commands to node running on <ip> (default: 127.0.0.1)") + "\n" + " -blocknotify=<cmd> " + _("Execute command when the best block changes (%s in cmd is replaced by block hash)") + "\n" + + " -walletnotify=<cmd> " + _("Execute command when a wallet transaction changes (%s in cmd is replaced by TxID)") + "\n" + " -upgradewallet " + _("Upgrade wallet to latest format") + "\n" + " -keypool=<n> " + _("Set key pool size to <n> (default: 100)") + "\n" + " -rescan " + _("Rescan the block chain for missing wallet transactions") + "\n" + diff --git a/src/wallet.cpp b/src/wallet.cpp index 880f7aa8bd..f9da100e21 100644 --- a/src/wallet.cpp +++ b/src/wallet.cpp @@ -8,6 +8,7 @@ #include "crypter.h" #include "ui_interface.h" #include "base58.h" +#include <boost/algorithm/string/replace.hpp> using namespace std; @@ -470,6 +471,16 @@ bool CWallet::AddToWallet(const CWalletTx& wtxIn) // Notify UI of new or updated transaction NotifyTransactionChanged(this, hash, fInsertedNew ? CT_NEW : CT_UPDATED); + + // notify an external script when a wallet transaction comes in or is updated + std::string strCmd = GetArg("-walletnotify", ""); + + if ( !strCmd.empty()) + { + boost::replace_all(strCmd, "%s", wtxIn.GetHash().GetHex()); + boost::thread t(runCommand, strCmd); // thread runs free + } + } return true; } |