mirror of
https://github.com/pragma-/pbot.git
synced 2025-01-10 20:12:35 +01:00
001f2024c4
Uses POSIX shell parameter expansion syntax. <pragma-> !factadd cookie /me gives a cookie to ${args:-nobody. What a shame}! <PBot> cookie added to the global channel. <pragma-> !cookie Bob * PBot gives a cookie to Bob! <pragma-> !cookie * PBot gives a cookie to nobody. What a shame! <pragma-> !factadd sum /call calc $arg[0]:-1 + $arg[1]:-2 <PBot> sum added to the global channel. <pragma-> !sum <PBot> 1 + 2 = 3 <pragma-> !sum 3 <PBot> 3 + 2 = 5 <pragma-> !sum 4 6 <PBot> 4 + 6 = 10
134 lines
6.0 KiB
Markdown
134 lines
6.0 KiB
Markdown
# Frequently Asked Questions
|
|
This is a work in progress. More questions coming soon!
|
|
|
|
<!-- md-toc-begin -->
|
|
* [When I type `!version` it say "new version available"?](#when-i-type-version-it-say-new-version-available)
|
|
* [How do I change the bot trigger?](#how-do-i-change-the-bot-trigger)
|
|
* [How do I whitelist a user?](#how-do-i-whitelist-a-user)
|
|
* [How do I change how the bot outputs multi-line messages?](#how-do-i-change-how-the-bot-outputs-multi-line-messages)
|
|
* [How can I remove excessive spaces and tabs from command output?](#how-can-i-remove-excessive-spaces-and-tabs-from-command-output)
|
|
* [How do I change my password?](#how-do-i-change-my-password)
|
|
* [How do I make PBot remember my `date` timezone?](#how-do-i-make-pbot-remember-my-date-timezone)
|
|
* [How do I make PBot remember my `weather` location?](#how-do-i-make-pbot-remember-my-weather-location)
|
|
* [How do I set up automatic join-flood enforcement?](#how-do-i-set-up-automatic-join-flood-enforcement)
|
|
<!-- md-toc-end -->
|
|
|
|
## When I type `!version` it say "new version available"?
|
|
The PBot [`version`](Commands.md#version) command checks PBot's version information on GitHub.
|
|
The command caches and reuses this version result for 5 minutes before issuing another GitHub version check.
|
|
|
|
You can live-update PBot without shutting it down. None of your files in your custom
|
|
data-directories will be touched unless the update includes a migration script in the
|
|
[`updates/`](../updates) directory.
|
|
|
|
If you used `git` to install PBot, type `git pull` in the `pbot` directory. This will
|
|
update the PBot files to the latest version from GitHub. If you used ZIP archives, download
|
|
the latest files and extract them again.
|
|
|
|
Then, in your PBot instance on IRC, use the [`refresh`](Admin.md#refresh) command to refresh
|
|
the PBot core and plugins. No restart required!
|
|
|
|
If there is a migration script for this update then [`refresh`](Admin.md#refresh) will say "Migration available;
|
|
restart required." and you will need to restart PBot at some point for the update to take effect.
|
|
|
|
## How do I change the bot trigger?
|
|
To change the default `!` trigger to a different character use the [`regset`](Registry.md#regset)
|
|
command to change the `general.trigger` value. Use `#channel.trigger` to change the trigger only
|
|
for that channel.
|
|
|
|
For example, to change it to the `~` character:
|
|
|
|
regset general.trigger ~
|
|
|
|
To change it to both `!` and `~` (and others):
|
|
|
|
regset general.trigger [!~]
|
|
|
|
To use only the bot's nick:
|
|
|
|
regset general.trigger ""
|
|
|
|
## How do I whitelist a user?
|
|
Whitelisting a user exempts them from anti-flood enforcement, ban-evasion checking,
|
|
being automatically muted or kicked for various offenses, and more.
|
|
|
|
To whitelist a user, use the [`useradd`](Admin.md#useradd) command with the
|
|
`is-whitelisted` capability argument. To whitelist them in all channels, add
|
|
the user to the global channel.
|
|
|
|
Usage: `useradd <username> <hostmasks> <channels> is-whitelisted`
|
|
|
|
If the user already exists, use the [`userset`](Admin.md#userset) command to
|
|
grant them the `is-whitelisted` capability.
|
|
|
|
Usage: `userset <username> is-whitelisted 1`
|
|
|
|
## How do I change how the bot outputs multi-line messages?
|
|
When output from a command contains newlines, PBot will convert the newlines
|
|
to spaces and output it as one message.
|
|
|
|
If you prefer to output each line instead, you can control this behavior with
|
|
the `general.preserve_newlines` and `general.max_newlines` registry entries. To
|
|
set this behavior for specific channels, replace `general` with the `#channel`.
|
|
|
|
For example:
|
|
|
|
<pragma-> !sh printf "a\nb\nc\nd\ne\n"
|
|
<PBot> a b c d e
|
|
|
|
<pragma-> !regset general.preserve_newlines 1
|
|
<PBot> general.preserve_newlines set to 1
|
|
|
|
<pragma-> !regset general.max_newlines 4
|
|
<PBot> general.max_newlines set to 4
|
|
|
|
<pragma-> !sh printf "a\nb\nc\nd\ne\n"
|
|
<PBot> a
|
|
<PBot> b
|
|
<PBot> c
|
|
<PBot> <truncated; https://0x0.st/Okb.txt>
|
|
|
|
## How can I remove excessive spaces and tabs from command output?
|
|
If a command or factoid is producing too much whitespace and making it
|
|
difficult to read, you enable a metadata option to collapse adjacent
|
|
whitespace to a single space.
|
|
|
|
If your command is registered by a plugin, use the [`cmdset`](Admin.md#cmdset) command
|
|
to set the `condense-whitespace` [command metadata](Admin.md#command-metadata-list).
|
|
|
|
If your command is a command-line applet, use the [`factset`](Factoids.md#factset) command
|
|
to set the `condense-whitespace` [factoid metadata](Factoids.md#factoid-metadata-list) instead.
|
|
|
|
## How do I change my password?
|
|
If you have a NickServ account or a unique hostmask, you don't need a PBot password.
|
|
The `autologin` and `stayloggedin` metadata on your user account can be set instead.
|
|
|
|
But if you prefer to be safe instead of sorry, use the [`my`](Commands.md#my) command
|
|
to set the `password` and unset the `autologin` and `stayloggedin` metadata for your
|
|
user account. Your hostmask must match the user account and you must be logged in.
|
|
|
|
my password <your password>
|
|
my autologin 0
|
|
my stayloggedin 0
|
|
|
|
If you are unable to log in, ask an admin to set a temporary password for you
|
|
with the [`userset`](Admin.md#userset) command. Log in with the temporary
|
|
password and then use the above commands to update your password.
|
|
|
|
## How do I make PBot remember my `date` timezone?
|
|
Use the [`my`](Commands.md#my) command to set the `timezone` user metadata for your
|
|
user account. Your hostmask must match the user account. The `my` command will automatically
|
|
create a user account for you if one does not exist.
|
|
|
|
my timezone <your timezone>
|
|
|
|
## How do I make PBot remember my `weather` location?
|
|
Use the [`my`](Commands.md#my) command to set the `location` user metadata for your
|
|
user account. Your hostmask must match the user account. The `my` command will automatically
|
|
create a user account for you if one does not exist.
|
|
|
|
my location <your location>
|
|
|
|
## How do I set up automatic join-flood enforcement?
|
|
[See how to set up automatic join-flood enforcement here.](AntiAbuse.md#setting-up-automatic-join-flood-enforcement)
|