2020-05-07 02:36:54 +00:00
|
|
|
// Copyright (c) 2014-2020, The Monero Project
|
2017-02-05 22:48:03 +00:00
|
|
|
//
|
2014-07-23 13:03:52 +00:00
|
|
|
// All rights reserved.
|
2017-02-05 22:48:03 +00:00
|
|
|
//
|
2014-07-23 13:03:52 +00:00
|
|
|
// Redistribution and use in source and binary forms, with or without modification, are
|
|
|
|
// permitted provided that the following conditions are met:
|
2017-02-05 22:48:03 +00:00
|
|
|
//
|
2014-07-23 13:03:52 +00:00
|
|
|
// 1. Redistributions of source code must retain the above copyright notice, this list of
|
|
|
|
// conditions and the following disclaimer.
|
2017-02-05 22:48:03 +00:00
|
|
|
//
|
2014-07-23 13:03:52 +00:00
|
|
|
// 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.
|
2017-02-05 22:48:03 +00:00
|
|
|
//
|
2014-07-23 13:03:52 +00:00
|
|
|
// 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.
|
2017-02-05 22:48:03 +00:00
|
|
|
//
|
2014-07-23 13:03:52 +00:00
|
|
|
// 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.
|
2017-02-05 22:48:03 +00:00
|
|
|
//
|
2014-03-03 22:07:58 +00:00
|
|
|
#pragma once
|
|
|
|
|
2016-12-17 23:07:15 +00:00
|
|
|
#include <boost/optional/optional.hpp>
|
2017-02-05 22:48:03 +00:00
|
|
|
#include <boost/program_options/options_description.hpp>
|
|
|
|
#include <boost/program_options/variables_map.hpp>
|
|
|
|
#include <string>
|
|
|
|
|
|
|
|
#include "common/command_line.h"
|
|
|
|
#include "common/password.h"
|
2019-05-22 04:09:11 +00:00
|
|
|
#include "net/net_ssl.h"
|
2014-03-03 22:07:58 +00:00
|
|
|
|
2017-02-05 22:48:03 +00:00
|
|
|
namespace cryptonote
|
2014-03-03 22:07:58 +00:00
|
|
|
{
|
2017-02-05 22:48:03 +00:00
|
|
|
//! Processes command line arguments related to server-side RPC
|
|
|
|
struct rpc_args
|
2014-03-03 22:07:58 +00:00
|
|
|
{
|
2017-02-05 22:48:03 +00:00
|
|
|
// non-static construction prevents initialization order issues
|
|
|
|
struct descriptors
|
|
|
|
{
|
|
|
|
descriptors();
|
|
|
|
descriptors(const descriptors&) = delete;
|
|
|
|
descriptors(descriptors&&) = delete;
|
|
|
|
descriptors& operator=(const descriptors&) = delete;
|
|
|
|
descriptors& operator=(descriptors&&) = delete;
|
2016-12-17 23:07:15 +00:00
|
|
|
|
2017-02-05 22:48:03 +00:00
|
|
|
const command_line::arg_descriptor<std::string> rpc_bind_ip;
|
2019-04-10 22:34:30 +00:00
|
|
|
const command_line::arg_descriptor<std::string> rpc_bind_ipv6_address;
|
2020-10-28 23:47:42 +00:00
|
|
|
const command_line::arg_descriptor<std::string> rpc_restricted_bind_ip;
|
|
|
|
const command_line::arg_descriptor<std::string> rpc_restricted_bind_ipv6_address;
|
2019-04-10 22:34:30 +00:00
|
|
|
const command_line::arg_descriptor<bool> rpc_use_ipv6;
|
2019-10-13 13:27:46 +00:00
|
|
|
const command_line::arg_descriptor<bool> rpc_ignore_ipv4;
|
2017-02-05 22:48:03 +00:00
|
|
|
const command_line::arg_descriptor<std::string> rpc_login;
|
|
|
|
const command_line::arg_descriptor<bool> confirm_external_bind;
|
2017-10-24 13:26:05 +00:00
|
|
|
const command_line::arg_descriptor<std::string> rpc_access_control_origins;
|
2019-05-22 04:09:11 +00:00
|
|
|
const command_line::arg_descriptor<std::string> rpc_ssl;
|
|
|
|
const command_line::arg_descriptor<std::string> rpc_ssl_private_key;
|
|
|
|
const command_line::arg_descriptor<std::string> rpc_ssl_certificate;
|
|
|
|
const command_line::arg_descriptor<std::string> rpc_ssl_ca_certificates;
|
|
|
|
const command_line::arg_descriptor<std::vector<std::string>> rpc_ssl_allowed_fingerprints;
|
|
|
|
const command_line::arg_descriptor<bool> rpc_ssl_allow_chained;
|
|
|
|
const command_line::arg_descriptor<bool> rpc_ssl_allow_any_cert;
|
2019-12-04 12:21:39 +00:00
|
|
|
const command_line::arg_descriptor<bool> disable_rpc_ban;
|
2017-02-05 22:48:03 +00:00
|
|
|
};
|
2014-03-03 22:07:58 +00:00
|
|
|
|
2019-05-22 04:09:11 +00:00
|
|
|
// `allow_any_cert` bool toggles `--rpc-ssl-allow-any-cert` configuration
|
|
|
|
|
2017-02-05 22:48:03 +00:00
|
|
|
static const char* tr(const char* str);
|
2019-05-22 04:09:11 +00:00
|
|
|
static void init_options(boost::program_options::options_description& desc, const bool any_cert_option = false);
|
2016-12-17 23:07:15 +00:00
|
|
|
|
2017-02-05 22:48:03 +00:00
|
|
|
//! \return Arguments specified by user, or `boost::none` if error
|
2019-05-22 04:09:11 +00:00
|
|
|
static boost::optional<rpc_args> process(const boost::program_options::variables_map& vm, const bool any_cert_option = false);
|
|
|
|
|
|
|
|
//! \return SSL arguments specified by user, or `boost::none` if error
|
|
|
|
static boost::optional<epee::net_utils::ssl_options_t> process_ssl(const boost::program_options::variables_map& vm, const bool any_cert_option = false);
|
2016-12-17 23:07:15 +00:00
|
|
|
|
2017-02-05 22:48:03 +00:00
|
|
|
std::string bind_ip;
|
2019-04-10 22:34:30 +00:00
|
|
|
std::string bind_ipv6_address;
|
2020-10-28 23:47:42 +00:00
|
|
|
std::string restricted_bind_ip;
|
|
|
|
std::string restricted_bind_ipv6_address;
|
2019-04-10 22:34:30 +00:00
|
|
|
bool use_ipv6;
|
|
|
|
bool require_ipv4;
|
2017-10-24 13:26:05 +00:00
|
|
|
std::vector<std::string> access_control_origins;
|
2017-02-05 22:48:03 +00:00
|
|
|
boost::optional<tools::login> login; // currently `boost::none` if unspecified by user
|
2019-05-22 04:09:11 +00:00
|
|
|
epee::net_utils::ssl_options_t ssl_options = epee::net_utils::ssl_support_t::e_ssl_support_enabled;
|
2019-12-04 12:21:39 +00:00
|
|
|
bool disable_rpc_ban = false;
|
2014-03-03 22:07:58 +00:00
|
|
|
};
|
|
|
|
}
|