Skip to content
/ rekrvn Public
forked from gmoomau/rekrvn

a modular multi-protocol bot framework for clojure

License

Notifications You must be signed in to change notification settings

Nevicar/rekrvn

 
 

Folders and files

NameName
Last commit message
Last commit date

Latest commit

 
 
 
 
 
 
 
 
 
 
 
 
 

Repository files navigation

rekrvn
==============
a bot. pretty buggy.

Usage
--------------
list modules you want enabled in config.clj
eg. "example" will enable modules/example.clj
    "irc.client" will enable modules/irc/client.clj

See complete example in config.clj.example

Writing a Module
--------------
(:require rekrvn.hub)

publish events via (rekrvn.hub/broadcast content replyfn)
- content is a string beginning with a one-word identifier for your module
- replyFn is a function to be used by other modules in order to respond to published events

It takes two arguments, modId and msg. modId is a string name for the module calling replyFn and msg is the module's response.

For example, the irc module provides a replyFn that sends message to the channel from which
the message originated.

subscribe to events/messages via (rekrvn.hub/addListener modname matcher actFn)
- modname is the name of the module adding the listener
- matcher is an re-pattern to match applicable publications
- actFn is the function to be called on matching publications. As arguments, it takes a list containing the parenthesized groups in matcher and a replyFn.

See modules/example.clj for examples.

About

a modular multi-protocol bot framework for clojure

Resources

License

Stars

Watchers

Forks

Releases

No releases published

Packages

No packages published

Languages

  • Clojure 100.0%