Rename some stuff
This commit is contained in:
parent
0741a7db88
commit
b8892f3860
3 changed files with 14 additions and 27 deletions
|
@ -72,10 +72,10 @@ static int query_callback(int sock, const struct sockaddr* from, size_t addrlen,
|
||||||
case MDNS_RECORDTYPE_PTR: {
|
case MDNS_RECORDTYPE_PTR: {
|
||||||
// Keep just the service name instead of the full "<service-name>.<_service-type>._tcp.local." string
|
// Keep just the service name instead of the full "<service-name>.<_service-type>._tcp.local." string
|
||||||
mdns_string_pair_t serviceNamePos = mdns_get_next_substring(data, size, record_offset);
|
mdns_string_pair_t serviceNamePos = mdns_get_next_substring(data, size, record_offset);
|
||||||
discoveredService->serviceName = QString::fromLatin1((char *)data + serviceNamePos.offset, serviceNamePos.length);
|
discoveredService->name = QString::fromLatin1((char *)data + serviceNamePos.offset, serviceNamePos.length);
|
||||||
//static char serviceNameBuffer[256];
|
//static char serviceNameBuffer[256];
|
||||||
//mdns_string_t serviceName = mdns_record_parse_ptr(data, size, record_offset, record_length, serviceNameBuffer, sizeof(serviceNameBuffer));
|
//mdns_string_t serviceName = mdns_record_parse_ptr(data, size, record_offset, record_length, serviceNameBuffer, sizeof(serviceNameBuffer));
|
||||||
//discoveredService->serviceName = QString::fromLatin1(serviceName.str, serviceName.length);
|
//discoveredService->name = QString::fromLatin1(serviceName.str, serviceName.length);
|
||||||
if (discoveredService->address == QHostAddress::Null) {
|
if (discoveredService->address == QHostAddress::Null) {
|
||||||
discoveredService->address = QHostAddress(from); // In case we don't receive a A record, use from as address
|
discoveredService->address = QHostAddress(from); // In case we don't receive a A record, use from as address
|
||||||
}
|
}
|
||||||
|
@ -114,13 +114,13 @@ static int query_callback(int sock, const struct sockaddr* from, size_t addrlen,
|
||||||
return 0;
|
return 0;
|
||||||
}
|
}
|
||||||
|
|
||||||
void MdnsWrapper::startDiscovering(const char *serviceName)
|
void MdnsWrapper::startDiscovering(const char *serviceType)
|
||||||
{
|
{
|
||||||
int num_sockets = listenForQueryResponses();
|
int num_sockets = listenForQueryResponses();
|
||||||
if (num_sockets <= 0) {
|
if (num_sockets <= 0) {
|
||||||
qWarning() << "Failed to open any client sockets";
|
qWarning() << "Failed to open any client sockets";
|
||||||
} else {
|
} else {
|
||||||
sendQuery(serviceName);
|
sendQuery(serviceType);
|
||||||
}
|
}
|
||||||
}
|
}
|
||||||
|
|
||||||
|
@ -175,7 +175,7 @@ int MdnsWrapper::listenForQueryResponses()
|
||||||
size_t num_records = mdns_query_recv(socket, buffer, capacity, query_callback, (void *)&discoveredService, 0);
|
size_t num_records = mdns_query_recv(socket, buffer, capacity, query_callback, (void *)&discoveredService, 0);
|
||||||
free(buffer);
|
free(buffer);
|
||||||
|
|
||||||
// qCDebug(KDECONNECT_CORE) << "Discovered service" << discoveredService.serviceName << "at" << discoveredService.address << "in" << num_records <<
|
// qCDebug(KDECONNECT_CORE) << "Discovered service" << discoveredService.name << "at" << discoveredService.address << "in" << num_records <<
|
||||||
// "records via socket" << socket;
|
// "records via socket" << socket;
|
||||||
|
|
||||||
Q_EMIT serviceFound(discoveredService);
|
Q_EMIT serviceFound(discoveredService);
|
||||||
|
@ -188,13 +188,13 @@ int MdnsWrapper::listenForQueryResponses()
|
||||||
return sockets.size();
|
return sockets.size();
|
||||||
}
|
}
|
||||||
|
|
||||||
void MdnsWrapper::sendQuery(const char *serviceName)
|
void MdnsWrapper::sendQuery(const char *serviceType)
|
||||||
{
|
{
|
||||||
qCDebug(KDECONNECT_CORE) << "Sending MDNS query for service" << serviceName;
|
qCDebug(KDECONNECT_CORE) << "Sending MDNS query for service" << serviceType;
|
||||||
|
|
||||||
mdns_query_t query;
|
mdns_query_t query;
|
||||||
query.name = serviceName;
|
query.name = serviceType;
|
||||||
query.length = strlen(serviceName);
|
query.length = strlen(serviceType);
|
||||||
query.type = MDNS_RECORDTYPE_PTR;
|
query.type = MDNS_RECORDTYPE_PTR;
|
||||||
|
|
||||||
size_t capacity = 2048;
|
size_t capacity = 2048;
|
||||||
|
@ -395,21 +395,8 @@ static int service_callback(int sock, const struct sockaddr* from, size_t addrle
|
||||||
size_t offset = name_offset;
|
size_t offset = name_offset;
|
||||||
mdns_string_t name = mdns_string_extract(data, size, &offset, namebuffer, sizeof(namebuffer));
|
mdns_string_t name = mdns_string_extract(data, size, &offset, namebuffer, sizeof(namebuffer));
|
||||||
|
|
||||||
const char* record_name = 0;
|
const char* record_name = recordTypeToStr(rtype);
|
||||||
if (rtype == MDNS_RECORDTYPE_PTR)
|
|
||||||
record_name = "PTR";
|
|
||||||
else if (rtype == MDNS_RECORDTYPE_SRV)
|
|
||||||
record_name = "SRV";
|
|
||||||
else if (rtype == MDNS_RECORDTYPE_A)
|
|
||||||
record_name = "A";
|
|
||||||
else if (rtype == MDNS_RECORDTYPE_AAAA)
|
|
||||||
record_name = "AAAA";
|
|
||||||
else if (rtype == MDNS_RECORDTYPE_TXT)
|
|
||||||
record_name = "TXT";
|
|
||||||
else if (rtype == MDNS_RECORDTYPE_ANY)
|
|
||||||
record_name = "ANY";
|
|
||||||
else
|
|
||||||
return 0;
|
|
||||||
printf("Query %s %.*s\n", record_name, MDNS_STRING_FORMAT(name));
|
printf("Query %s %.*s\n", record_name, MDNS_STRING_FORMAT(name));
|
||||||
|
|
||||||
if ((name.length == (sizeof(dns_sd) - 1)) &&
|
if ((name.length == (sizeof(dns_sd) - 1)) &&
|
||||||
|
|
|
@ -23,7 +23,7 @@ class MdnsWrapper : public QObject
|
||||||
|
|
||||||
public:
|
public:
|
||||||
struct MdnsService {
|
struct MdnsService {
|
||||||
QString serviceName;
|
QString name;
|
||||||
int port;
|
int port;
|
||||||
QHostAddress address;
|
QHostAddress address;
|
||||||
QMap<QString, QString> txtRecords;
|
QMap<QString, QString> txtRecords;
|
||||||
|
|
|
@ -19,12 +19,12 @@ MdnsDiscovery::MdnsDiscovery(LanLinkProvider *lanLinkProvider)
|
||||||
: lanLinkProvider(lanLinkProvider)
|
: lanLinkProvider(lanLinkProvider)
|
||||||
{
|
{
|
||||||
connect(&mdnsWrapper, &MdnsWrapper::serviceFound, [lanLinkProvider](const MdnsWrapper::MdnsService &service) {
|
connect(&mdnsWrapper, &MdnsWrapper::serviceFound, [lanLinkProvider](const MdnsWrapper::MdnsService &service) {
|
||||||
if (KdeConnectConfig::instance().deviceId() == service.serviceName) {
|
if (KdeConnectConfig::instance().deviceId() == service.name) {
|
||||||
qCDebug(KDECONNECT_CORE) << "Discovered myself, ignoring";
|
qCDebug(KDECONNECT_CORE) << "Discovered myself, ignoring";
|
||||||
return;
|
return;
|
||||||
}
|
}
|
||||||
qCDebug(KDECONNECT_CORE) << "Discovered" << service.serviceName << "at" << service.address;
|
|
||||||
lanLinkProvider->sendUdpIdentityPacket(QList<QHostAddress>{service.address});
|
lanLinkProvider->sendUdpIdentityPacket(QList<QHostAddress>{service.address});
|
||||||
|
qCDebug(KDECONNECT_CORE) << "Discovered" << service.name << "at" << service.address;
|
||||||
});
|
});
|
||||||
}
|
}
|
||||||
|
|
||||||
|
|
Loading…
Reference in a new issue