diff options
Diffstat (limited to 'linden/indra/llmessage')
-rw-r--r-- | linden/indra/llmessage/llares.cpp | 11 | ||||
-rw-r--r-- | linden/indra/llmessage/llares.h | 4 | ||||
-rw-r--r-- | linden/indra/llmessage/llhttpclient.cpp | 4 | ||||
-rw-r--r-- | linden/indra/llmessage/llmessagetemplate.h | 8 | ||||
-rw-r--r-- | linden/indra/llmessage/llmessagetemplateparser.cpp | 4 | ||||
-rw-r--r-- | linden/indra/llmessage/lltemplatemessagebuilder.cpp | 1 | ||||
-rw-r--r-- | linden/indra/llmessage/lltemplatemessagereader.cpp | 6 | ||||
-rw-r--r-- | linden/indra/llmessage/lltemplatemessagereader.h | 3 | ||||
-rw-r--r-- | linden/indra/llmessage/llurlrequest.cpp | 78 | ||||
-rw-r--r-- | linden/indra/llmessage/llurlrequest.h | 5 | ||||
-rw-r--r-- | linden/indra/llmessage/message.cpp | 10 |
11 files changed, 96 insertions, 38 deletions
diff --git a/linden/indra/llmessage/llares.cpp b/linden/indra/llmessage/llares.cpp index 5a310b3..7f573d2 100644 --- a/linden/indra/llmessage/llares.cpp +++ b/linden/indra/llmessage/llares.cpp | |||
@@ -100,9 +100,16 @@ void LLAres::QueryResponder::queryError(int code) | |||
100 | << LLAres::strerror(code) << llendl; | 100 | << LLAres::strerror(code) << llendl; |
101 | } | 101 | } |
102 | 102 | ||
103 | LLAres::LLAres() | 103 | LLAres::LLAres() : |
104 | chan_(NULL), mInitSuccess(false) | ||
104 | { | 105 | { |
105 | ares_init(&chan_); | 106 | if (ares_init(&chan_) != ARES_SUCCESS) |
107 | { | ||
108 | llwarns << "Could not succesfully initialize ares!" << llendl; | ||
109 | return; | ||
110 | } | ||
111 | |||
112 | mInitSuccess = true; | ||
106 | } | 113 | } |
107 | 114 | ||
108 | LLAres::~LLAres() | 115 | LLAres::~LLAres() |
diff --git a/linden/indra/llmessage/llares.h b/linden/indra/llmessage/llares.h index 5d72170..17f6085 100644 --- a/linden/indra/llmessage/llares.h +++ b/linden/indra/llmessage/llares.h | |||
@@ -437,9 +437,11 @@ public: | |||
437 | */ | 437 | */ |
438 | static const char *strerror(int code); | 438 | static const char *strerror(int code); |
439 | 439 | ||
440 | bool isInitialized(void) { return mInitSuccess; } | ||
441 | |||
440 | protected: | 442 | protected: |
441 | ares_channel chan_; | 443 | ares_channel chan_; |
442 | 444 | bool mInitSuccess; | |
443 | }; | 445 | }; |
444 | 446 | ||
445 | /** | 447 | /** |
diff --git a/linden/indra/llmessage/llhttpclient.cpp b/linden/indra/llmessage/llhttpclient.cpp index caeaee1..fc2612f 100644 --- a/linden/indra/llmessage/llhttpclient.cpp +++ b/linden/indra/llmessage/llhttpclient.cpp | |||
@@ -56,7 +56,7 @@ namespace | |||
56 | { | 56 | { |
57 | public: | 57 | public: |
58 | LLHTTPClientURLAdaptor(LLCurl::ResponderPtr responder) | 58 | LLHTTPClientURLAdaptor(LLCurl::ResponderPtr responder) |
59 | : mResponder(responder), mStatus(499), | 59 | : LLURLRequestComplete(), mResponder(responder), mStatus(499), |
60 | mReason("LLURLRequest complete w/no status") | 60 | mReason("LLURLRequest complete w/no status") |
61 | { | 61 | { |
62 | } | 62 | } |
@@ -67,6 +67,8 @@ namespace | |||
67 | 67 | ||
68 | virtual void httpStatus(U32 status, const std::string& reason) | 68 | virtual void httpStatus(U32 status, const std::string& reason) |
69 | { | 69 | { |
70 | LLURLRequestComplete::httpStatus(status,reason); | ||
71 | |||
70 | mStatus = status; | 72 | mStatus = status; |
71 | mReason = reason; | 73 | mReason = reason; |
72 | } | 74 | } |
diff --git a/linden/indra/llmessage/llmessagetemplate.h b/linden/indra/llmessage/llmessagetemplate.h index f92c4b7..716c618 100644 --- a/linden/indra/llmessage/llmessagetemplate.h +++ b/linden/indra/llmessage/llmessagetemplate.h | |||
@@ -265,6 +265,7 @@ enum EMsgDeprecation | |||
265 | { | 265 | { |
266 | MD_NOTDEPRECATED, | 266 | MD_NOTDEPRECATED, |
267 | MD_UDPDEPRECATED, | 267 | MD_UDPDEPRECATED, |
268 | MD_UDPBLACKLISTED, | ||
268 | MD_DEPRECATED | 269 | MD_DEPRECATED |
269 | }; | 270 | }; |
270 | 271 | ||
@@ -299,7 +300,7 @@ public: | |||
299 | ~LLMessageTemplate() | 300 | ~LLMessageTemplate() |
300 | { | 301 | { |
301 | for_each(mMemberBlocks.begin(), mMemberBlocks.end(), DeletePointer()); | 302 | for_each(mMemberBlocks.begin(), mMemberBlocks.end(), DeletePointer()); |
302 | } | 303 | } |
303 | 304 | ||
304 | void addBlock(LLMessageBlock *blockp) | 305 | void addBlock(LLMessageBlock *blockp) |
305 | { | 306 | { |
@@ -380,6 +381,11 @@ public: | |||
380 | return trustedSource ? mBanFromTrusted : mBanFromUntrusted; | 381 | return trustedSource ? mBanFromTrusted : mBanFromUntrusted; |
381 | } | 382 | } |
382 | 383 | ||
384 | bool isUdpBanned() const | ||
385 | { | ||
386 | return mDeprecation == MD_UDPBLACKLISTED; | ||
387 | } | ||
388 | |||
383 | friend std::ostream& operator<<(std::ostream& s, LLMessageTemplate &msg); | 389 | friend std::ostream& operator<<(std::ostream& s, LLMessageTemplate &msg); |
384 | 390 | ||
385 | const LLMessageBlock* getBlock(char* name) const | 391 | const LLMessageBlock* getBlock(char* name) const |
diff --git a/linden/indra/llmessage/llmessagetemplateparser.cpp b/linden/indra/llmessage/llmessagetemplateparser.cpp index d6adba8..9f6eeca 100644 --- a/linden/indra/llmessage/llmessagetemplateparser.cpp +++ b/linden/indra/llmessage/llmessagetemplateparser.cpp | |||
@@ -525,6 +525,10 @@ LLMessageTemplate * LLTemplateParser::parseMessage(LLTemplateTokenizer & tokens) | |||
525 | { | 525 | { |
526 | templatep->setDeprecation(MD_UDPDEPRECATED); | 526 | templatep->setDeprecation(MD_UDPDEPRECATED); |
527 | } | 527 | } |
528 | else if (tokens.want("UDPBlackListed")) | ||
529 | { | ||
530 | templatep->setDeprecation(MD_UDPBLACKLISTED); | ||
531 | } | ||
528 | else if (tokens.want("NotDeprecated")) | 532 | else if (tokens.want("NotDeprecated")) |
529 | { | 533 | { |
530 | // this is the default value, but it can't hurt to set it twice | 534 | // this is the default value, but it can't hurt to set it twice |
diff --git a/linden/indra/llmessage/lltemplatemessagebuilder.cpp b/linden/indra/llmessage/lltemplatemessagebuilder.cpp index cd06c07..6d3ff8f 100644 --- a/linden/indra/llmessage/lltemplatemessagebuilder.cpp +++ b/linden/indra/llmessage/lltemplatemessagebuilder.cpp | |||
@@ -60,7 +60,6 @@ LLTemplateMessageBuilder::~LLTemplateMessageBuilder() | |||
60 | mCurrentSMessageData = NULL; | 60 | mCurrentSMessageData = NULL; |
61 | } | 61 | } |
62 | 62 | ||
63 | |||
64 | // virtual | 63 | // virtual |
65 | void LLTemplateMessageBuilder::newMessage(const char *name) | 64 | void LLTemplateMessageBuilder::newMessage(const char *name) |
66 | { | 65 | { |
diff --git a/linden/indra/llmessage/lltemplatemessagereader.cpp b/linden/indra/llmessage/lltemplatemessagereader.cpp index f5da14b..2c457e8 100644 --- a/linden/indra/llmessage/lltemplatemessagereader.cpp +++ b/linden/indra/llmessage/lltemplatemessagereader.cpp | |||
@@ -791,12 +791,16 @@ bool LLTemplateMessageReader::isTrusted() const | |||
791 | return mCurrentRMessageTemplate->getTrust() == MT_TRUST; | 791 | return mCurrentRMessageTemplate->getTrust() == MT_TRUST; |
792 | } | 792 | } |
793 | 793 | ||
794 | //virtual | ||
795 | bool LLTemplateMessageReader::isBanned(bool trustedSource) const | 794 | bool LLTemplateMessageReader::isBanned(bool trustedSource) const |
796 | { | 795 | { |
797 | return mCurrentRMessageTemplate->isBanned(trustedSource); | 796 | return mCurrentRMessageTemplate->isBanned(trustedSource); |
798 | } | 797 | } |
799 | 798 | ||
799 | bool LLTemplateMessageReader::isUdpBanned() const | ||
800 | { | ||
801 | return mCurrentRMessageTemplate->isUdpBanned(); | ||
802 | } | ||
803 | |||
800 | //virtual | 804 | //virtual |
801 | void LLTemplateMessageReader::copyToBuilder(LLMessageBuilder& builder) const | 805 | void LLTemplateMessageReader::copyToBuilder(LLMessageBuilder& builder) const |
802 | { | 806 | { |
diff --git a/linden/indra/llmessage/lltemplatemessagereader.h b/linden/indra/llmessage/lltemplatemessagereader.h index 98f41ae..ff124f3 100644 --- a/linden/indra/llmessage/lltemplatemessagereader.h +++ b/linden/indra/llmessage/lltemplatemessagereader.h | |||
@@ -109,7 +109,8 @@ public: | |||
109 | 109 | ||
110 | bool isTrusted() const; | 110 | bool isTrusted() const; |
111 | bool isBanned(bool trusted_source) const; | 111 | bool isBanned(bool trusted_source) const; |
112 | 112 | bool isUdpBanned() const; | |
113 | |||
113 | private: | 114 | private: |
114 | 115 | ||
115 | void getData(const char *blockname, const char *varname, void *datap, | 116 | void getData(const char *blockname, const char *varname, void *datap, |
diff --git a/linden/indra/llmessage/llurlrequest.cpp b/linden/indra/llmessage/llurlrequest.cpp index 42f3f04..fbd002b 100644 --- a/linden/indra/llmessage/llurlrequest.cpp +++ b/linden/indra/llmessage/llurlrequest.cpp | |||
@@ -461,58 +461,76 @@ size_t LLURLRequest::upCallback( | |||
461 | 461 | ||
462 | static size_t headerCallback(void* data, size_t size, size_t nmemb, void* user) | 462 | static size_t headerCallback(void* data, size_t size, size_t nmemb, void* user) |
463 | { | 463 | { |
464 | const char* headerLine = (const char*)data; | 464 | const char* header_line = (const char*)data; |
465 | size_t headerLen = size * nmemb; | 465 | size_t header_len = size * nmemb; |
466 | LLURLRequestComplete* complete = (LLURLRequestComplete*)user; | 466 | LLURLRequestComplete* complete = (LLURLRequestComplete*)user; |
467 | 467 | ||
468 | if (!complete || !header_line) | ||
469 | { | ||
470 | return header_len; | ||
471 | } | ||
472 | |||
468 | // *TODO: This should be a utility in llstring.h: isascii() | 473 | // *TODO: This should be a utility in llstring.h: isascii() |
469 | for (size_t i = 0; i < headerLen; ++i) | 474 | for (size_t i = 0; i < header_len; ++i) |
470 | { | 475 | { |
471 | if (headerLine[i] < 0) | 476 | if (header_line[i] < 0) |
472 | { | 477 | { |
473 | return headerLen; | 478 | return header_len; |
474 | } | 479 | } |
475 | } | 480 | } |
476 | 481 | ||
477 | size_t sep; | 482 | std::string header(header_line, header_len); |
478 | for (sep = 0; sep < headerLen && headerLine[sep] != ':'; ++sep) { } | ||
479 | |||
480 | if (sep < headerLen && complete) | ||
481 | { | ||
482 | std::string key(headerLine, sep); | ||
483 | std::string value(headerLine + sep + 1, headerLen - sep - 1); | ||
484 | |||
485 | key = utf8str_tolower(utf8str_trim(key)); | ||
486 | value = utf8str_trim(value); | ||
487 | 483 | ||
488 | complete->header(key, value); | 484 | // Per HTTP spec the first header line must be the status line. |
489 | } | 485 | if (!complete->haveHTTPStatus()) |
490 | else | ||
491 | { | 486 | { |
492 | std::string s(headerLine, headerLen); | 487 | std::string::iterator end = header.end(); |
493 | 488 | std::string::iterator pos1 = std::find(header.begin(), end, ' '); | |
494 | std::string::iterator end = s.end(); | ||
495 | std::string::iterator pos1 = std::find(s.begin(), end, ' '); | ||
496 | if (pos1 != end) ++pos1; | 489 | if (pos1 != end) ++pos1; |
497 | std::string::iterator pos2 = std::find(pos1, end, ' '); | 490 | std::string::iterator pos2 = std::find(pos1, end, ' '); |
498 | if (pos2 != end) ++pos2; | 491 | if (pos2 != end) ++pos2; |
499 | std::string::iterator pos3 = std::find(pos2, end, '\r'); | 492 | std::string::iterator pos3 = std::find(pos2, end, '\r'); |
500 | 493 | ||
501 | std::string version(s.begin(), pos1); | 494 | std::string version(header.begin(), pos1); |
502 | std::string status(pos1, pos2); | 495 | std::string status(pos1, pos2); |
503 | std::string reason(pos2, pos3); | 496 | std::string reason(pos2, pos3); |
504 | 497 | ||
505 | int statusCode = atoi(status.c_str()); | 498 | int statusCode = atoi(status.c_str()); |
506 | if (statusCode > 0) | 499 | if (statusCode > 0) |
507 | { | 500 | { |
508 | if (complete) | 501 | complete->httpStatus((U32)statusCode, reason); |
509 | { | 502 | } |
510 | complete->httpStatus((U32)statusCode, reason); | 503 | else |
511 | } | 504 | { |
505 | llwarns << "Unable to parse http response status line: " | ||
506 | << header << llendl; | ||
507 | complete->httpStatus(499,"Unable to parse status line."); | ||
508 | } | ||
509 | return header_len; | ||
510 | } | ||
511 | |||
512 | std::string::iterator sep = std::find(header.begin(),header.end(),':'); | ||
513 | |||
514 | if (sep != header.end()) | ||
515 | { | ||
516 | std::string key(header.begin(), sep); | ||
517 | std::string value(sep + 1, header.end()); | ||
518 | |||
519 | key = utf8str_tolower(utf8str_trim(key)); | ||
520 | value = utf8str_trim(value); | ||
521 | |||
522 | complete->header(key, value); | ||
523 | } | ||
524 | else | ||
525 | { | ||
526 | LLStringUtil::trim(header); | ||
527 | if (!header.empty()) | ||
528 | { | ||
529 | llwarns << "Unable to parse header: " << header << llendl; | ||
512 | } | 530 | } |
513 | } | 531 | } |
514 | 532 | ||
515 | return headerLen; | 533 | return header_len; |
516 | } | 534 | } |
517 | 535 | ||
518 | /** | 536 | /** |
@@ -553,7 +571,8 @@ LLIOPipe::EStatus LLContextURLExtractor::process_impl( | |||
553 | * LLURLRequestComplete | 571 | * LLURLRequestComplete |
554 | */ | 572 | */ |
555 | LLURLRequestComplete::LLURLRequestComplete() : | 573 | LLURLRequestComplete::LLURLRequestComplete() : |
556 | mRequestStatus(LLIOPipe::STATUS_ERROR) | 574 | mRequestStatus(LLIOPipe::STATUS_ERROR), |
575 | mHaveHTTPStatus(false) | ||
557 | { | 576 | { |
558 | LLMemType m1(LLMemType::MTYPE_IO_URL_REQUEST); | 577 | LLMemType m1(LLMemType::MTYPE_IO_URL_REQUEST); |
559 | } | 578 | } |
@@ -572,6 +591,7 @@ void LLURLRequestComplete::header(const std::string& header, const std::string& | |||
572 | //virtual | 591 | //virtual |
573 | void LLURLRequestComplete::httpStatus(U32 status, const std::string& reason) | 592 | void LLURLRequestComplete::httpStatus(U32 status, const std::string& reason) |
574 | { | 593 | { |
594 | mHaveHTTPStatus = true; | ||
575 | } | 595 | } |
576 | 596 | ||
577 | //virtual | 597 | //virtual |
diff --git a/linden/indra/llmessage/llurlrequest.h b/linden/indra/llmessage/llurlrequest.h index 888b962..f965dad 100644 --- a/linden/indra/llmessage/llurlrequest.h +++ b/linden/indra/llmessage/llurlrequest.h | |||
@@ -327,6 +327,9 @@ public: | |||
327 | LLURLRequestComplete(); | 327 | LLURLRequestComplete(); |
328 | virtual ~LLURLRequestComplete(); | 328 | virtual ~LLURLRequestComplete(); |
329 | 329 | ||
330 | // The first line of an http response must be the status line | ||
331 | // true if we have already parsed this line. | ||
332 | bool haveHTTPStatus() const { return mHaveHTTPStatus; } | ||
330 | protected: | 333 | protected: |
331 | /* @name LLIOPipe virtual implementations | 334 | /* @name LLIOPipe virtual implementations |
332 | */ | 335 | */ |
@@ -345,6 +348,8 @@ protected: | |||
345 | // value to note if we actually got the response. This value | 348 | // value to note if we actually got the response. This value |
346 | // depends on correct useage from the LLURLRequest instance. | 349 | // depends on correct useage from the LLURLRequest instance. |
347 | EStatus mRequestStatus; | 350 | EStatus mRequestStatus; |
351 | |||
352 | bool mHaveHTTPStatus; | ||
348 | }; | 353 | }; |
349 | 354 | ||
350 | 355 | ||
diff --git a/linden/indra/llmessage/message.cpp b/linden/indra/llmessage/message.cpp index 27f9d12..b20731a 100644 --- a/linden/indra/llmessage/message.cpp +++ b/linden/indra/llmessage/message.cpp | |||
@@ -754,11 +754,19 @@ BOOL LLMessageSystem::checkMessages( S64 frame_count ) | |||
754 | clearReceiveState(); | 754 | clearReceiveState(); |
755 | valid_packet = FALSE; | 755 | valid_packet = FALSE; |
756 | } | 756 | } |
757 | |||
758 | if( valid_packet && mTemplateMessageReader->isUdpBanned()) | ||
759 | { | ||
760 | llwarns << "Received UDP black listed message " | ||
761 | << mTemplateMessageReader->getMessageName() | ||
762 | << " from " << host << llendl; | ||
763 | clearReceiveState(); | ||
764 | valid_packet = FALSE; | ||
765 | } | ||
757 | 766 | ||
758 | if( valid_packet ) | 767 | if( valid_packet ) |
759 | { | 768 | { |
760 | logValidMsg(cdp, host, recv_reliable, recv_resent, (BOOL)(acks>0) ); | 769 | logValidMsg(cdp, host, recv_reliable, recv_resent, (BOOL)(acks>0) ); |
761 | |||
762 | valid_packet = mTemplateMessageReader->readMessage(buffer, host); | 770 | valid_packet = mTemplateMessageReader->readMessage(buffer, host); |
763 | } | 771 | } |
764 | 772 | ||