mirror of
https://github.com/keepassxreboot/keepassxc.git
synced 2025-01-27 23:07:11 -05:00
Incorporated fix for IPV6 remote server
This commit is contained in:
parent
bb2e1ee8da
commit
99bb5d33f2
@ -323,51 +323,76 @@ void Server::request_completed(void *, struct MHD_Connection *,
|
|||||||
|
|
||||||
void Server::start(void)
|
void Server::start(void)
|
||||||
{
|
{
|
||||||
if (m_started) return;
|
if (m_started)
|
||||||
|
return;
|
||||||
|
|
||||||
int port = HttpSettings::httpPort();
|
|
||||||
|
|
||||||
struct sockaddr_in as;
|
|
||||||
struct sockaddr_in *ss = &as;
|
|
||||||
bool nohost = true;
|
bool nohost = true;
|
||||||
|
int port = HttpSettings::httpPort();
|
||||||
|
|
||||||
QHostInfo info = QHostInfo::fromName(HttpSettings::httpHost());
|
QHostInfo info = QHostInfo::fromName(HttpSettings::httpHost());
|
||||||
if (!info.addresses().isEmpty()) {
|
if (!info.addresses().isEmpty()) {
|
||||||
|
void* addrx = NULL;
|
||||||
|
unsigned int flags = MHD_USE_SELECT_INTERNALLY;
|
||||||
QHostAddress address = info.addresses().first();
|
QHostAddress address = info.addresses().first();
|
||||||
|
|
||||||
if (address.protocol() == QAbstractSocket::IPv4Protocol) {
|
if (address.protocol() == QAbstractSocket::IPv4Protocol) {
|
||||||
struct sockaddr_in* addr = ss;
|
struct sockaddr_in *addr = static_cast<struct sockaddr_in*>(calloc(1, sizeof(struct sockaddr_in)));
|
||||||
memset(addr, 0, sizeof(struct sockaddr_in));
|
addrx = static_cast<void*>(addr);
|
||||||
addr->sin_family = AF_INET;
|
addr->sin_family = AF_INET;
|
||||||
addr->sin_port = htons(HttpSettings::httpPort());
|
addr->sin_port = htons(HttpSettings::httpPort());
|
||||||
addr->sin_addr.s_addr = htonl(address.toIPv4Address());
|
addr->sin_addr.s_addr = htonl(address.toIPv4Address());
|
||||||
nohost = false;
|
nohost = false;
|
||||||
#ifdef MHD_USE_IPv6
|
//qWarning("HTTPPlugin: IPv4 host configured");
|
||||||
} else {
|
} else {
|
||||||
struct sockaddr_in6* addr = (sockaddr_in6*)ss;
|
if (MHD_YES == MHD_is_feature_supported(MHD_FEATURE_IPv6)) {
|
||||||
memset(addr, 0, sizeof(struct sockaddr_in6));
|
struct sockaddr_in6 *addr = static_cast<struct sockaddr_in6*>(calloc(1, sizeof(struct sockaddr_in6)));
|
||||||
addr->sin6_family = AF_INET6;
|
addrx = static_cast<void*>(addr);
|
||||||
addr->sin6_port = htons(HttpSettings::httpPort());
|
addr->sin6_family = AF_INET6;
|
||||||
memcpy(&addr->sin6_addr, address.toIPv6Address().c, 16);
|
addr->sin6_port = htons(HttpSettings::httpPort());
|
||||||
nohost = false;
|
memcpy(&addr->sin6_addr, address.toIPv6Address().c, 16);
|
||||||
#endif
|
nohost = false;
|
||||||
|
flags |= MHD_USE_IPv6;
|
||||||
|
/*
|
||||||
|
qWarning("HTTPPlugin: IPv6 host configured and IPv6 enabled");
|
||||||
|
} else {
|
||||||
|
qWarning("HTTPPlugin: IPv6 host configured but IPv6 support disabled!");
|
||||||
|
*/
|
||||||
|
}
|
||||||
}
|
}
|
||||||
|
|
||||||
daemon = MHD_start_daemon(MHD_USE_SELECT_INTERNALLY, port, NULL, NULL,
|
if (nohost) {
|
||||||
&this->request_handler_wrapper, this,
|
qWarning("HTTPPlugin: Faled to get configured host!");
|
||||||
MHD_OPTION_NOTIFY_COMPLETED,
|
} else {
|
||||||
this->request_completed, NULL,
|
if (NULL == (daemon = MHD_start_daemon(flags, port, NULL, NULL,
|
||||||
MHD_OPTION_SOCK_ADDR,
|
&this->request_handler_wrapper, this,
|
||||||
ss,
|
MHD_OPTION_NOTIFY_COMPLETED,
|
||||||
MHD_OPTION_END);
|
this->request_completed, NULL,
|
||||||
|
MHD_OPTION_SOCK_ADDR,
|
||||||
|
addrx,
|
||||||
|
MHD_OPTION_END))) {
|
||||||
|
nohost = true;
|
||||||
|
qWarning("HTTPPlugin: Failed to bind to configured host!");
|
||||||
|
} else {
|
||||||
|
nohost = false;
|
||||||
|
//qWarning("HTTPPlugin: Binded to configured host.");
|
||||||
|
}
|
||||||
|
|
||||||
|
}
|
||||||
|
|
||||||
|
if (addrx != NULL)
|
||||||
|
free(addrx);
|
||||||
}
|
}
|
||||||
|
|
||||||
if (nohost) {
|
if (nohost) {
|
||||||
daemon = MHD_start_daemon(MHD_USE_SELECT_INTERNALLY, port, NULL, NULL,
|
if (NULL == (daemon = MHD_start_daemon(MHD_USE_SELECT_INTERNALLY, port, NULL, NULL,
|
||||||
&this->request_handler_wrapper, this,
|
&this->request_handler_wrapper, this,
|
||||||
MHD_OPTION_NOTIFY_COMPLETED,
|
MHD_OPTION_NOTIFY_COMPLETED,
|
||||||
this->request_completed, NULL,
|
this->request_completed, NULL,
|
||||||
MHD_OPTION_END);
|
MHD_OPTION_END))) {
|
||||||
|
qWarning("HTTPPlugin: Fatal! Failed to bind to both configured and default hosts!");
|
||||||
|
} else {
|
||||||
|
qWarning("HTTPPlugin: Bound to fallback address 0.0.0.0/:::!");
|
||||||
|
}
|
||||||
}
|
}
|
||||||
|
|
||||||
m_started = true;
|
m_started = true;
|
||||||
|
Loading…
x
Reference in New Issue
Block a user