internal async void Execute(IJabbRClient client, Room room)
    {
      Guard.NullParameter(client, () => client);
      Guard.NullParameter(room, () => room);

      if (!IsHandled)
      {
        return;
      }

      foreach (var response in Responses)
      {
        switch (response.ResponseType)
        {
          case MessageHandlerResultResponseType.DefaultMessage:
            await client.Send(response.ResponseText, room.Name);
            break;

          case MessageHandlerResultResponseType.ActionMessage:
            await client.Send("/me " + response.ResponseText, room.Name);
            break;

          case MessageHandlerResultResponseType.Kick:
            await client.Kick(response.ResponseText, room.Name);
            break;
        }
      }
    }
		public void ProcessMessage(Message message, IPluginContext context, IJabbRClient client)
		{
			Guard.NullParameter(message, () => message);
			Guard.NullParameter(context, () => context);
			Guard.NullParameter(client, () => client);

			foreach (var messageHandler in _messageHandlers)
			{
				Log.Trace("Applying handler: {0}", messageHandler.Name);

				try
				{
					var result = messageHandler.Execute(message, context);
					result.Execute(client, context.Room);

					var continueProcessing = !result.IsHandled || messageHandler.ContinueProcessing;
					if (!continueProcessing)
					{
						Log.Trace("Terminating message processing after: {0}.", messageHandler.Name);
						break;
					}
				}
				catch (Exception ex)
				{
					Log.ErrorException("Error applying handler: " + messageHandler.Name, ex);
				}
			}
		}
    public async Task Start()
    {
      Log.Info("Starting BawBag");
      Log.Info("Connecting to '{0}' as '{1}'.", _configuration.JabbrUrl, _configuration.JabbrNick);

      _store.Initialize();
      IndexCreation.CreateIndexes(Assembly.GetExecutingAssembly(), _store);

      _pluginManager = new PluginManager();
      _pluginManager.Initialize(_configuration.PluginsDirectory, _store);

      ServicePointManager.DefaultConnectionLimit = 10;

      _client = new JabbRClient(_configuration.JabbrUrl) { AutoReconnect = true };

      _client.MessageReceived += MessageReceived;
      _client.MeMessageReceived += MeMessageReceived;
      _client.UserJoined += UserJoined;
      _client.UserLeft += UserLeft;

      Log.Info("Starting BawBag: Connecting");
      JabbR.Client.Models.LogOnInfo logOnInfo;
      try
      {
        logOnInfo = await _client.Connect(_configuration.JabbrNick, _configuration.JabbrPassword);
      }
      catch (Exception ex)
      {
        Log.Fatal("Failed to connect", ex);
        throw;
      }

      Log.Info("Starting BawBag: Connected");
      foreach (var roomName in logOnInfo.Rooms.Select(r => r.Name))
      {
        var jabbrRoom = await _client.GetRoomInfo(roomName);
        var room = Room.Create(jabbrRoom);
        _rooms[room.Name] = room;
      }

      Log.Info("Started BawBag");

      foreach (var roomName in _configuration.Rooms)
      {
        if (_rooms.ContainsKey(roomName))
        {
          continue;
        }

        await _client.JoinRoom(roomName);
        var jabbrRoom = await _client.GetRoomInfo(roomName);
        var room = Room.Create(jabbrRoom);
        _rooms[room.Name] = room;
      }
    }
示例#4
0
        /// <summary>
        /// Initializes a new instance of the <see cref="JabbRContext"/> class.
        /// </summary>
        /// <param name="jabbrClient">The jabbr client.</param>
        /// <param name="eventAggregator">The event aggregator.</param>
        /// <exception cref="System.ArgumentNullException">
        /// jabbrClient
        /// or
        /// eventAggregator
        /// </exception>
        public JabbRContext(IJabbRClient jabbrClient,
                            IEventAggregator eventAggregator,
                            IDependencyResolver dependencyResolver)
        {
            if (jabbrClient == null)
            {
                throw new ArgumentNullException("jabbrClient");
            }
            if (eventAggregator == null)
            {
                throw new ArgumentNullException("eventAggregator");
            }
            if (dependencyResolver == null)
            {
                throw new ArgumentNullException("dependencyResolver");
            }

            this.jabbrClient        = jabbrClient;
            this.eventAggregator    = eventAggregator;
            this.dependencyResolver = dependencyResolver;
        }
示例#5
0
        private static async void RunClientAsync(string server, string roomName, string userName, string password, IJabbRClient client, ManualResetEventSlim wh)
        {
            LogOnInfo info = null;

            try
            {
                await EnsureAccount(server, userName, password);

                // Connect to chat
                info = await client.Connect(userName, password);

                Console.WriteLine("Logged on successfully. You are currently in the following rooms:");
                foreach (var room in info.Rooms)
                {
                    Console.WriteLine(room.Name);
                    Console.WriteLine(room.Private);
                }

                Console.WriteLine("User id is {0}. Don't share this!", info.UserId);

                Console.WriteLine();

                // Get my user info
                User myInfo = await client.GetUserInfo();

                Console.WriteLine(myInfo.Name);
                Console.WriteLine(myInfo.LastActivity);
                Console.WriteLine(myInfo.Status);
                Console.WriteLine(myInfo.Country);

                // Join a room called test
                await client.JoinRoom(roomName);

                // Send a client side message
                var message = new ClientMessage
                {
                    Id = Guid.NewGuid().ToString(),
                    Content = "Hey",
                    Room = roomName
                };

                // Send the message to the server and wait for the ack
                await client.Send(message, TimeSpan.FromSeconds(2));

                // Get info about the test room
                Room roomInfo = await client.GetRoomInfo(roomName);

                Console.WriteLine("Users");

                foreach (var u in roomInfo.Users)
                {
                    Console.WriteLine(u.Name);
                }

                Console.WriteLine();

                foreach (var u in roomInfo.Users)
                {
                    if (u.Name != userName)
                    {
                        await client.SendPrivateMessage(u.Name, "hey there, this is private right?");
                    }
                }

                // Set the flag
                await client.SetFlag("bb");

                // Set the user note
                await client.SetNote("This is testing a note");

                // Mark the client as typing
                await client.SetTyping(roomName);

                // Clear the note
                await client.SetNote(null);

                // Say hello to the room
                await client.Send("Hello world", roomName);

                if (roomInfo.Owners.Contains(userName))
                {
                    // Post a notification (You must be room owner)
                    //await client.PostNotification(new ClientNotification
                    //{
                    //    Source = "Github",
                    //    Content = "This is a fake github notification from the client",
                    //    ImageUrl = "",
                    //    Room = "test"
                    //});
                }

                Console.WriteLine("Press any key to leave the room and disconnect");

                Console.Read();

                await client.LeaveRoom(roomName);

                client.Disconnect();
            }
            catch (Exception ex)
            {
                Console.WriteLine("Error: " + ex.GetBaseException().Message);
            }
            finally
            {
                wh.Set();
            }
        }
示例#6
0
文件: Robot.cs 项目: xt0rted/JibbR
        public void SetupClient(Uri host)
        {
            if (_isSetup)
            {
                Console.Error.WriteLine("Client is already setup.");
                return;
            }

            _isSetup = true;

            _client = new JabbRClient(host);

            _client.MessageReceived += ClientOnMessageReceived;
            _client.PrivateMessage += ClientOnPrivateMessage;
            _client.UserJoined += ClientOnUserJoined;
            _client.UserLeft += ClientOnUserLeft;

            _eventBus.Pull<JabbrMessage>()
                     .Subscribe(DoSendMessage);

            _adapterManager.SetupAdapters(this);
        }
示例#7
0
        private static async void RunClientAsync(string server, string roomName, string userName, string password, IJabbRClient client, ManualResetEventSlim wh)
        {
            LogOnInfo info = null;

            try
            {
                await EnsureAccount(server, userName, password);

                // Connect to chat
                info = await client.Connect(userName, password);

                Console.WriteLine("Logged on successfully. You are currently in the following rooms:");
                foreach (var room in info.Rooms)
                {
                    Console.WriteLine(room.Name);
                    Console.WriteLine(room.Private);
                }

                Console.WriteLine("User id is {0}. Don't share this!", info.UserId);

                Console.WriteLine();

                // Get my user info
                User myInfo = await client.GetUserInfo();

                Console.WriteLine(myInfo.Name);
                Console.WriteLine(myInfo.LastActivity);
                Console.WriteLine(myInfo.Status);
                Console.WriteLine(myInfo.Country);

                // Join a room called test
                await client.JoinRoom(roomName);

                // Send a client side message
                var message = new ClientMessage
                {
                    Id      = Guid.NewGuid().ToString(),
                    Content = "Hey",
                    Room    = roomName
                };

                // Send the message to the server and wait for the ack
                await client.Send(message, TimeSpan.FromSeconds(2));

                // Get info about the test room
                Room roomInfo = await client.GetRoomInfo(roomName);

                Console.WriteLine("Users");

                foreach (var u in roomInfo.Users)
                {
                    Console.WriteLine(u.Name);
                }

                Console.WriteLine();

                foreach (var u in roomInfo.Users)
                {
                    if (u.Name != userName)
                    {
                        await client.SendPrivateMessage(u.Name, "hey there, this is private right?");
                    }
                }

                // Set the flag
                await client.SetFlag("bb");

                // Set the user note
                await client.SetNote("This is testing a note");

                // Mark the client as typing
                await client.SetTyping(roomName);

                // Clear the note
                await client.SetNote(null);

                // Say hello to the room
                await client.Send("Hello world", roomName);

                if (roomInfo.Owners.Contains(userName))
                {
                    // Post a notification (You must be room owner)
                    //await client.PostNotification(new ClientNotification
                    //{
                    //    Source = "Github",
                    //    Content = "This is a fake github notification from the client",
                    //    ImageUrl = "",
                    //    Room = "test"
                    //});
                }

                Console.WriteLine("Press any key to leave the room and disconnect");

                Console.Read();

                await client.LeaveRoom(roomName);

                client.Disconnect();
            }
            catch (Exception ex)
            {
                Console.WriteLine("Error: " + ex.GetBaseException().Message);
            }
            finally
            {
                wh.Set();
            }
        }