GitXplorerGitXplorer
K

Porygon-Z

public
3 stars
0 forks
3 issues

Commits

List of commits on branch master.
Unverified
146bb813180c8c797e4b8dbb5d3fac013b72e814

"works" is slightly too strong

KKamilaBorowska committed 11 years ago
Unverified
8a9cb97972d17842f02915f5e8cb6de723d56947

Update README.md

KKamilaBorowska committed 11 years ago
Unverified
17cc4fbdcc0dbdd35569f80b5b3d9f16f85f8cff

Use real name here

KKamilaBorowska committed 11 years ago
Unverified
4bad6557559b1fc8fb9f1c7ba7555841a689094f

Remove useless whitespace from sample.

KKamilaBorowska committed 11 years ago
Unverified
323d2e8f38d3d1becbd98822d0623aebe58947d2

Update homepage.

gglitchmr committed 11 years ago
Unverified
0eb9fda2257b86b801b54f18540d3bb6c344c042

Update e-mail.

gglitchmr committed 11 years ago

README

The README file for this repository.

PorygonZ

Build Status Dependency Status

The simple bot that sort of works. Initially, it was just an IRC bot, but in later releases it got XMPP support. It contains an IRC server support, but can be used without IRC (as REPL). Also, it supports XMPP servers, so you can easily make a bot for Internet Messaging. It's very configurable by using plugins, and you can even decide whatever command names are used by the plugin.

Plugins available

  • randomness
    • coin - throws a coin, while using random.org
  • help
    • help - allows you to read list of commands, and help for the command. You can overwrite the help, by changing the help property of the object.
  • math
    • math - uses matheval to solve mathematical problem. Takes three configuration arguments, hex, binary, and octal. Those decide whatever the calculator shows the results in other bases.
  • version
    • version - shows pointless version information. Yep.
  • tell
    • tell - informs other users when they are away.
    • tellCheck - event parser to actually inform users. Needed if you want tell that actually does work.
  • pug

Installation

If you want to use the stable version, use standard npm install command.

npm install porygonz

If you want to use development version, just clone the repository using npm. Following command should be able to install PorygonZ.

npm install git://github.com/GlitchMr/PorygonZ.git

You will need to write some code to load plugins of IRC bot, and its servers. The source code already contains one, available in the porygonz.litcoffee.sample file. You are encouraged to copy it to some other file ending with .litcoffee.

The config file can be put almost anywhere - all it does it running actual code that was installed by npm install command. It's sort of bootstrap, I would say.

Because the configuration file is written in CoffeeScript, you should be aware that it cares about indentation. It's also sort of complex, but it also gives lots of flexibility. If you feel like, you can even monkey punch things while using CoffeeScript syntax. You generally shouldn't have to, but sometimes it's needed. Generally, the configuration file has two things you would have to change.

Plugins

The first would be list of plugins, and the second would be the list of containers. By default, PorygonZ contains list of plugins containing one plugin.

{version} = require 'PorygonZ/plugins/version'

plugins =
  version: version()

This imports the plugin file PorygonZ/plugins/version, and imports the function from it called version. Every plugin is a function you should call to get the function. The reason why you have to call it, is that the plugin can be configured. version doesn't have any sort of configuration, but some plugins, like math can have it.

The plugins array contains the list of commands and the plugins mapped to it. If you would like that version be called like ver, you could add ver: version().

Servers

The second would be list of servers. By default, this bot joins #botters-test on Freenode, and enables REPL. Adding the new servers would be simply adding new entries that follow the pattern. The list of the channels is array, separated by commas.

The prefix is regular expression. It has to be at beginning of the message, otherwise bot won't listen. It uses the regular expressions syntax. To learn more about them, check out regular-expressions.info. It contains a short tutorial for regular expressions.

If you still don't know how to regular expressions, you can put string here. It's less flexible, but it works. Please note that prefixes are only needed for conferences/channels, but they are removed automatically if you will use them anyway in private messages.

Running

You need to have CoffeeScript installed globally (or at least in PATH). After doing that, you can just run the following command.

coffee porygonz.litcoffee