aboutsummaryrefslogtreecommitdiffstatshomepage
diff options
context:
space:
mode:
authorDr Scofield2008-07-01 08:50:22 +0000
committerDr Scofield2008-07-01 08:50:22 +0000
commit0a657b941606f6edb5a27bc047f122a6255f1706 (patch)
tree402cfb783f7d278e5547d2c570e9f433956d4323
parentFrom: kurt taylor (krtaylor) (diff)
downloadopensim-SC-0a657b941606f6edb5a27bc047f122a6255f1706.zip
opensim-SC-0a657b941606f6edb5a27bc047f122a6255f1706.tar.gz
opensim-SC-0a657b941606f6edb5a27bc047f122a6255f1706.tar.bz2
opensim-SC-0a657b941606f6edb5a27bc047f122a6255f1706.tar.xz
making XmlRpcs of RemoteController more robust; this fixes mantis #1467
Diffstat (limited to '')
-rw-r--r--OpenSim/ApplicationPlugins/RemoteController/RemoteAdminPlugin.cs40
1 files changed, 23 insertions, 17 deletions
diff --git a/OpenSim/ApplicationPlugins/RemoteController/RemoteAdminPlugin.cs b/OpenSim/ApplicationPlugins/RemoteController/RemoteAdminPlugin.cs
index d3fe0e0..2239001 100644
--- a/OpenSim/ApplicationPlugins/RemoteController/RemoteAdminPlugin.cs
+++ b/OpenSim/ApplicationPlugins/RemoteController/RemoteAdminPlugin.cs
@@ -98,12 +98,12 @@ namespace OpenSim.ApplicationPlugins.RemoteController
98 public XmlRpcResponse XmlRpcRestartMethod(XmlRpcRequest request) 98 public XmlRpcResponse XmlRpcRestartMethod(XmlRpcRequest request)
99 { 99 {
100 XmlRpcResponse response = new XmlRpcResponse(); 100 XmlRpcResponse response = new XmlRpcResponse();
101 Hashtable requestData = (Hashtable) request.Params[0];
102
103 Hashtable responseData = new Hashtable(); 101 Hashtable responseData = new Hashtable();
104 102
105 m_log.Info("[RADMIN]: Request to restart Region.");
106 try { 103 try {
104 Hashtable requestData = (Hashtable) request.Params[0];
105
106 m_log.Info("[RADMIN]: Request to restart Region.");
107 checkStringParameters(request, new string[] { "password", "regionID" }); 107 checkStringParameters(request, new string[] { "password", "regionID" });
108 108
109 if (requiredPassword != String.Empty && 109 if (requiredPassword != String.Empty &&
@@ -140,10 +140,11 @@ namespace OpenSim.ApplicationPlugins.RemoteController
140 public XmlRpcResponse XmlRpcAlertMethod(XmlRpcRequest request) 140 public XmlRpcResponse XmlRpcAlertMethod(XmlRpcRequest request)
141 { 141 {
142 XmlRpcResponse response = new XmlRpcResponse(); 142 XmlRpcResponse response = new XmlRpcResponse();
143 Hashtable requestData = (Hashtable) request.Params[0];
144 Hashtable responseData = new Hashtable(); 143 Hashtable responseData = new Hashtable();
145 144
146 try { 145 try {
146 Hashtable requestData = (Hashtable) request.Params[0];
147
147 checkStringParameters(request, new string[] { "password", "message" }); 148 checkStringParameters(request, new string[] { "password", "message" });
148 149
149 if (requiredPassword != String.Empty && 150 if (requiredPassword != String.Empty &&
@@ -175,17 +176,18 @@ namespace OpenSim.ApplicationPlugins.RemoteController
175 public XmlRpcResponse XmlRpcLoadHeightmapMethod(XmlRpcRequest request) 176 public XmlRpcResponse XmlRpcLoadHeightmapMethod(XmlRpcRequest request)
176 { 177 {
177 XmlRpcResponse response = new XmlRpcResponse(); 178 XmlRpcResponse response = new XmlRpcResponse();
178 Hashtable requestData = (Hashtable)request.Params[0];
179
180 m_log.DebugFormat("[RADMIN]: Load Terrain: XmlRpc {0}", request.ToString());
181 foreach (string k in requestData.Keys)
182 {
183 m_log.DebugFormat("[RADMIN]: Load Terrain: XmlRpc {0}: >{1}< {2}",
184 k, (string)requestData[k], ((string)requestData[k]).Length);
185 }
186
187 Hashtable responseData = new Hashtable(); 179 Hashtable responseData = new Hashtable();
180
188 try { 181 try {
182 Hashtable requestData = (Hashtable)request.Params[0];
183
184 m_log.DebugFormat("[RADMIN]: Load Terrain: XmlRpc {0}", request.ToString());
185 // foreach (string k in requestData.Keys)
186 // {
187 // m_log.DebugFormat("[RADMIN]: Load Terrain: XmlRpc {0}: >{1}< {2}",
188 // k, (string)requestData[k], ((string)requestData[k]).Length);
189 // }
190
189 checkStringParameters(request, new string[] { "password", "filename", "regionid"}); 191 checkStringParameters(request, new string[] { "password", "filename", "regionid"});
190 192
191 if (requiredPassword != String.Empty && 193 if (requiredPassword != String.Empty &&
@@ -227,10 +229,11 @@ namespace OpenSim.ApplicationPlugins.RemoteController
227 { 229 {
228 m_log.Info("[RADMIN]: Received Shutdown Administrator Request"); 230 m_log.Info("[RADMIN]: Received Shutdown Administrator Request");
229 XmlRpcResponse response = new XmlRpcResponse(); 231 XmlRpcResponse response = new XmlRpcResponse();
230 Hashtable requestData = (Hashtable) request.Params[0];
231 Hashtable responseData = new Hashtable(); 232 Hashtable responseData = new Hashtable();
232 233
233 try { 234 try {
235 Hashtable requestData = (Hashtable) request.Params[0];
236
234 if (requiredPassword != String.Empty && 237 if (requiredPassword != String.Empty &&
235 (!requestData.Contains("password") || (string) requestData["password"] != requiredPassword)) 238 (!requestData.Contains("password") || (string) requestData["password"] != requiredPassword))
236 throw new Exception("wrong password"); 239 throw new Exception("wrong password");
@@ -355,10 +358,11 @@ namespace OpenSim.ApplicationPlugins.RemoteController
355 { 358 {
356 m_log.Info("[RADMIN]: CreateRegion: new request"); 359 m_log.Info("[RADMIN]: CreateRegion: new request");
357 XmlRpcResponse response = new XmlRpcResponse(); 360 XmlRpcResponse response = new XmlRpcResponse();
358 Hashtable requestData = (Hashtable) request.Params[0];
359 Hashtable responseData = new Hashtable(); 361 Hashtable responseData = new Hashtable();
360 362
361 try { 363 try {
364 Hashtable requestData = (Hashtable) request.Params[0];
365
362 checkStringParameters(request, new string[] { "password", 366 checkStringParameters(request, new string[] { "password",
363 "region_name", 367 "region_name",
364 "region_master_first", "region_master_last", 368 "region_master_first", "region_master_last",
@@ -507,11 +511,12 @@ namespace OpenSim.ApplicationPlugins.RemoteController
507 { 511 {
508 m_log.Info("[RADMIN]: CreateUser: new request"); 512 m_log.Info("[RADMIN]: CreateUser: new request");
509 XmlRpcResponse response = new XmlRpcResponse(); 513 XmlRpcResponse response = new XmlRpcResponse();
510 Hashtable requestData = (Hashtable) request.Params[0];
511 Hashtable responseData = new Hashtable(); 514 Hashtable responseData = new Hashtable();
512 515
513 try 516 try
514 { 517 {
518 Hashtable requestData = (Hashtable) request.Params[0];
519
515 // check completeness 520 // check completeness
516 checkStringParameters(request, new string[] { "password", "user_firstname", 521 checkStringParameters(request, new string[] { "password", "user_firstname",
517 "user_lastname", "user_password" }); 522 "user_lastname", "user_password" });
@@ -563,11 +568,12 @@ namespace OpenSim.ApplicationPlugins.RemoteController
563 { 568 {
564 m_log.Info("[RADMIN]: Received Load XML Administrator Request"); 569 m_log.Info("[RADMIN]: Received Load XML Administrator Request");
565 XmlRpcResponse response = new XmlRpcResponse(); 570 XmlRpcResponse response = new XmlRpcResponse();
566 Hashtable requestData = (Hashtable) request.Params[0];
567 Hashtable responseData = new Hashtable(); 571 Hashtable responseData = new Hashtable();
568 572
569 try 573 try
570 { 574 {
575 Hashtable requestData = (Hashtable) request.Params[0];
576
571 // check completeness 577 // check completeness
572 foreach (string p in new string[] { "password", "filename" }) 578 foreach (string p in new string[] { "password", "filename" })
573 { 579 {