/* * Copyright (c) 2006-2014, openmetaverse.org * All rights reserved. * * - Redistribution and use in source and binary forms, with or without * modification, are permitted provided that the following conditions are met: * * - Redistributions of source code must retain the above copyright notice, this * list of conditions and the following disclaimer. * - Neither the name of the openmetaverse.org nor the names * of its contributors may be used to endorse or promote products derived from * this software without specific prior written permission. * * THIS SOFTWARE IS PROVIDED BY THE COPYRIGHT HOLDERS AND CONTRIBUTORS "AS IS" * AND ANY EXPRESS OR IMPLIED WARRANTIES, INCLUDING, BUT NOT LIMITED TO, THE * IMPLIED WARRANTIES OF MERCHANTABILITY AND FITNESS FOR A PARTICULAR PURPOSE * ARE DISCLAIMED. IN NO EVENT SHALL THE COPYRIGHT OWNER OR CONTRIBUTORS BE * LIABLE FOR ANY DIRECT, INDIRECT, INCIDENTAL, SPECIAL, EXEMPLARY, OR * CONSEQUENTIAL DAMAGES (INCLUDING, BUT NOT LIMITED TO, PROCUREMENT OF * SUBSTITUTE GOODS OR SERVICES; LOSS OF USE, DATA, OR PROFITS; OR BUSINESS * INTERRUPTION) HOWEVER CAUSED AND ON ANY THEORY OF LIABILITY, WHETHER IN * CONTRACT, STRICT LIABILITY, OR TORT (INCLUDING NEGLIGENCE OR OTHERWISE) * ARISING IN ANY WAY OUT OF THE USE OF THIS SOFTWARE, EVEN IF ADVISED OF THE * POSSIBILITY OF SUCH DAMAGE. */ using System; using System.Collections.Generic; using System.Threading; using OpenMetaverse; using OpenMetaverse.Utilities; namespace VoiceTest { public class VoiceException: Exception { public bool LoggedIn = false; public VoiceException(string msg): base(msg) { } public VoiceException(string msg, bool loggedIn): base(msg) { LoggedIn = loggedIn; } } class VoiceTest { static AutoResetEvent EventQueueRunningEvent = new AutoResetEvent(false); static AutoResetEvent ProvisionEvent = new AutoResetEvent(false); static AutoResetEvent ParcelVoiceInfoEvent = new AutoResetEvent(false); static string VoiceAccount = String.Empty; static string VoicePassword = String.Empty; static string VoiceRegionName = String.Empty; static int VoiceLocalID = 0; static string VoiceChannelURI = String.Empty; static void Main(string[] args) { if (args.Length < 3) { Console.WriteLine("Usage: VoiceTest.exe [firstname] [lastname] [password]"); return; } string firstName = args[0]; string lastName = args[1]; string password = args[2]; GridClient client = new GridClient(); client.Settings.MULTIPLE_SIMS = false; Settings.LOG_LEVEL = Helpers.LogLevel.None; client.Settings.LOG_RESENDS = false; client.Settings.STORE_LAND_PATCHES = true; client.Settings.ALWAYS_DECODE_OBJECTS = true; client.Settings.ALWAYS_REQUEST_OBJECTS = true; client.Settings.SEND_AGENT_UPDATES = true; string loginURI = client.Settings.LOGIN_SERVER; if (4 == args.Length) { loginURI = args[3]; } VoiceManager voice = new VoiceManager(client); voice.OnProvisionAccount += voice_OnProvisionAccount; voice.OnParcelVoiceInfo += voice_OnParcelVoiceInfo; client.Network.EventQueueRunning += client_OnEventQueueRunning; try { if (!voice.ConnectToDaemon()) throw new VoiceException("Failed to connect to the voice daemon"); List captureDevices = voice.CaptureDevices(); Console.WriteLine("Capture Devices:"); for (int i = 0; i < captureDevices.Count; i++) Console.WriteLine(String.Format("{0}. \"{1}\"", i, captureDevices[i])); Console.WriteLine(); List renderDevices = voice.RenderDevices(); Console.WriteLine("Render Devices:"); for (int i = 0; i < renderDevices.Count; i++) Console.WriteLine(String.Format("{0}. \"{1}\"", i, renderDevices[i])); Console.WriteLine(); // Login Console.WriteLine("Logging into the grid as " + firstName + " " + lastName + "..."); LoginParams loginParams = client.Network.DefaultLoginParams(firstName, lastName, password, "Voice Test", "1.0.0"); loginParams.URI = loginURI; if (!client.Network.Login(loginParams)) throw new VoiceException("Login to SL failed: " + client.Network.LoginMessage); Console.WriteLine("Logged in: " + client.Network.LoginMessage); Console.WriteLine("Creating voice connector..."); int status; string connectorHandle = voice.CreateConnector(out status); if (String.IsNullOrEmpty(connectorHandle)) throw new VoiceException("Failed to create a voice connector, error code: " + status, true); Console.WriteLine("Voice connector handle: " + connectorHandle); Console.WriteLine("Waiting for OnEventQueueRunning"); if (!EventQueueRunningEvent.WaitOne(45 * 1000, false)) throw new VoiceException("EventQueueRunning event did not occur", true); Console.WriteLine("EventQueue running"); Console.WriteLine("Asking the current simulator to create a provisional account..."); if (!voice.RequestProvisionAccount()) throw new VoiceException("Failed to request a provisional account", true); if (!ProvisionEvent.WaitOne(120 * 1000, false)) throw new VoiceException("Failed to create a provisional account", true); Console.WriteLine("Provisional account created. Username: " + VoiceAccount + ", Password: " + VoicePassword); Console.WriteLine("Logging in to voice server " + voice.VoiceServer); string accountHandle = voice.Login(VoiceAccount, VoicePassword, connectorHandle, out status); if (String.IsNullOrEmpty(accountHandle)) throw new VoiceException("Login failed, error code: " + status, true); Console.WriteLine("Login succeeded, account handle: " + accountHandle); if (!voice.RequestParcelVoiceInfo()) throw new Exception("Failed to request parcel voice info"); if (!ParcelVoiceInfoEvent.WaitOne(45 * 1000, false)) throw new VoiceException("Failed to obtain parcel info voice", true); Console.WriteLine("Parcel Voice Info obtained. Region name {0}, local parcel ID {1}, channel URI {2}", VoiceRegionName, VoiceLocalID, VoiceChannelURI); client.Network.Logout(); } catch(Exception e) { Console.WriteLine(e.Message); if (e is VoiceException && (e as VoiceException).LoggedIn) { client.Network.Logout(); } } Console.WriteLine("Press any key to continue..."); Console.ReadKey(); } static void client_OnEventQueueRunning(object sender, EventQueueRunningEventArgs e) { EventQueueRunningEvent.Set(); } static void voice_OnProvisionAccount(string username, string password) { VoiceAccount = username; VoicePassword = password; ProvisionEvent.Set(); } static void voice_OnParcelVoiceInfo(string regionName, int localID, string channelURI) { VoiceRegionName = regionName; VoiceLocalID = localID; VoiceChannelURI = channelURI; ParcelVoiceInfoEvent.Set(); } } }