diff options
Diffstat (limited to 'linden/indra/llmessage')
-rw-r--r-- | linden/indra/llmessage/llassetstorage.cpp | 18 | ||||
-rw-r--r-- | linden/indra/llmessage/llassetstorage.h | 19 | ||||
-rw-r--r-- | linden/indra/llmessage/llblowfishcipher.cpp | 56 | ||||
-rw-r--r-- | linden/indra/llmessage/llcachename.cpp | 196 | ||||
-rw-r--r-- | linden/indra/llmessage/llcurl.cpp | 2 | ||||
-rw-r--r-- | linden/indra/llmessage/llhttpassetstorage.cpp | 68 | ||||
-rw-r--r-- | linden/indra/llmessage/llhttpassetstorage.h | 8 | ||||
-rw-r--r-- | linden/indra/llmessage/llhttpnode.cpp | 2 | ||||
-rw-r--r-- | linden/indra/llmessage/lliohttpserver.cpp | 2 | ||||
-rw-r--r-- | linden/indra/llmessage/lliosocket.cpp | 2 | ||||
-rw-r--r-- | linden/indra/llmessage/llmessagethrottle.cpp | 2 | ||||
-rw-r--r-- | linden/indra/llmessage/llservicebuilder.cpp | 1 | ||||
-rw-r--r-- | linden/indra/llmessage/lltemplatemessagereader.cpp | 2 | ||||
-rw-r--r-- | linden/indra/llmessage/message.cpp | 16 | ||||
-rw-r--r-- | linden/indra/llmessage/net.cpp | 12 | ||||
-rw-r--r-- | linden/indra/llmessage/net.h | 2 |
16 files changed, 246 insertions, 162 deletions
diff --git a/linden/indra/llmessage/llassetstorage.cpp b/linden/indra/llmessage/llassetstorage.cpp index c8610a7..8696438 100644 --- a/linden/indra/llmessage/llassetstorage.cpp +++ b/linden/indra/llmessage/llassetstorage.cpp | |||
@@ -162,6 +162,8 @@ LLAssetRequest::LLAssetRequest(const LLUUID &uuid, const LLAssetType::EType type | |||
162 | mHost(), | 162 | mHost(), |
163 | mIsTemp( FALSE ), | 163 | mIsTemp( FALSE ), |
164 | mIsLocal(FALSE), | 164 | mIsLocal(FALSE), |
165 | mIsUserWaiting(FALSE), | ||
166 | mTimeout(LL_ASSET_STORAGE_TIMEOUT), | ||
165 | mIsPriority(FALSE), | 167 | mIsPriority(FALSE), |
166 | mDataSentInFirstPacket(FALSE), | 168 | mDataSentInFirstPacket(FALSE), |
167 | mDataIsInVFS( FALSE ) | 169 | mDataIsInVFS( FALSE ) |
@@ -1270,7 +1272,9 @@ void LLAssetStorage::storeAssetData( | |||
1270 | void* user_data, | 1272 | void* user_data, |
1271 | bool temp_file, | 1273 | bool temp_file, |
1272 | bool is_priority, | 1274 | bool is_priority, |
1273 | bool store_local) | 1275 | bool store_local, |
1276 | bool user_waiting, | ||
1277 | F64 timeout) | ||
1274 | { | 1278 | { |
1275 | llwarns << "storeAssetData: wrong version called" << llendl; | 1279 | llwarns << "storeAssetData: wrong version called" << llendl; |
1276 | } | 1280 | } |
@@ -1285,7 +1289,9 @@ void LLAssetStorage::storeAssetData( | |||
1285 | bool temp_file , | 1289 | bool temp_file , |
1286 | bool is_priority, | 1290 | bool is_priority, |
1287 | bool store_local, | 1291 | bool store_local, |
1288 | const LLUUID& requesting_agent_id) | 1292 | const LLUUID& requesting_agent_id, |
1293 | bool user_waiting, | ||
1294 | F64 timeout) | ||
1289 | { | 1295 | { |
1290 | llwarns << "storeAssetData: wrong version called" << llendl; | 1296 | llwarns << "storeAssetData: wrong version called" << llendl; |
1291 | } | 1297 | } |
@@ -1299,7 +1305,9 @@ void LLAssetStorage::storeAssetData( | |||
1299 | LLStoreAssetCallback callback, | 1305 | LLStoreAssetCallback callback, |
1300 | void* user_data, | 1306 | void* user_data, |
1301 | bool temp_file, | 1307 | bool temp_file, |
1302 | bool is_priority) | 1308 | bool is_priority, |
1309 | bool user_waiting, | ||
1310 | F64 timeout) | ||
1303 | { | 1311 | { |
1304 | llwarns << "storeAssetData: wrong version called" << llendl; | 1312 | llwarns << "storeAssetData: wrong version called" << llendl; |
1305 | } | 1313 | } |
@@ -1313,7 +1321,9 @@ void LLAssetStorage::storeAssetData( | |||
1313 | LLStoreAssetCallback callback, | 1321 | LLStoreAssetCallback callback, |
1314 | void* user_data, | 1322 | void* user_data, |
1315 | bool temp_file, | 1323 | bool temp_file, |
1316 | bool is_priority) | 1324 | bool is_priority, |
1325 | bool user_waiting, | ||
1326 | F64 timeout) | ||
1317 | { | 1327 | { |
1318 | llwarns << "storeAssetData: wrong version called" << llendl; | 1328 | llwarns << "storeAssetData: wrong version called" << llendl; |
1319 | } | 1329 | } |
diff --git a/linden/indra/llmessage/llassetstorage.h b/linden/indra/llmessage/llassetstorage.h index f80a77d..ab12b7a 100644 --- a/linden/indra/llmessage/llassetstorage.h +++ b/linden/indra/llmessage/llassetstorage.h | |||
@@ -95,6 +95,7 @@ public: | |||
95 | 95 | ||
96 | void setUUID(const LLUUID& id) { mUUID = id; } | 96 | void setUUID(const LLUUID& id) { mUUID = id; } |
97 | void setType(LLAssetType::EType type) { mType = type; } | 97 | void setType(LLAssetType::EType type) { mType = type; } |
98 | void setTimeout (F64 timeout) { mTimeout = timeout; } | ||
98 | 99 | ||
99 | protected: | 100 | protected: |
100 | LLUUID mUUID; | 101 | LLUUID mUUID; |
@@ -109,7 +110,9 @@ public: | |||
109 | LLHost mHost; | 110 | LLHost mHost; |
110 | BOOL mIsTemp; | 111 | BOOL mIsTemp; |
111 | BOOL mIsLocal; | 112 | BOOL mIsLocal; |
113 | BOOL mIsUserWaiting; // We don't want to try forever if a user is waiting for a result. | ||
112 | F64 mTime; // Message system time | 114 | F64 mTime; // Message system time |
115 | F64 mTimeout; // Amount of time before timing out. | ||
113 | BOOL mIsPriority; | 116 | BOOL mIsPriority; |
114 | BOOL mDataSentInFirstPacket; | 117 | BOOL mDataSentInFirstPacket; |
115 | BOOL mDataIsInVFS; | 118 | BOOL mDataIsInVFS; |
@@ -252,7 +255,9 @@ public: | |||
252 | void* user_data, | 255 | void* user_data, |
253 | bool temp_file = false, | 256 | bool temp_file = false, |
254 | bool is_priority = false, | 257 | bool is_priority = false, |
255 | bool store_local = false); | 258 | bool store_local = false, |
259 | bool user_waiting= false, | ||
260 | F64 timeout=LL_ASSET_STORAGE_TIMEOUT); | ||
256 | 261 | ||
257 | /* | 262 | /* |
258 | * AssetID version | 263 | * AssetID version |
@@ -266,7 +271,9 @@ public: | |||
266 | bool temp_file = false, | 271 | bool temp_file = false, |
267 | bool is_priority = false, | 272 | bool is_priority = false, |
268 | bool store_local = false, | 273 | bool store_local = false, |
269 | const LLUUID& requesting_agent_id = LLUUID::null); | 274 | const LLUUID& requesting_agent_id = LLUUID::null, |
275 | bool user_waiting= false, | ||
276 | F64 timeout=LL_ASSET_STORAGE_TIMEOUT); | ||
270 | 277 | ||
271 | virtual void checkForTimeouts(); | 278 | virtual void checkForTimeouts(); |
272 | 279 | ||
@@ -360,7 +367,9 @@ public: | |||
360 | LLStoreAssetCallback callback, | 367 | LLStoreAssetCallback callback, |
361 | void* user_data, | 368 | void* user_data, |
362 | bool temp_file = false, | 369 | bool temp_file = false, |
363 | bool is_priority = false); | 370 | bool is_priority = false, |
371 | bool user_waiting = false, | ||
372 | F64 timeout = LL_ASSET_STORAGE_TIMEOUT); | ||
364 | 373 | ||
365 | /* | 374 | /* |
366 | * TransactionID version | 375 | * TransactionID version |
@@ -372,7 +381,9 @@ public: | |||
372 | LLStoreAssetCallback callback, | 381 | LLStoreAssetCallback callback, |
373 | void *user_data, | 382 | void *user_data, |
374 | bool temp_file = false, | 383 | bool temp_file = false, |
375 | bool is_priority = false); | 384 | bool is_priority = false, |
385 | bool user_waiting = false, | ||
386 | F64 timeout = LL_ASSET_STORAGE_TIMEOUT); | ||
376 | 387 | ||
377 | static void legacyGetDataCallback(LLVFS *vfs, const LLUUID &uuid, LLAssetType::EType, void *user_data, S32 status); | 388 | static void legacyGetDataCallback(LLVFS *vfs, const LLUUID &uuid, LLAssetType::EType, void *user_data, S32 status); |
378 | static void legacyStoreDataCallback(const LLUUID &uuid, void *user_data, S32 status); | 389 | static void legacyStoreDataCallback(const LLUUID &uuid, void *user_data, S32 status); |
diff --git a/linden/indra/llmessage/llblowfishcipher.cpp b/linden/indra/llmessage/llblowfishcipher.cpp index 1772078..62464de 100644 --- a/linden/indra/llmessage/llblowfishcipher.cpp +++ b/linden/indra/llmessage/llblowfishcipher.cpp | |||
@@ -1,5 +1,5 @@ | |||
1 | /** | 1 | /** |
2 | * @file llblowcipher.cpp | 2 | * @file llblowfishcipher.cpp |
3 | * @brief Wrapper around OpenSSL Blowfish encryption algorithm. | 3 | * @brief Wrapper around OpenSSL Blowfish encryption algorithm. |
4 | * | 4 | * |
5 | * We do not have OpenSSL headers or libraries on Windows, so this | 5 | * We do not have OpenSSL headers or libraries on Windows, so this |
@@ -85,33 +85,33 @@ U32 LLBlowfishCipher::encrypt(const U8* src, U32 src_len, U8* dst, U32 dst_len) | |||
85 | << " iv_len " << iv_length | 85 | << " iv_len " << iv_length |
86 | << llendl; | 86 | << llendl; |
87 | 87 | ||
88 | int output_len = 0; | 88 | int output_len = 0; |
89 | int temp_len = 0; | 89 | int temp_len = 0; |
90 | if (!EVP_EncryptUpdate(&context, | 90 | if (!EVP_EncryptUpdate(&context, |
91 | dst, | 91 | dst, |
92 | &output_len, | 92 | &output_len, |
93 | src, | 93 | src, |
94 | src_len)) | 94 | src_len)) |
95 | { | 95 | { |
96 | llwarns << "LLBlowfishCipher::encrypt EVP_EncryptUpdate failure" << llendl; | 96 | llwarns << "LLBlowfishCipher::encrypt EVP_EncryptUpdate failure" << llendl; |
97 | goto ERROR; | 97 | goto ERROR; |
98 | } | 98 | } |
99 | 99 | ||
100 | // There may be some final data left to encrypt if the input is | 100 | // There may be some final data left to encrypt if the input is |
101 | // not an exact multiple of the block size. | 101 | // not an exact multiple of the block size. |
102 | if (!EVP_EncryptFinal_ex(&context, (unsigned char*)(dst + output_len), &temp_len)) | 102 | if (!EVP_EncryptFinal_ex(&context, (unsigned char*)(dst + output_len), &temp_len)) |
103 | { | 103 | { |
104 | llwarns << "LLBlowfishCipher::encrypt EVP_EncryptFinal failure" << llendl; | 104 | llwarns << "LLBlowfishCipher::encrypt EVP_EncryptFinal failure" << llendl; |
105 | goto ERROR; | 105 | goto ERROR; |
106 | } | 106 | } |
107 | output_len += temp_len; | 107 | output_len += temp_len; |
108 | 108 | ||
109 | EVP_CIPHER_CTX_cleanup(&context); | 109 | EVP_CIPHER_CTX_cleanup(&context); |
110 | return output_len; | 110 | return output_len; |
111 | 111 | ||
112 | ERROR: | 112 | ERROR: |
113 | EVP_CIPHER_CTX_cleanup(&context); | 113 | EVP_CIPHER_CTX_cleanup(&context); |
114 | return 0; | 114 | return 0; |
115 | } | 115 | } |
116 | 116 | ||
117 | // virtual | 117 | // virtual |
diff --git a/linden/indra/llmessage/llcachename.cpp b/linden/indra/llmessage/llcachename.cpp index 2a21b5a..d960429 100644 --- a/linden/indra/llmessage/llcachename.cpp +++ b/linden/indra/llmessage/llcachename.cpp | |||
@@ -66,132 +66,130 @@ LLCacheName* gCacheName = NULL; | |||
66 | /// class LLCacheNameEntry | 66 | /// class LLCacheNameEntry |
67 | /// --------------------------------------------------------------------------- | 67 | /// --------------------------------------------------------------------------- |
68 | 68 | ||
69 | namespace { | 69 | class LLCacheNameEntry |
70 | class LLCacheNameEntry | 70 | { |
71 | { | 71 | public: |
72 | public: | 72 | LLCacheNameEntry(); |
73 | LLCacheNameEntry(); | ||
74 | 73 | ||
75 | public: | 74 | public: |
76 | bool mIsGroup; | 75 | bool mIsGroup; |
77 | U32 mCreateTime; // unix time_t | 76 | U32 mCreateTime; // unix time_t |
78 | char mFirstName[DB_FIRST_NAME_BUF_SIZE]; /*Flawfinder: ignore*/ | 77 | char mFirstName[DB_FIRST_NAME_BUF_SIZE]; /*Flawfinder: ignore*/ |
79 | char mLastName[DB_LAST_NAME_BUF_SIZE]; /*Flawfinder: ignore*/ | 78 | char mLastName[DB_LAST_NAME_BUF_SIZE]; /*Flawfinder: ignore*/ |
80 | char mGroupName[DB_GROUP_NAME_BUF_SIZE]; /*Flawfinder: ignore*/ | 79 | char mGroupName[DB_GROUP_NAME_BUF_SIZE]; /*Flawfinder: ignore*/ |
81 | }; | 80 | }; |
82 | 81 | ||
83 | LLCacheNameEntry::LLCacheNameEntry() | 82 | LLCacheNameEntry::LLCacheNameEntry() |
84 | { | 83 | { |
85 | mFirstName[0] = '\0'; | 84 | mFirstName[0] = '\0'; |
86 | mLastName[0] = '\0'; | 85 | mLastName[0] = '\0'; |
87 | mGroupName[0] = '\0'; | 86 | mGroupName[0] = '\0'; |
88 | } | 87 | } |
89 | 88 | ||
90 | 89 | ||
91 | class PendingReply | 90 | class PendingReply |
92 | { | 91 | { |
93 | public: | 92 | public: |
94 | LLUUID mID; | 93 | LLUUID mID; |
95 | LLCacheNameCallback mCallback; | 94 | LLCacheNameCallback mCallback; |
96 | LLHost mHost; | 95 | LLHost mHost; |
97 | void* mData; | 96 | void* mData; |
98 | PendingReply(const LLUUID& id, LLCacheNameCallback callback, void* data = NULL) | 97 | PendingReply(const LLUUID& id, LLCacheNameCallback callback, void* data = NULL) |
99 | : mID(id), mCallback(callback), mData(data) | 98 | : mID(id), mCallback(callback), mData(data) |
100 | { } | 99 | { } |
101 | 100 | ||
102 | PendingReply(const LLUUID& id, const LLHost& host) | 101 | PendingReply(const LLUUID& id, const LLHost& host) |
103 | : mID(id), mCallback(0), mHost(host) | 102 | : mID(id), mCallback(0), mHost(host) |
104 | { } | 103 | { } |
105 | 104 | ||
106 | void done() { mID.setNull(); } | 105 | void done() { mID.setNull(); } |
107 | bool isDone() const { return mID.isNull() != FALSE; } | 106 | bool isDone() const { return mID.isNull() != FALSE; } |
108 | }; | 107 | }; |
109 | 108 | ||
110 | class ReplySender | 109 | class ReplySender |
111 | { | 110 | { |
112 | public: | 111 | public: |
113 | ReplySender(LLMessageSystem* msg); | 112 | ReplySender(LLMessageSystem* msg); |
114 | ~ReplySender(); | 113 | ~ReplySender(); |
115 | 114 | ||
116 | void send(const LLUUID& id, | 115 | void send(const LLUUID& id, |
117 | const LLCacheNameEntry& entry, const LLHost& host); | 116 | const LLCacheNameEntry& entry, const LLHost& host); |
118 | 117 | ||
119 | private: | 118 | private: |
120 | void flush(); | 119 | void flush(); |
121 | 120 | ||
122 | LLMessageSystem* mMsg; | 121 | LLMessageSystem* mMsg; |
123 | bool mPending; | 122 | bool mPending; |
124 | bool mCurrIsGroup; | 123 | bool mCurrIsGroup; |
125 | LLHost mCurrHost; | 124 | LLHost mCurrHost; |
126 | }; | 125 | }; |
127 | 126 | ||
128 | ReplySender::ReplySender(LLMessageSystem* msg) | 127 | ReplySender::ReplySender(LLMessageSystem* msg) |
129 | : mMsg(msg), mPending(false) | 128 | : mMsg(msg), mPending(false) |
130 | { } | 129 | { } |
131 | 130 | ||
132 | ReplySender::~ReplySender() | 131 | ReplySender::~ReplySender() |
133 | { | 132 | { |
134 | flush(); | 133 | flush(); |
135 | } | 134 | } |
136 | 135 | ||
137 | void ReplySender::send(const LLUUID& id, | 136 | void ReplySender::send(const LLUUID& id, |
138 | const LLCacheNameEntry& entry, const LLHost& host) | 137 | const LLCacheNameEntry& entry, const LLHost& host) |
138 | { | ||
139 | if (mPending) | ||
139 | { | 140 | { |
140 | if (mPending) | 141 | if (mCurrIsGroup != entry.mIsGroup |
142 | || mCurrHost != host) | ||
141 | { | 143 | { |
142 | if (mCurrIsGroup != entry.mIsGroup | 144 | flush(); |
143 | || mCurrHost != host) | ||
144 | { | ||
145 | flush(); | ||
146 | } | ||
147 | } | 145 | } |
146 | } | ||
148 | 147 | ||
149 | if (!mPending) | 148 | if (!mPending) |
150 | { | 149 | { |
151 | mPending = true; | 150 | mPending = true; |
152 | mCurrIsGroup = entry.mIsGroup; | 151 | mCurrIsGroup = entry.mIsGroup; |
153 | mCurrHost = host; | 152 | mCurrHost = host; |
154 | |||
155 | if(mCurrIsGroup) | ||
156 | mMsg->newMessageFast(_PREHASH_UUIDGroupNameReply); | ||
157 | else | ||
158 | mMsg->newMessageFast(_PREHASH_UUIDNameReply); | ||
159 | } | ||
160 | 153 | ||
161 | mMsg->nextBlockFast(_PREHASH_UUIDNameBlock); | ||
162 | mMsg->addUUIDFast(_PREHASH_ID, id); | ||
163 | if(mCurrIsGroup) | 154 | if(mCurrIsGroup) |
164 | { | 155 | mMsg->newMessageFast(_PREHASH_UUIDGroupNameReply); |
165 | mMsg->addStringFast(_PREHASH_GroupName, entry.mGroupName); | ||
166 | } | ||
167 | else | 156 | else |
168 | { | 157 | mMsg->newMessageFast(_PREHASH_UUIDNameReply); |
169 | mMsg->addStringFast(_PREHASH_FirstName, entry.mFirstName); | 158 | } |
170 | mMsg->addStringFast(_PREHASH_LastName, entry.mLastName); | ||
171 | } | ||
172 | 159 | ||
173 | if(mMsg->isSendFullFast(_PREHASH_UUIDNameBlock)) | 160 | mMsg->nextBlockFast(_PREHASH_UUIDNameBlock); |
174 | { | 161 | mMsg->addUUIDFast(_PREHASH_ID, id); |
175 | flush(); | 162 | if(mCurrIsGroup) |
176 | } | 163 | { |
164 | mMsg->addStringFast(_PREHASH_GroupName, entry.mGroupName); | ||
165 | } | ||
166 | else | ||
167 | { | ||
168 | mMsg->addStringFast(_PREHASH_FirstName, entry.mFirstName); | ||
169 | mMsg->addStringFast(_PREHASH_LastName, entry.mLastName); | ||
177 | } | 170 | } |
178 | 171 | ||
179 | void ReplySender::flush() | 172 | if(mMsg->isSendFullFast(_PREHASH_UUIDNameBlock)) |
180 | { | 173 | { |
181 | if (mPending) | 174 | flush(); |
182 | { | ||
183 | mMsg->sendReliable(mCurrHost); | ||
184 | mPending = false; | ||
185 | } | ||
186 | } | 175 | } |
176 | } | ||
187 | 177 | ||
178 | void ReplySender::flush() | ||
179 | { | ||
180 | if (mPending) | ||
181 | { | ||
182 | mMsg->sendReliable(mCurrHost); | ||
183 | mPending = false; | ||
184 | } | ||
185 | } | ||
188 | 186 | ||
189 | typedef std::set<LLUUID> AskQueue; | 187 | |
190 | typedef std::vector<PendingReply> ReplyQueue; | 188 | typedef std::set<LLUUID> AskQueue; |
191 | typedef std::map<LLUUID,U32> PendingQueue; | 189 | typedef std::vector<PendingReply> ReplyQueue; |
192 | typedef std::map<LLUUID, LLCacheNameEntry*> Cache; | 190 | typedef std::map<LLUUID,U32> PendingQueue; |
193 | typedef std::vector<LLCacheNameCallback> Observers; | 191 | typedef std::map<LLUUID, LLCacheNameEntry*> Cache; |
194 | }; | 192 | typedef std::vector<LLCacheNameCallback> Observers; |
195 | 193 | ||
196 | class LLCacheName::Impl | 194 | class LLCacheName::Impl |
197 | { | 195 | { |
diff --git a/linden/indra/llmessage/llcurl.cpp b/linden/indra/llmessage/llcurl.cpp index 5eaaab0..362204a 100644 --- a/linden/indra/llmessage/llcurl.cpp +++ b/linden/indra/llmessage/llcurl.cpp | |||
@@ -28,6 +28,8 @@ | |||
28 | * COMPLETENESS OR PERFORMANCE. | 28 | * COMPLETENESS OR PERFORMANCE. |
29 | */ | 29 | */ |
30 | 30 | ||
31 | #include "linden_common.h" | ||
32 | |||
31 | #include "llcurl.h" | 33 | #include "llcurl.h" |
32 | 34 | ||
33 | #include <iomanip> | 35 | #include <iomanip> |
diff --git a/linden/indra/llmessage/llhttpassetstorage.cpp b/linden/indra/llmessage/llhttpassetstorage.cpp index 5a0cdad..d83349b 100644 --- a/linden/indra/llmessage/llhttpassetstorage.cpp +++ b/linden/indra/llmessage/llhttpassetstorage.cpp | |||
@@ -428,14 +428,18 @@ void LLHTTPAssetStorage::storeAssetData( | |||
428 | bool temp_file, | 428 | bool temp_file, |
429 | bool is_priority, | 429 | bool is_priority, |
430 | bool store_local, | 430 | bool store_local, |
431 | const LLUUID& requesting_agent_id) | 431 | const LLUUID& requesting_agent_id, |
432 | bool user_waiting, | ||
433 | F64 timeout) | ||
432 | { | 434 | { |
433 | if (mVFS->getExists(uuid, type)) | 435 | if (mVFS->getExists(uuid, type)) |
434 | { | 436 | { |
435 | LLAssetRequest *req = new LLAssetRequest(uuid, type); | 437 | LLAssetRequest *req = new LLAssetRequest(uuid, type); |
436 | req->mUpCallback = callback; | 438 | req->mUpCallback = callback; |
437 | req->mUserData = user_data; | 439 | req->mUserData = user_data; |
438 | req->mRequestingAgentID = requesting_agent_id; | 440 | req->mRequestingAgentID = requesting_agent_id; |
441 | req->mIsUserWaiting = user_waiting; | ||
442 | req->mTimeout = timeout; | ||
439 | 443 | ||
440 | // this will get picked up and transmitted in checkForTimeouts | 444 | // this will get picked up and transmitted in checkForTimeouts |
441 | if(store_local) | 445 | if(store_local) |
@@ -469,7 +473,9 @@ void LLHTTPAssetStorage::storeAssetData( | |||
469 | LLStoreAssetCallback callback, | 473 | LLStoreAssetCallback callback, |
470 | void* user_data, | 474 | void* user_data, |
471 | bool temp_file, | 475 | bool temp_file, |
472 | bool is_priority) | 476 | bool is_priority, |
477 | bool user_waiting, | ||
478 | F64 timeout) | ||
473 | { | 479 | { |
474 | llinfos << "LLAssetStorage::storeAssetData (legacy)" << asset_id << ":" << LLAssetType::lookup(asset_type) << llendl; | 480 | llinfos << "LLAssetStorage::storeAssetData (legacy)" << asset_id << ":" << LLAssetType::lookup(asset_type) << llendl; |
475 | 481 | ||
@@ -509,7 +515,11 @@ void LLHTTPAssetStorage::storeAssetData( | |||
509 | legacyStoreDataCallback, | 515 | legacyStoreDataCallback, |
510 | (void**)legacy, | 516 | (void**)legacy, |
511 | temp_file, | 517 | temp_file, |
512 | is_priority); | 518 | is_priority, |
519 | false, | ||
520 | LLUUID::null, | ||
521 | user_waiting, | ||
522 | timeout); | ||
513 | } | 523 | } |
514 | else | 524 | else |
515 | { | 525 | { |
@@ -608,7 +618,19 @@ bool LLHTTPAssetStorage::deletePendingRequest(LLAssetStorage::ERequestType rt, | |||
608 | // This request was found in the pending list. Move it to the end! | 618 | // This request was found in the pending list. Move it to the end! |
609 | LLAssetRequest* pending_req = *result; | 619 | LLAssetRequest* pending_req = *result; |
610 | pending->remove(pending_req); | 620 | pending->remove(pending_req); |
611 | pending->push_back(pending_req); | 621 | |
622 | if (!pending_req->mIsUserWaiting) //A user is waiting on this request. Toss it. | ||
623 | { | ||
624 | pending->push_back(pending_req); | ||
625 | } | ||
626 | else | ||
627 | { | ||
628 | if (pending_req->mUpCallback) //Clean up here rather than _callUploadCallbacks because this request is already cleared the req. | ||
629 | { | ||
630 | pending_req->mUpCallback(pending_req->getUUID(), pending_req->mUserData, -1); | ||
631 | } | ||
632 | |||
633 | } | ||
612 | 634 | ||
613 | llinfos << "Asset " << getRequestName(rt) << " request for " | 635 | llinfos << "Asset " << getRequestName(rt) << " request for " |
614 | << asset_id << "." << LLAssetType::lookup(asset_type) | 636 | << asset_id << "." << LLAssetType::lookup(asset_type) |
@@ -744,6 +766,14 @@ void LLHTTPAssetStorage::checkForTimeouts() | |||
744 | 766 | ||
745 | LLHTTPAssetRequest *new_req = new LLHTTPAssetRequest(this, req->getUUID(), | 767 | LLHTTPAssetRequest *new_req = new LLHTTPAssetRequest(this, req->getUUID(), |
746 | req->getType(), RT_UPLOAD, tmp_url, mCurlMultiHandle); | 768 | req->getType(), RT_UPLOAD, tmp_url, mCurlMultiHandle); |
769 | |||
770 | if (req->mIsUserWaiting) //If a user is waiting on a realtime response, we want to perserve information across upload attempts. | ||
771 | { | ||
772 | new_req->mTime = req->mTime; | ||
773 | new_req->mTimeout = req->mTimeout; | ||
774 | new_req->mIsUserWaiting = req->mIsUserWaiting; | ||
775 | } | ||
776 | |||
747 | if (do_compress) | 777 | if (do_compress) |
748 | { | 778 | { |
749 | new_req->prepareCompressedUpload(); | 779 | new_req->prepareCompressedUpload(); |
@@ -839,11 +869,12 @@ void LLHTTPAssetStorage::checkForTimeouts() | |||
839 | if (curl_msg && curl_msg->msg == CURLMSG_DONE) | 869 | if (curl_msg && curl_msg->msg == CURLMSG_DONE) |
840 | { | 870 | { |
841 | long curl_result = 0; | 871 | long curl_result = 0; |
842 | S32 xfer_result = 0; | 872 | S32 xfer_result = LL_ERR_NOERR; |
843 | 873 | ||
844 | LLHTTPAssetRequest *req = NULL; | 874 | LLHTTPAssetRequest *req = NULL; |
845 | curl_easy_getinfo(curl_msg->easy_handle, CURLINFO_PRIVATE, &req); | 875 | curl_easy_getinfo(curl_msg->easy_handle, CURLINFO_PRIVATE, &req); |
846 | 876 | ||
877 | // TODO: Throw curl_result at all callbacks. | ||
847 | curl_easy_getinfo(curl_msg->easy_handle, CURLINFO_HTTP_CODE, &curl_result); | 878 | curl_easy_getinfo(curl_msg->easy_handle, CURLINFO_HTTP_CODE, &curl_result); |
848 | if (RT_UPLOAD == req->mRequestType || RT_LOCALUPLOAD == req->mRequestType) | 879 | if (RT_UPLOAD == req->mRequestType || RT_LOCALUPLOAD == req->mRequestType) |
849 | { | 880 | { |
@@ -865,6 +896,12 @@ void LLHTTPAssetStorage::checkForTimeouts() | |||
865 | { | 896 | { |
866 | llwarns << "Re-requesting upload for " << req->getUUID() << ". Received upload error to " << req->mURLBuffer << | 897 | llwarns << "Re-requesting upload for " << req->getUUID() << ". Received upload error to " << req->mURLBuffer << |
867 | " with result " << curl_easy_strerror(curl_msg->data.result) << ", http result " << curl_result << llendl; | 898 | " with result " << curl_easy_strerror(curl_msg->data.result) << ", http result " << curl_result << llendl; |
899 | |||
900 | ////HACK (probably) I am sick of this getting requeued and driving me mad. | ||
901 | //if (req->mIsUserWaiting) | ||
902 | //{ | ||
903 | // deletePendingRequest(RT_UPLOAD, req->getType(), req->getUUID()); | ||
904 | //} | ||
868 | } | 905 | } |
869 | else | 906 | else |
870 | { | 907 | { |
@@ -949,14 +986,23 @@ void LLHTTPAssetStorage::checkForTimeouts() | |||
949 | 986 | ||
950 | void LLHTTPAssetStorage::bumpTimedOutUploads() | 987 | void LLHTTPAssetStorage::bumpTimedOutUploads() |
951 | { | 988 | { |
989 | bool user_waiting=FALSE; | ||
990 | |||
991 | F64 mt_secs = LLMessageSystem::getMessageTimeSeconds(); | ||
992 | |||
993 | if (mPendingUploads.size()) | ||
994 | { | ||
995 | request_list_t::iterator it = mPendingUploads.begin(); | ||
996 | LLAssetRequest* req = *it; | ||
997 | user_waiting=req->mIsUserWaiting; | ||
998 | } | ||
999 | |||
952 | // No point bumping currently running uploads if there are no others in line. | 1000 | // No point bumping currently running uploads if there are no others in line. |
953 | if (!(mPendingUploads.size() > mRunningUploads.size())) | 1001 | if (!(mPendingUploads.size() > mRunningUploads.size()) && !user_waiting) |
954 | { | 1002 | { |
955 | return; | 1003 | return; |
956 | } | 1004 | } |
957 | 1005 | ||
958 | F64 mt_secs = LLMessageSystem::getMessageTimeSeconds(); | ||
959 | |||
960 | // deletePendingRequest will modify the mRunningUploads list so we don't want to iterate over it. | 1006 | // deletePendingRequest will modify the mRunningUploads list so we don't want to iterate over it. |
961 | request_list_t temp_running = mRunningUploads; | 1007 | request_list_t temp_running = mRunningUploads; |
962 | 1008 | ||
@@ -967,7 +1013,7 @@ void LLHTTPAssetStorage::bumpTimedOutUploads() | |||
967 | //request_list_t::iterator curiter = iter++; | 1013 | //request_list_t::iterator curiter = iter++; |
968 | LLAssetRequest* req = *it; | 1014 | LLAssetRequest* req = *it; |
969 | 1015 | ||
970 | if ( LL_ASSET_STORAGE_TIMEOUT < (mt_secs - req->mTime) ) | 1016 | if ( req->mTimeout < (mt_secs - req->mTime) ) |
971 | { | 1017 | { |
972 | llwarns << "Asset upload request timed out for " | 1018 | llwarns << "Asset upload request timed out for " |
973 | << req->getUUID() << "." | 1019 | << req->getUUID() << "." |
diff --git a/linden/indra/llmessage/llhttpassetstorage.h b/linden/indra/llmessage/llhttpassetstorage.h index 2977301..962bece 100644 --- a/linden/indra/llmessage/llhttpassetstorage.h +++ b/linden/indra/llmessage/llhttpassetstorage.h | |||
@@ -66,7 +66,9 @@ public: | |||
66 | bool temp_file = false, | 66 | bool temp_file = false, |
67 | bool is_priority = false, | 67 | bool is_priority = false, |
68 | bool store_local = false, | 68 | bool store_local = false, |
69 | const LLUUID& requesting_agent_id = LLUUID::null); | 69 | const LLUUID& requesting_agent_id = LLUUID::null, |
70 | bool user_waiting=FALSE, | ||
71 | F64 timeout=LL_ASSET_STORAGE_TIMEOUT); | ||
70 | 72 | ||
71 | virtual void storeAssetData( | 73 | virtual void storeAssetData( |
72 | const char* filename, | 74 | const char* filename, |
@@ -75,7 +77,9 @@ public: | |||
75 | LLStoreAssetCallback callback, | 77 | LLStoreAssetCallback callback, |
76 | void* user_data, | 78 | void* user_data, |
77 | bool temp_file, | 79 | bool temp_file, |
78 | bool is_priority); | 80 | bool is_priority, |
81 | bool user_waiting=FALSE, | ||
82 | F64 timeout=LL_ASSET_STORAGE_TIMEOUT); | ||
79 | 83 | ||
80 | virtual LLSD getPendingDetails(ERequestType rt, | 84 | virtual LLSD getPendingDetails(ERequestType rt, |
81 | LLAssetType::EType asset_type, | 85 | LLAssetType::EType asset_type, |
diff --git a/linden/indra/llmessage/llhttpnode.cpp b/linden/indra/llmessage/llhttpnode.cpp index 97064a1..25413b4 100644 --- a/linden/indra/llmessage/llhttpnode.cpp +++ b/linden/indra/llmessage/llhttpnode.cpp | |||
@@ -29,7 +29,7 @@ | |||
29 | #include "linden_common.h" | 29 | #include "linden_common.h" |
30 | #include "llhttpnode.h" | 30 | #include "llhttpnode.h" |
31 | 31 | ||
32 | #include "boost/tokenizer.hpp" | 32 | #include <boost/tokenizer.hpp> |
33 | 33 | ||
34 | #include "llstl.h" | 34 | #include "llstl.h" |
35 | 35 | ||
diff --git a/linden/indra/llmessage/lliohttpserver.cpp b/linden/indra/llmessage/lliohttpserver.cpp index d7fc54e..5c96102 100644 --- a/linden/indra/llmessage/lliohttpserver.cpp +++ b/linden/indra/llmessage/lliohttpserver.cpp | |||
@@ -49,7 +49,7 @@ | |||
49 | 49 | ||
50 | #include <sstream> | 50 | #include <sstream> |
51 | 51 | ||
52 | #include "boost/tokenizer.hpp" | 52 | #include <boost/tokenizer.hpp> |
53 | 53 | ||
54 | static const char HTTP_VERSION_STR[] = "HTTP/1.0"; | 54 | static const char HTTP_VERSION_STR[] = "HTTP/1.0"; |
55 | static const std::string CONTEXT_REQUEST("request"); | 55 | static const std::string CONTEXT_REQUEST("request"); |
diff --git a/linden/indra/llmessage/lliosocket.cpp b/linden/indra/llmessage/lliosocket.cpp index 0ceb436..8bc347c 100644 --- a/linden/indra/llmessage/lliosocket.cpp +++ b/linden/indra/llmessage/lliosocket.cpp | |||
@@ -441,6 +441,8 @@ LLIOPipe::EStatus LLIOSocketWriter::process_impl( | |||
441 | #if LL_WINDOWS | 441 | #if LL_WINDOWS |
442 | if (status == 730035) | 442 | if (status == 730035) |
443 | break; | 443 | break; |
444 | #else | ||
445 | (void) status; | ||
444 | #endif | 446 | #endif |
445 | mLastWritten = segment.data() + len - 1; | 447 | mLastWritten = segment.data() + len - 1; |
446 | 448 | ||
diff --git a/linden/indra/llmessage/llmessagethrottle.cpp b/linden/indra/llmessage/llmessagethrottle.cpp index 07c22a5..bbaa9d8 100644 --- a/linden/indra/llmessage/llmessagethrottle.cpp +++ b/linden/indra/llmessage/llmessagethrottle.cpp | |||
@@ -26,6 +26,8 @@ | |||
26 | * COMPLETENESS OR PERFORMANCE. | 26 | * COMPLETENESS OR PERFORMANCE. |
27 | */ | 27 | */ |
28 | 28 | ||
29 | #include "linden_common.h" | ||
30 | |||
29 | #include "llhash.h" | 31 | #include "llhash.h" |
30 | 32 | ||
31 | #include "llmessagethrottle.h" | 33 | #include "llmessagethrottle.h" |
diff --git a/linden/indra/llmessage/llservicebuilder.cpp b/linden/indra/llmessage/llservicebuilder.cpp index 86b7d9d..91040c0 100644 --- a/linden/indra/llmessage/llservicebuilder.cpp +++ b/linden/indra/llmessage/llservicebuilder.cpp | |||
@@ -26,6 +26,7 @@ | |||
26 | * COMPLETENESS OR PERFORMANCE. | 26 | * COMPLETENESS OR PERFORMANCE. |
27 | */ | 27 | */ |
28 | 28 | ||
29 | #include "linden_common.h" | ||
29 | #include "llapp.h" | 30 | #include "llapp.h" |
30 | #include "llfile.h" | 31 | #include "llfile.h" |
31 | #include "llservicebuilder.h" | 32 | #include "llservicebuilder.h" |
diff --git a/linden/indra/llmessage/lltemplatemessagereader.cpp b/linden/indra/llmessage/lltemplatemessagereader.cpp index 892efb8..bb3f4f4 100644 --- a/linden/indra/llmessage/lltemplatemessagereader.cpp +++ b/linden/indra/llmessage/lltemplatemessagereader.cpp | |||
@@ -594,7 +594,7 @@ BOOL LLTemplateMessageReader::decodeData(const U8* buffer, const LLHost& sender | |||
594 | tsize = tsizeh; | 594 | tsize = tsizeh; |
595 | break; | 595 | break; |
596 | case 4: | 596 | case 4: |
597 | htonmemcpy(&tsizeb, &buffer[decode_pos], MVT_U32, 4); | 597 | htonmemcpy(&tsize, &buffer[decode_pos], MVT_U32, 4); |
598 | break; | 598 | break; |
599 | default: | 599 | default: |
600 | llerrs << "Attempting to read variable field with unknown size of " << data_size << llendl; | 600 | llerrs << "Attempting to read variable field with unknown size of " << data_size << llendl; |
diff --git a/linden/indra/llmessage/message.cpp b/linden/indra/llmessage/message.cpp index ab41cca..d1c2875 100644 --- a/linden/indra/llmessage/message.cpp +++ b/linden/indra/llmessage/message.cpp | |||
@@ -1341,7 +1341,7 @@ LLMessageSystem::~LLMessageSystem() | |||
1341 | 1341 | ||
1342 | if (!mbError) | 1342 | if (!mbError) |
1343 | { | 1343 | { |
1344 | end_net(); | 1344 | end_net(mSocket); |
1345 | } | 1345 | } |
1346 | 1346 | ||
1347 | delete mTemplateMessageReader; | 1347 | delete mTemplateMessageReader; |
@@ -1355,6 +1355,9 @@ LLMessageSystem::~LLMessageSystem() | |||
1355 | delete mLLSDMessageReader; | 1355 | delete mLLSDMessageReader; |
1356 | mLLSDMessageReader = NULL; | 1356 | mLLSDMessageReader = NULL; |
1357 | 1357 | ||
1358 | delete mLLSDMessageBuilder; | ||
1359 | mLLSDMessageBuilder = NULL; | ||
1360 | |||
1358 | delete mPollInfop; | 1361 | delete mPollInfop; |
1359 | mPollInfop = NULL; | 1362 | mPollInfop = NULL; |
1360 | 1363 | ||
@@ -4164,11 +4167,13 @@ void LLMessageSystem::dumpPacketToLog() | |||
4164 | char line_buffer[256]; /* Flawfinder: ignore */ | 4167 | char line_buffer[256]; /* Flawfinder: ignore */ |
4165 | S32 i; | 4168 | S32 i; |
4166 | S32 cur_line_pos = 0; | 4169 | S32 cur_line_pos = 0; |
4167 | |||
4168 | S32 cur_line = 0; | 4170 | S32 cur_line = 0; |
4171 | |||
4169 | for (i = 0; i < mTrueReceiveSize; i++) | 4172 | for (i = 0; i < mTrueReceiveSize; i++) |
4170 | { | 4173 | { |
4171 | snprintf(line_buffer + cur_line_pos*3, sizeof(line_buffer),"%02x ", mTrueReceiveBuffer[i]); /* Flawfinder: ignore */ | 4174 | S32 offset = cur_line_pos * 3; |
4175 | snprintf(line_buffer + offset, sizeof(line_buffer) - offset, | ||
4176 | "%02x ", mTrueReceiveBuffer[i]); /* Flawfinder: ignore */ | ||
4172 | cur_line_pos++; | 4177 | cur_line_pos++; |
4173 | if (cur_line_pos >= 16) | 4178 | if (cur_line_pos >= 16) |
4174 | { | 4179 | { |
@@ -4345,11 +4350,6 @@ std::string get_shared_secret() | |||
4345 | 4350 | ||
4346 | typedef std::map<const char*, LLMessageBuilder*> BuilderMap; | 4351 | typedef std::map<const char*, LLMessageBuilder*> BuilderMap; |
4347 | 4352 | ||
4348 | static void setBuilder(BuilderMap& map, const char* name, LLMessageBuilder* builder) | ||
4349 | { | ||
4350 | map[gMessageStringTable.getString(name)] = builder; | ||
4351 | } | ||
4352 | |||
4353 | void LLMessageSystem::newMessageFast(const char *name) | 4353 | void LLMessageSystem::newMessageFast(const char *name) |
4354 | { | 4354 | { |
4355 | if(LLMessageConfig::isMessageBuiltTemplate(name)) | 4355 | if(LLMessageConfig::isMessageBuiltTemplate(name)) |
diff --git a/linden/indra/llmessage/net.cpp b/linden/indra/llmessage/net.cpp index c61f4a2..1395093 100644 --- a/linden/indra/llmessage/net.cpp +++ b/linden/indra/llmessage/net.cpp | |||
@@ -289,8 +289,12 @@ S32 start_net(S32& socket_out, int& nPort) | |||
289 | return 0; | 289 | return 0; |
290 | } | 290 | } |
291 | 291 | ||
292 | void end_net() | 292 | void end_net(S32& socket_out) |
293 | { | 293 | { |
294 | if (socket_out < 0) | ||
295 | { | ||
296 | closesocket(socket_out); | ||
297 | } | ||
294 | WSACleanup(); | 298 | WSACleanup(); |
295 | } | 299 | } |
296 | 300 | ||
@@ -457,8 +461,12 @@ S32 start_net(S32& socket_out, int& nPort) | |||
457 | return 0; | 461 | return 0; |
458 | } | 462 | } |
459 | 463 | ||
460 | void end_net() | 464 | void end_net(S32& socket_out) |
461 | { | 465 | { |
466 | if (socket_out < 0) | ||
467 | { | ||
468 | close(socket_out); | ||
469 | } | ||
462 | } | 470 | } |
463 | 471 | ||
464 | int receive_packet(int hSocket, char * receiveBuffer) | 472 | int receive_packet(int hSocket, char * receiveBuffer) |
diff --git a/linden/indra/llmessage/net.h b/linden/indra/llmessage/net.h index b2f931f..cfc1f88 100644 --- a/linden/indra/llmessage/net.h +++ b/linden/indra/llmessage/net.h | |||
@@ -40,7 +40,7 @@ class LLHost; | |||
40 | // Returns 0 on success, non-zero on error. | 40 | // Returns 0 on success, non-zero on error. |
41 | // Sets socket handler/descriptor, changes nPort if port requested is unavailable. | 41 | // Sets socket handler/descriptor, changes nPort if port requested is unavailable. |
42 | S32 start_net(S32& socket_out, int& nPort); | 42 | S32 start_net(S32& socket_out, int& nPort); |
43 | void end_net(); | 43 | void end_net(S32& socket_out); |
44 | 44 | ||
45 | // returns size of packet or -1 in case of error | 45 | // returns size of packet or -1 in case of error |
46 | S32 receive_packet(int hSocket, char * receiveBuffer); | 46 | S32 receive_packet(int hSocket, char * receiveBuffer); |