1
2
3
4
5
6
7
8
9
10
11
12
13
14
15
16
17
18
19
20
21
22
23
24
25
26
27
28
29
30
31
32
33
34
35
36
37
38
39
40
41
42
43
44
45
46
47
48
49
50
51
52
53
54
55
56
57
58
59
|
/**
* @file llurldispatcherlistener.cpp
* @author Nat Goodspeed
* @date 2009-12-10
* @brief Implementation for llurldispatcherlistener.
*
* $LicenseInfo:firstyear=2009&license=viewergpl$
* Copyright (c) 2009, Linden Research, Inc.
* $/LicenseInfo$
*/
// Precompiled header
#include "llviewerprecompiledheaders.h"
// associated header
#include "llurldispatcherlistener.h"
// STL headers
// std headers
// external library headers
// other Linden headers
#include "llslurl.h"
#include "llurldispatcher.h"
LLURLDispatcherListener::LLURLDispatcherListener(/* LLURLDispatcher* instance */):
LLEventAPI("LLURLDispatcher", "Internal URL handling") /* ,
mDispatcher(instance) */
{
add("dispatch",
"At startup time or on clicks in internal web browsers,\n"
"teleport, open map, or run requested command.\n"
"[\"url\"] string url to dispatch\n"
"[\"trusted\"] boolean indicating trusted browser [default true]",
&LLURLDispatcherListener::dispatch);
add("dispatchRightClick", "Dispatch [\"url\"] as if from a right-click on a hot link.",
&LLURLDispatcherListener::dispatchRightClick);
add("dispatchFromTextEditor", "Dispatch [\"url\"] as if from an edit field.",
&LLURLDispatcherListener::dispatchFromTextEditor);
}
void LLURLDispatcherListener::dispatch(const LLSD& params) const
{
// For most purposes, we expect callers to want to be trusted.
bool trusted_browser = true;
if (params.has("trusted"))
{
// But for testing, allow a caller to specify untrusted.
trusted_browser = params["trusted"].asBoolean();
}
LLURLDispatcher::dispatch(params["url"], NULL, trusted_browser);
}
void LLURLDispatcherListener::dispatchRightClick(const LLSD& params) const
{
LLURLDispatcher::dispatchRightClick(params["url"]);
}
void LLURLDispatcherListener::dispatchFromTextEditor(const LLSD& params) const
{
LLURLDispatcher::dispatchFromTextEditor(params["url"]);
}
|