Ecosyste.ms: Awesome
An open API service indexing awesome lists of open source software.
https://github.com/auscompgeek/aucgbot
:robot: auscompgeek's IRC bot written in JS
https://github.com/auscompgeek/aucgbot
bot irc-bot javascript
Last synced: 3 months ago
JSON representation
:robot: auscompgeek's IRC bot written in JS
- Host: GitHub
- URL: https://github.com/auscompgeek/aucgbot
- Owner: auscompgeek
- License: mpl-2.0
- Created: 2010-09-29T00:55:24.000Z (over 14 years ago)
- Default Branch: master
- Last Pushed: 2017-04-02T05:59:13.000Z (almost 8 years ago)
- Last Synced: 2024-10-04T18:33:09.888Z (3 months ago)
- Topics: bot, irc-bot, javascript
- Language: JavaScript
- Homepage:
- Size: 573 KB
- Stars: 8
- Watchers: 6
- Forks: 3
- Open Issues: 9
-
Metadata Files:
- Readme: README.md
- License: LICENSE
Awesome Lists containing this project
README
aucgbot - auscompgeek's JavaScript IRC bot
==========================================This bot is designed to be run with [JSDB](http://jsdb.org/) 1.8.0.6 or higher.
It is licensed under the [Mozilla Public License v. 2.0](http://mozilla.org/MPL/2.0/).
aucgbot can typically be found live on freenode with the nick "seedbot".
Features
--------- Generalised per-connection flood protection.
- Logging.
- Remote control.
- Multi-server support.
- Modular.### Calculator (calcbot) features
- Error reporting.
- Dice.
- Temperature conversion.
- Base conversion.
- Solve quadratic equations.### Other modules
- **infobot**: Create and recall factoids! (Database stored across channels and networks.)
Commands:
* def: define factoids
* no: redefine factoids
* reloadfacts: reload factoid database (e.g. if edited by hand)
* what is/fact/info: recall factoids
* tell: send factoid to someone in PM
* show: target factoid at someone in channel- **badword**: Track a person's usage of "bad words"! (Database stored across channels and networks.)
Usage: !badword \[*nick*] [*word*|total]: Get how many times *nick* has said *word* (all if omitted). If *word* = total, sum the counts.
If you don't want messages from this module to be sent to a channel: rc js `this.modules["badword"].sfwChans.push("channel")`
- **elf**: A unique Christmas game (across networks if you wish)!
Runs in ##elf by default, to change: rc js `this.modules["elf"].chan = "channel"`
Note, it will run in the same channel across all networks.
- **tr**: Transform text!
Commands:
* tr "*text*" "*frm*" "*to*": Replaces each character in *frm* with the corresponding character in *to* within *text*.
* rot13: ROT13. If you don't know what it is, Google it.
* rot47: ROT47. Google it.
* rev: Reverse the text.
* encode/decode: Encode/decode text.Encodings:
* base64
* html
* url
* charcode: a.k.a. dec encoding. Isn't exactly the same with Unicode characters however.
* albhed: The Al Bhed language from Final Fantasy X, for all those FF fans out there.- **yt**: YouTube! Get info about a YouTube video before clicking the link!
- **google**: Google!
Basic usage
-----------``` javascript
run("aucgbot.js");
aucgbot.prefs[pref] = setting;
aucgbot.loadModule("helloworld");
aucgbot.start([hostname, port, nick, ident, pass, channels]...);
```The above can be run from a script, not just from a jsdb prompt.
I don't recommend storing passwords on disk however.
Running `./start-aucgbot` will prompt for modules and each server property.License
-------The majority of aucgbot's codebase is licensed under the MPL.
Portions of the codebase are under other licenses. See each file for more details.