summaryrefslogtreecommitdiff
path: root/data/anope.example.conf
diff options
context:
space:
mode:
Diffstat (limited to 'data/anope.example.conf')
-rw-r--r--data/anope.example.conf1354
1 files changed, 1354 insertions, 0 deletions
diff --git a/data/anope.example.conf b/data/anope.example.conf
new file mode 100644
index 000000000..7c2614f53
--- /dev/null
+++ b/data/anope.example.conf
@@ -0,0 +1,1354 @@
+/*
+ * Example configuration file for Anope. After making the appropriate
+ * changes to this file, place it in the Anope conf directory (as
+ * specified in the "Config" script, default /home/username/anope/conf)
+ * under the name "anope.conf".
+ *
+ * The format of this file is fairly simple: three types of comments are supported:
+ * - All text after a '#' on a line is ignored, as in shell scripting
+ * - All text after '//' on a line is ignored, as in C++
+ * - A block of text like this one is ignored, as in C
+ *
+ * Outside of comments, there are three structures: blocks, keys, and values.
+ *
+ * A block is a named container, which contains a number of key to value pairs
+ * - you may think of this as an array.
+ *
+ * A block is created like so:
+ * foobar
+ * {
+ * moo = "cow"
+ * foo = bar
+ * }
+ *
+ * Note that nameless blocks are allowed and are often used with comments to allow
+ * easily commenting an entire block, for example:
+ * #foobar
+ * {
+ * moo = "cow"
+ * foo = bar
+ * }
+ * is an entirely commented block.
+ *
+ * Keys are case insensitive. Values depend on what key - generally, information is
+ * given in the key comment. The quoting of values (and most other syntax) is quite
+ * flexible, however, please do not forget to quote your strings:
+ *
+ * "This is a parameter string with spaces in it"
+ *
+ * If you need to include a double quote inside a quoted string, precede it
+ * by a backslash:
+ *
+ * "This string has \"double quotes\" in it"
+ *
+ * Time parameters can be specified either as an integer representing a
+ * number of seconds (e.g. "3600" = 1 hour), or as an integer with a unit
+ * specifier: "s" = seconds, "m" = minutes, "h" = hours, "d" = days.
+ * Combinations (such as "1h30m") are not permitted. Examples (all of which
+ * represent the same length of time, one day):
+ *
+ * "86400", "86400s", "1440m", "24h", "1d"
+ *
+ * In the documentation for each directive, one of the following will be
+ * included to indicate whether an option is required:
+ *
+ * [REQUIRED]
+ * Indicates a directive which must be given. Without it, Anope will
+ * not start.
+ *
+ * [RECOMMENDED]
+ * Indicates a directive which may be omitted, but omitting it may cause
+ * undesirable side effects.
+ *
+ * [OPTIONAL]
+ * Indicates a directive which is optional. If not given, the feature
+ * will typically be disabled. If this is not the case, more
+ * information will be given in the documentation.
+ *
+ * [DISCOURAGED]
+ * Indicates a directive which may cause undesirable side effects if
+ * specified.
+ *
+ * [DEPRECATED]
+ * Indicates a directive which will disappear in a future version of
+ * Anope, usually because its functionality has been either
+ * superseded by that of other directives or incorporated into the main
+ * program.
+ */
+
+/*
+ * [OPTIONAL] Defines
+ *
+ * You can define values to other values, which can be used to easily change
+ * many values in the configuration at once.
+ */
+
+/*
+ * The services.host define is used in multiple different locations throughout the
+ * configuration for services clients hostnames.
+ */
+define
+{
+ name = "services.host"
+ value = "services.example.com"
+}
+
+/*
+ * [OPTIONAL] Additional Includes
+ *
+ * You can include additional configuration files here.
+ * You may also include executable files, which will be executed and
+ * the output from it will be included into your configuration.
+ */
+
+#include
+{
+ type = "file"
+ name = "some.conf"
+}
+
+#include
+{
+ type = "executable"
+ name = "/usr/bin/wget -q -O - https://some.misconfigured.network.com/anope.conf"
+}
+
+/*
+ * [REQUIRED] IRCd Config
+ *
+ * This section is used to set up Anope to connect to your IRC network.
+ * This section can be included multiple times, and Anope will attempt to
+ * connect to each server until it finally connects.
+ *
+ * Each uplink IRCd should have a corresponding configuration to allow Anope
+ * to link to it.
+ *
+ * An example configuration for InspIRCd that is compatible with the below uplink
+ * and serverinfo configuration would look like:
+ *
+ * # This goes in inspircd.conf, *NOT* your Anope config!
+ * <module name="hidechans">
+ * <module name="services_account">
+ * <module name="spanningtree">
+ * <bind address="127.0.0.1" port="7000" type="servers">
+ * <link name="services.example.com"
+ * ipaddr="127.0.0.1"
+ * port="7000"
+ * sendpass="mypassword"
+ * recvpass="mypassword">
+ * <uline server="services.example.com" silent="yes">
+ *
+ * An example configuration for UnrealIRCd that is compatible with the below uplink
+ * and serverinfo configuration would look like:
+ *
+ * // This goes in unrealircd.conf, *NOT* your Anope config!
+ * listen {
+ * ip 127.0.0.1;
+ * port 7000;
+ * options {
+ * serversonly;
+ * };
+ * };
+ * link services.example.com {
+ * incoming {
+ * mask *@127.0.0.1;
+ * };
+ * password "mypassword";
+ * class servers;
+ * };
+ * ulines { services.example.com; };
+ */
+uplink
+{
+ /*
+ * The IP address, hostname, or UNIX socket path of the IRC server you wish
+ * to connect Anope to.
+ * Usually, you will want to connect over 127.0.0.1 (aka localhost).
+ *
+ * NOTE: On some shell providers, this will not be an option.
+ */
+ host = "127.0.0.1"
+
+ /*
+ * The protocol that Anope should use when connecting to the uplink. Can
+ * be set to "ipv4" (the default), "ipv6", or "unix".
+ */
+ protocol = "ipv4"
+
+ /*
+ * Enable if Anope should connect using SSL.
+ * You must have an SSL module loaded for this to work.
+ */
+ ssl = no
+
+ /*
+ * The port to connect to.
+ * The IRCd *MUST* be configured to listen on this port, and to accept
+ * server connections.
+ *
+ * Refer to your IRCd documentation for how this is to be done.
+ */
+ port = 7000
+
+ /*
+ * The password to send to the IRC server for authentication.
+ * This must match the link block on your IRCd.
+ *
+ * Refer to your IRCd documentation for more information on link blocks.
+ */
+ password = "mypassword"
+}
+
+/*
+ * [REQUIRED] Server Information
+ *
+ * This section contains information about the services server.
+ */
+serverinfo
+{
+ /*
+ * The hostname that Anope will be seen as, it must have no conflicts with any
+ * other server names on the rest of your IRC network. Note that it does not have
+ * to be an existing hostname, just one that isn't on your network already.
+ */
+ name = "services.example.com"
+
+ /*
+ * The text which should appear as the server's information in /WHOIS and similar
+ * queries.
+ */
+ description = "Anope IRC Services"
+
+ /*
+ * The local address that Anope will bind to before connecting to the remote
+ * server. This may be useful for multihomed hosts. If omitted, Anope will let
+ * the Operating System choose the local address. This directive is optional.
+ *
+ * If you don't know what this means or don't need to use it, just leave this
+ * directive commented out.
+ */
+ #localhost = "nowhere."
+
+ /*
+ * What Server ID to use for this connection?
+ * Note: This should *ONLY* be used for TS6/P10 IRCds. Refer to your IRCd documentation
+ * to see if this is needed.
+ */
+ #id = "00A"
+
+ /*
+ * The filename containing the Anope process ID. The path is relative to the
+ * data directory.
+ */
+ pid = "anope.pid"
+
+ /*
+ * The filename containing the Message of the Day. The path is relative to the
+ * config directory.
+ */
+ motd = "motd.txt"
+}
+
+/*
+ * [REQUIRED] Protocol module
+ *
+ * This directive tells Anope which IRCd Protocol to speak when connecting.
+ * You MUST modify this to match the IRCd you run.
+ *
+ * Supported:
+ * - bahamut
+ * - hybrid
+ * - inspircd
+ * - ngircd
+ * - plexus
+ * - ratbox
+ * - solanum
+ * - unrealircd
+ */
+module { name = "inspircd" }
+
+/*
+ * [REQUIRED] Network Information
+ *
+ * This section contains information about the IRC network that Anope will be
+ * connecting to.
+ */
+networkinfo
+{
+ /*
+ * This is the name of the network that Anope will be running on.
+ */
+ networkname = "LocalNet"
+
+ /*
+ * Set this to the maximum allowed nick length on your network.
+ * Be sure to set this correctly, as setting this wrong can result in
+ * Anope being disconnected from the network. Defaults to 31.
+ */
+ #nicklen = 31
+
+ /* Set this to the maximum allowed ident length on your network.
+ * Be sure to set this correctly, as setting this wrong can result in
+ * Anope being disconnected from the network. Defaults to 10.
+ */
+ #userlen = 10
+
+ /* Set this to the maximum allowed hostname length on your network.
+ * Be sure to set this correctly, as setting this wrong can result in
+ * Anope being disconnected from the network. Defaults to 64.
+ */
+ #hostlen = 64
+
+ /* Set this to the maximum allowed channel length on your network.
+ * Defaults to 32.
+ */
+ #chanlen = 32
+
+ /* The maximum number of list modes settable on a channel (such as b, e, I).
+ * Set to 0 to disable. Defaults to 100.
+ */
+ #modelistsize = 100
+
+ /*
+ * Characters allowed in nicknames. This always includes the characters described
+ * in RFC1459, and so does not need to be set for normal behavior. Changing this to
+ * include characters your IRCd doesn't support will cause your IRCd and/or Anope
+ * to break. Multibyte characters are not supported, nor are escape sequences.
+ *
+ * It is recommended you DON'T change this.
+ */
+ #nick_chars = ""
+
+ /*
+ * The characters allowed in hostnames. This is used for validating hostnames given
+ * to services, such as BotServ bot hostnames and user vhosts. Changing this is not
+ * recommended unless you know for sure your IRCd supports whatever characters you are
+ * wanting to use. Telling services to set a vHost containing characters your IRCd
+ * disallows could potentially break the IRCd and/or Anope.
+ *
+ * It is recommended you DON'T change this.
+ */
+ vhost_chars = "abcdefghijklmnopqrstuvwxyzABCDEFGHIJKLMNOPQRSTUVWXYZ0123456789.-"
+
+ /*
+ * If set to true, allows vHosts to not contain dots (.).
+ * Newer IRCds generally do not have a problem with this, but the same warning as
+ * vhost_chars applies.
+ *
+ * It is recommended you DON'T change this.
+ */
+ allow_undotted_vhosts = false
+
+ /*
+ * The characters that are not allowed to be at the very beginning or very ending
+ * of a vHost. The same warning as vhost_chars applies.
+ *
+ * It is recommended you DON'T change this.
+ */
+ disallow_start_or_end = ".-"
+}
+
+/*
+ * [REQUIRED] Anope Options
+ *
+ * This section contains various options which determine how Anope will operate.
+ */
+options
+{
+ /*
+ * On Linux/UNIX systems Anope can setuid and setgid to this user and group
+ * after starting up. This is useful if Anope has to bind to privileged ports.
+ */
+ #user = "anope"
+ #group = "anope"
+
+ /*
+ * The case mapping used by services. This must be set to a valid locale name
+ * installed on your machine. Anope uses this case map to compare, with
+ * case insensitivity, things such as nick names, channel names, etc.
+ *
+ * We provide two special casemaps shipped with Anope, ascii and rfc1459.
+ *
+ * This value should be set to what your IRCd uses, which is probably rfc1459,
+ * however Anope has always used ascii for comparison, so the default is ascii.
+ *
+ * Changing this value once set is not recommended.
+ */
+ casemap = "ascii"
+
+ /*
+ * Sets the number of invalid password tries before services removes a user
+ * from the network. If a user enters a number of invalid passwords equal to
+ * the given amount for any services function or combination of functions
+ * during a single IRC session (subject to badpasstimeout, below), services
+ * will issues a /KILL for the user. If not given, services will ignore
+ * failed password attempts (though they will be logged in any case).
+ *
+ * This directive is optional, but recommended.
+ */
+ badpasslimit = 5
+
+ /*
+ * Sets the time after which invalid passwords are forgotten about. If a user
+ * does not enter any incorrect passwords in this amount of time, the incorrect
+ * password count will reset to zero. If not given, the timeout will be
+ * disabled, and the incorrect password count will never be reset until the user
+ * disconnects.
+ *
+ * This directive is optional.
+ */
+ badpasstimeout = 1h
+
+ /*
+ * Sets the delay between automatic database updates.
+ */
+ updatetimeout = 2m
+
+ /*
+ * Sets the delay between checks for expired nicknames and channels.
+ */
+ expiretimeout = 30m
+
+ /*
+ * Sets the timeout period for reading from the uplink.
+ */
+ readtimeout = 5s
+
+ /*
+ * Sets the interval between sending warning messages for program errors via
+ * WALLOPS/GLOBOPS.
+ */
+ warningtimeout = 4h
+
+ /*
+ * Sets the (maximum) frequency at which the timeout list is checked. This,
+ * combined with readtimeout above, determines how accurately timed events,
+ * such as nick kills, occur; it also determines how much CPU time services
+ * will use doing this. Higher values will cause less accurate timing but
+ * less CPU usage.
+ *
+ * Note that this value is not an absolute limit on the period between
+ * checks of the timeout list; the previous may be as great as readtimeout
+ * (above) during periods of inactivity.
+ *
+ * If this directive is not given, it will default to 0.
+ */
+ timeoutcheck = 3s
+
+ /*
+ * If set, this will allow users to let services send PRIVMSGs to them
+ * instead of NOTICEs. Also see the "msg" option of nickserv:defaults,
+ * which also toggles the default communication (PRIVMSG or NOTICE) to
+ * use for unregistered users.
+ *
+ * This is a feature that is against the IRC RFC and should be used ONLY
+ * if absolutely necessary.
+ *
+ * This directive is optional, and not recommended.
+ */
+ #useprivmsg = yes
+
+ /*
+ * If set, will force services to only respond to PRIVMSGs addresses to
+ * Nick@ServerName - e.g. NickServ@example.com. This should be used in
+ * conjunction with IRCd aliases. This directive is optional.
+ *
+ * This option will have no effect on some IRCds, such as TS6 IRCds.
+ */
+ #usestrictprivmsg = yes
+
+ /*
+ * If set, Anope will only show /stats o to IRC Operators. This directive
+ * is optional.
+ */
+ #hidestatso = yes
+
+ /*
+ * A space-separated list of U-lined servers on your network, it is assumed that
+ * the servers in this list are allowed to set channel modes and Anope will
+ * not attempt to reverse their mode changes.
+ *
+ * WARNING: Do NOT put your normal IRC user servers in this directive.
+ *
+ * This directive is optional.
+ */
+ #ulineservers = "stats.your.network"
+
+ /*
+ * How long to wait between connection retries with the uplink(s).
+ */
+ retrywait = 60s
+
+ /*
+ * If set, services will hide commands that users don't have the privilege to execute
+ * from HELP output.
+ */
+ hideprivilegedcommands = yes
+
+ /*
+ * If set, services will hide commands that users can't execute because they are not
+ * logged in from HELP output.
+ */
+ hideregisteredcommands = yes
+
+ /*
+ * If set, the maximum difference between an invalid and valid command name to allow
+ * as a suggestion. Defaults to 4.
+ */
+ didyoumeandifference = 4
+
+ /* The regex engine to use, as provided by the regex modules.
+ * Leave commented to disable regex matching.
+ *
+ * Note for this to work the regex module providing the regex engine must be loaded.
+ */
+ #regexengine = "regex/stdlib"
+
+ /*
+ * A list of languages to load on startup that will be available in /NICKSERV SET LANGUAGE.
+ * Useful if you translate Anope to your language. (Explained further in docs/LANGUAGE).
+ * Note that English should not be listed here because it is the base language.
+ *
+ * Removing .UTF-8 will instead use the default encoding for the language, e.g. iso-8859-1 for western European languages.
+ */
+ languages = "de_DE.UTF-8 el_GR.UTF-8 es_ES.UTF-8 fr_FR.UTF-8 it_IT.UTF-8 nl_NL.UTF-8 pl_PL.UTF-8 pt_PT.UTF-8 tr_TR.UTF-8"
+
+ /*
+ * Default language that non- and newly-registered nicks will receive messages in.
+ * Set to "en" to enable English. Defaults to the language the system uses.
+ */
+ #defaultlanguage = "es_ES.UTF-8"
+}
+
+/*
+ * [OPTIONAL] BotServ
+ *
+ * Includes botserv.example.conf, which is necessary for BotServ functionality.
+ *
+ * Remove this block to disable BotServ.
+ */
+include
+{
+ type = "file"
+ name = "botserv.example.conf"
+}
+
+/*
+ * [RECOMMENDED] ChanServ
+ *
+ * Includes chanserv.example.conf, which is necessary for ChanServ functionality.
+ *
+ * Remove this block to disable ChanServ.
+ */
+include
+{
+ type = "file"
+ name = "chanserv.example.conf"
+}
+
+/*
+ * [RECOMMENDED] Global
+ *
+ * Includes global.example.conf, which is necessary for Global functionality.
+ *
+ * Remove this block to disable Global.
+ */
+include
+{
+ type = "file"
+ name = "global.example.conf"
+}
+
+/*
+ * [OPTIONAL] HostServ
+ *
+ * Includes hostserv.example.conf, which is necessary for HostServ functionality.
+ *
+ * Remove this block to disable HostServ.
+ */
+include
+{
+ type = "file"
+ name = "hostserv.example.conf"
+}
+
+/*
+ * [OPTIONAL] MemoServ
+ *
+ * Includes memoserv.example.conf, which is necessary for MemoServ functionality.
+ *
+ * Remove this block to disable MemoServ.
+ */
+include
+{
+ type = "file"
+ name = "memoserv.example.conf"
+}
+
+/*
+ * [OPTIONAL] NickServ
+ *
+ * Includes nickserv.example.conf, which is necessary for NickServ functionality.
+ *
+ * Remove this block to disable NickServ.
+ */
+include
+{
+ type = "file"
+ name = "nickserv.example.conf"
+}
+
+/*
+ * [RECOMMENDED] OperServ
+ *
+ * Includes operserv.example.conf, which is necessary for OperServ functionality.
+ *
+ * Remove this block to disable OperServ.
+ */
+include
+{
+ type = "file"
+ name = "operserv.example.conf"
+}
+
+/*
+ * [RECOMMENDED] Logging Configuration
+ *
+ * This section is used for configuring what is logged and where it is logged to.
+ * You may have multiple log blocks if you wish. Remember to properly secure any
+ * channels you choose to have Anope log to!
+ */
+log
+{
+ /*
+ * Target(s) to log to, which may be one of the following:
+ * - a channel name
+ * - a filename
+ * - globops
+ *
+ * If you specify a filename the current date in the format ".YYYYMMDD" will be appended to the path.
+ */
+ target = "services.log"
+
+ /* Log to both services.log and the channel #services
+ *
+ * Note that some older IRCds, such as Ratbox, require services to be in the
+ * log channel to be able to message it. To do this, configure service:channels to
+ * join your logging channel.
+ */
+ #target = "services.log #services"
+
+ /*
+ * The source(s) to only accept log messages from. Leave commented to allow all sources.
+ * This can be a users name, a channel name, one of our clients (e.g. OperServ), or a server name.
+ */
+ #source = ""
+
+ /*
+ * The bot used to log generic messages which have no predefined sender if the
+ * target directive is set to a channel or globops.
+ */
+ bot = "Global"
+
+ /*
+ * The number of days to keep log files, only useful if you are logging to a file.
+ * Set to 0 to never delete old log files.
+ *
+ * Note that Anope must run 24 hours a day for this feature to work correctly.
+ */
+ logage = 7
+
+ /*
+ * What types of log messages should be logged by this block. There are nine general categories:
+ *
+ * admin - Execution of admin commands (OperServ, etc).
+ * override - A services operator using their powers to execute a command they couldn't normally.
+ * commands - Execution of general commands.
+ * servers - Server actions, linking, squitting, etc.
+ * channels - Actions in channels such as joins, parts, kicks, etc.
+ * users - User actions such as connecting, disconnecting, changing name, etc.
+ * other - All other messages without a category.
+ * rawio - Logs raw input and output from services
+ * debug - Debug messages (log files can become VERY large from this).
+ *
+ * These options determine what messages from the categories should be logged. Wildcards are accepted, and
+ * you can also negate values with a ~. For example, "~operserv/akill operserv/*" would log all operserv
+ * messages except for operserv/akill. Note that processing stops at the first matching option, which
+ * means "* ~operserv/*" would log everything because * matches everything.
+ *
+ * Valid admin, override, and command options are:
+ * pseudo-serv/commandname (e.g. operserv/akill, chanserv/set)
+ *
+ * Valid server options are:
+ * connect, quit, sync, squit
+ *
+ * Valid channel options are:
+ * create, destroy, join, part, kick, leave, mode
+ *
+ * Valid user options are:
+ * connect, disconnect, quit, nick, ident, host, mode, maxusers, oper, away
+ *
+ * Rawio and debug are simple yes/no answers, there are no types for them.
+ *
+ * Note that modules may add their own values to these options.
+ */
+ admin = "*"
+ override = "chanserv/* nickserv/* memoserv/set ~botserv/set botserv/*"
+ commands = "~operserv/* *"
+ servers = "*"
+ #channels = "~mode *"
+ users = "connect disconnect nick"
+ other = "*"
+ rawio = no
+ debug = no
+}
+
+/*
+ * A log block to globops some useful things.
+ */
+log
+{
+ bot = "Global"
+ target = "globops"
+ admin = "global/* operserv/chankill operserv/mode operserv/kick operserv/akill operserv/s*line operserv/noop operserv/jupe operserv/set operserv/svsnick operserv/svsjoin operserv/svspart nickserv/getpass */drop"
+ servers = "squit"
+ users = "oper"
+ other = "expire/* bados akill/*"
+}
+
+/*
+ * [RECOMMENDED] Oper Access Config
+ *
+ * This section is used to set up staff access to restricted oper only commands.
+ * You may define groups of commands and privileges, as well as who may use them.
+ *
+ * This block is recommended, as without it you will be unable to access most oper commands.
+ *
+ * The command names below are defaults and are configured in the *serv.conf's. If you configure
+ * additional commands with permissions, such as commands from third party modules, the permissions
+ * must be included in the opertype block before the command can be used.
+ *
+ * Available privileges:
+ * botserv/administration - Can view and assign private BotServ bots
+ * botserv/fantasy - Can use fantasy commands without the FANTASY privilege
+ * chanserv/administration - Can modify the settings of any channel (including changing of the owner!)
+ * chanserv/access/list - Can view channel access and akick lists, but not modify them
+ * chanserv/access/modify - Can modify channel access and akick lists, and use /chanserv enforce
+ * chanserv/auspex - Can see any information with /CHANSERV INFO
+ * chanserv/no-register-limit - May register an unlimited number of channels and nicknames
+ * chanserv/kick - Can kick and ban users from channels through ChanServ
+ * chanserv/drop/override - Allows dropping channels without using a confirmation code
+ * memoserv/info - Can see any information with /MEMOSERV INFO
+ * memoserv/set-limit - Can set the limit of max stored memos on any user and channel
+ * memoserv/no-limit - Can send memos through limits and throttles
+ * nickserv/alist - Can see the channel access list of other users
+ * nickserv/auspex - Can see any information with /NICKSERV INFO
+ * nickserv/cert - Can modify other users certificate lists
+ * nickserv/confirm - Can confirm other users nicknames
+ * nickserv/drop - Can drop other users nicks
+ * nickserv/drop/display - Allows dropping display nicks when preservedisplay is enabled
+ * nickserv/drop/override - Allows dropping nicks without using a confirmation code
+ * nickserv/recover - Can recover other users nicks
+ * operserv/config - Can modify services's configuration
+ * operserv/oper/modify - Can add and remove operators with at most the same privileges
+ * protected - Can not be kicked from channels by services
+ *
+ * Available commands:
+ * botserv/bot/del botserv/bot/add botserv/bot/change botserv/set/private
+ * botserv/set/nobot
+ *
+ * chanserv/drop chanserv/getkey chanserv/invite
+ * chanserv/list chanserv/suspend chanserv/topic
+ *
+ * chanserv/saset/noexpire
+ *
+ * memoserv/sendall memoserv/staff
+ *
+ * nickserv/getemail nickserv/suspend nickserv/ajoin nickserv/list
+ *
+ * nickserv/saset/autoop nickserv/saset/display nickserv/saset/email nickserv/saset/greet
+ * nickserv/saset/kill nickserv/saset/keepmodes nickserv/saset/language nickserv/saset/message
+ * nickserv/saset/neverop nickserv/saset/noexpire nickserv/saset/password nickserv/saset/private
+ * nickserv/saset/url
+ *
+ * hostserv/set hostserv/del hostserv/list
+ *
+ * global/global global/queue global/server
+ *
+ * operserv/news operserv/stats operserv/kick operserv/exception operserv/seen
+ * operserv/mode operserv/session operserv/modinfo operserv/ignore operserv/chanlist
+ * operserv/chankill operserv/akill operserv/sqline operserv/snline operserv/userlist
+ * operserv/oper operserv/config operserv/umode operserv/logsearch
+ * operserv/modload operserv/jupe operserv/set operserv/noop
+ * operserv/quit operserv/update operserv/reload operserv/restart
+ * operserv/shutdown operserv/svs operserv/kill
+ *
+ * Firstly, we define 'opertypes' which are named whatever we want ('Network Administrator', etc).
+ * These can contain commands for oper-only strings (see above) which grants access to that specific command,
+ * and privileges (which grant access to more general permissions for the named area).
+ * Wildcard entries are permitted for both, e.g. 'commands = "operserv/*"' for all OperServ commands.
+ * You can also negate values with a ~. For example, "~operserv/akill operserv/*" would allow all OperServ
+ * commands except for operserv/akill. Note that processing stops at the first matching option, which
+ * means "* ~operserv/*" would allow everything because * matches everything.
+ *
+ * Below are some default example types, but this is by no means exhaustive,
+ * and it is recommended that you configure them to your needs.
+ */
+
+opertype
+{
+ /* The name of this opertype */
+ name = "Helper"
+
+ /* What commands (see above) this opertype has */
+ commands = "hostserv/*"
+}
+
+opertype
+{
+ /* The name of this opertype */
+ name = "Services Operator"
+
+ /* What opertype(s) this inherits from. Separate with a comma. */
+ inherits = "Helper, Another Helper"
+
+ /* What commands (see above) this opertype may use */
+ commands = "chanserv/list chanserv/suspend chanserv/topic memoserv/staff nickserv/list nickserv/suspend operserv/mode operserv/chankill operserv/akill operserv/session operserv/modinfo operserv/sqline operserv/oper operserv/kick operserv/ignore operserv/snline"
+
+ /* What privs (see above) this opertype has */
+ privs = "chanserv/auspex chanserv/no-register-limit memoserv/* nickserv/auspex nickserv/confirm"
+
+ /*
+ * Modes to be set on users when they identify to accounts linked to this opertype.
+ *
+ * This can be used to automatically oper users who identify for services operator accounts, and is
+ * useful for setting modes such as Plexus's user mode +N.
+ *
+ * Note that some IRCds, such as InspIRCd, do not allow directly setting +o, and this will not work.
+ */
+ #modes = "+o"
+}
+
+opertype
+{
+ name = "Services Administrator"
+
+ inherits = "Services Operator"
+
+ commands = "botserv/* chanserv/access/list chanserv/drop chanserv/getkey chanserv/saset/noexpire memoserv/sendall nickserv/saset/* nickserv/getemail operserv/news operserv/jupe operserv/svs operserv/stats operserv/noop operserv/forbid global/*"
+
+ privs = "*"
+}
+
+opertype
+{
+ name = "Services Root"
+
+ commands = "*"
+
+ privs = "*"
+}
+
+/*
+ * After defining different types of operators in the above opertype section, we now define who is in these groups
+ * through 'oper' blocks, similar to ircd access.
+ *
+ * The default is to comment these out (so NOBODY will have access).
+ * You probably want to add yourself and a few other people at minimum.
+ *
+ * As with all permissions, make sure to only give trustworthy people access.
+ */
+
+#oper
+{
+ /* The nickname of this services oper */
+ #name = "nick1"
+
+ /* The opertype this person will have */
+ type = "Services Root"
+
+ /* If set, the user must be an oper on the IRCd to gain their
+ * oper privileges.
+ */
+ require_oper = yes
+
+ /* An optional password. If defined, the user must login using "/OPERSERV LOGIN" first */
+ #password = "secret"
+
+ /* An optional SSL fingerprint. If defined, it's required to be able to use this opertype. */
+ #certfp = "ed3383b3f7d74e89433ddaa4a6e5b2d7"
+
+ /* An optional list of user@host masks. If defined the user must be connected from one of them */
+ #host = "*@*.anope.org ident@*"
+
+ /* An optional vHost to set on users who identify for this oper block.
+ * This will override HostServ vHosts, and may not be available on all IRCds
+ */
+ #vhost = "oper.mynet"
+}
+
+#oper
+{
+ name = "nick2"
+ type = "Services Administrator"
+}
+
+#oper
+{
+ name = "nick3"
+ type = "Helper"
+}
+
+/*
+ * [OPTIONAL] Mail Config
+ *
+ * This section contains settings related to the use of email from services.
+ * If the usemail directive is set to yes, unless specified otherwise, all other
+ * directives are required.
+ *
+ * NOTE: Users can find the IP of the machine services is running on by examining
+ * mail headers. If you do not want your IP known, you should set up a mail relay
+ * to strip the relevant headers.
+ */
+mail
+{
+ /*
+ * If set, this option enables the mail commands in Anope. You may choose
+ * to disable it if you have no Sendmail-compatible mailer installed. Whilst
+ * this directive (and entire block) is optional, it is required if
+ * nickserv:registration is set to mail.
+ */
+ usemail = yes
+
+ /*
+ * This is the command-line that will be used to call the mailer to send an
+ * email. It must be called with all the parameters needed to make it
+ * scan the mail input to find the mail recipient; consult your mailer
+ * documentation.
+ *
+ * Postfix users must use the compatible sendmail utility provided with
+ * it. This one usually needs no parameters on the command-line. Most
+ * sendmail applications (or replacements of it) require the -t option
+ * to be used.
+ *
+ * If you are running on Windows you should use a Windows sendmail port
+ * like https://www.glob.com.au/sendmail/ for sending emails.
+ */
+ #sendmailpath = "/usr/sbin/sendmail -it"
+
+ /*
+ * This is the email address from which all the emails are to be sent from.
+ * It should really exist.
+ */
+ sendfrom = "services@example.com"
+
+ /*
+ * This controls the minimum amount of time a user must wait before sending
+ * another email after they have sent one. It also controls the minimum time
+ * a user must wait before they can receive another email.
+ *
+ * This feature prevents users from being mail bombed using services and
+ * it is highly recommended that it be used.
+ *
+ * This directive is optional, but highly recommended.
+ */
+ delay = 5m
+
+ /*
+ * If set, Anope will not put quotes around the TO: fields
+ * in emails.
+ *
+ * This directive is optional, and as far as we know, it's only needed
+ * if you are using ESMTP or QMail to send out emails.
+ */
+ #dontquoteaddresses = yes
+
+ /*
+ * The content type to use when sending emails.
+ *
+ * This directive is optional, and is generally only needed if you want to
+ * use HTML or non UTF-8 text in your services emails.
+ */
+ #content_type = "text/plain; charset=UTF-8"
+
+ /*
+ * The subject and message of emails sent to users when they register accounts.
+ *
+ * Available tokens for this template are:
+ * %n - Gets replaced with the nickname
+ * %N - Gets replaced with the network name
+ * %c - Gets replaced with the confirmation code
+ */
+ registration_subject = "Nickname registration for %n"
+ registration_message = "Hi,
+
+ You have requested to register the nickname %n on %N.
+ Please type \" /msg NickServ CONFIRM %c \" to complete registration.
+
+ If you don't know why this mail was sent to you, please ignore it silently.
+
+ %N administrators."
+
+ /*
+ * The subject and message of emails sent to users when they request a new password.
+ *
+ * Available tokens for this template are:
+ * %n - Gets replaced with the nickname
+ * %N - Gets replaced with the network name
+ * %c - Gets replaced with the confirmation code
+ */
+ reset_subject = "Reset password request for %n"
+ reset_message = "Hi,
+
+ You have requested to have the password for %n reset.
+ To reset your password, type \" /msg NickServ CONFIRM %n %c \"
+
+ If you don't know why this mail was sent to you, please ignore it silently.
+
+ %N administrators."
+
+ /*
+ * The subject and message of emails sent to users when they request a new email address.
+ *
+ * Available tokens for this template are:
+ * %e - Gets replaced with the old email address
+ * %E - Gets replaced with the new email address
+ * %n - Gets replaced with the nickname
+ * %N - Gets replaced with the network name
+ * %c - Gets replaced with the confirmation code
+ */
+ emailchange_subject = "Email confirmation"
+ emailchange_message = "Hi,
+
+ You have requested to change your email address from %e to %E.
+ Please type \" /msg NickServ CONFIRM %c \" to confirm this change.
+
+ If you don't know why this mail was sent to you, please ignore it silently.
+
+ %N administrators."
+
+ /*
+ * The subject and message of emails sent to users when they receive a new memo.
+ *
+ * Available tokens for this template are:
+ * %n - Gets replaced with the nickname
+ * %s - Gets replaced with the sender's nickname
+ * %d - Gets replaced with the memo number
+ * %t - Gets replaced with the memo text
+ * %N - Gets replaced with the network name
+ */
+ memo_subject = "New memo"
+ memo_message = "Hi %n,
+
+ You've just received a new memo from %s. This is memo number %d.
+
+ Memo text:
+
+ %t"
+}
+
+/*
+ * [REQUIRED] Database configuration.
+ *
+ * This section is used to configure databases used by Anope.
+ * You should at least load one database method, otherwise any data you
+ * have will not be stored!
+ */
+
+/*
+ * [DEPRECATED] db_old
+ *
+ * This is the old binary database format from late Anope 1.7.x, Anope 1.8.x, and
+ * early Anope 1.9.x. This module only loads these databases, and will NOT save them.
+ * You should only use this to upgrade old databases to a newer database format by loading
+ * other database modules in addition to this one, which will be used when saving databases.
+ */
+#module
+{
+ name = "db_old"
+
+ /*
+ * This is the encryption type used by the databases. This must be set correctly or
+ * your passwords will not work. Valid options are: md5, oldmd5, sha1, and plain.
+ * You must also be sure to load the correct encryption module below in the Encryption
+ * Modules section so that your passwords work.
+ */
+ #hash = "md5"
+}
+
+/*
+ * db_atheme
+ *
+ * This allows importing databases from Atheme. You should load another database module as
+ * well as this as it can only read Atheme databases not write them.
+ */
+#module
+{
+ name = "db_atheme"
+
+ /*
+ * The database name db_atheme should use.
+ */
+ database = "atheme.db"
+}
+
+/*
+ * [RECOMMENDED] db_flatfile
+ *
+ * This is the default flatfile database format.
+ */
+module
+{
+ name = "db_flatfile"
+
+ /*
+ * The database name db_flatfile should use
+ */
+ database = "anope.db"
+
+ /*
+ * Sets the number of days backups of databases are kept. If you don't give it,
+ * or if you set it to 0, Anope won't backup the databases.
+ *
+ * NOTE: Anope must run 24 hours a day for this feature to work.
+ *
+ * This directive is optional, but recommended.
+ */
+ keepbackups = 3
+
+ /*
+ * Allows Anope to continue file write operations (i.e. database saving)
+ * even if the original file cannot be backed up. Enabling this option may
+ * allow Anope to continue operation under conditions where it might
+ * otherwise fail, such as a nearly-full disk.
+ *
+ * NOTE: Enabling this option can cause irrecoverable data loss under some
+ * conditions, so make CERTAIN you know what you're doing when you enable it!
+ *
+ * This directive is optional, and you are discouraged against enabling it.
+ */
+ #nobackupokay = yes
+
+ /*
+ * If enabled, services will fork a child process to save databases.
+ *
+ * This is only useful with very large databases, with hundreds
+ * of thousands of objects, that have a noticeable delay from
+ * writing databases.
+ */
+ fork = no
+}
+
+/*
+ * db_sql and db_sql_live
+ *
+ * db_sql module allows saving and loading databases using one of the SQL engines.
+ * This module loads the databases once on startup, then incrementally updates
+ * objects in the database as they are changed within Anope in real time. Changes
+ * to the SQL tables not done by Anope will have no effect and will be overwritten.
+ *
+ * db_sql_live module allows saving and loading databases using one of the SQL engines.
+ * This module reads and writes to SQL in real time. Changes to the SQL tables
+ * will be immediately reflected into Anope. This module should not be loaded
+ * in conjunction with db_sql.
+ *
+ */
+#module
+{
+ name = "db_sql"
+ #name = "db_sql_live"
+
+ /*
+ * The SQL service db_sql(_live) should use, these are configured in modules.conf.
+ * For MySQL, this should probably be mysql/main.
+ */
+ engine = "sqlite/main"
+
+ /*
+ * An optional prefix to prepended to the name of each created table.
+ * Do not use the same prefix for other programs.
+ */
+ #prefix = "anope_db_"
+
+ /* Whether or not to import data from another database module in to SQL on startup.
+ * If you enable this, be sure that the database services is configured to use is
+ * empty and that another database module to import from is loaded before db_sql.
+ * After you enable this and do a database import you should disable it for
+ * subsequent restarts.
+ *
+ * Note that you can not import databases using db_sql_live. If you want to import
+ * databases and use db_sql_live you should import them using db_sql, then shut down
+ * and start services with db_sql_live.
+ */
+ import = false
+}
+
+/*
+ * db_redis.
+ *
+ * This module allows using Redis (https://redis.io/) as a database backend.
+ * This module requires that redis is loaded and configured properly.
+ *
+ * Redis 2.8 supports keyspace notifications which allows Redis to push notifications
+ * to Anope about outside modifications to the database. This module supports this and
+ * will internally reflect any changes made to the database immediately once notified.
+ * See docs/REDIS for more information regarding this.
+ */
+#module
+{
+ name = "db_redis"
+
+ /*
+ * Redis database to use. This must be configured with redis.
+ */
+ engine = "redis/main"
+}
+
+/*
+ * [RECOMMENDED] Encryption modules.
+ *
+ * The encryption modules are used when dealing with passwords. This determines
+ * how the passwords are stored in the databases.
+ *
+ * The first encryption module loaded is the primary encryption module. All new
+ * passwords are encrypted by this module. Old passwords encrypted with another
+ * encryption method are automatically re-encrypted with the primary encryption
+ * module the next time the user identifies.
+ */
+
+/*
+ * enc_sha2
+ *
+ * Provides support for encrypting passwords using the HMAC-SHA-2 algorithm. See
+ * https://en.wikipedia.org/wiki/SHA-2 and https://en.wikipedia.org/wiki/HMAC
+ * for more information.
+ */
+module
+{
+ name = "enc_sha2"
+
+ /** The sub-algorithm to use. Can be set to sha224 for SHA-224, sha256 for
+ * SHA-256, sha284 for SHA-384 or sha512 to SHA-512. Defaults to sha256.
+ */
+ #algorithm = "sha256"
+}
+
+/*
+ * [EXTRA] enc_argon2
+ *
+ * Provides support for encrypting passwords using the Argon2 algorithm. See
+ * https://en.wikipedia.org/wiki/Argon2 for more information.
+ */
+#module
+{
+ name = "enc_argon2"
+
+ /** The sub-algorithm to use. Can be set to argon2d for Argon2d, argon2i for
+ * Argon2i, or argon2id for Argon2id. Defaults to argon2id.
+ */
+ #algorithm = "argon2id"
+
+ /** The memory hardness in kibibytes of the Argon2 algorithm. Defaults to
+ * 128 mebibytes.
+ */
+ #memory_cost = 121072
+
+ /** The time hardness (iterations) of the Argon2 algorithm. Defaults to 3.
+ */
+ #time_cost = 3
+
+ /** The amount of parallel threads to use when encrypting passwords.
+ * Defaults to 1.
+ */
+ #parallelism = 1
+
+ /** The length in bytes of an Argon2 hash. Defaults to 32. */
+ #hash_length = 32
+
+ /** The length in bytes of an Argon2 salt. Defaults to 32. */
+ #salt_length = 32
+}
+
+/*
+ * enc_bcrypt
+ *
+ * Provides support for encrypting passwords using the Bcrypt algorithm. See
+ * https://en.wikipedia.org/wiki/Bcrypt for more information.
+ */
+#module
+{
+ name = "enc_bcrypt"
+
+ /** The number of Bcrypt rounds to perform on passwords. Can be set to any
+ * number between 10 and 32 but higher numbers are more CPU intensive and
+ * may impact performance.
+ */
+ #rounds = 10
+}
+
+/*
+ * [EXTRA] enc_posix
+ *
+ * Provides verify-only support for passwords encrypted using the POSIX crypt()
+ * function. Load this if you are migrating from another services packages such
+ * as Atheme. See https://en.wikipedia.org/wiki/Crypt_(C) for more information.
+ *
+ * You must load another encryption method before this to re-encrypt passwords
+ * with when a user logs in.
+ */
+#module { name = "enc_posix" }
+
+/*
+ * [DEPRECATED] enc_md5, enc_none, enc_old, enc_sha1, enc_sha256
+ *
+ * Provides verify-only support for passwords encrypted using encryption methods
+ * from older versions of Anope. These methods are no longer considered secure
+ * and will be removed in a future version of Anope. Only load them if you are
+ * upgrading from a previous version of Anope that used them.
+ *
+ * enc_md5: Verifies passwords encrypted with the MD5 algorithm
+ * enc_none: Verifies passwords that are not encrypted
+ * enc_sha1: Verifies passwords encrypted with the SHA1 algorithm
+ * enc_old: Verifies passwords encrypted with the broken MD5 algorithm used
+ * before 1.7.17.
+ * enc_sha256: Verifies passwords encrypted with the SHA256 algorithm using a
+ * custom initialisation vector as a salt.
+ *
+ * You must load another encryption method before this to re-encrypt passwords
+ * with when a user logs in.
+ */
+#module { name = "enc_md5" }
+#module { name = "enc_none" }
+#module { name = "enc_old" }
+#module { name = "enc_sha1" }
+#module { name = "enc_sha256" }
+
+/* Extra (optional) modules. */
+include
+{
+ type = "file"
+ name = "modules.example.conf"
+}
+
+/*
+ * Chanstats module.
+ * Requires a MySQL Database.
+ */
+#include
+{
+ type = "file"
+ name = "chanstats.example.conf"
+}
+
+/*
+ * IRC2SQL Gateway
+ * This module collects data about users, channels and servers. It doesn't build stats
+ * itself, however, it gives you the database, it's up to you how you use it.
+ *
+ * Requires a MySQL Database and MySQL version 5.5 or higher
+ */
+#include
+{
+ type = "file"
+ name = "irc2sql.example.conf"
+}