// Copyright (c) 2014-2023, 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. #ifndef DAEMON_COMMAND_LINE_ARGS_H #define DAEMON_COMMAND_LINE_ARGS_H #include "common/command_line.h" #include "cryptonote_config.h" #include "daemonizer/daemonizer.h" namespace daemon_args { std::string const WINDOWS_SERVICE_NAME = "Monero Daemon"; const command_line::arg_descriptor arg_config_file = { "config-file" , "Specify configuration file" , (daemonizer::get_default_data_dir() / std::string(CRYPTONOTE_NAME ".conf")).string() , {{ &cryptonote::arg_testnet_on, &cryptonote::arg_stagenet_on }} , [](std::array testnet_stagenet, bool defaulted, std::string val)->std::string { if (testnet_stagenet[0] && defaulted) return (daemonizer::get_default_data_dir() / "testnet" / std::string(CRYPTONOTE_NAME ".conf")).string(); else if (testnet_stagenet[1] && defaulted) return (daemonizer::get_default_data_dir() / "stagenet" / std::string(CRYPTONOTE_NAME ".conf")).string(); return val; } }; const command_line::arg_descriptor arg_log_file = { "log-file" , "Specify log file" , (daemonizer::get_default_data_dir() / std::string(CRYPTONOTE_NAME ".log")).string() , {{ &cryptonote::arg_testnet_on, &cryptonote::arg_stagenet_on }} , [](std::array testnet_stagenet, bool defaulted, std::string val)->std::string { if (testnet_stagenet[0] && defaulted) return (daemonizer::get_default_data_dir() / "testnet" / std::string(CRYPTONOTE_NAME ".log")).string(); else if (testnet_stagenet[1] && defaulted) return (daemonizer::get_default_data_dir() / "stagenet" / std::string(CRYPTONOTE_NAME ".log")).string(); return val; } }; const command_line::arg_descriptor arg_max_log_file_size = { "max-log-file-size" , "Specify maximum log file size [B]" , MAX_LOG_FILE_SIZE }; const command_line::arg_descriptor arg_max_log_files = { "max-log-files" , "Specify maximum number of rotated log files to be saved (no limit by setting to 0)" , MAX_LOG_FILES }; const command_line::arg_descriptor arg_log_level = { "log-level" , "" , "" }; const command_line::arg_descriptor> arg_command = { "daemon_command" , "Hidden" }; const command_line::arg_descriptor arg_max_concurrency = { "max-concurrency" , "Max number of threads to use for a parallel job" , 0 }; const command_line::arg_descriptor arg_proxy = { "proxy", "Network communication through proxy: i.e. \"127.0.0.1:9050\"", "", }; const command_line::arg_descriptor arg_proxy_allow_dns_leaks = { "proxy-allow-dns-leaks", "Allow DNS leaks outside of proxy", false, }; const command_line::arg_descriptor arg_public_node = { "public-node" , "Allow other users to use the node as a remote (restricted RPC mode, view-only commands) and advertise it over P2P" , false }; const command_line::arg_descriptor arg_zmq_rpc_bind_ip = { "zmq-rpc-bind-ip" , "IP for ZMQ RPC server to listen on" , "127.0.0.1" }; const command_line::arg_descriptor arg_zmq_rpc_bind_port = { "zmq-rpc-bind-port" , "Port for ZMQ RPC server to listen on" , std::to_string(config::ZMQ_RPC_DEFAULT_PORT) , {{ &cryptonote::arg_testnet_on, &cryptonote::arg_stagenet_on }} , [](std::array testnet_stagenet, bool defaulted, std::string val)->std::string { if (testnet_stagenet[0] && defaulted) return std::to_string(config::testnet::ZMQ_RPC_DEFAULT_PORT); if (testnet_stagenet[1] && defaulted) return std::to_string(config::stagenet::ZMQ_RPC_DEFAULT_PORT); return val; } }; const command_line::arg_descriptor> arg_zmq_pub = { "zmq-pub" , "Address for ZMQ pub - tcp://ip:port or ipc://path" }; const command_line::arg_descriptor arg_zmq_rpc_disabled = { "no-zmq" , "Disable ZMQ RPC server" }; } // namespace daemon_args #endif // DAEMON_COMMAND_LINE_ARGS_H