Пример #1
0
        private async Task MessageInvoker(Message message)
        {
            //Log stats
            await StatsManager.AddStatAction(ActionType.Message);

            //Get message data
            var user = await UserManager.AddOrUpdateUser(message.From);

            var chat = await ChatManager.AddOrUpdateChat(message);

            //Get all handlers
            var handlers = ReflectiveEnumerator.GetEnumerableOfType <BaseHandler>();

            foreach (var handlerType in handlers)
            {
                //Find method in handler
                MethodInfo[] handlerMethods = handlerType.GetMethods();

                foreach (var method in handlerMethods)
                {
                    //Pattern matching for message text
                    if (BaseHandler.MatchMethod(method, message.Text))
                    {
                        //Check user access by role
                        if (!BaseHandler.ValidateAccess(method, user))
                        {
                            return;
                        }

                        try
                        {
                            //Get and send chatAction from attributes
                            var chatAction = BaseHandler.GetChatActionAttributes(method);
                            if (chatAction.HasValue)
                            {
                                await Bot.SendChatActionAsync(message.Chat.Id, chatAction.Value);
                            }

                            //Cast handler object
                            var handler = Activator.CreateInstance(handlerType);

                            //Set params
                            ((BaseHandler)handler).Init(Bot, user, message: message);

                            //Invoke method
                            await(Task) method.Invoke(handler, parameters: new object[] { });
                        }
                        catch (Exception ex)
                        {
                            await LogsManager.CreateLog($"Invoker error *{ex.Message}*", LogLevel.Critical);

                            //Log stats
                            await StatsManager.AddStatAction(ActionType.Error);
                        }
                    }
                    else
                    {
                        //Cant find method
                        //await LogsManager.CreateLog($"Can't find method for *{messageEventArgs.Message.Text}*", LogLevel.Warning);
                        //Console.WriteLine($"Can't find method for *{messageEventArgs.Message.Text}*");
                    }
                }
            }
        }