Limnoria/plugins/MoobotFactoids
Valentin Lorentz 833af36b08 all plugins: auto-generate READMEs
Starting with this commit, there should be no "original" text
in READMEs.
Instead, the entire text should be in docstrings, and READMEs
should be automatically generated from these docstrings.

Motivation:

* The same help is available both via IRC and in the README
  (although the README can be more detailed, as only the first
  paragraph will be shown on IRC)
* This will allow auto-generating plugin help on docs.limnoria.net
  using the same content as the README, as it's sourced from the
  docstrings

Additionally, this converts all READMEs from Markdown to ReST,
because the documentation already uses ReST, and other docstrings
in the codebase are in ReST for this reason.
2021-04-05 17:42:31 +02:00
..
locales Fix msgfmt warnings. 2020-03-26 22:10:28 +01:00
__init__.py Use importlib instead of imp. 2020-01-26 12:00:08 +01:00
config.py Fix neutral pronouns. 2014-04-11 21:56:42 +00:00
messages.pot Squashed commit of the following: 2014-12-20 14:37:27 +01:00
plugin.py all plugins: auto-generate READMEs 2021-04-05 17:42:31 +02:00
README.rst all plugins: auto-generate READMEs 2021-04-05 17:42:31 +02:00
test.py plugins: use r'' strings to fix DeprecationWarning in test cases (#1328) 2020-01-26 11:14:25 -08:00

Documentation for the MoobotFactoids plugin for Supybot

Purpose

Moobot factoid compatibility module. Moobot's factoids were originally designed to emulate Blootbot's factoids, so in either case, you should find this plugin comfortable.

Usage

An alternative to the Factoids plugin, this plugin keeps factoids in your bot.

To add factoid say @something is something And when you call @something the bot says something is something.

If you want factoid to be in different format say (for example): @Hi is <reply> Hello And when you call @hi the bot says Hello.

If you want the bot to use /mes with Factoids, that is possible too. @test is <action> tests. and everytime when someone calls for test the bot answers * bot tests.

Commands

factinfo [<channel>] <factoid key>

Returns the various bits of info on the factoid for the given key. <channel> is only necessary if the message isn't sent in the channel itself.

listauth [<channel>] <author name>

Lists the keys of the factoids with the given author. Note that if an author has an integer name, you'll have to use that author's id to use this function (so don't use integer usernames!). <channel> is only necessary if the message isn't sent in the channel itself.

listkeys [<channel>] <text>

Lists the keys of the factoids whose key contains the provided text. <channel> is only necessary if the message isn't sent in the channel itself.

listvalues [<channel>] <text>

Lists the keys of the factoids whose value contains the provided text. <channel> is only necessary if the message isn't sent in the channel itself.

literal [<channel>] <factoid key>

Returns the literal factoid for the given factoid key. No parsing of the factoid value is done as it is with normal retrieval. <channel> is only necessary if the message isn't sent in the channel itself.

lock [<channel>] <factoid key>

Locks the factoid with the given factoid key. Requires that the user be registered and have created the factoid originally. <channel> is only necessary if the message isn't sent in the channel itself.

most [<channel>] {popularrecent}

Lists the most {popularrecent} factoids. "popular" lists the most frequently requested factoids. "authored" lists the author with the most factoids. "recent" lists the most recently created factoids. <channel> is only necessary if the message isn't sent in the channel itself.

random [<channel>]

Displays a random factoid (along with its key) from the database. <channel> is only necessary if the message isn't sent in the channel itself.

remove [<channel>] <factoid key>

Deletes the factoid with the given key. <channel> is only necessary if the message isn't sent in the channel itself.

unlock [<channel>] <factoid key>

Unlocks the factoid with the given factoid key. Requires that the user be registered and have locked the factoid. <channel> is only necessary if the message isn't sent in the channel itself.

Configuration

supybot.plugins.MoobotFactoids.mostCount

This config variable defaults to "10", is network-specific, and is channel-specific.

Determines how many items are shown when the 'most' command is called.

supybot.plugins.MoobotFactoids.public

This config variable defaults to "True", is not network-specific, and is not channel-specific.

Determines whether this plugin is publicly visible.

supybot.plugins.MoobotFactoids.showFactoidIfOnlyOneMatch

This config variable defaults to "True", is network-specific, and is channel-specific.

Determines whether or not the factoid value will be shown when a listkeys search returns only one factoid key.