mirror of
https://github.com/Mikaela/Limnoria-doc.git
synced 2024-12-26 05:02:37 +01:00
421 lines
17 KiB
ReStructuredText
421 lines
17 KiB
ReStructuredText
.. _getting-started:
|
|
|
|
****************************
|
|
Getting Started with Supybot
|
|
****************************
|
|
|
|
Introduction
|
|
============
|
|
|
|
Ok, so you've decided to try out Supybot. That's great! The more people who
|
|
use Supybot, the more people can submit bugs and help us to make it the best
|
|
IRC bot in the world :)
|
|
|
|
You should have already read through our install document (if you had to
|
|
manually install) before reading any further. Now we'll give you a whirlwind
|
|
tour as to how you can get Supybot setup and use Supybot effectively.
|
|
|
|
Initial Setup
|
|
=============
|
|
|
|
Now that you have Supybot installed, you'll want to get it running. The first
|
|
thing you'll want to do is run supybot-wizard. Before running supybot-wizard,
|
|
you should be in the directory in which you want your bot-related files to
|
|
reside. The wizard will walk you through setting up a base config file for
|
|
your Supybot. Once you've completed the wizard, you will have a config file
|
|
called botname.conf. In order to get the bot running, run ``supybot
|
|
botname.conf``.
|
|
|
|
Listing Commands
|
|
================
|
|
|
|
Ok, so let's assume your bot connected to the server and joined the channels
|
|
you told it to join. For now we'll assume you named your bot 'supybot' (you
|
|
probably didn't, but it'll make it much clearer in the examples that follow to
|
|
assume that you did). We'll also assume that you told it to join #channel (a
|
|
nice generic name for a channel, isn't it? :)) So what do you do with this
|
|
bot that you just made to join your channel? Try this in the channel::
|
|
|
|
supybot: list
|
|
|
|
Replacing 'supybot' with the actual name you picked for your bot, of course.
|
|
Your bot should reply with a list of the plugins it currently has loaded. At
|
|
least `Admin`, `Channel`, `Config`, `Misc`, `Owner`, and `User` should be
|
|
there; if you used supybot-wizard to create your configuration file you may
|
|
have many more plugins loaded. The list command can also be used to list the
|
|
commands in a given plugin::
|
|
|
|
supybot: list Misc
|
|
|
|
will list all the commands in the `Misc` plugin. If you want to see the help
|
|
for any command, just use the help command::
|
|
|
|
supybot: help help
|
|
supybot: help list
|
|
supybot: help load
|
|
|
|
Sometimes more than one plugin will have a given command; for instance, the
|
|
"list" command exists in both the Misc and Config plugins (both loaded by
|
|
default). List, in this case, defaults to the Misc plugin, but you may want
|
|
to get the help for the list command in the Config plugin. In that case,
|
|
you'll want to give your command like this::
|
|
|
|
supybot: help config list
|
|
|
|
Anytime your bot tells you that a given command is defined in several plugins,
|
|
you'll want to use this syntax ("plugin command") to disambiguate which
|
|
plugin's command you wish to call. For instance, if you wanted to call the
|
|
Config plugin's list command, then you'd need to say::
|
|
|
|
supybot: config list
|
|
|
|
Rather than just 'list'.
|
|
|
|
Making Supybot Recognize You
|
|
============================
|
|
|
|
If you ran the wizard, then it is almost certainly the case that you already
|
|
added an owner user for yourself. If not, however, you can add one via the
|
|
handy-dandy 'supybot-adduser' script. You'll want to run it while the bot is
|
|
not running (otherwise it could overwrite supybot-adduser's changes to your
|
|
user database before you get a chance to reload them). Just follow the
|
|
prompts, and when it asks if you want to give the user any capabilities, say
|
|
yes and then give yourself the 'owner' capability, restart the bot and you'll
|
|
be ready to load some plugins!
|
|
|
|
Now, in order for the bot to recognize you as your owner user, you'll have to
|
|
identify with the bot.
|
|
|
|
Open up a query window in your irc client ('/query'
|
|
should do it; if not, just know that you can't identify in a channel because
|
|
it requires sending your password to the bot). Then type this::
|
|
|
|
help identify
|
|
|
|
And follow the instructions; the command you send will probably look like
|
|
this, with 'myowneruser' and 'myuserpassword' replaced::
|
|
|
|
identify myowneruser myuserpassword
|
|
|
|
The bot will tell you that 'The operation succeeded' if you got the right name
|
|
and password. Now that you're identified, you can do anything that requires
|
|
any privilege: that includes all the commands in the Owner and Admin plugins,
|
|
which you may want to take a look at (using the list and help commands, of
|
|
course). One command in particular that you might want to use (it's from the
|
|
User plugin) is the 'hostmask add' command: it lets you add a hostmask to your
|
|
user record so the bot recognizes you by your hostmask instead of requiring
|
|
you always to identify with it before it recognizes you. Use the 'help'
|
|
command to see how this command works. Here's how I often use it::
|
|
|
|
hostmask add myuser [hostmask] mypassword
|
|
|
|
You may not have seen that '[hostmask]' syntax before. Supybot allows nested
|
|
commands, which means that any command's output can be nested as an argument
|
|
to another command. The hostmask command from the Misc plugin returns the
|
|
hostmask of a given nick, but if given no arguments, it returns the hostmask
|
|
of the person giving the command. So the command above adds the hostmask I'm
|
|
currently using to my user's list of recognized hostmasks. I'm only required
|
|
to give mypassword if I'm not already identified with the bot.
|
|
|
|
Limnoria
|
|
--------
|
|
|
|
Limnoria has two additional methods to identify. GPG and NickAuth.
|
|
|
|
GPG
|
|
^^^
|
|
|
|
First you must associate your GPG key with your Limnoria account. The gpg
|
|
add command takes two arguments, key id and key server.
|
|
|
|
My key is 0x0C207F07B2F32B67 and it's on keyserver pool.sks-keyservers.net
|
|
so and now I add it to my bot::
|
|
|
|
<Mikaela> +gpg add 0x0C207F07B2F32B67 pool.sks-keyservers.net
|
|
<Yvzabevn> 1 key imported, 0 unchanged, 0 not imported.
|
|
|
|
Now I can get token to sign so I can identify::
|
|
|
|
<Guest45020> +gpg gettoken
|
|
<Yvzabevn> Your token is: {03640620-97ea-4fdf-b0c3-ce8fb62f2dc5}. Please sign it with your GPG key, paste it somewhere, and call the 'auth' command with the URL to the (raw) file containing the signature.
|
|
|
|
Then I follow the instructions and sign my token in terminal::
|
|
|
|
echo "{03640620-97ea-4fdf-b0c3-ce8fb62f2dc5}"|gpg --clearsign|curl -F 'sprunge=<-' http://sprunge.us
|
|
|
|
Note that I sent the output to curl with flags to directly send the
|
|
clearsigned content to sprunge.us pastebin. Curl should be installed on
|
|
most of distributions and comes with msysgit. If you remove the curl part,
|
|
you get the output to terminal and can pastebin it to any pastebin of
|
|
your choice. Sprunge.us has only plain text and is easy so I used it in
|
|
this example.
|
|
|
|
And last I give the bot link to the plain text signature::
|
|
|
|
<Guest45020> +gpg auth http://sprunge.us/DUdd
|
|
<Yvzabevn> You are now authenticated as Mikaela.
|
|
|
|
NickAuth
|
|
^^^^^^^^
|
|
|
|
This requires you to load the NickAuth plugin (see next section of this
|
|
page for loading plugins).
|
|
|
|
NickAuth allows you to identify to the bot using your NickServ account.
|
|
First I add my NickServ account name which I can see with "/whois Mikaela Mikaela" (because my current nick is Mikaela). It gives me something like::
|
|
|
|
[Mikaela] is logged in as Mikaela
|
|
|
|
Now I tell the bot add my NickServ account Mikaela to my bot user on
|
|
freenode. The syntax is [<network>] <bot-username> <NickServ-account>::
|
|
|
|
<Mikaela> +nickauth nick add freenode Mikaela Mikaela
|
|
<Yvzabevn> OK.
|
|
|
|
Next time when I identify to NickServ I can use the NickAuth Auth command
|
|
to also identify to the bot::
|
|
|
|
<Guest45020> +whoami
|
|
<Yvzabevn> I don't recognize you. You can messsage me either of these two commands: "user identify <username> <password>" to log in or "user register <username> <password>" to register.
|
|
<Guest45020> +nickauth auth
|
|
<Yvzabevn> You are now authenticated as Mikaela.
|
|
|
|
Identifying the bot to services
|
|
===============================
|
|
|
|
The different methods are listed in order which I (Mikaela) recommend. You
|
|
can use all of these methods or only some of them. I (Mikaela) personally
|
|
use SASL, CertFP and Server password.
|
|
|
|
Please also note that SASL and CertFP are only supported on Limnoria.
|
|
|
|
SASL
|
|
----
|
|
|
|
Note that SASL isn't supported on all networks. You can easily test if it's
|
|
supported with ``/msg SaslServ help`` and if you get response, SASL is
|
|
probably supported, if you don't get reply or get error about no such nick,
|
|
SASL isn't supported.
|
|
|
|
SASL is widely agreed as the best method to identify to services as it
|
|
identifies you before anyone (other than IRC operators) can see that you
|
|
are connected. To enable SASL, simply::
|
|
|
|
config networks.<network>.sasl.username AccountName
|
|
config networks.<network>.sasl.password P455w0rd
|
|
|
|
where you of course replace AccountName and P455w0rd with your actual
|
|
NickServ account name and password. Remember to replace ``<network>`` with
|
|
the real network name like ``freenode``.
|
|
|
|
CertFP
|
|
------
|
|
|
|
You can test if CertFP is supported by services simply by doing
|
|
``/msg NickServ cert``. If you get an error about "Insufficient parameters
|
|
for CERT", CertFP is supported, and if you get an error about unknown
|
|
command, it's not supported.
|
|
|
|
CertFP identifies you to services using a client (SSL) certificate and
|
|
naturally requires an SSL connection. It doesn't identify you as soon as
|
|
SASL, but unlike SASL, it identifies you even when services return from a
|
|
netsplit, unlike any other mechanism.
|
|
|
|
First you must generate a certificate, and the easiest method is probably
|
|
using OpenSSL which you should have even on Windows if you installed with pip::
|
|
|
|
openssl req -nodes -newkey rsa:4096 -keyout <BOT>.pem -x509 -days 3650 -out <BOT>.pem -subj "/CN=<BOT>"
|
|
|
|
Now you should have a ``<BOT>.pem`` file in the directory where you ran
|
|
the command, presumably your home directory and you only tell your
|
|
bot where to find it and tell NickServ that it belongs to you.
|
|
Note that you should replace ``<BOT>`` with the account name of your bot.
|
|
|
|
You have two choices, using the same certificate on all networks::
|
|
|
|
config protocols.irc.certfile /home/<username>/<BOT>.pem
|
|
|
|
or only on one or more network where it's manually configured::
|
|
|
|
config networks.<network>.certfile /home/<username>/<BOT>.pem
|
|
|
|
And lastly, you must tell the services what is your certificate
|
|
fingerprint, which you can find out with::
|
|
|
|
openssl x509 -sha1 -noout -fingerprint -in BOT.pem | tr -d ':' | tr 'A-Z' 'a-z'
|
|
|
|
This results in something like
|
|
``05dd01fedc1b821b796d0d785160f03e32f53fa8`` which you tell your bot to
|
|
tell services::
|
|
|
|
owner ircquote PRIVMSG NickServ :cert add 05dd01fedc1b821b796d0d785160f03e32f53fa8
|
|
|
|
Or if your bot identifies as you, you can do that by yourself with::
|
|
|
|
/msg NickServ cert add 05dd01fedc1b821b796d0d785160f03e32f53fa8
|
|
|
|
|
|
Remember to replace ``05dd01fedc1b821b796d0d785160f03e32f53fa8`` with your
|
|
own fingerprint! Next time your bot connects, it should get identified
|
|
automatically.
|
|
|
|
Server password
|
|
---------------
|
|
|
|
Many networks support identifying using ``username:password`` as server
|
|
password. If this is the case with your network (anything that uses a
|
|
charybdis-like IRCd), this should work for you. Note that this identifies
|
|
you after SASL so, your real host might be seen. To do this, simply::
|
|
|
|
config networks.<network>.password username:password
|
|
|
|
Replace ``<network>`` with the name of network, for example ``freenode``
|
|
and username:password with your real username and password.
|
|
|
|
ZNC users: since ZNC 1.0, ZNC's identification format has been
|
|
``username/network:password``.
|
|
|
|
Services plugin
|
|
---------------
|
|
|
|
The Services plugin comes with Supybot and should be an easy way to
|
|
identify your bot, but SASL and ``username:password`` as server password
|
|
are recommended over it. Start by loading Services with::
|
|
|
|
load Services
|
|
|
|
and then tell it what NickServ and ChanServ are called::
|
|
|
|
config plugins.services.nickserv NickServ
|
|
config plugins.services.chanserv ChanServ
|
|
|
|
Remember to replace NickServ/ChanServ with their real names if they have a
|
|
different name on any network. Note that they must have the same name on
|
|
all networks, and you must have the same password on all networks.
|
|
|
|
Now you can set your password::
|
|
|
|
services password Bot P455w0rd
|
|
|
|
makes the bot attempt identifying as Bot using password P455w0rd. Replace
|
|
them with your real nickname and password. Note that if you have multiple
|
|
nicknames, you must run ``services password`` for them all.
|
|
|
|
If your bot happens to get a nickname that isn't configured, it won't
|
|
know how to identify. You might be able to avoid this issue by loading
|
|
NickCapture, (``load NickCapture``) which attempts to regain the primary
|
|
nick, when it's possible, and when it regains the primary nick, the
|
|
identification should work.
|
|
|
|
Loading Plugins
|
|
===============
|
|
|
|
Let's take a look at loading other plugins. If you didn't use supybot-wizard,
|
|
though, you might do well to try it before playing around with loading plugins
|
|
yourself: each plugin has its own configure function that the wizard uses to
|
|
setup the appropriate registry entries if the plugin requires any.
|
|
|
|
If you do want to play around with loading plugins, you're going to need to
|
|
have the owner capability.
|
|
|
|
Remember earlier when I told you to try ``help load``? That's the very command
|
|
you'll be using. Basically, if you want to load, say, the Games plugin, then
|
|
``load Games``. Simple, right? If you need a list of the plugins you can load,
|
|
you'll have to list the directory the plugins are in (using whatever command
|
|
is appropriate for your operating system, either 'ls' or 'dir').
|
|
|
|
Understanding the help syntax
|
|
=============================
|
|
|
|
The syntax of a command describes how to run a command.
|
|
The syntax is given by the help command.
|
|
Some examples:
|
|
|
|
help [<plugin>] [<command>]
|
|
This is the help of :ref:`command-plugin-help`.
|
|
|
|
The chevrons mean you have to replace <plugin> and <command> by a plugin
|
|
name and a command name.
|
|
|
|
The brackets mean the argument they wrap is **optional**.
|
|
|
|
So, the fellowing commands are correct::
|
|
|
|
help
|
|
help PluginName
|
|
help PluginName CommandName
|
|
help CommandName
|
|
|
|
ping takes no arguments
|
|
This is the help for :ref:`command-misc-ping`.
|
|
|
|
I think it is clear enough.
|
|
|
|
join <channel> [<key>]
|
|
This is the help for :ref:`command-admin-join`.
|
|
|
|
It requires a channel name, and the channel key is optional.
|
|
|
|
This two commands are ok::
|
|
|
|
join #limnoria
|
|
join #limnoria MySecretKey
|
|
|
|
utilities last <text> [<text> ...]
|
|
This is the help for :ref:`command-utilities-last`.
|
|
By the way, there is another ``last`` command in the `Misc` plugin, which
|
|
doesn't do the same thing, that's why you need to give the plugin name.
|
|
|
|
You have to give at least one argument, but you can give as many as you
|
|
wish.
|
|
|
|
Getting More From Your Supybot
|
|
==============================
|
|
|
|
Another command you might find yourself needing somewhat often is the 'more'
|
|
command. The IRC protocol limits messages to 512 bytes, 60 or so of which
|
|
must be devoted to some bookkeeping. Sometimes, however, Supybot wants to
|
|
send a message that's longer than that. What it does, then, is break it into
|
|
"chunks" and send the first one, following it with ``(X more messages)`` where
|
|
X is how many more chunks there are. To get to these chunks, use the `more`
|
|
command. One way to try is to look at the default value of
|
|
`supybot.replies.genericNoCapability` -- it's so long that it'll stretch
|
|
across two messages::
|
|
|
|
<jemfinch|lambda> $config default
|
|
supybot.replies.genericNoCapability
|
|
<lambdaman> jemfinch|lambda: You're missing some capability
|
|
you need. This could be because you actually
|
|
possess the anti-capability for the capability
|
|
that's required of you, or because the channel
|
|
provides that anti-capability by default, or
|
|
because the global capabilities include that
|
|
anti-capability. Or, it could be because the
|
|
channel or the global defaultAllow is set to
|
|
False, meaning (1 more message)
|
|
<jemfinch|lambda> $more
|
|
<lambdaman> jemfinch|lambda: that no commands are allowed
|
|
unless explicitly in your capabilities. Either
|
|
way, you can't do what you want to do.
|
|
|
|
So basically, the bot keeps, for each person it sees, a list of "chunks" which
|
|
are "released" one at a time by the `more` command. In fact, you can even get
|
|
the more chunks for another user: if you want to see another chunk in the last
|
|
command jemfinch gave, for instance, you would just say `more jemfinch` after
|
|
which, his "chunks" now belong to you. So, you would just need to say `more`
|
|
to continue seeing chunks from jemfinch's initial command.
|
|
|
|
Final Word
|
|
==========
|
|
|
|
You should now have a solid foundation for using Supybot. You can use the
|
|
`list` command to see what plugins your bot has loaded and what commands are
|
|
in those plugins; you can use the 'help' command to see how to use a specific
|
|
command, and you can use the 'more' command to continue a long response from
|
|
the bot. With these three commands, you should have a strong basis with which
|
|
to discover the rest of the features of Supybot!
|
|
|
|
Do be sure to read our other documentation and make use of the resources we
|
|
provide for assistance; this website and, of course, #supybot on
|
|
irc.freenode.net if you run into any trouble!
|