mirror of
https://github.com/Palakis/obs-websocket.git
synced 2024-08-30 18:12:16 +00:00
Config, websocketserver: Add feature to bind to loopback (default)
Binds to localhost or 127.0.0.1 by default, since most users don't have to access obs-websocket externally.
This commit is contained in:
parent
226c81ce78
commit
1da0214201
@ -28,6 +28,7 @@ with this program. If not, see <https://www.gnu.org/licenses/>
|
|||||||
#define PARAM_FIRSTLOAD "FirstLoad"
|
#define PARAM_FIRSTLOAD "FirstLoad"
|
||||||
#define PARAM_ENABLED "ServerEnabled"
|
#define PARAM_ENABLED "ServerEnabled"
|
||||||
#define PARAM_PORT "ServerPort"
|
#define PARAM_PORT "ServerPort"
|
||||||
|
#define PARAM_BINDLOOPBACK "BindLoopback"
|
||||||
#define PARAM_ALERTS "AlertsEnabled"
|
#define PARAM_ALERTS "AlertsEnabled"
|
||||||
#define PARAM_AUTHREQUIRED "AuthRequired"
|
#define PARAM_AUTHREQUIRED "AuthRequired"
|
||||||
#define PARAM_PASSWORD "ServerPassword"
|
#define PARAM_PASSWORD "ServerPassword"
|
||||||
@ -43,6 +44,7 @@ Config::Config() :
|
|||||||
FirstLoad(true),
|
FirstLoad(true),
|
||||||
ServerEnabled(true),
|
ServerEnabled(true),
|
||||||
ServerPort(4455),
|
ServerPort(4455),
|
||||||
|
BindLoopback(true),
|
||||||
Ipv4Only(false),
|
Ipv4Only(false),
|
||||||
DebugEnabled(false),
|
DebugEnabled(false),
|
||||||
AlertsEnabled(false),
|
AlertsEnabled(false),
|
||||||
@ -64,6 +66,7 @@ void Config::Load()
|
|||||||
ServerEnabled = config_get_bool(obsConfig, CONFIG_SECTION_NAME, PARAM_ENABLED);
|
ServerEnabled = config_get_bool(obsConfig, CONFIG_SECTION_NAME, PARAM_ENABLED);
|
||||||
AlertsEnabled = config_get_bool(obsConfig, CONFIG_SECTION_NAME, PARAM_ALERTS);
|
AlertsEnabled = config_get_bool(obsConfig, CONFIG_SECTION_NAME, PARAM_ALERTS);
|
||||||
ServerPort = config_get_uint(obsConfig, CONFIG_SECTION_NAME, PARAM_PORT);
|
ServerPort = config_get_uint(obsConfig, CONFIG_SECTION_NAME, PARAM_PORT);
|
||||||
|
BindLoopback = config_get_bool(obsConfig, CONFIG_SECTION_NAME, PARAM_BINDLOOPBACK);
|
||||||
AuthRequired = config_get_bool(obsConfig, CONFIG_SECTION_NAME, PARAM_AUTHREQUIRED);
|
AuthRequired = config_get_bool(obsConfig, CONFIG_SECTION_NAME, PARAM_AUTHREQUIRED);
|
||||||
ServerPassword = config_get_string(obsConfig, CONFIG_SECTION_NAME, PARAM_PASSWORD);
|
ServerPassword = config_get_string(obsConfig, CONFIG_SECTION_NAME, PARAM_PASSWORD);
|
||||||
|
|
||||||
@ -131,6 +134,7 @@ void Config::Save()
|
|||||||
if (!PortOverridden) {
|
if (!PortOverridden) {
|
||||||
config_set_uint(obsConfig, CONFIG_SECTION_NAME, PARAM_PORT, ServerPort);
|
config_set_uint(obsConfig, CONFIG_SECTION_NAME, PARAM_PORT, ServerPort);
|
||||||
}
|
}
|
||||||
|
config_set_bool(obsConfig, CONFIG_SECTION_NAME, PARAM_BINDLOOPBACK, BindLoopback);
|
||||||
config_set_bool(obsConfig, CONFIG_SECTION_NAME, PARAM_ALERTS, AlertsEnabled);
|
config_set_bool(obsConfig, CONFIG_SECTION_NAME, PARAM_ALERTS, AlertsEnabled);
|
||||||
if (!PasswordOverridden) {
|
if (!PasswordOverridden) {
|
||||||
config_set_bool(obsConfig, CONFIG_SECTION_NAME, PARAM_AUTHREQUIRED, AuthRequired);
|
config_set_bool(obsConfig, CONFIG_SECTION_NAME, PARAM_AUTHREQUIRED, AuthRequired);
|
||||||
@ -151,6 +155,7 @@ void Config::SetDefaultsToGlobalStore()
|
|||||||
config_set_default_bool(obsConfig, CONFIG_SECTION_NAME, PARAM_FIRSTLOAD, FirstLoad);
|
config_set_default_bool(obsConfig, CONFIG_SECTION_NAME, PARAM_FIRSTLOAD, FirstLoad);
|
||||||
config_set_default_bool(obsConfig, CONFIG_SECTION_NAME, PARAM_ENABLED, ServerEnabled);
|
config_set_default_bool(obsConfig, CONFIG_SECTION_NAME, PARAM_ENABLED, ServerEnabled);
|
||||||
config_set_default_uint(obsConfig, CONFIG_SECTION_NAME, PARAM_PORT, ServerPort);
|
config_set_default_uint(obsConfig, CONFIG_SECTION_NAME, PARAM_PORT, ServerPort);
|
||||||
|
config_set_default_bool(obsConfig, CONFIG_SECTION_NAME, PARAM_BINDLOOPBACK, BindLoopback);
|
||||||
config_set_default_bool(obsConfig, CONFIG_SECTION_NAME, PARAM_ALERTS, AlertsEnabled);
|
config_set_default_bool(obsConfig, CONFIG_SECTION_NAME, PARAM_ALERTS, AlertsEnabled);
|
||||||
config_set_default_bool(obsConfig, CONFIG_SECTION_NAME, PARAM_AUTHREQUIRED, AuthRequired);
|
config_set_default_bool(obsConfig, CONFIG_SECTION_NAME, PARAM_AUTHREQUIRED, AuthRequired);
|
||||||
config_set_default_string(obsConfig, CONFIG_SECTION_NAME, PARAM_PASSWORD, QT_TO_UTF8(ServerPassword));
|
config_set_default_string(obsConfig, CONFIG_SECTION_NAME, PARAM_PASSWORD, QT_TO_UTF8(ServerPassword));
|
||||||
|
@ -38,6 +38,7 @@ struct Config {
|
|||||||
std::atomic<bool> FirstLoad;
|
std::atomic<bool> FirstLoad;
|
||||||
std::atomic<bool> ServerEnabled;
|
std::atomic<bool> ServerEnabled;
|
||||||
std::atomic<uint16_t> ServerPort;
|
std::atomic<uint16_t> ServerPort;
|
||||||
|
std::atomic<bool> BindLoopback;
|
||||||
std::atomic<bool> Ipv4Only;
|
std::atomic<bool> Ipv4Only;
|
||||||
std::atomic<bool> DebugEnabled;
|
std::atomic<bool> DebugEnabled;
|
||||||
std::atomic<bool> AlertsEnabled;
|
std::atomic<bool> AlertsEnabled;
|
||||||
|
@ -76,6 +76,21 @@ std::string Utils::Platform::GetLocalAddress()
|
|||||||
return preferredAddresses[0].first.toStdString();
|
return preferredAddresses[0].first.toStdString();
|
||||||
}
|
}
|
||||||
|
|
||||||
|
std::string Utils::Platform::GetLoopbackAddress(bool allowIpv6)
|
||||||
|
{
|
||||||
|
std::vector<QString> validAddresses;
|
||||||
|
for (auto address : QNetworkInterface::allAddresses()) {
|
||||||
|
if (address == QHostAddress::LocalHost)
|
||||||
|
return address.toString().toStdString();
|
||||||
|
else if (address == QHostAddress::LocalHostIPv6 && allowIpv6)
|
||||||
|
return address.toString().toStdString();
|
||||||
|
else if (address.isLoopback())
|
||||||
|
return address.toString().toStdString();
|
||||||
|
}
|
||||||
|
|
||||||
|
return "";
|
||||||
|
}
|
||||||
|
|
||||||
QString Utils::Platform::GetCommandLineArgument(QString arg)
|
QString Utils::Platform::GetCommandLineArgument(QString arg)
|
||||||
{
|
{
|
||||||
QCommandLineParser parser;
|
QCommandLineParser parser;
|
||||||
|
@ -26,6 +26,7 @@ with this program. If not, see <https://www.gnu.org/licenses/>
|
|||||||
namespace Utils {
|
namespace Utils {
|
||||||
namespace Platform {
|
namespace Platform {
|
||||||
std::string GetLocalAddress();
|
std::string GetLocalAddress();
|
||||||
|
std::string GetLoopbackAddress(bool allowIpv6 = true);
|
||||||
QString GetCommandLineArgument(QString arg);
|
QString GetCommandLineArgument(QString arg);
|
||||||
bool GetCommandLineFlagSet(QString arg);
|
bool GetCommandLineFlagSet(QString arg);
|
||||||
void SendTrayNotification(QSystemTrayIcon::MessageIcon icon, QString title, QString body);
|
void SendTrayNotification(QSystemTrayIcon::MessageIcon icon, QString title, QString body);
|
||||||
|
@ -129,17 +129,25 @@ void WebSocketServer::Start()
|
|||||||
_server.reset();
|
_server.reset();
|
||||||
|
|
||||||
websocketpp::lib::error_code errorCode;
|
websocketpp::lib::error_code errorCode;
|
||||||
if (conf->Ipv4Only) {
|
if (conf->BindLoopback) {
|
||||||
blog(LOG_INFO, "[WebSocketServer::Start] Locked to IPv4 bindings");
|
std::string addr = Utils::Platform::GetLoopbackAddress(!conf->Ipv4Only);
|
||||||
|
if (addr.empty()) {
|
||||||
|
blog(LOG_ERROR, "[WebSocketServer::Start] Failed to find loopback interface. Server not started.");
|
||||||
|
return;
|
||||||
|
}
|
||||||
|
_server.listen(addr, std::to_string(conf->ServerPort), errorCode);
|
||||||
|
blog(LOG_INFO, "[WebSocketServer::Start] Locked to loopback interface.");
|
||||||
|
} else if (conf->Ipv4Only) {
|
||||||
_server.listen(websocketpp::lib::asio::ip::tcp::v4(), conf->ServerPort, errorCode);
|
_server.listen(websocketpp::lib::asio::ip::tcp::v4(), conf->ServerPort, errorCode);
|
||||||
|
blog(LOG_INFO, "[WebSocketServer::Start] Locked to IPv4 bindings.");
|
||||||
} else {
|
} else {
|
||||||
blog(LOG_INFO, "[WebSocketServer::Start] Not locked to IPv4 bindings");
|
|
||||||
_server.listen(conf->ServerPort, errorCode);
|
_server.listen(conf->ServerPort, errorCode);
|
||||||
|
blog(LOG_INFO, "[WebSocketServer::Start] Not locked to IPv4 bindings.");
|
||||||
}
|
}
|
||||||
|
|
||||||
if (errorCode) {
|
if (errorCode) {
|
||||||
std::string errorCodeMessage = errorCode.message();
|
std::string errorCodeMessage = errorCode.message();
|
||||||
blog(LOG_INFO, "[WebSocketServer::Start] Listen failed: %s", errorCodeMessage.c_str());
|
blog(LOG_ERROR, "[WebSocketServer::Start] Listen failed: %s", errorCodeMessage.c_str());
|
||||||
return;
|
return;
|
||||||
}
|
}
|
||||||
|
|
||||||
|
Loading…
Reference in New Issue
Block a user