mirror of
https://git.wownero.com/wownero/wownero.git
synced 2024-08-15 01:03:23 +00:00
core: include a dummy encrypted payment id when no payment is used
For better transaction uniformity, even though this wastes space.
This commit is contained in:
parent
d85d908ddc
commit
4411a412be
4 changed files with 146 additions and 15 deletions
|
@ -226,13 +226,15 @@ namespace cryptonote
|
||||||
std::vector<tx_extra_field> tx_extra_fields;
|
std::vector<tx_extra_field> tx_extra_fields;
|
||||||
if (parse_tx_extra(tx.extra, tx_extra_fields))
|
if (parse_tx_extra(tx.extra, tx_extra_fields))
|
||||||
{
|
{
|
||||||
|
bool add_dummy_payment_id = true;
|
||||||
tx_extra_nonce extra_nonce;
|
tx_extra_nonce extra_nonce;
|
||||||
if (find_tx_extra_field_by_type(tx_extra_fields, extra_nonce))
|
if (find_tx_extra_field_by_type(tx_extra_fields, extra_nonce))
|
||||||
{
|
{
|
||||||
crypto::hash8 payment_id = null_hash8;
|
crypto::hash payment_id = null_hash;
|
||||||
if (get_encrypted_payment_id_from_tx_extra_nonce(extra_nonce.nonce, payment_id))
|
crypto::hash8 payment_id8 = null_hash8;
|
||||||
|
if (get_encrypted_payment_id_from_tx_extra_nonce(extra_nonce.nonce, payment_id8))
|
||||||
{
|
{
|
||||||
LOG_PRINT_L2("Encrypting payment id " << payment_id);
|
LOG_PRINT_L2("Encrypting payment id " << payment_id8);
|
||||||
crypto::public_key view_key_pub = get_destination_view_key_pub(destinations, change_addr);
|
crypto::public_key view_key_pub = get_destination_view_key_pub(destinations, change_addr);
|
||||||
if (view_key_pub == null_pkey)
|
if (view_key_pub == null_pkey)
|
||||||
{
|
{
|
||||||
|
@ -240,21 +242,53 @@ namespace cryptonote
|
||||||
return false;
|
return false;
|
||||||
}
|
}
|
||||||
|
|
||||||
if (!hwdev.encrypt_payment_id(payment_id, view_key_pub, tx_key))
|
if (!hwdev.encrypt_payment_id(payment_id8, view_key_pub, tx_key))
|
||||||
{
|
{
|
||||||
LOG_ERROR("Failed to encrypt payment id");
|
LOG_ERROR("Failed to encrypt payment id");
|
||||||
return false;
|
return false;
|
||||||
}
|
}
|
||||||
|
|
||||||
std::string extra_nonce;
|
std::string extra_nonce;
|
||||||
set_encrypted_payment_id_to_tx_extra_nonce(extra_nonce, payment_id);
|
set_encrypted_payment_id_to_tx_extra_nonce(extra_nonce, payment_id8);
|
||||||
remove_field_from_tx_extra(tx.extra, typeid(tx_extra_nonce));
|
remove_field_from_tx_extra(tx.extra, typeid(tx_extra_nonce));
|
||||||
if (!add_extra_nonce_to_tx_extra(tx.extra, extra_nonce))
|
if (!add_extra_nonce_to_tx_extra(tx.extra, extra_nonce))
|
||||||
{
|
{
|
||||||
LOG_ERROR("Failed to add encrypted payment id to tx extra");
|
LOG_ERROR("Failed to add encrypted payment id to tx extra");
|
||||||
return false;
|
return false;
|
||||||
}
|
}
|
||||||
LOG_PRINT_L1("Encrypted payment ID: " << payment_id);
|
LOG_PRINT_L1("Encrypted payment ID: " << payment_id8);
|
||||||
|
add_dummy_payment_id = false;
|
||||||
|
}
|
||||||
|
else if (get_payment_id_from_tx_extra_nonce(extra_nonce.nonce, payment_id))
|
||||||
|
{
|
||||||
|
add_dummy_payment_id = false;
|
||||||
|
}
|
||||||
|
}
|
||||||
|
|
||||||
|
// we don't add one if we've got more than the usual 1 destination plus change
|
||||||
|
if (destinations.size() > 2)
|
||||||
|
add_dummy_payment_id = false;
|
||||||
|
|
||||||
|
if (add_dummy_payment_id)
|
||||||
|
{
|
||||||
|
// if we have neither long nor short payment id, add a dummy short one,
|
||||||
|
// this should end up being the vast majority of txes as time goes on
|
||||||
|
std::string extra_nonce;
|
||||||
|
crypto::hash8 payment_id8 = null_hash8;
|
||||||
|
crypto::public_key view_key_pub = get_destination_view_key_pub(destinations, change_addr);
|
||||||
|
if (view_key_pub == null_pkey)
|
||||||
|
{
|
||||||
|
LOG_ERROR("Failed to get key to encrypt dummy payment id with");
|
||||||
|
}
|
||||||
|
else
|
||||||
|
{
|
||||||
|
hwdev.encrypt_payment_id(payment_id8, view_key_pub, tx_key);
|
||||||
|
set_encrypted_payment_id_to_tx_extra_nonce(extra_nonce, payment_id8);
|
||||||
|
if (!add_extra_nonce_to_tx_extra(tx.extra, extra_nonce))
|
||||||
|
{
|
||||||
|
LOG_ERROR("Failed to add dummy encrypted payment id to tx extra");
|
||||||
|
// continue anyway
|
||||||
|
}
|
||||||
}
|
}
|
||||||
}
|
}
|
||||||
}
|
}
|
||||||
|
|
34
src/net/string.cpp
Normal file
34
src/net/string.cpp
Normal file
|
@ -0,0 +1,34 @@
|
||||||
|
|
||||||
|
|
||||||
|
#include "string.h"
|
||||||
|
|
||||||
|
#include "net/tor_address.h"
|
||||||
|
#include "string_tools.h"
|
||||||
|
|
||||||
|
namespace net
|
||||||
|
{
|
||||||
|
expect<epee::net_utils::network_address>
|
||||||
|
get_network_address(const boost::string_ref address, const std::uint16_t default_port)
|
||||||
|
{
|
||||||
|
const boost::string_ref host = address.substr(0, address.rfind(':'));
|
||||||
|
|
||||||
|
if (host.empty())
|
||||||
|
return make_error_code(net::error::kInvalidHost);
|
||||||
|
if (host.ends_with(".onion"))
|
||||||
|
return tor_address::make(address, default_port);
|
||||||
|
if (host.ends_with(".i2p"))
|
||||||
|
return make_error_code(net::error::kInvalidI2PAddress); // not yet implemented (prevent public DNS lookup)
|
||||||
|
|
||||||
|
std::uint16_t port = default_port;
|
||||||
|
if (host.size() < address.size())
|
||||||
|
{
|
||||||
|
if (!epee::string_tools::get_xtype_from_string(port, std::string{address.substr(host.size() + 1)}))
|
||||||
|
return make_error_code(net::error::kInvalidPort);
|
||||||
|
}
|
||||||
|
|
||||||
|
std::uint32_t ip = 0;
|
||||||
|
if (epee::string_tools::get_ip_int32_from_string(ip, std::string{host}))
|
||||||
|
return {epee::net_utils::ipv4_network_address{ip, port}};
|
||||||
|
return make_error_code(net::error::kUnsupportedAddress);
|
||||||
|
}
|
||||||
|
}
|
54
src/net/string.h
Normal file
54
src/net/string.h
Normal file
|
@ -0,0 +1,54 @@
|
||||||
|
// 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.
|
||||||
|
|
||||||
|
#pragma once
|
||||||
|
|
||||||
|
#include <boost/utility/string_ref.hpp>
|
||||||
|
#include <cstdint>
|
||||||
|
|
||||||
|
#include "common/expect.h"
|
||||||
|
#include "net/net_utils_base.h"
|
||||||
|
|
||||||
|
namespace net
|
||||||
|
{
|
||||||
|
/*!
|
||||||
|
Identifies onion and IPv4 addresses and returns them as a generic
|
||||||
|
`network_address`. If the type is unsupported, it might be a hostname,
|
||||||
|
and `error() == net::error::kUnsupportedAddress` is returned.
|
||||||
|
|
||||||
|
\param address An onion address, ipv4 address or hostname. Hostname
|
||||||
|
will return an error.
|
||||||
|
\param default_port If `address` does not specify a port, this value
|
||||||
|
will be used.
|
||||||
|
|
||||||
|
\return A tor or IPv4 address, else error.
|
||||||
|
*/
|
||||||
|
expect<epee::net_utils::network_address>
|
||||||
|
get_network_address(boost::string_ref address, std::uint16_t default_port);
|
||||||
|
}
|
||||||
|
|
|
@ -4563,12 +4563,8 @@ void simple_wallet::on_money_received(uint64_t height, const crypto::hash &txid,
|
||||||
tx_extra_nonce extra_nonce;
|
tx_extra_nonce extra_nonce;
|
||||||
if (find_tx_extra_field_by_type(tx_extra_fields, extra_nonce))
|
if (find_tx_extra_field_by_type(tx_extra_fields, extra_nonce))
|
||||||
{
|
{
|
||||||
crypto::hash8 payment_id8 = crypto::null_hash8;
|
|
||||||
crypto::hash payment_id = crypto::null_hash;
|
crypto::hash payment_id = crypto::null_hash;
|
||||||
if (get_encrypted_payment_id_from_tx_extra_nonce(extra_nonce.nonce, payment_id8))
|
if (get_payment_id_from_tx_extra_nonce(extra_nonce.nonce, payment_id))
|
||||||
message_writer() <<
|
|
||||||
tr("NOTE: this transaction uses an encrypted payment ID: consider using subaddresses instead");
|
|
||||||
else if (get_payment_id_from_tx_extra_nonce(extra_nonce.nonce, payment_id))
|
|
||||||
message_writer(console_color_red, false) <<
|
message_writer(console_color_red, false) <<
|
||||||
tr("WARNING: this transaction uses an unencrypted payment ID: these are obsolete. Use subaddresses instead.");
|
tr("WARNING: this transaction uses an unencrypted payment ID: these are obsolete. Use subaddresses instead.");
|
||||||
}
|
}
|
||||||
|
@ -6391,15 +6387,28 @@ bool simple_wallet::accept_loaded_tx(const std::function<size_t()> get_num_txes,
|
||||||
{
|
{
|
||||||
if (!payment_id_string.empty())
|
if (!payment_id_string.empty())
|
||||||
payment_id_string += ", ";
|
payment_id_string += ", ";
|
||||||
payment_id_string = std::string("encrypted payment ID ") + epee::string_tools::pod_to_hex(payment_id8);
|
|
||||||
has_encrypted_payment_id = true;
|
// if none of the addresses are integrated addresses, it's a dummy one
|
||||||
|
bool is_dummy = true;
|
||||||
|
for (const auto &e: cd.dests)
|
||||||
|
if (e.is_integrated)
|
||||||
|
is_dummy = false;
|
||||||
|
|
||||||
|
if (is_dummy)
|
||||||
|
{
|
||||||
|
payment_id_string += std::string("dummy encrypted payment ID");
|
||||||
|
}
|
||||||
|
else
|
||||||
|
{
|
||||||
|
payment_id_string += std::string("encrypted payment ID ") + epee::string_tools::pod_to_hex(payment_id8);
|
||||||
|
has_encrypted_payment_id = true;
|
||||||
|
}
|
||||||
}
|
}
|
||||||
else if (get_payment_id_from_tx_extra_nonce(extra_nonce.nonce, payment_id))
|
else if (get_payment_id_from_tx_extra_nonce(extra_nonce.nonce, payment_id))
|
||||||
{
|
{
|
||||||
if (!payment_id_string.empty())
|
if (!payment_id_string.empty())
|
||||||
payment_id_string += ", ";
|
payment_id_string += ", ";
|
||||||
payment_id_string = std::string("unencrypted payment ID ") + epee::string_tools::pod_to_hex(payment_id);
|
payment_id_string += std::string("unencrypted payment ID ") + epee::string_tools::pod_to_hex(payment_id);
|
||||||
payment_id_string += " (OBSOLETE)";
|
|
||||||
}
|
}
|
||||||
}
|
}
|
||||||
}
|
}
|
||||||
|
|
Loading…
Reference in a new issue