llareslistener.cpp
上传用户:king477883
上传日期:2021-03-01
资源大小:9553k
文件大小:4k
源码类别:

游戏引擎

开发平台:

C++ Builder

  1. /**
  2.  * @file   llareslistener.cpp
  3.  * @author Nat Goodspeed
  4.  * @date   2009-03-18
  5.  * @brief  Implementation for llareslistener.
  6.  * 
  7.  * $LicenseInfo:firstyear=2009&license=viewergpl$
  8.  * 
  9.  * Copyright (c) 2009-2010, Linden Research, Inc.
  10.  * 
  11.  * Second Life Viewer Source Code
  12.  * The source code in this file ("Source Code") is provided by Linden Lab
  13.  * to you under the terms of the GNU General Public License, version 2.0
  14.  * ("GPL"), unless you have obtained a separate licensing agreement
  15.  * ("Other License"), formally executed by you and Linden Lab.  Terms of
  16.  * the GPL can be found in doc/GPL-license.txt in this distribution, or
  17.  * online at http://secondlifegrid.net/programs/open_source/licensing/gplv2
  18.  * 
  19.  * There are special exceptions to the terms and conditions of the GPL as
  20.  * it is applied to this Source Code. View the full text of the exception
  21.  * in the file doc/FLOSS-exception.txt in this software distribution, or
  22.  * online at
  23.  * http://secondlifegrid.net/programs/open_source/licensing/flossexception
  24.  * 
  25.  * By copying, modifying or distributing this software, you acknowledge
  26.  * that you have read and understood your obligations described above,
  27.  * and agree to abide by those obligations.
  28.  * 
  29.  * ALL LINDEN LAB SOURCE CODE IS PROVIDED "AS IS." LINDEN LAB MAKES NO
  30.  * WARRANTIES, EXPRESS, IMPLIED OR OTHERWISE, REGARDING ITS ACCURACY,
  31.  * COMPLETENESS OR PERFORMANCE.
  32.  * $/LicenseInfo$
  33.  */
  34. // Precompiled header
  35. #include "linden_common.h"
  36. // associated header
  37. #include "llareslistener.h"
  38. // STL headers
  39. // std headers
  40. // external library headers
  41. // other Linden headers
  42. #include "llares.h"
  43. #include "llerror.h"
  44. #include "llevents.h"
  45. #include "llsdutil.h"
  46. LLAresListener::LLAresListener(LLAres* llares):
  47.     LLEventAPI("LLAres",
  48.                "LLAres listener to request DNS operations"),
  49.     mAres(llares)
  50. {
  51.     // add() every method we want to be able to invoke via this event API.
  52.     // Optional last parameter validates expected LLSD request structure.
  53.     add("rewriteURI",
  54.         "Given ["uri"], return on ["reply"] an array of alternative URIs.n"
  55.         "On failure, returns an array containing only the original URI, son"
  56.         "failure case can be processed like success case.",
  57.         &LLAresListener::rewriteURI,
  58.         LLSD().with("uri", LLSD()).with("reply", LLSD()));
  59. }
  60. /// This UriRewriteResponder subclass packages returned URIs as an LLSD
  61. /// array to send back to the requester.
  62. class UriRewriteResponder: public LLAres::UriRewriteResponder
  63. {
  64. public:
  65.     /**
  66.      * Specify the request, containing the event pump name on which to send
  67.      * the reply.
  68.      */
  69.     UriRewriteResponder(const LLSD& request):
  70.         mReqID(request),
  71.         mPumpName(request["reply"])
  72.     {}
  73.     /// Called by base class with results. This is called in both the
  74.     /// success and error cases. On error, the calling logic passes the
  75.     /// original URI.
  76.     virtual void rewriteResult(const std::vector<std::string>& uris)
  77.     {
  78.         LLSD result;
  79.         for (std::vector<std::string>::const_iterator ui(uris.begin()), uend(uris.end());
  80.              ui != uend; ++ui)
  81.         {
  82.             result.append(*ui);
  83.         }
  84.         // This call knows enough to avoid trying to insert a map key into an
  85.         // LLSD array. It's there so that if, for any reason, we ever decide
  86.         // to change the response from array to map, it will Just Start Working.
  87.         mReqID.stamp(result);
  88.         LLEventPumps::instance().obtain(mPumpName).post(result);
  89.     }
  90. private:
  91.     LLReqID mReqID;
  92.     const std::string mPumpName;
  93. };
  94. void LLAresListener::rewriteURI(const LLSD& data)
  95. {
  96.     mAres->rewriteURI(data["uri"], new UriRewriteResponder(data));
  97. }