mirror of
https://git.wownero.com/wownero/wownero.git
synced 2025-01-23 15:58:34 +00:00
notify: handle arbitrary tags
This commit is contained in:
parent
eaf602bceb
commit
3353e6e784
@ -27,6 +27,7 @@
|
|||||||
// THE USE OF THIS SOFTWARE, EVEN IF ADVISED OF THE POSSIBILITY OF SUCH DAMAGE.
|
// THE USE OF THIS SOFTWARE, EVEN IF ADVISED OF THE POSSIBILITY OF SUCH DAMAGE.
|
||||||
|
|
||||||
#include <boost/algorithm/string.hpp>
|
#include <boost/algorithm/string.hpp>
|
||||||
|
#include <stdarg.h>
|
||||||
#include "misc_log_ex.h"
|
#include "misc_log_ex.h"
|
||||||
#include "file_io_utils.h"
|
#include "file_io_utils.h"
|
||||||
#include "spawn.h"
|
#include "spawn.h"
|
||||||
@ -50,11 +51,26 @@ Notify::Notify(const char *spec)
|
|||||||
CHECK_AND_ASSERT_THROW_MES(epee::file_io_utils::is_file_exist(filename), "File not found: " << filename);
|
CHECK_AND_ASSERT_THROW_MES(epee::file_io_utils::is_file_exist(filename), "File not found: " << filename);
|
||||||
}
|
}
|
||||||
|
|
||||||
int Notify::notify(const char *parameter)
|
static void replace(std::vector<std::string> &v, const char *tag, const char *s)
|
||||||
|
{
|
||||||
|
for (std::string &str: v)
|
||||||
|
boost::replace_all(str, tag, s);
|
||||||
|
}
|
||||||
|
|
||||||
|
int Notify::notify(const char *tag, const char *s, ...)
|
||||||
{
|
{
|
||||||
std::vector<std::string> margs = args;
|
std::vector<std::string> margs = args;
|
||||||
for (std::string &s: margs)
|
|
||||||
boost::replace_all(s, "%s", parameter);
|
replace(margs, tag, s);
|
||||||
|
|
||||||
|
va_list ap;
|
||||||
|
va_start(ap, s);
|
||||||
|
while ((tag = va_arg(ap, const char*)))
|
||||||
|
{
|
||||||
|
s = va_arg(ap, const char*);
|
||||||
|
replace(margs, tag, s);
|
||||||
|
}
|
||||||
|
va_end(ap);
|
||||||
|
|
||||||
return tools::spawn(filename.c_str(), margs, false);
|
return tools::spawn(filename.c_str(), margs, false);
|
||||||
}
|
}
|
||||||
|
@ -39,7 +39,7 @@ class Notify
|
|||||||
public:
|
public:
|
||||||
Notify(const char *spec);
|
Notify(const char *spec);
|
||||||
|
|
||||||
int notify(const char *parameter);
|
int notify(const char *tag, const char *s, ...);
|
||||||
|
|
||||||
private:
|
private:
|
||||||
std::string filename;
|
std::string filename;
|
||||||
|
@ -3575,7 +3575,7 @@ leave:
|
|||||||
|
|
||||||
std::shared_ptr<tools::Notify> block_notify = m_block_notify;
|
std::shared_ptr<tools::Notify> block_notify = m_block_notify;
|
||||||
if (block_notify)
|
if (block_notify)
|
||||||
block_notify->notify(epee::string_tools::pod_to_hex(id).c_str());
|
block_notify->notify("%s", epee::string_tools::pod_to_hex(id).c_str(), NULL);
|
||||||
|
|
||||||
return true;
|
return true;
|
||||||
}
|
}
|
||||||
|
@ -1861,7 +1861,7 @@ void wallet2::process_new_transaction(const crypto::hash &txid, const cryptonote
|
|||||||
{
|
{
|
||||||
std::shared_ptr<tools::Notify> tx_notify = m_tx_notify;
|
std::shared_ptr<tools::Notify> tx_notify = m_tx_notify;
|
||||||
if (tx_notify)
|
if (tx_notify)
|
||||||
tx_notify->notify(epee::string_tools::pod_to_hex(txid).c_str());
|
tx_notify->notify("%s", epee::string_tools::pod_to_hex(txid).c_str(), NULL);
|
||||||
}
|
}
|
||||||
}
|
}
|
||||||
//----------------------------------------------------------------------------------------------------
|
//----------------------------------------------------------------------------------------------------
|
||||||
|
@ -62,6 +62,7 @@ set(unit_tests_sources
|
|||||||
mul_div.cpp
|
mul_div.cpp
|
||||||
multiexp.cpp
|
multiexp.cpp
|
||||||
multisig.cpp
|
multisig.cpp
|
||||||
|
notify.cpp
|
||||||
parse_amount.cpp
|
parse_amount.cpp
|
||||||
random.cpp
|
random.cpp
|
||||||
serialization.cpp
|
serialization.cpp
|
||||||
|
90
tests/unit_tests/notify.cpp
Normal file
90
tests/unit_tests/notify.cpp
Normal file
@ -0,0 +1,90 @@
|
|||||||
|
// Copyright (c) 2018, The Monero Project
|
||||||
|
//
|
||||||
|
// All rights reserved.
|
||||||
|
//
|
||||||
|
// Redistribution and use in source and binary forms, with or without modification, are
|
||||||
|
// permitted provided that the following conditions are met:
|
||||||
|
//
|
||||||
|
// 1. Redistributions of source code must retain the above copyright notice, this list of
|
||||||
|
// conditions and the following disclaimer.
|
||||||
|
//
|
||||||
|
// 2. Redistributions in binary form must reproduce the above copyright notice, this list
|
||||||
|
// of conditions and the following disclaimer in the documentation and/or other
|
||||||
|
// materials provided with the distribution.
|
||||||
|
//
|
||||||
|
// 3. Neither the name of the copyright holder nor the names of its contributors may be
|
||||||
|
// used to endorse or promote products derived from this software without specific
|
||||||
|
// prior written permission.
|
||||||
|
//
|
||||||
|
// THIS SOFTWARE IS PROVIDED BY THE COPYRIGHT HOLDERS AND CONTRIBUTORS "AS IS" AND ANY
|
||||||
|
// EXPRESS OR IMPLIED WARRANTIES, INCLUDING, BUT NOT LIMITED TO, THE IMPLIED WARRANTIES OF
|
||||||
|
// MERCHANTABILITY AND FITNESS FOR A PARTICULAR PURPOSE ARE DISCLAIMED. IN NO EVENT SHALL
|
||||||
|
// THE COPYRIGHT HOLDER OR CONTRIBUTORS BE LIABLE FOR ANY DIRECT, INDIRECT, INCIDENTAL,
|
||||||
|
// SPECIAL, EXEMPLARY, OR CONSEQUENTIAL DAMAGES (INCLUDING, BUT NOT LIMITED TO,
|
||||||
|
// PROCUREMENT OF SUBSTITUTE GOODS OR SERVICES; LOSS OF USE, DATA, OR PROFITS; OR BUSINESS
|
||||||
|
// INTERRUPTION) HOWEVER CAUSED AND ON ANY THEORY OF LIABILITY, WHETHER IN CONTRACT,
|
||||||
|
// STRICT LIABILITY, OR TORT (INCLUDING NEGLIGENCE OR OTHERWISE) ARISING IN ANY WAY OUT OF
|
||||||
|
// THE USE OF THIS SOFTWARE, EVEN IF ADVISED OF THE POSSIBILITY OF SUCH DAMAGE.
|
||||||
|
|
||||||
|
#ifdef __GLIBC__
|
||||||
|
#include <sys/stat.h>
|
||||||
|
#endif
|
||||||
|
|
||||||
|
#include "gtest/gtest.h"
|
||||||
|
|
||||||
|
#include <boost/filesystem.hpp>
|
||||||
|
|
||||||
|
#include "misc_language.h"
|
||||||
|
#include "string_tools.h"
|
||||||
|
#include "file_io_utils.h"
|
||||||
|
#include "common/notify.h"
|
||||||
|
|
||||||
|
TEST(notify, works)
|
||||||
|
{
|
||||||
|
#ifdef __GLIBC__
|
||||||
|
mode_t prevmode = umask(077);
|
||||||
|
#endif
|
||||||
|
const char *tmp = getenv("TEMP");
|
||||||
|
if (!tmp)
|
||||||
|
tmp = "/tmp";
|
||||||
|
static const char *filename = "monero-notify-unit-test-XXXXXX";
|
||||||
|
const size_t len = strlen(tmp) + 1 + strlen(filename);
|
||||||
|
std::unique_ptr<char[]> name_template_(new char[len + 1]);
|
||||||
|
char *name_template = name_template_.get();
|
||||||
|
ASSERT_TRUE(name_template != NULL);
|
||||||
|
snprintf(name_template, len + 1, "%s/%s", tmp, filename);
|
||||||
|
int fd = mkstemp(name_template);
|
||||||
|
#ifdef __GLIBC__
|
||||||
|
umask(prevmode);
|
||||||
|
#endif
|
||||||
|
ASSERT_TRUE(fd >= 0);
|
||||||
|
close(fd);
|
||||||
|
|
||||||
|
const std::string spec = epee::string_tools::get_current_module_folder() + "/test_notifier"
|
||||||
|
#ifdef _WIN32
|
||||||
|
+ ".exe"
|
||||||
|
#endif
|
||||||
|
+ " " + name_template + " %s";
|
||||||
|
|
||||||
|
tools::Notify notify(spec.c_str());
|
||||||
|
notify.notify("%s", "1111111111111111111111111111111111111111111111111111111111111111", NULL);
|
||||||
|
|
||||||
|
bool ok = false;
|
||||||
|
for (int i = 0; i < 10; ++i)
|
||||||
|
{
|
||||||
|
epee::misc_utils::sleep_no_w(100);
|
||||||
|
|
||||||
|
std::string s;
|
||||||
|
if (epee::file_io_utils::load_file_to_string(name_template, s))
|
||||||
|
{
|
||||||
|
if (s == "1111111111111111111111111111111111111111111111111111111111111111")
|
||||||
|
{
|
||||||
|
ok = true;
|
||||||
|
break;
|
||||||
|
}
|
||||||
|
std::cout << "got: [" << s << "]" << std::endl;
|
||||||
|
}
|
||||||
|
}
|
||||||
|
boost::filesystem::remove(name_template);
|
||||||
|
ASSERT_TRUE(ok);
|
||||||
|
}
|
Loading…
x
Reference in New Issue
Block a user