summaryrefslogtreecommitdiff
path: root/indra/newview/llurldispatcher.cpp
diff options
context:
space:
mode:
Diffstat (limited to 'indra/newview/llurldispatcher.cpp')
-rw-r--r--indra/newview/llurldispatcher.cpp500
1 files changed, 250 insertions, 250 deletions
diff --git a/indra/newview/llurldispatcher.cpp b/indra/newview/llurldispatcher.cpp
index 07ea8a4ec6..fbcaaef1b8 100644
--- a/indra/newview/llurldispatcher.cpp
+++ b/indra/newview/llurldispatcher.cpp
@@ -5,21 +5,21 @@
* $LicenseInfo:firstyear=2007&license=viewerlgpl$
* Second Life Viewer Source Code
* Copyright (C) 2010, Linden Research, Inc.
- *
+ *
* This library is free software; you can redistribute it and/or
* modify it under the terms of the GNU Lesser General Public
* License as published by the Free Software Foundation;
* version 2.1 of the License only.
- *
+ *
* This library is distributed in the hope that it will be useful,
* but WITHOUT ANY WARRANTY; without even the implied warranty of
* MERCHANTABILITY or FITNESS FOR A PARTICULAR PURPOSE. See the GNU
* Lesser General Public License for more details.
- *
+ *
* You should have received a copy of the GNU Lesser General Public
* License along with this library; if not, write to the Free Software
* Foundation, Inc., 51 Franklin Street, Fifth Floor, Boston, MA 02110-1301 USA
- *
+ *
* Linden Research, Inc., 945 Battery Street, San Francisco, CA 94111 USA
* $/LicenseInfo$
*/
@@ -28,7 +28,7 @@
#include "llurldispatcher.h"
// viewer includes
-#include "llagent.h" // teleportViaLocation()
+#include "llagent.h" // teleportViaLocation()
#include "llcommandhandler.h"
#include "llfloaterhelpbrowser.h"
#include "llfloaterreg.h"
@@ -38,7 +38,7 @@
#include "llpanellogin.h"
#include "llregionhandle.h"
#include "llslurl.h"
-#include "llstartup.h" // gStartupState
+#include "llstartup.h" // gStartupState
#include "llweb.h"
#include "llworldmapmessage.h"
#include "llurldispatcherlistener.h"
@@ -54,162 +54,162 @@ static LLURLDispatcherListener sURLDispatcherListener;
class LLURLDispatcherImpl
{
public:
- static bool dispatch(const LLSLURL& slurl,
- const std::string& nav_type,
- LLMediaCtrl* web,
- bool trusted_browser);
- // returns true if handled or explicitly blocked.
+ static bool dispatch(const LLSLURL& slurl,
+ const std::string& nav_type,
+ LLMediaCtrl* web,
+ bool trusted_browser);
+ // returns true if handled or explicitly blocked.
- static bool dispatchRightClick(const LLSLURL& slurl);
+ static bool dispatchRightClick(const LLSLURL& slurl);
private:
- static bool dispatchCore(const LLSLURL& slurl,
- const std::string& nav_type,
- bool right_mouse,
- LLMediaCtrl* web,
- bool trusted_browser);
- // handles both left and right click
-
- static bool dispatchHelp(const LLSLURL& slurl, bool right_mouse);
- // Handles sl://app.floater.html.help by showing Help floater.
- // Returns true if handled.
-
- static bool dispatchApp(const LLSLURL& slurl,
- const std::string& nav_type,
- bool right_mouse,
- LLMediaCtrl* web,
- bool trusted_browser);
- // Handles secondlife:///app/agent/<agent_id>/about and similar
- // by showing panel in Search floater.
- // Returns true if handled or explicitly blocked.
-
- static bool dispatchRegion(const LLSLURL& slurl, const std::string& nav_type, bool right_mouse);
- // handles secondlife://Ahern/123/45/67/
- // Returns true if handled.
-
- static void regionHandleCallback(U64 handle, const LLSLURL& slurl,
- const LLUUID& snapshot_id, bool teleport);
- // Called by LLWorldMap when a location has been resolved to a
- // region name
-
- static void regionNameCallback(U64 handle, const LLSLURL& slurl,
- const LLUUID& snapshot_id, bool teleport);
- // Called by LLWorldMap when a region name has been resolved to a
- // location in-world, used by places-panel display.
+ static bool dispatchCore(const LLSLURL& slurl,
+ const std::string& nav_type,
+ bool right_mouse,
+ LLMediaCtrl* web,
+ bool trusted_browser);
+ // handles both left and right click
+
+ static bool dispatchHelp(const LLSLURL& slurl, bool right_mouse);
+ // Handles sl://app.floater.html.help by showing Help floater.
+ // Returns true if handled.
+
+ static bool dispatchApp(const LLSLURL& slurl,
+ const std::string& nav_type,
+ bool right_mouse,
+ LLMediaCtrl* web,
+ bool trusted_browser);
+ // Handles secondlife:///app/agent/<agent_id>/about and similar
+ // by showing panel in Search floater.
+ // Returns true if handled or explicitly blocked.
+
+ static bool dispatchRegion(const LLSLURL& slurl, const std::string& nav_type, bool right_mouse);
+ // handles secondlife://Ahern/123/45/67/
+ // Returns true if handled.
+
+ static void regionHandleCallback(U64 handle, const LLSLURL& slurl,
+ const LLUUID& snapshot_id, bool teleport);
+ // Called by LLWorldMap when a location has been resolved to a
+ // region name
+
+ static void regionNameCallback(U64 handle, const LLSLURL& slurl,
+ const LLUUID& snapshot_id, bool teleport);
+ // Called by LLWorldMap when a region name has been resolved to a
+ // location in-world, used by places-panel display.
static bool handleGrid(const LLSLURL& slurl);
- friend class LLTeleportHandler;
+ friend class LLTeleportHandler;
};
// static
bool LLURLDispatcherImpl::dispatchCore(const LLSLURL& slurl,
- const std::string& nav_type,
- bool right_mouse,
- LLMediaCtrl* web,
- bool trusted_browser)
+ const std::string& nav_type,
+ bool right_mouse,
+ LLMediaCtrl* web,
+ bool trusted_browser)
{
- //if (dispatchHelp(slurl, right_mouse)) return true;
- switch(slurl.getType())
- {
- case LLSLURL::APP:
- return dispatchApp(slurl, nav_type, right_mouse, web, trusted_browser);
- case LLSLURL::LOCATION:
- return dispatchRegion(slurl, nav_type, right_mouse);
- default:
- return false;
- }
-
- /*
- // Inform the user we can't handle this
- std::map<std::string, std::string> args;
- args["SLURL"] = slurl;
- r;
- */
+ //if (dispatchHelp(slurl, right_mouse)) return true;
+ switch(slurl.getType())
+ {
+ case LLSLURL::APP:
+ return dispatchApp(slurl, nav_type, right_mouse, web, trusted_browser);
+ case LLSLURL::LOCATION:
+ return dispatchRegion(slurl, nav_type, right_mouse);
+ default:
+ return false;
+ }
+
+ /*
+ // Inform the user we can't handle this
+ std::map<std::string, std::string> args;
+ args["SLURL"] = slurl;
+ r;
+ */
}
// static
bool LLURLDispatcherImpl::dispatch(const LLSLURL& slurl,
- const std::string& nav_type,
- LLMediaCtrl* web,
- bool trusted_browser)
+ const std::string& nav_type,
+ LLMediaCtrl* web,
+ bool trusted_browser)
{
// SL-20422 : Clicking the "Bring it back" link on Aditi displays a teleport alert
// Stop further processing empty urls like [secondlife:/// Bring it back.]
if (slurl.getType() == LLSLURL::EMPTY)
return true;
- const bool right_click = false;
- return dispatchCore(slurl, nav_type, right_click, web, trusted_browser);
+ const bool right_click = false;
+ return dispatchCore(slurl, nav_type, right_click, web, trusted_browser);
}
// static
bool LLURLDispatcherImpl::dispatchRightClick(const LLSLURL& slurl)
{
- const bool right_click = true;
- LLMediaCtrl* web = NULL;
- const bool trusted_browser = false;
+ const bool right_click = true;
+ LLMediaCtrl* web = NULL;
+ const bool trusted_browser = false;
return dispatchCore(slurl, LLCommandHandler::NAV_TYPE_CLICKED, right_click, web, trusted_browser);
}
// static
-bool LLURLDispatcherImpl::dispatchApp(const LLSLURL& slurl,
- const std::string& nav_type,
- bool right_mouse,
- LLMediaCtrl* web,
- bool trusted_browser)
+bool LLURLDispatcherImpl::dispatchApp(const LLSLURL& slurl,
+ const std::string& nav_type,
+ bool right_mouse,
+ LLMediaCtrl* web,
+ bool trusted_browser)
{
- LL_INFOS() << "cmd: " << slurl.getAppCmd() << " path: " << slurl.getAppPath() << " query: " << slurl.getAppQuery() << LL_ENDL;
- const LLSD& query_map = LLURI::queryMap(slurl.getAppQuery());
- bool handled = LLCommandDispatcher::dispatch(
- slurl.getAppCmd(), slurl.getAppPath(), query_map, slurl.getGrid(), web, nav_type, trusted_browser);
-
- // alert if we didn't handle this secondlife:///app/ SLURL
- // (but still return true because it is a valid app SLURL)
- if (! handled)
- {
- LLNotificationsUtil::add("UnsupportedCommandSLURL");
- }
- return true;
+ LL_INFOS() << "cmd: " << slurl.getAppCmd() << " path: " << slurl.getAppPath() << " query: " << slurl.getAppQuery() << LL_ENDL;
+ const LLSD& query_map = LLURI::queryMap(slurl.getAppQuery());
+ bool handled = LLCommandDispatcher::dispatch(
+ slurl.getAppCmd(), slurl.getAppPath(), query_map, slurl.getGrid(), web, nav_type, trusted_browser);
+
+ // alert if we didn't handle this secondlife:///app/ SLURL
+ // (but still return true because it is a valid app SLURL)
+ if (! handled)
+ {
+ LLNotificationsUtil::add("UnsupportedCommandSLURL");
+ }
+ return true;
}
// static
bool LLURLDispatcherImpl::dispatchRegion(const LLSLURL& slurl, const std::string& nav_type, bool right_mouse)
{
- if(slurl.getType() != LLSLURL::LOCATION)
+ if(slurl.getType() != LLSLURL::LOCATION)
+ {
+ return false;
+ }
+ // Before we're logged in, need to update the startup screen
+ // to tell the user where they are going.
+ if (LLStartUp::getStartupState() < STATE_LOGIN_CLEANUP)
{
- return false;
+ // We're at the login screen, so make sure user can see
+ // the login location box to know where they are going.
+
+ LLPanelLogin::setLocation(slurl);
+ return true;
}
- // Before we're logged in, need to update the startup screen
- // to tell the user where they are going.
- if (LLStartUp::getStartupState() < STATE_LOGIN_CLEANUP)
- {
- // We're at the login screen, so make sure user can see
- // the login location box to know where they are going.
-
- LLPanelLogin::setLocation(slurl);
- return true;
- }
if (!handleGrid(slurl))
{
return true;
}
- // Request a region handle by name
- LLWorldMapMessage::getInstance()->sendNamedRegionRequest(slurl.getRegion(),
- LLURLDispatcherImpl::regionNameCallback,
- slurl.getSLURLString(),
- LLUI::getInstance()->mSettingGroups["config"]->getBOOL("SLURLTeleportDirectly")); // don't teleport
- return true;
+ // Request a region handle by name
+ LLWorldMapMessage::getInstance()->sendNamedRegionRequest(slurl.getRegion(),
+ LLURLDispatcherImpl::regionNameCallback,
+ slurl.getSLURLString(),
+ LLUI::getInstance()->mSettingGroups["config"]->getBOOL("SLURLTeleportDirectly")); // don't teleport
+ return true;
}
/*static*/
void LLURLDispatcherImpl::regionNameCallback(U64 region_handle, const LLSLURL& slurl, const LLUUID& snapshot_id, bool teleport)
{
-
+
if(slurl.getType() == LLSLURL::LOCATION)
- {
+ {
regionHandleCallback(region_handle, slurl, snapshot_id, teleport);
}
}
@@ -247,29 +247,29 @@ void LLURLDispatcherImpl::regionHandleCallback(U64 region_handle, const LLSLURL&
// we can't teleport cross grid at this point
return;
}
-
- LLVector3d global_pos = from_region_handle(region_handle);
- global_pos += LLVector3d(slurl.getPosition());
-
- if (teleport)
- {
- gAgent.teleportViaLocation(global_pos);
- LLFloaterWorldMap* instance = LLFloaterWorldMap::getInstance();
- if(instance)
- {
- instance->trackLocation(global_pos);
- }
- }
- else
- {
- LLSD key;
- key["type"] = "remote_place";
- key["x"] = global_pos.mdV[VX];
- key["y"] = global_pos.mdV[VY];
- key["z"] = global_pos.mdV[VZ];
-
- LLFloaterSidePanelContainer::showPanel("places", key);
- }
+
+ LLVector3d global_pos = from_region_handle(region_handle);
+ global_pos += LLVector3d(slurl.getPosition());
+
+ if (teleport)
+ {
+ gAgent.teleportViaLocation(global_pos);
+ LLFloaterWorldMap* instance = LLFloaterWorldMap::getInstance();
+ if(instance)
+ {
+ instance->trackLocation(global_pos);
+ }
+ }
+ else
+ {
+ LLSD key;
+ key["type"] = "remote_place";
+ key["x"] = global_pos.mdV[VX];
+ key["y"] = global_pos.mdV[VY];
+ key["z"] = global_pos.mdV[VZ];
+
+ LLFloaterSidePanelContainer::showPanel("places", key);
+ }
}
//---------------------------------------------------------------------------
@@ -279,111 +279,111 @@ void LLURLDispatcherImpl::regionHandleCallback(U64 region_handle, const LLSLURL&
class LLTeleportHandler : public LLCommandHandler, public LLEventAPI
{
public:
- // Teleport requests *must* come from a trusted browser
- // inside the app, otherwise a malicious web page could
- // cause a constant teleport loop. JC
- LLTeleportHandler() :
- LLCommandHandler("teleport", UNTRUSTED_CLICK_ONLY),
- LLEventAPI("LLTeleportHandler", "Low-level teleport API")
- {
- LLEventAPI::add("teleport",
- "Teleport to specified [\"regionname\"] at\n"
- "specified region-relative [\"x\"], [\"y\"], [\"z\"].\n"
- "If [\"regionname\"] omitted, teleport to GLOBAL\n"
- "coordinates [\"x\"], [\"y\"], [\"z\"].",
- &LLTeleportHandler::from_event);
- }
-
- bool handle(const LLSD& tokens,
+ // Teleport requests *must* come from a trusted browser
+ // inside the app, otherwise a malicious web page could
+ // cause a constant teleport loop. JC
+ LLTeleportHandler() :
+ LLCommandHandler("teleport", UNTRUSTED_CLICK_ONLY),
+ LLEventAPI("LLTeleportHandler", "Low-level teleport API")
+ {
+ LLEventAPI::add("teleport",
+ "Teleport to specified [\"regionname\"] at\n"
+ "specified region-relative [\"x\"], [\"y\"], [\"z\"].\n"
+ "If [\"regionname\"] omitted, teleport to GLOBAL\n"
+ "coordinates [\"x\"], [\"y\"], [\"z\"].",
+ &LLTeleportHandler::from_event);
+ }
+
+ bool handle(const LLSD& tokens,
const LLSD& query_map,
const std::string& grid,
LLMediaCtrl* web)
- {
- // construct a "normal" SLURL, resolve the region to
- // a global position, and teleport to it
- if (tokens.size() < 1) return false;
-
- LLVector3 coords(128, 128, 0);
- if (tokens.size() <= 4)
- {
- coords = LLVector3(tokens[1].asReal(),
- tokens[2].asReal(),
- tokens[3].asReal());
- }
-
- // Region names may be %20 escaped.
- std::string region_name = LLURI::unescape(tokens[0]);
-
- LLSD args;
- args["LOCATION"] = region_name;
-
- LLSD payload;
- payload["region_name"] = region_name;
- payload["callback_url"] = LLSLURL(grid, region_name, coords).getSLURLString();
-
- LLNotificationsUtil::add("TeleportViaSLAPP", args, payload);
- return true;
- }
-
- void from_event(const LLSD& params) const
- {
- Response response(LLSD(), params);
- if (params.has("regionname"))
- {
- // region specified, coordinates (if any) are region-local
- LLVector3 local_pos(
- params.has("x")? params["x"].asReal() : 128,
- params.has("y")? params["y"].asReal() : 128,
- params.has("z")? params["z"].asReal() : 0);
- std::string regionname(params["regionname"]);
- std::string destination(LLSLURL(regionname, local_pos).getSLURLString());
- // have to resolve region's global coordinates first
- teleport_via_slapp(regionname, destination);
- response["message"] = "Teleporting to " + destination;
- }
- else // no regionname
- {
- // coordinates are global, and at least (x, y) are required
- if (! (params.has("x") && params.has("y")))
- {
- return response.error("Specify either regionname or global (x, y)");
- }
- LLVector3d global_pos(params["x"].asReal(), params["y"].asReal(),
- params["z"].asReal());
- gAgent.teleportViaLocation(global_pos);
- LLFloaterWorldMap* instance = LLFloaterWorldMap::getInstance();
- if (instance)
- {
- instance->trackLocation(global_pos);
- }
- response["message"] = STRINGIZE("Teleporting to global " << global_pos);
- }
- }
-
- static void teleport_via_slapp(std::string region_name, std::string callback_url)
- {
-
- LLWorldMapMessage::getInstance()->sendNamedRegionRequest(region_name,
- LLURLDispatcherImpl::regionHandleCallback,
- callback_url,
- true); // teleport
- }
-
- static bool teleport_via_slapp_callback(const LLSD& notification, const LLSD& response)
- {
- S32 option = LLNotificationsUtil::getSelectedOption(notification, response);
-
- std::string region_name = notification["payload"]["region_name"].asString();
- std::string callback_url = notification["payload"]["callback_url"].asString();
-
- if (option == 0)
- {
- teleport_via_slapp(region_name, callback_url);
- return true;
- }
-
- return false;
- }
+ {
+ // construct a "normal" SLURL, resolve the region to
+ // a global position, and teleport to it
+ if (tokens.size() < 1) return false;
+
+ LLVector3 coords(128, 128, 0);
+ if (tokens.size() <= 4)
+ {
+ coords = LLVector3(tokens[1].asReal(),
+ tokens[2].asReal(),
+ tokens[3].asReal());
+ }
+
+ // Region names may be %20 escaped.
+ std::string region_name = LLURI::unescape(tokens[0]);
+
+ LLSD args;
+ args["LOCATION"] = region_name;
+
+ LLSD payload;
+ payload["region_name"] = region_name;
+ payload["callback_url"] = LLSLURL(grid, region_name, coords).getSLURLString();
+
+ LLNotificationsUtil::add("TeleportViaSLAPP", args, payload);
+ return true;
+ }
+
+ void from_event(const LLSD& params) const
+ {
+ Response response(LLSD(), params);
+ if (params.has("regionname"))
+ {
+ // region specified, coordinates (if any) are region-local
+ LLVector3 local_pos(
+ params.has("x")? params["x"].asReal() : 128,
+ params.has("y")? params["y"].asReal() : 128,
+ params.has("z")? params["z"].asReal() : 0);
+ std::string regionname(params["regionname"]);
+ std::string destination(LLSLURL(regionname, local_pos).getSLURLString());
+ // have to resolve region's global coordinates first
+ teleport_via_slapp(regionname, destination);
+ response["message"] = "Teleporting to " + destination;
+ }
+ else // no regionname
+ {
+ // coordinates are global, and at least (x, y) are required
+ if (! (params.has("x") && params.has("y")))
+ {
+ return response.error("Specify either regionname or global (x, y)");
+ }
+ LLVector3d global_pos(params["x"].asReal(), params["y"].asReal(),
+ params["z"].asReal());
+ gAgent.teleportViaLocation(global_pos);
+ LLFloaterWorldMap* instance = LLFloaterWorldMap::getInstance();
+ if (instance)
+ {
+ instance->trackLocation(global_pos);
+ }
+ response["message"] = STRINGIZE("Teleporting to global " << global_pos);
+ }
+ }
+
+ static void teleport_via_slapp(std::string region_name, std::string callback_url)
+ {
+
+ LLWorldMapMessage::getInstance()->sendNamedRegionRequest(region_name,
+ LLURLDispatcherImpl::regionHandleCallback,
+ callback_url,
+ true); // teleport
+ }
+
+ static bool teleport_via_slapp_callback(const LLSD& notification, const LLSD& response)
+ {
+ S32 option = LLNotificationsUtil::getSelectedOption(notification, response);
+
+ std::string region_name = notification["payload"]["region_name"].asString();
+ std::string callback_url = notification["payload"]["callback_url"].asString();
+
+ if (option == 0)
+ {
+ teleport_via_slapp(region_name, callback_url);
+ return true;
+ }
+
+ return false;
+ }
};
LLTeleportHandler gTeleportHandler;
@@ -395,30 +395,30 @@ static LLNotificationFunctorRegistration open_landmark_callback_reg("TeleportVia
// static
bool LLURLDispatcher::dispatch(const std::string& slurl,
- const std::string& nav_type,
- LLMediaCtrl* web,
- bool trusted_browser)
+ const std::string& nav_type,
+ LLMediaCtrl* web,
+ bool trusted_browser)
{
- return LLURLDispatcherImpl::dispatch(LLSLURL(slurl), nav_type, web, trusted_browser);
+ return LLURLDispatcherImpl::dispatch(LLSLURL(slurl), nav_type, web, trusted_browser);
}
// static
bool LLURLDispatcher::dispatchRightClick(const std::string& slurl)
{
- return LLURLDispatcherImpl::dispatchRightClick(LLSLURL(slurl));
+ return LLURLDispatcherImpl::dispatchRightClick(LLSLURL(slurl));
}
// static
bool LLURLDispatcher::dispatchFromTextEditor(const std::string& slurl, bool trusted_content)
{
- // *NOTE: Text editors are considered sources of trusted URLs
- // in order to make avatar profile links in chat history work.
- // While a malicious resident could chat an app SLURL, the
- // receiving resident will see it and must affirmatively
- // click on it.
- // *TODO: Make this trust model more refined. JC
-
- LLMediaCtrl* web = NULL;
+ // *NOTE: Text editors are considered sources of trusted URLs
+ // in order to make avatar profile links in chat history work.
+ // While a malicious resident could chat an app SLURL, the
+ // receiving resident will see it and must affirmatively
+ // click on it.
+ // *TODO: Make this trust model more refined. JC
+
+ LLMediaCtrl* web = NULL;
return LLURLDispatcherImpl::dispatch(LLSLURL(slurl), LLCommandHandler::NAV_TYPE_CLICKED, web, trusted_content);
}