diff options
Diffstat (limited to 'linden/indra/newview/llstartup.cpp')
-rw-r--r-- | linden/indra/newview/llstartup.cpp | 43 |
1 files changed, 35 insertions, 8 deletions
diff --git a/linden/indra/newview/llstartup.cpp b/linden/indra/newview/llstartup.cpp index 4af02cb..0130edf 100644 --- a/linden/indra/newview/llstartup.cpp +++ b/linden/indra/newview/llstartup.cpp | |||
@@ -117,6 +117,7 @@ | |||
117 | #include "llpreviewscript.h" | 117 | #include "llpreviewscript.h" |
118 | #include "llselectmgr.h" | 118 | #include "llselectmgr.h" |
119 | #include "llsky.h" | 119 | #include "llsky.h" |
120 | #include "llsrv.h" | ||
120 | #include "llstatview.h" | 121 | #include "llstatview.h" |
121 | #include "llsurface.h" | 122 | #include "llsurface.h" |
122 | #include "lltexturecache.h" | 123 | #include "lltexturecache.h" |
@@ -285,7 +286,8 @@ BOOL idle_startup() | |||
285 | // auth/transform loop will do. | 286 | // auth/transform loop will do. |
286 | static F32 progress = 0.10f; | 287 | static F32 progress = 0.10f; |
287 | 288 | ||
288 | static std::string auth_uri; | 289 | static std::vector<std::string> auth_uris; |
290 | static int auth_uri_num = -1; | ||
289 | static std::string auth_method; | 291 | static std::string auth_method; |
290 | static std::string auth_desc; | 292 | static std::string auth_desc; |
291 | static std::string auth_message; | 293 | static std::string auth_message; |
@@ -1109,7 +1111,11 @@ BOOL idle_startup() | |||
1109 | gSavedSettings.setBOOL("UseDebugMenus", TRUE); | 1111 | gSavedSettings.setBOOL("UseDebugMenus", TRUE); |
1110 | requested_options.push_back("god-connect"); | 1112 | requested_options.push_back("god-connect"); |
1111 | } | 1113 | } |
1112 | auth_uri = getLoginURI(); | 1114 | if (auth_uris.empty()) |
1115 | { | ||
1116 | auth_uris = getLoginURIs(); | ||
1117 | } | ||
1118 | auth_uri_num = 0; | ||
1113 | auth_method = "login_to_simulator"; | 1119 | auth_method = "login_to_simulator"; |
1114 | auth_desc = "Logging in. "; | 1120 | auth_desc = "Logging in. "; |
1115 | auth_desc += gSecondLife; | 1121 | auth_desc += gSecondLife; |
@@ -1152,7 +1158,7 @@ BOOL idle_startup() | |||
1152 | hashed_mac.hex_digest(hashed_mac_string); | 1158 | hashed_mac.hex_digest(hashed_mac_string); |
1153 | 1159 | ||
1154 | gUserAuthp->authenticate( | 1160 | gUserAuthp->authenticate( |
1155 | auth_uri.c_str(), | 1161 | auth_uris[auth_uri_num].c_str(), |
1156 | auth_method.c_str(), | 1162 | auth_method.c_str(), |
1157 | firstname.c_str(), | 1163 | firstname.c_str(), |
1158 | lastname.c_str(), | 1164 | lastname.c_str(), |
@@ -1248,7 +1254,8 @@ BOOL idle_startup() | |||
1248 | else if(login_response && (0 == strcmp(login_response, "indeterminate"))) | 1254 | else if(login_response && (0 == strcmp(login_response, "indeterminate"))) |
1249 | { | 1255 | { |
1250 | llinfos << "Indeterminate login..." << llendl; | 1256 | llinfos << "Indeterminate login..." << llendl; |
1251 | auth_uri = gUserAuthp->getResponse("next_url"); | 1257 | auth_uris = LLSRV::rewriteURI(gUserAuthp->getResponse("next_url")); |
1258 | auth_uri_num = 0; | ||
1252 | auth_method = gUserAuthp->getResponse("next_method"); | 1259 | auth_method = gUserAuthp->getResponse("next_method"); |
1253 | auth_message = gUserAuthp->getResponse("message"); | 1260 | auth_message = gUserAuthp->getResponse("message"); |
1254 | if(auth_method.substr(0, 5) == "login") | 1261 | if(auth_method.substr(0, 5) == "login") |
@@ -1351,13 +1358,33 @@ BOOL idle_startup() | |||
1351 | case LLUserAuth::E_SSL_PEER_CERTIFICATE: | 1358 | case LLUserAuth::E_SSL_PEER_CERTIFICATE: |
1352 | case LLUserAuth::E_UNHANDLED_ERROR: | 1359 | case LLUserAuth::E_UNHANDLED_ERROR: |
1353 | default: | 1360 | default: |
1354 | emsg << "Unable to connect to " << gSecondLife << ".\n"; | 1361 | if (auth_uri_num >= (int) auth_uris.size()) |
1355 | emsg << gUserAuthp->errorMessage(); | 1362 | { |
1363 | emsg << "Unable to connect to " << gSecondLife << ".\n"; | ||
1364 | emsg << gUserAuthp->errorMessage(); | ||
1365 | } else { | ||
1366 | std::ostringstream s; | ||
1367 | s << "Logging in (attempt " << (auth_uri_num + 1) << "). "; | ||
1368 | auth_desc = s.str(); | ||
1369 | gStartupState = STATE_LOGIN_AUTHENTICATE; | ||
1370 | auth_uri_num++; | ||
1371 | return do_normal_idle; | ||
1372 | } | ||
1356 | break; | 1373 | break; |
1357 | case LLUserAuth::E_SSL_CACERT: | 1374 | case LLUserAuth::E_SSL_CACERT: |
1358 | case LLUserAuth::E_SSL_CONNECT_ERROR: | 1375 | case LLUserAuth::E_SSL_CONNECT_ERROR: |
1359 | emsg << "Unable to establish a secure connection to the login server.\n"; | 1376 | if (auth_uri_num >= (int) auth_uris.size()) |
1360 | emsg << gUserAuthp->errorMessage(); | 1377 | { |
1378 | emsg << "Unable to establish a secure connection to the login server.\n"; | ||
1379 | emsg << gUserAuthp->errorMessage(); | ||
1380 | } else { | ||
1381 | std::ostringstream s; | ||
1382 | s << "Logging in (attempt " << (auth_uri_num + 1) << "). "; | ||
1383 | auth_desc = s.str(); | ||
1384 | gStartupState = STATE_LOGIN_AUTHENTICATE; | ||
1385 | auth_uri_num++; | ||
1386 | return do_normal_idle; | ||
1387 | } | ||
1361 | break; | 1388 | break; |
1362 | } | 1389 | } |
1363 | 1390 | ||