/**
 * @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 "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"]);
}