diff options
| author | Remko Tronçon <git@el-tramo.be> | 2009-12-03 07:53:34 (GMT) | 
|---|---|---|
| committer | Remko Tronçon <git@el-tramo.be> | 2009-12-03 08:09:01 (GMT) | 
| commit | 9b3edba27b8683f1a87ad66ee05802dd93bbbdfc (patch) | |
| tree | e78433ae108123ce370b6abdb1474ec5dcedc75a /Swiften/Network/PlatformDomainNameServiceQuery.cpp | |
| parent | e15c6fd319af1303db47f00e78e4ec42d0605279 (diff) | |
| download | swift-9b3edba27b8683f1a87ad66ee05802dd93bbbdfc.zip swift-9b3edba27b8683f1a87ad66ee05802dd93bbbdfc.tar.bz2 | |
Added debugging output for DNS.
Diffstat (limited to 'Swiften/Network/PlatformDomainNameServiceQuery.cpp')
| -rw-r--r-- | Swiften/Network/PlatformDomainNameServiceQuery.cpp | 3 | 
1 files changed, 3 insertions, 0 deletions
| diff --git a/Swiften/Network/PlatformDomainNameServiceQuery.cpp b/Swiften/Network/PlatformDomainNameServiceQuery.cpp index 12afbb7..bc2138d 100644 --- a/Swiften/Network/PlatformDomainNameServiceQuery.cpp +++ b/Swiften/Network/PlatformDomainNameServiceQuery.cpp @@ -37,137 +37,140 @@ PlatformDomainNameServiceQuery::PlatformDomainNameServiceQuery(const String& ser  PlatformDomainNameServiceQuery::~PlatformDomainNameServiceQuery() {  	if (safeToJoin) {  		thread->join();  	}  	else {  		// FIXME: UGLYYYYY  	}  	delete thread;  }  void PlatformDomainNameServiceQuery::run() {  	safeToJoin = false;  	thread = new boost::thread(boost::bind(&PlatformDomainNameServiceQuery::doRun, shared_from_this()));  }  void PlatformDomainNameServiceQuery::doRun() {  	std::vector<DomainNameServiceQuery::Result> records;  #if defined(SWIFTEN_PLATFORM_WINDOWS)  	DNS_RECORD* responses;  	// FIXME: This conversion doesn't work if unicode is deffed above  	if (DnsQuery(service.getUTF8Data(), DNS_TYPE_SRV, DNS_QUERY_STANDARD, NULL, &responses, NULL) != ERROR_SUCCESS) {  		emitError();  		return;  	}  	DNS_RECORD* currentEntry = responses;  	while (currentEntry) {  		if (currentEntry->wType == DNS_TYPE_SRV) {  			SRVRecord record;  			record.priority = currentEntry->Data.SRV.wPriority;  			record.weight = currentEntry->Data.SRV.wWeight;  			record.port = currentEntry->Data.SRV.wPort;  			// The pNameTarget is actually a PCWSTR, so I would have expected this   			// conversion to not work at all, but it does.  			// Actually, it doesn't. Fix this and remove explicit cast  			// Remove unicode undef above as well  			record.hostname = std::string((const char*) currentEntry->Data.SRV.pNameTarget);  			records.push_back(record);  		}  		currentEntry = currentEntry->pNext;  	}  	DnsRecordListFree(responses, DnsFreeRecordList);  #else +	std::cout << "SRV: Querying " << service << std::endl;  	ByteArray response;  	response.resize(NS_PACKETSZ);  	int responseLength = res_query(const_cast<char*>(service.getUTF8Data()), ns_c_in, ns_t_srv, reinterpret_cast<u_char*>(response.getData()), response.getSize()); +	std::cout << "res_query done " << (responseLength != -1) << std::endl;  	if (responseLength == -1) {  		emitError();  		return;  	}  	// Parse header  	HEADER* header = reinterpret_cast<HEADER*>(response.getData());  	unsigned char* messageStart = reinterpret_cast<unsigned char*>(response.getData());  	unsigned char* messageEnd = messageStart + responseLength;  	unsigned char* currentEntry = messageStart + NS_HFIXEDSZ;  	// Skip over the queries  	int queriesCount = ntohs(header->qdcount);  	while (queriesCount > 0) {  		int entryLength = dn_skipname(currentEntry, messageEnd);  		if (entryLength < 0) {  			emitError();  			return;  		}  		currentEntry += entryLength + NS_QFIXEDSZ;  		queriesCount--;  	}  	// Process the SRV answers  	int answersCount = ntohs(header->ancount);  	while (answersCount > 0) {  		DomainNameServiceQuery::Result record;  		int entryLength = dn_skipname(currentEntry, messageEnd);  		currentEntry += entryLength;  		currentEntry += NS_RRFIXEDSZ;  		// Priority  		if (currentEntry + 2 >= messageEnd) {  			emitError();  			return;  		}  		record.priority = ns_get16(currentEntry);  		currentEntry += 2;  		// Weight  		if (currentEntry + 2 >= messageEnd) {  			emitError();  			return;  		}  		record.weight = ns_get16(currentEntry);  		currentEntry += 2;  		// Port  		if (currentEntry + 2 >= messageEnd) {  			emitError();  			return;  		}  		record.port = ns_get16(currentEntry);  		currentEntry += 2;   		// Hostname  		if (currentEntry >= messageEnd) {  			emitError();  			return;  		}  		ByteArray entry;  		entry.resize(NS_MAXDNAME);  		entryLength = dn_expand(messageStart, messageEnd, currentEntry, entry.getData(), entry.getSize());  		if (entryLength < 0) {  			emitError();  			return;  		}  		record.hostname = String(entry.getData());  		records.push_back(record);  		currentEntry += entryLength;  		answersCount--;  	}  #endif  	safeToJoin = true;  	std::sort(records.begin(), records.end(), SRVRecordPriorityComparator()); +	std::cout << "Sending out " << records.size() << " SRV results " << std::endl;  	MainEventLoop::postEvent(boost::bind(boost::ref(onResult), records));   }  void PlatformDomainNameServiceQuery::emitError() {  	safeToJoin = true;  	MainEventLoop::postEvent(boost::bind(boost::ref(onResult), std::vector<DomainNameServiceQuery::Result>()), shared_from_this());  }  } | 
 Swift
 Swift