Пример #1
0
        // -------- Functions --------

        /// <summary>
        /// Initializes the plugin.  This includes loading any configuration files,
        /// starting services, etc.  Allowed to throw Exceptions.
        ///
        /// This function should be used to validates that the environment is good for the plugin.
        /// For example, it has all dependencies installed, config files are in the correct spot, etc.
        /// It should also load GetHandlers() with the handlers.
        /// </summary>
        /// <param name="pluginInit">The class that has information required for initing the plugin.</param>
        public void Init(PluginInitor initor)
        {
            string configPath = Path.Combine(
                initor.ChaskisConfigPluginRoot,
                "UserListBot",
                "UserListBotConfig.xml"
                );

            if (File.Exists(configPath) == false)
            {
                throw new FileNotFoundException(
                          "Can not open " + configPath
                          );
            }

            this.userListConfig = XmlLoader.LoadConfig(configPath);

            // User query command:
            {
                MessageHandlerConfig msgConfig = new MessageHandlerConfig
                {
                    LineRegex  = this.userListConfig.Command,
                    LineAction = this.HandleGetUsersCommand,
                    CoolDown   = this.userListConfig.Cooldown
                };

                MessageHandler userQueryHandler = new MessageHandler(
                    msgConfig
                    );

                this.handlers.Add(userQueryHandler);
            }
            {
                AllHandlerConfig allHandlerConfig = new AllHandlerConfig
                {
                    AllAction = this.HandleNamesResponse
                };
                AllHandler nameResponseHandler = new AllHandler(allHandlerConfig);
                this.handlers.Add(nameResponseHandler);
            }

            {
                AllHandlerConfig allHandlerConfig = new AllHandlerConfig
                {
                    AllAction = this.HandleEndOfNamesResponse
                };
                AllHandler endOfNamesHandler = new AllHandler(allHandlerConfig);
                this.handlers.Add(endOfNamesHandler);
            }
        }
Пример #2
0
        // -------- Functions --------

        /// <summary>
        /// Initializes the plugin.  This includes loading any configuration files,
        /// starting services, etc.  Allowed to throw Exceptions.
        ///
        /// This function should be used to validates that the environment is good for the plugin.
        /// For example, it has all dependencies installed, config files are in the correct spot, etc.
        /// It should also load GetHandlers() with the handlers.
        /// </summary>
        /// <param name="pluginPath">
        /// The absolute path to the plugin, including the file name.  To just get
        /// the path to the plugin, call Path.GetDirectoryName on this argument.
        /// </param>
        /// <param name="ircConfig">The IRC config we are using.</param>
        public void Init(string pluginPath, IIrcConfig ircConfig)
        {
            string configPath = Path.Combine(
                Path.GetDirectoryName(pluginPath),
                "UserListBotConfig.xml"
                );

            if (File.Exists(configPath) == false)
            {
                throw new FileNotFoundException(
                          "Can not open " + configPath
                          );
            }

            this.ircConfig      = ircConfig;
            this.userListConfig = XmlLoader.LoadConfig(configPath);

            // User query command:
            {
                MessageHandler userQueryHandler = new MessageHandler(
                    this.userListConfig.Command.Replace("{%nick%}", this.ircConfig.Nick),
                    this.HandleGetUsersCommand,
                    this.userListConfig.Cooldown
                    );

                this.handlers.Add(userQueryHandler);
            }
            {
                AllHandler nameResponseHandler = new AllHandler(HandleNamesResponse);
                this.handlers.Add(nameResponseHandler);
            }

            {
                AllHandler endOfNamesHandler = new AllHandler(HandleEndOfNamesResponse);
                this.handlers.Add(endOfNamesHandler);
            }
        }