/SimpleIRC

IRC Library for Haskell

Primary LanguageHaskellOtherNOASSERTION

SimpleIRC

SimpleIRC is a simple IRC Library for haskell.

Installation

To install SimpleIRC as a library you need cabal.

You can then use cabal install to install.

Example

For an example on how to use the library see example/example.hs and tests/testbot.hs

I'm also creating an IRC Bot which uses this library. Take a look at it for more practical usage of the lib.

Usage

The first step is to create an IrcConfig datatype. You have to specify the address of the server, the server port, nickname, username, realname, list of channels to join when connected, and a list of events which will be called when certain commands are received from the server.

You can specify 0 events, if for some unlikely reason you want your bot to not respond to anything. But in the more likely event when you do want to specify functions, you can do that simply by creating a function with the type of EventFunc

onMessage :: EventFunc

EventFunc has the type of (IrcServer -> IrcMessage -> IO ()). For Haskell beginners that's a function which takes two arguments; an IrcServer and an IrcMessage, and which returns a IO ()

onMessage server message
| actualMessage == (B.pack "|hello") = do
    sendMsg server channel "hello!"
| otherwise = return ()
    where channel :: B.ByteString
          channel = case mChan message of
               Just channel -> channel
               Nothing -> B.pack ""
          actualMessage :: B.ByteString
          actualMessage = mMsg message

This function will send "hello!" to a channel whenever someone says "|hello".

Then you can pass [(Privmsg onMessage)] to IrcConfig.

Take a look at the IrcEvent type in Network/SimpleIRC/Core.hs to see other events.

There is one(as of now) event which doesn't take a EventFunc function. You should be able to figure out what type of function it does take by looking at Network/SimpleIRC/Core.hs

After you create a IrcConfig you can then call connect. Connect takes two arguments; the IrcConfig and a boolean. The boolean specifies whether to run the listenLoop in a new thread.

If you have any questions you can ask them @ irc://irc.freenode.net/#()

License

SimpleIRC is licensed under the BSD3 license. Read the license file for more information.