Provided by: kgb-bot_1.61-1_all bug

NAME

       kgb.conf -- KGB bot configuration file

DESCRIPTION

       kgb.conf is the main configuration file of the KGB bot. Its location is in /etc/kgb-bot/
       unless changed with the --conf command line option. See kgb-bot(1).

       The file format is YAML. Elaborate example configuration is at the end of this document.

Settings

   soap
       A map with the following possible keys:

       server_addr
           IP address to listen to. Defaults to 127.0.0.1.

           For making KGB bot listen on all addresses, set the value to 0.0.0.0.

       server_port
           Port to listen to.

       service_name
           SOAP service name. Defaults to "KGB".

   pid_dir
       Directory to store PID file to. Defaults to /var/run/kgb-bot/.

   include
       Path to file with additional configuration. May be a path to a directory, in which case
       all files in it ending with ".conf" are loaded, in alphabetical order.

   min_protocol_version
       Minimum version of the protocol that will be supported by the server. Defaults to 1.
       Protocol version 0 has no authentication.

   queue_limit
       When messages are sent to IRC, there is certain rate limitting, which may prevent the
       message to be sent right away. In this case messages are enqueued, and this parameter
       configures the size of the queue. When the queue is full client requests are rejected.

   repositories
       A map with keys project names and values maps with project details:

       password
           Password used for authenticating all requests from this project.

       private
           If true, disables commit announces to 'broadcast' IRC channels.

   networks
       A map with keys network names and values map of network configuration, containing the
       following items:

       server
           IP address/hostname of the IRC server to connect to.

       use_ssl
           Whether to use SSL when connecting to the IRC server. Defaults to 1.

       port
           Port number to connect to.

           Defaults to 6697 when use_ssl is true and 6667 otherwise.

       nick
           Bot's nick on the network.

       ircname
           The full name of the bot on the network.

       username
           The username presented to the network.

       password
           A password for the network.

       nickserv_password
           A password for Nick server identification.

       flood
           If defined to a true value, the built-in rate-limitting feature of the IRC component
           will be turned off. WARNING: this may cause the bot to be kicked off the IRC network.
           Use only when you control both the bot and the IRC network (e.g. when testing).

   channels
       A list of channels. Each element is a map and represents the channel's configuration:

       name
           Channel name, e.g. "#commits". Mandatory.

       network
           Network name, as described in the networks map. Mandatory.

       broadcast
           Enables broadcasting all commit notifications to this channel.

       repos
           A list of project names, as described in the repositories map. Mandatory unless
           broadcast is enabled.

       smart_answers
           Each channel can contain separate list of smart answers, see below.

   smart_answers
       A list of strings to be used as replies when the bot is addressed on IRC.

   smart_answers_polygen
       If set to a true value, polygen(1) will be used to generate replies when the bot is
       addressed on IRC.

   debug
       Enables logging of additional diagnostic information.

   admins
       A list of IRC masks, used to determine if a given IRC nick is bot administrator. Note that
       currently these nicks have no additional power.

   colors
       A map of colors to be used when painting commit messages. The following keys are
       recognized:

       revision
           Commit ID. Default: none.

       path
           Changed path. Default: teal.

           Depending on the action performed to the path, additional coloring is made:

           addition
               Used for added paths. Default: green.

           modification
               Used for modified paths. Default: teal.

           deletion
               Used for deleted paths. Default: bold red.

           replacement
               Used for replaced paths (a Subversion concept). Default: brown.

           prop_change
               Used for paths with changed properties (a Subversion concept), combined with other
               colors depending on the action -- addition, modification or replacement.  Default:
               underline.

       author
           Commit author. Default: green.

       branch
           Commit branch. Default: brown.

       module
           Project module. Default: purple.

       web URL to commit information. Default: silver.

       separator
           The separator before the commit log. Default: none.

   webhook
       A map for enabling GitLab webook support. Possible keys:

       enabled
           Enable webhhok support by setting this to 1.

       allowed_networks
           A list of allowed IP networks. Required.

   short_url_service name
       The name of a WWW::Shorten module to use for URL-shortening. The leading "WWW::Shorten::"
       part must be omitted.

       Default: none

       Example: Debli

EXAMPLE CONFGURATION

        # vim: filetype=yaml
        ---
        soap:
          server_addr: 127.0.0.1
          server_port: 9999
          service_name: KGB
        queue_limit: 150
        log_file: "/var/log/kgb-bot.log"
        include: "/etc/kgb-bot/kgb.conf.d"
        repositories:
          # just a name to identify it
          foo:
            # needs to be the same on the client
            password: supersecret
            # private repositories aren't announced to broadcast channels
            # private: yes
        # Some witty answer for people that talk to the bot
        #smart_answers:
        #  - "I won't speak with you!"
        #  - "Do not disturb!"
        #  - "Leave me alone, I am buzy!"
        # Admins are allowed some special !commands (currently only !version)
        #admins:
        #  - some!irc@mask
        #  - some!other@host
        networks:
          freenode:
            nick: KGB
            ircname: KGB bot
            username: kgb
            password: ~
            nickserv_password: ~
            server: irc.freenode.net
            port: 6667
        channels:
        # a broadcast channel
          - name: '#commits'
            network: freenode
            broadcast: yes
        # a channel, tied to one or several repositories
          - name: '#foo'
            network: freenode
            repos:
              - foo
            # Can also be set per-channel
            #smart_answers:
            #  - "I'm in ur channel, watching ur commits!"
            #  - "I am not listening"
            #  - "Shut up! I am buzy watching you."
        pid_dir: /var/run/kgb-bot
        # anything less is rejected
        min_protocol_ver: 1
        # default colors:
        colors:
         repository: bold
         revision: bold
         author: green
         branch: brown
         module: purple
         path: teal
         addition: green
         modification: teal
         deletion: "bold red"
         replacement: reverse
         prop_change: underline
         web: silver
        # you can combine them like "bold red" (ouch!)
        # available colors: black, navy, green, red, brown, purple, orange, yellow,
        #  lime, teal, aqua, blue, fuchsia, gray, silver, white
        # available modifiers: bold underline reverse
        webhook:
         enabled: 1
         allowed_networks:
          - 127.0.0.1
        short_url_service: Debli

SEE ALSO

       kgb-bot(1), kgb-client(1)

AUTHOR

       Damyan Ivanov dmn@debian.org

COPYRIGHT & LICENSE

       Copyright (C) 2012, 2013 Damyan Ivanov

       This program is free software; you can redistribute it and/or modify it under the terms of
       the GNU General Public License as published by the Free Software Foundation; either
       version 2 of the License, or (at your option) any later version.

       This program is distributed in the hope that it will be useful, but WITHOUT ANY WARRANTY;
       without even the implied warranty of MERCHANTABILITY or FITNESS FOR A PARTICULAR PURPOSE.
       See the GNU General Public License for more details.

       You should have received a copy of the GNU General Public License along with this program;
       if not, write to the Free Software Foundation, Inc., 51 Franklin Street, Fifth Floor,
       Boston, MA  02110-1301, USA.