kameloso ~2080-overflow1
IRC bot in D
To use this package, run the following command in your project's root directory:
Manual usage
Put the following dependency into your project's dependences section:
kameloso
kameloso sits and listens in the channels you specify and reacts to events, like bots generally do.
It is written in D. A variety of features comes bundled in the form of plugins, and it's very easy to write your own. Any and all ideas welcome. API documentation is available online.
It works well with the majority of server networks. IRC is standardised but servers still come in many flavours, where some outright conflict with others. If something doesn't immediately work it's most often an easy issue of specialcasing for that particular IRC network or server daemon.
Current functionality includes:
- bedazzling coloured terminal output like it's the 90s
- automatic mode sets (eg. auto
+o
for op) - looking up titles of pasted web URLs
sed
-replacement of the last message sent (s/this/that/
substitution)- saving
notes
to offline users that get played back when they come online seen
plugin; reporting when a user was last seen, written as a rough example plugin- user
quotes
plugin - Reddit post lookup
bash.org
quoting- Twitch events; simple Twitch chatbot is now easy (see notes on connecting below)
- piping text from the terminal to the server (Posix only)
- mIRC colour coding and text effects (bold, underlined, ...), translated into Bash terminal formatting
- SASL authentication (
plain
)
Current limitations:
- the dmd and ldc compilers segfault if building in anything other than
debug
mode (bug #18026, see more on build modes below). Don't believe the failed/error/failing build badges. - the gdc compiler doesn't yet support
static foreach
and thus cannot be used to build this bot. - some plugins don't yet differentiate between different home channels if there is more than one.
- quirky IRC server daemons that have not been tested against may exhibit weird behaviour if parsing goes awry. Need concrete examples to fix; please report abnormalities, like error messages or fields silently having wrong values.
Use on networks without services (NickServ
/Q
/AuthServ
/...) may be difficult, since the bot identifies people by their account names. You will probably want to register yourself with such, where available.
Testing is mainly done on freenode, so support and coverage is best there.
Table of contents
News
- compiler segfaults are back.
- experimental
automodes
plugin, please test. - the
printer
plugin can now save logs to disk. Regenerate your configuration file and enable it withsaveLogs
set totrue
. It can either write lines as they are received, or buffer writes to write with a cadence of once every PING, configured withbufferedWrites
. By default only homes are logged; configurable with thelogAllChannels
knob. Needs testing and feedback. - direct imgur links are now rewritten to the non-direct HTML pages so we can get a meaningful page title, as we do with stale YouTube ones.
- all* (non-service) plugins can now be toggled as enabled or disabled in the configuration file. Regenerate it to get the needed entries.
Getting started
These instructions will get you a copy of the project up and running on your local machine for development and testing purposes, as well as general use.
Prerequisites
You need a D compiler and the official dub package manager. There are three compilers available; see here for an overview. You need one based on version 2.076 or later (released September 2017).
kameloso can be built using the reference compiler dmd and the LLVM-based ldc, in debug
mode (see below). The GCC-based gdc is currently too old to be used.
It's possible to build it manually without dub, but it is non-trivial if you want the web-related plugins to work.
Downloading
GitHub offers downloads in ZIP format, but it's arguably easier to use git and clone a copy of the source that way.
$ git clone https://github.com/zorael/kameloso.git
$ cd kameloso
Compiling
$ dub build
This will compile it in the default debug
build type, which adds some extra code and debugging symbols.
You can automatically strip these and add some optimisations by building it in
release
mode withdub build -b release
. Mind that build times will increase. Refer to the output ofdub build --help
for more build types.
The above will currently not work, as the compiler will crash on anything other than debug
mode.
Unit tests are built into the language, but you need to compile the project in unittest
mode to include them.
$ dub build -b unittest
The tests are run at the start of the program, not during compilation. You can use the shorthand dub test
to compile with tests and run them in one go. unittest
builds will only run the unit tests and immediately exit.
The available build configurations are:
vanilla
, builds without any specific extrascolours
, compiles in terminal coloursweb
, compiles in plugins with web lookup (webtitles
,reddit
andbashquotes
)colours+web
, includes both of the aboveposix
, default on Posix-like systems, equalscolours+web
windows
, default on Windows, equalsweb
cygwin
, equalscolours+web
but with extra code needed for running it under the default Cygwin terminal (mintty)
You can specify which to compile with the -c
switch. Not supplying one will make it build the default for your operating system.
$ dub build -c cygwin
Windows
There are a few Windows caveats.
- Web URL lookup, including the web titles and Reddit plugins, may not work out of the box with secure HTTPS connections due to the default installation of
dlang-requests
not finding the correct libraries. Unsure of how to fix this. Normal HTTP access should work fine. - Terminal colours may also not work, depending on your version of Windows and likely your terminal font. Unsure of how to enable this.
- Use in Cygwin terminals without compiling the aforementioned
cygwin
build configuration will be unpleasant. Normalcmd
and Powershell consoles are not affected and can be used with any configuration.
How to use
The bot needs the services account name of the administrator(s) of the bot, and/or one or more home channels to operate in. It cannot work without having at least one of the two, so you need to generate and edit a configuration file before starting.
$ ./kameloso --writeconfig
Open the new kameloso.conf
in a text editor and fill in the fields. Additional resource files will have been created as well; for instance, see users.json
for where to enter whitelisted (and blacklisted) account names.
If you enter an authentification password (authPassword
) and then regenerate the file, the password will be encoded into Base64 format. Mind that this does not mean it's encrypted! It just makes it less easy to tell what the password is at a mere glance.
Once the bot has joined a home channel, it's ready. Mind that you need to authorise yourself with services with an account listed as an administrator in the configuration file to make it listen to anything you do. Before allowing anyone to trigger any functionality it will look them up and compare their accounts with its white- and blacklists.
you joined #channel
kameloso sets mode +o you
you | !say foo
kameloso | foo
you | foo bar baz
you | s/bar/BAR/
kameloso | you | foo BAR baz
you | !8ball
kameloso | It is decidedly so
you | !addquote you This is a quote
kameloso | Quote saved. (1 on record)
you | !quote you
kameloso | you | This is a quote
you | !note OfflinePerson Why so offline?
kameloso | Note added.
you | !seen OfflinePerson
kameloso | I last saw OfflinePerson 1 hour and 34 minutes ago.
you | kameloso: sudo PRIVMSG #channel :this is a raw IRC command
kameloso | this is a raw IRC command
you | !bash 85514
kameloso | <Reverend> IRC is just multiplayer notepad.
you | https://www.youtube.com/watch?v=s-mOy8VUEBk
kameloso | [youtube.com] Danish language
you | !reddit https://dlang.org/blog/2018/01/04/dmd-2-078-0-has-been-released/
kameloso | Reddit post: https://www.reddit.com/r/programming/comments/7o2tcw/dmd_20780_has_been_released
Send help
to the bot in a private message for a summary of available bot commands, and help [plugin] [command]
for a brief description of a specific one. Mind that commands defined as regular expressions cannot be shown, due to technical reasons.
The prefix character (here "!
") is configurable; refer to your generated configuration file. Common alternatives are .
and ~
, making it .note
and ~quote
respectively.
[Core]
prefix !
It can technically be any string and not just one character. Enquote it if you want any spaces as part of the prefix token, like "please "
.
If you have compiled in colours and you have bright terminal background, the colours may be hard to see and the text difficult to read. If so, make sure to pass the --bright
argument, and/or modify the configuration file; brightTerminal
under [Core]
. The bot uses the entire range of 8-colour ANSI, so if one or more colours are too dark or bright even with the right brightTerminal
setting, please see to your terminal appearance settings. This is not uncommon, especially with backgrounds that are not fully black or white. (read: Monokai, Breeze, Solaris, ...)
Twitch
To connect to Twitch servers you must supply an OAuth token. Generate one here, then add it to your kameloso.conf
in the pass
field.
[IRCBot]
nickname twitchaccount
pass oauth:the50letteroauthstringgoeshere
homes #twitchaccount
channels #streamer1,#streamer2,#streamer3
[IRCServer]
address irc.chat.twitch.tv
port 6667
pass
is not the same as authPassword
. It is supplied very early during login (or registration) to allow you to connect -- even before negotiating username and nickname, which is otherwise the very first thing to happen. authPassword
is something that is sent to a services bot (like NickServ
or AuthServ
) after registration has finished and you have successfully logged onto the server. (In the case of SASL authentication, authPassword
is used during late registration.)
Mind that a full Twitch bot cannot be implemented as an IRC client. It needs Nightbot or similar to be able to see events like subscriptions, donations, cheers and other Twitch-specifics.
Use as a library
The IRC event parsing bits are largely decoupled from the rest of the program, needing only some helper modules.
Feel free to copy these and drop them into your own project.
Roadmap
- pipedream zero: no compiler segfaults
- pipedream: DCC
- pipedream two:
ncurses
- optional formatting in IRC output? (later if at all)
- notes triggers? (later)
seen
doing what? channel-split?IRCEvent
-based? (later)- set up a real configuration home like
~/.kameloso
? what of Windows? - automode channel awareness boost
Built with
License
This project is licensed under the MIT license - see the LICENSE file for details.
Acknowledgements
- kameloso for obvious reasons
README.md
template gist- ikod for
dlang-requests
making the web-related plugins possible - Adam D. Ruppe for
arsd
, extending web functionality #d
on Freenode for always answering questions- IRC Definition Files and
#ircdocs
on freenode for their excellent resource pages
- ~2080-overflow1 released 6 years ago
- zorael/kameloso
- MIT
- Copyright © 2018, JR
- Authors:
- Dependencies:
- none
- Versions:
-
3.14.159 2024-Jan-27 3.13.0 2023-Sep-26 3.12.1 2023-Sep-06 3.12.0 2023-Aug-25 3.11.1 2023-Jul-21 - Download Stats:
-
-
0 downloads today
-
0 downloads this week
-
0 downloads this month
-
0 downloads total
-
- Score:
- 1.7
- Short URL:
- kameloso.dub.pm