# This is a sample configuration file for PyLink. You'll likely want to rename it to config.yml
# and begin your configuration there.

# Note: lines starting with a "#" are comments and will be ignored.

bot:
    # Sets nick, user/ident, and real name.
    nick: pylink
    user: pylink
    realname: PyLink Service Client

    # Server description (shown in /links, /whois, etc.)
    serverdesc: PyLink Server

    # Console log verbosity: see https://docs.python.org/3/library/logging.html#logging-levels
    loglevel: DEBUG

login:
    # PyLink administrative login - Change this, or the service will not start!
    user: admin
    password: changeme

relay:
    # This block defines various options for the Relay plugin. You don't need this
    # if you aren't using it.

    # Determines whether remote opers will have user mode +H (hideoper) set on them.
    # This has the benefit of lowering the oper count in /lusers and /stats (P|p),
    # but only on IRCds that supported the mode.
    # It defaults to true if not set.
    hideoper: true

    # Determines whether real IPs should be sent across the relay. You should
    # generally have a consensus with your linked networks whether this should
    # be turned on. You will see other networks' user IP addresses, and they
    # will see yours.
    show_ips: false

servers:
    yournet:
        # Server IP, port, and passwords
        ip: 127.0.0.1
        port: 7000
        recvpass: "abcd"
        sendpass: "abcd"

        # The full network name, used by plugins.
        netname: "yournet"

        # Hostname we will use to connect to the remote server
        hostname: "pylink.yournet"

        # SID - required for InspIRCd and TS6 based servers. This must be three characters long.
        # The first char must be a digit [0-9], and the remaining two chars may be letters [A-Z] or digits.
        sid: "0AL"

        # SID range - the range of SIDs PyLink is allowed to use to generate server IDs. On TS6,
        # this should be a combination of digits, letters, and #'s. Each # denotes a range (0-9A-Z)
        # of characters that can be used by PyLink. You will want to make sure no other servers
        # are using this range. There must be at least one # in the entry.
        sidrange: "8##"

        # Autojoin channels
        channels: ["#pylink"]

        # Sets the protocol module to use - see the protocols/ folder for a list of valid values
        # (omitting the .py extension).
        protocol: "inspircd"

        # Sets autoconnect delay - comment this out or set the value negative to disable autoconnect entirely.
        autoconnect: 5

        # Sets ping frequency (i.e. how long we should wait between sending pings to our uplink).
        # When more than two consecutive pings are missed, PyLink will disconnect with a ping timeout.
        # Defaults to 30 if not set.
        pingfreq: 30

        # Separator character (used by relay)
        separator: "/"

        # Sets the max nick length for the network. It is important this is set correctly, or
        # PyLink might introduce a nick that is too long and cause netsplits!
        maxnicklen: 30

        # Toggles SSL for this network. Defaults to false if not specified, and requires the
        # ssl_certfile and ssl_keyfile options to work.
        # ssl: true

        # ssl_certfile: pylink-cert.pem
        # ssl_keyfile: pylink-key.pem

        # Optionally, you can set this option to verify the SSL certificate
        # fingerprint (SHA1) of your uplink.
        # ssl_fingerprint: "e0fee1adf795c84eec4735f039503eb18d9c35cc"

    ts6net:
        ip: 127.0.0.1
        port: 7000
        recvpass: "abcd"
        sendpass: "abcd"
        hostname: "pylink.example.com"
        sid: "8PY"
        netname: "some network"

        # Leave this as an empty list if you don't want to join any channels.
        channels: []

        protocol: "ts6"
        autoconnect: 5
        pingfreq: 30
        maxnicklen: 30

        # /'s in nicks are automatically converted to |'s for TS6 networks, since they
        # don't allow "/" in nicks
        separator: "|"

        # The following options are specific to TS6 servers:
        # Toggles owner (+y), admin (+a), and halfop (+h) support for shadowircd/elemental-ircd.
        # This defaults to off for the best compatibility.
        use_owner: false
        use_admin: false
        use_halfop: false

        # Toggles support of shadowircd/elemental-ircd specific channel modes:
        # +T (no notice), +u (hidden ban list), +E (no kicks), +J (blocks kickrejoin),
        # +K (no repeat messages), +d (no nick changes), and user modes:
        # +B (bot), +C (blocks CTCP), +D (deaf), +V (no invites), +I (hides channel list)
        use_elemental_modes: false

# Plugins to load (omit the .py extension)
plugins:
    - commands
    - networks
    # - bots
    # - relay