Merge branch 'master' of /var/git/opensim/
						commit
						dd67175edf
					
				|  | @ -41,6 +41,7 @@ using log4net; | ||||||
| using Nini.Config; | using Nini.Config; | ||||||
| using Nwc.XmlRpc; | using Nwc.XmlRpc; | ||||||
| using OpenSim.Framework; | using OpenSim.Framework; | ||||||
|  | using Mono.Addins; | ||||||
| 
 | 
 | ||||||
| using OpenSim.Framework.Capabilities; | using OpenSim.Framework.Capabilities; | ||||||
| using OpenSim.Framework.Servers; | using OpenSim.Framework.Servers; | ||||||
|  | @ -52,7 +53,8 @@ using System.Text.RegularExpressions; | ||||||
| 
 | 
 | ||||||
| namespace OpenSim.Region.OptionalModules.Avatar.Voice.FreeSwitchVoice | namespace OpenSim.Region.OptionalModules.Avatar.Voice.FreeSwitchVoice | ||||||
| { | { | ||||||
|     public class FreeSwitchVoiceModule : IRegionModule, IVoiceModule |     [Extension(Path = "/OpenSim/RegionModules", NodeName = "RegionModule", Id = "FreeSwitchVoiceModule")] | ||||||
|  |     public class FreeSwitchVoiceModule : INonSharedRegionModule, IVoiceModule | ||||||
|     { |     { | ||||||
|         private static readonly ILog m_log = LogManager.GetLogger(MethodBase.GetCurrentMethod().DeclaringType); |         private static readonly ILog m_log = LogManager.GetLogger(MethodBase.GetCurrentMethod().DeclaringType); | ||||||
| 
 | 
 | ||||||
|  | @ -64,8 +66,7 @@ namespace OpenSim.Region.OptionalModules.Avatar.Voice.FreeSwitchVoice | ||||||
|         private static readonly string m_chatSessionRequestPath = "0009/"; |         private static readonly string m_chatSessionRequestPath = "0009/"; | ||||||
| 
 | 
 | ||||||
|         // Control info |         // Control info | ||||||
|         private static bool   m_WOF = true; |         private static bool   m_Enabled  = false; | ||||||
|         private static bool   m_pluginEnabled  = false; |  | ||||||
| 
 | 
 | ||||||
|         // FreeSwitch server is going to contact us and ask us all |         // FreeSwitch server is going to contact us and ask us all | ||||||
|         // sorts of things. |         // sorts of things. | ||||||
|  | @ -104,9 +105,8 @@ namespace OpenSim.Region.OptionalModules.Avatar.Voice.FreeSwitchVoice | ||||||
| 
 | 
 | ||||||
|         private IConfig m_config; |         private IConfig m_config; | ||||||
| 
 | 
 | ||||||
|         public void Initialise(Scene scene, IConfigSource config) |         public void Initialise(IConfigSource config) | ||||||
|         { |         { | ||||||
|             m_scene = scene; |  | ||||||
|             m_config = config.Configs["FreeSwitchVoice"]; |             m_config = config.Configs["FreeSwitchVoice"]; | ||||||
| 
 | 
 | ||||||
|             if (null == m_config) |             if (null == m_config) | ||||||
|  | @ -121,86 +121,106 @@ namespace OpenSim.Region.OptionalModules.Avatar.Voice.FreeSwitchVoice | ||||||
|                 return; |                 return; | ||||||
|             } |             } | ||||||
| 
 | 
 | ||||||
|             // This is only done the FIRST time this method is invoked. |             m_Enabled = true; | ||||||
|             if (m_WOF) | 
 | ||||||
|  |             try | ||||||
|             { |             { | ||||||
|                 m_pluginEnabled = true; |                 m_freeSwitchServerUser = m_config.GetString("freeswitch_server_user", String.Empty); | ||||||
|                 m_WOF = false; |                 m_freeSwitchServerPass = m_config.GetString("freeswitch_server_pass", String.Empty); | ||||||
|  |                 m_freeSwitchAPIPrefix = m_config.GetString("freeswitch_api_prefix", String.Empty); | ||||||
| 
 | 
 | ||||||
|                 try |                 // XXX: get IP address of HTTP server. (This can be this OpenSim server or another, or could be a dedicated grid service or may live on the freeswitch server) | ||||||
|  | 
 | ||||||
|  |                 string serviceIP = m_config.GetString("freeswitch_service_server", String.Empty); | ||||||
|  |                 int servicePort = m_config.GetInt("freeswitch_service_port", 80); | ||||||
|  |                 IPAddress serviceIPAddress = IPAddress.Parse(serviceIP); | ||||||
|  |                 // m_FreeSwitchServiceIP = new IPEndPoint(serviceIPAddress, servicePort); | ||||||
|  |                 m_freeSwitchServicePort = servicePort; | ||||||
|  |                 m_freeSwitchRealm = m_config.GetString("freeswitch_realm", String.Empty); | ||||||
|  |                 m_freeSwitchSIPProxy = m_config.GetString("freeswitch_sip_proxy", m_freeSwitchRealm); | ||||||
|  |                 m_freeSwitchAttemptUseSTUN = m_config.GetBoolean("freeswitch_attempt_stun", true); | ||||||
|  |                 // m_freeSwitchSTUNServer = m_config.GetString("freeswitch_stun_server", m_freeSwitchRealm); | ||||||
|  |                 m_freeSwitchEchoServer = m_config.GetString("freeswitch_echo_server", m_freeSwitchRealm); | ||||||
|  |                 m_freeSwitchEchoPort = m_config.GetInt("freeswitch_echo_port", 50505); | ||||||
|  |                 m_freeSwitchDefaultWellKnownIP = m_config.GetString("freeswitch_well_known_ip", m_freeSwitchRealm); | ||||||
|  |                 m_openSimWellKnownHTTPAddress = m_config.GetString("opensim_well_known_http_address", serviceIPAddress.ToString()); | ||||||
|  |                 m_freeSwitchDefaultTimeout = m_config.GetInt("freeswitch_default_timeout", 5000); | ||||||
|  |                 // m_freeSwitchSubscribeRetry = m_config.GetInt("freeswitch_subscribe_retry", 120); | ||||||
|  |                 m_freeSwitchUrlResetPassword = m_config.GetString("freeswitch_password_reset_url", String.Empty); | ||||||
|  |                 m_freeSwitchContext = m_config.GetString("freeswitch_context", "default"); | ||||||
|  | 
 | ||||||
|  |                 if (String.IsNullOrEmpty(m_freeSwitchServerUser) || | ||||||
|  |                     String.IsNullOrEmpty(m_freeSwitchServerPass) || | ||||||
|  |                     String.IsNullOrEmpty(m_freeSwitchRealm) || | ||||||
|  |                     String.IsNullOrEmpty(m_freeSwitchAPIPrefix)) | ||||||
|                 { |                 { | ||||||
|                     m_freeSwitchServerUser = m_config.GetString("freeswitch_server_user", String.Empty); |                     m_log.Error("[FreeSwitchVoice] plugin mis-configured"); | ||||||
|                     m_freeSwitchServerPass = m_config.GetString("freeswitch_server_pass", String.Empty); |                     m_log.Info("[FreeSwitchVoice] plugin disabled: incomplete configuration"); | ||||||
|                     m_freeSwitchAPIPrefix = m_config.GetString("freeswitch_api_prefix", String.Empty); |  | ||||||
| 
 |  | ||||||
|                     // XXX: get IP address of HTTP server. (This can be this OpenSim server or another, or could be a dedicated grid service or may live on the freeswitch server) |  | ||||||
| 
 |  | ||||||
|                     string serviceIP = m_config.GetString("freeswitch_service_server", String.Empty); |  | ||||||
|                     int servicePort = m_config.GetInt("freeswitch_service_port", 80); |  | ||||||
|                     IPAddress serviceIPAddress = IPAddress.Parse(serviceIP); |  | ||||||
|                     // m_FreeSwitchServiceIP = new IPEndPoint(serviceIPAddress, servicePort); |  | ||||||
|                     m_freeSwitchServicePort = servicePort; |  | ||||||
|                     m_freeSwitchRealm = m_config.GetString("freeswitch_realm", String.Empty); |  | ||||||
|                     m_freeSwitchSIPProxy = m_config.GetString("freeswitch_sip_proxy", m_freeSwitchRealm); |  | ||||||
|                     m_freeSwitchAttemptUseSTUN = m_config.GetBoolean("freeswitch_attempt_stun", true); |  | ||||||
|                     // m_freeSwitchSTUNServer = m_config.GetString("freeswitch_stun_server", m_freeSwitchRealm); |  | ||||||
|                     m_freeSwitchEchoServer = m_config.GetString("freeswitch_echo_server", m_freeSwitchRealm); |  | ||||||
|                     m_freeSwitchEchoPort = m_config.GetInt("freeswitch_echo_port", 50505); |  | ||||||
|                     m_freeSwitchDefaultWellKnownIP = m_config.GetString("freeswitch_well_known_ip", m_freeSwitchRealm); |  | ||||||
|                     m_openSimWellKnownHTTPAddress = m_config.GetString("opensim_well_known_http_address", serviceIPAddress.ToString()); |  | ||||||
|                     m_freeSwitchDefaultTimeout = m_config.GetInt("freeswitch_default_timeout", 5000); |  | ||||||
|                     // m_freeSwitchSubscribeRetry = m_config.GetInt("freeswitch_subscribe_retry", 120); |  | ||||||
|                     m_freeSwitchUrlResetPassword = m_config.GetString("freeswitch_password_reset_url", String.Empty); |  | ||||||
|                     m_freeSwitchContext = m_config.GetString("freeswitch_context", "default"); |  | ||||||
| 
 |  | ||||||
|                     if (String.IsNullOrEmpty(m_freeSwitchServerUser) || |  | ||||||
|                         String.IsNullOrEmpty(m_freeSwitchServerPass) || |  | ||||||
|                         String.IsNullOrEmpty(m_freeSwitchRealm) || |  | ||||||
|                         String.IsNullOrEmpty(m_freeSwitchAPIPrefix)) |  | ||||||
|                     { |  | ||||||
|                         m_log.Error("[FreeSwitchVoice] plugin mis-configured"); |  | ||||||
|                         m_log.Info("[FreeSwitchVoice] plugin disabled: incomplete configuration"); |  | ||||||
|                         return; |  | ||||||
|                     } |  | ||||||
| 
 |  | ||||||
|                     // set up http request handlers for |  | ||||||
|                     // - prelogin: viv_get_prelogin.php |  | ||||||
|                     // - signin: viv_signin.php |  | ||||||
|                     // - buddies: viv_buddy.php |  | ||||||
|                     // - ???: viv_watcher.php |  | ||||||
|                     // - signout: viv_signout.php |  | ||||||
|                     MainServer.Instance.AddHTTPHandler(String.Format("{0}/viv_get_prelogin.php", m_freeSwitchAPIPrefix), |  | ||||||
|                                                          FreeSwitchSLVoiceGetPreloginHTTPHandler); |  | ||||||
| 
 |  | ||||||
|                     // RestStreamHandler h = new |  | ||||||
|                     // RestStreamHandler("GET", |  | ||||||
|                     // String.Format("{0}/viv_get_prelogin.php", m_freeSwitchAPIPrefix), FreeSwitchSLVoiceGetPreloginHTTPHandler); |  | ||||||
|                     //  MainServer.Instance.AddStreamHandler(h); |  | ||||||
| 
 |  | ||||||
| 
 |  | ||||||
| 
 |  | ||||||
|                     MainServer.Instance.AddHTTPHandler(String.Format("{0}/viv_signin.php", m_freeSwitchAPIPrefix), |  | ||||||
|                                      FreeSwitchSLVoiceSigninHTTPHandler); |  | ||||||
| 
 |  | ||||||
|                     MainServer.Instance.AddHTTPHandler(String.Format("{0}/viv_buddy.php", m_freeSwitchAPIPrefix), |  | ||||||
|                                      FreeSwitchSLVoiceBuddyHTTPHandler); |  | ||||||
| 
 |  | ||||||
|                     m_log.InfoFormat("[FreeSwitchVoice] using FreeSwitch server {0}", m_freeSwitchRealm); |  | ||||||
| 
 |  | ||||||
|                     m_pluginEnabled = true; |  | ||||||
|                     m_WOF = false; |  | ||||||
| 
 |  | ||||||
|                     m_log.Info("[FreeSwitchVoice] plugin enabled"); |  | ||||||
|                 } |  | ||||||
|                 catch (Exception e) |  | ||||||
|                 { |  | ||||||
|                     m_log.ErrorFormat("[FreeSwitchVoice] plugin initialization failed: {0}", e.Message); |  | ||||||
|                     m_log.DebugFormat("[FreeSwitchVoice] plugin initialization failed: {0}", e.ToString()); |  | ||||||
|                     return; |                     return; | ||||||
|                 } |                 } | ||||||
|  | 
 | ||||||
|  |                 // set up http request handlers for | ||||||
|  |                 // - prelogin: viv_get_prelogin.php | ||||||
|  |                 // - signin: viv_signin.php | ||||||
|  |                 // - buddies: viv_buddy.php | ||||||
|  |                 // - ???: viv_watcher.php | ||||||
|  |                 // - signout: viv_signout.php | ||||||
|  |                 MainServer.Instance.AddHTTPHandler(String.Format("{0}/viv_get_prelogin.php", m_freeSwitchAPIPrefix), | ||||||
|  |                                                      FreeSwitchSLVoiceGetPreloginHTTPHandler); | ||||||
|  | 
 | ||||||
|  |                 // RestStreamHandler h = new | ||||||
|  |                 // RestStreamHandler("GET", | ||||||
|  |                 // String.Format("{0}/viv_get_prelogin.php", m_freeSwitchAPIPrefix), FreeSwitchSLVoiceGetPreloginHTTPHandler); | ||||||
|  |                 //  MainServer.Instance.AddStreamHandler(h); | ||||||
|  | 
 | ||||||
|  | 
 | ||||||
|  | 
 | ||||||
|  |                 MainServer.Instance.AddHTTPHandler(String.Format("{0}/viv_signin.php", m_freeSwitchAPIPrefix), | ||||||
|  |                                  FreeSwitchSLVoiceSigninHTTPHandler); | ||||||
|  | 
 | ||||||
|  |                 MainServer.Instance.AddHTTPHandler(String.Format("{0}/viv_buddy.php", m_freeSwitchAPIPrefix), | ||||||
|  |                                  FreeSwitchSLVoiceBuddyHTTPHandler); | ||||||
|  | 
 | ||||||
|  |                 m_log.InfoFormat("[FreeSwitchVoice] using FreeSwitch server {0}", m_freeSwitchRealm); | ||||||
|  | 
 | ||||||
|  |                 m_Enabled = true; | ||||||
|  | 
 | ||||||
|  |                 m_log.Info("[FreeSwitchVoice] plugin enabled"); | ||||||
|  |             } | ||||||
|  |             catch (Exception e) | ||||||
|  |             { | ||||||
|  |                 m_log.ErrorFormat("[FreeSwitchVoice] plugin initialization failed: {0}", e.Message); | ||||||
|  |                 m_log.DebugFormat("[FreeSwitchVoice] plugin initialization failed: {0}", e.ToString()); | ||||||
|  |                 return; | ||||||
|             } |             } | ||||||
| 
 | 
 | ||||||
|             if (m_pluginEnabled) |             // This here is a region module trying to make a global setting. | ||||||
|  |             // Not really a good idea but it's Windows only, so I can't test. | ||||||
|  |             try | ||||||
|  |             { | ||||||
|  |                 ServicePointManager.ServerCertificateValidationCallback += CustomCertificateValidation; | ||||||
|  |             } | ||||||
|  |             catch (NotImplementedException) | ||||||
|  |             { | ||||||
|  |                 try | ||||||
|  |                 { | ||||||
|  | #pragma warning disable 0612, 0618 | ||||||
|  |                     // Mono does not implement the ServicePointManager.ServerCertificateValidationCallback yet!  Don't remove this! | ||||||
|  |                     ServicePointManager.CertificatePolicy = new MonoCert(); | ||||||
|  | #pragma warning restore 0612, 0618 | ||||||
|  |                 } | ||||||
|  |                 catch (Exception) | ||||||
|  |                 { | ||||||
|  |                     //m_log.Error("[FreeSwitchVoice]: Certificate validation handler change not supported.  You may get ssl certificate validation errors teleporting from your region to some SSL regions."); | ||||||
|  |                 } | ||||||
|  |             } | ||||||
|  |         } | ||||||
|  | 
 | ||||||
|  |         public void AddRegion(Scene scene) | ||||||
|  |         { | ||||||
|  |             m_scene = scene; | ||||||
|  | 
 | ||||||
|  |             if (m_Enabled) | ||||||
|             { |             { | ||||||
|                 // we need to capture scene in an anonymous method |                 // we need to capture scene in an anonymous method | ||||||
|                 // here as we need it later in the callbacks |                 // here as we need it later in the callbacks | ||||||
|  | @ -208,36 +228,21 @@ namespace OpenSim.Region.OptionalModules.Avatar.Voice.FreeSwitchVoice | ||||||
|                     { |                     { | ||||||
|                         OnRegisterCaps(scene, agentID, caps); |                         OnRegisterCaps(scene, agentID, caps); | ||||||
|                     }; |                     }; | ||||||
| 
 |  | ||||||
|                 try |  | ||||||
|                 { |  | ||||||
|                     ServicePointManager.ServerCertificateValidationCallback += CustomCertificateValidation; |  | ||||||
|                 } |  | ||||||
|                 catch (NotImplementedException) |  | ||||||
|                 { |  | ||||||
|                     try |  | ||||||
|                     { |  | ||||||
| #pragma warning disable 0612, 0618 |  | ||||||
|                         // Mono does not implement the ServicePointManager.ServerCertificateValidationCallback yet!  Don't remove this! |  | ||||||
|                         ServicePointManager.CertificatePolicy = new MonoCert(); |  | ||||||
| #pragma warning restore 0612, 0618 |  | ||||||
|                     } |  | ||||||
|                     catch (Exception) |  | ||||||
|                     { |  | ||||||
|                         m_log.Error("[FreeSwitchVoice]: Certificate validation handler change not supported.  You may get ssl certificate validation errors teleporting from your region to some SSL regions."); |  | ||||||
|                     } |  | ||||||
|                 } |  | ||||||
|             } |             } | ||||||
|         } |         } | ||||||
| 
 | 
 | ||||||
|         public void PostInitialise() |         public void RemoveRegion(Scene scene) | ||||||
|         { |         { | ||||||
|             if (m_pluginEnabled) |         } | ||||||
|  | 
 | ||||||
|  |         public void RegionLoaded(Scene scene) | ||||||
|  |         { | ||||||
|  |             if (m_Enabled) | ||||||
|             { |             { | ||||||
|                 m_log.Info("[FreeSwitchVoice] registering IVoiceModule with the scene"); |                 m_log.Info("[FreeSwitchVoice] registering IVoiceModule with the scene"); | ||||||
| 
 | 
 | ||||||
|                 // register the voice interface for this module, so the script engine can call us |                 // register the voice interface for this module, so the script engine can call us | ||||||
|                 m_scene.RegisterModuleInterface<IVoiceModule>(this); |                 scene.RegisterModuleInterface<IVoiceModule>(this); | ||||||
|             } |             } | ||||||
|         } |         } | ||||||
| 
 | 
 | ||||||
|  | @ -250,9 +255,9 @@ namespace OpenSim.Region.OptionalModules.Avatar.Voice.FreeSwitchVoice | ||||||
|             get { return "FreeSwitchVoiceModule"; } |             get { return "FreeSwitchVoiceModule"; } | ||||||
|         } |         } | ||||||
| 
 | 
 | ||||||
|         public bool IsSharedModule |         public Type ReplaceableInterface | ||||||
|         { |         { | ||||||
|             get { return true; } |             get { return null; } | ||||||
|         } |         } | ||||||
| 
 | 
 | ||||||
|         // <summary> |         // <summary> | ||||||
|  |  | ||||||
		Loading…
	
		Reference in New Issue
	
	 opensim mirror account
						opensim mirror account