Skip to content

emiln/stalmanu

Folders and files

NameName
Last commit message
Last commit date

Latest commit

 

History

49 Commits
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 

Repository files navigation

Richardo "GNU/dad" Stalmanu

Codeship Status

I'd just like to interject for a moment. What you're referring to as Linux, is in fact, GNU/Linux, or as I've recently taken to calling it, GNU plus Linux. Linux is not an operating system unto itself, but rather another free component of a fully functioning GNU system made useful by the GNU corelibs, shell utilities and vital system components comprising a full OS as defined by POSIX.

Many computer users run a modified version of the GNU system every day, without realizing it. Through a peculiar turn of events, the version of GNU which is widely used today is often called Linux, and many of its users are not aware that it is basically the GNU system, developed by the GNU Project.

There really is a Linux, and these people are using it, but it is just a part of the system they use. Linux is the kernel: the program in the system that allocates the machine's resources to the other programs that you run. The kernel is an essential part of an operating system, but useless by itself; it can only function in the context of a complete operating system. Linux is normally used in combination with the GNU operating system: the whole system is basically GNU with Linux added, or GNU/Linux. All the so-called Linux distributions are really distributions of GNU/Linux.

Installing and running

Stalmanu is a rather opinionated Slack bot. His hobbies include just interjecting for a moment, and... well that's about it. This is mostly an experiment in interfacing with Slack.io. Stalmanu uses Boot, which will be assumed installed in the remainder of the README.

You can compile Stalmanu into a runnable jar using

boot build

and then start him using

java -jar target/stalmanu-0.1.0.jar my-super-secret-token

where you supply the Slack bot token.

Extending

Stalmanu is most easily extended by hooking into the emit! and handle flow that his current functions are built on. Essentially, whenever anything happens on the channels that Stalmanu is monitoring, he will call (emit!) and supply a topic and some data:

(emit! "message"
  {:type "message" :channel "..." :user "..." :ts "..." :text "Hi, friends!"})

The topic will match the :type from the parsed JSON if present. You can emit events as well, supplying whatever topic and data you want to. To actually process events, you'll define some handlers:

(handle "message"
  (fn [msg]
    (when (> (count (:text msg)) 500)
      (send! websocket "Woah! That's a lot of text, mate."))))

(handle "presence_change"
  (fn [presence]
    (println (:user presence) "is now" (:presence presence) "!")))

This assumes you've saved the websocket returned when calling client!. That's probably what you want, though, as it's the only way to send messages to the Slack server.

It is perfectly acceptable for your handlers to emit additional events, but you probably want to condition them in a way that doesn't lead to infinite loops. You should also remember that calling send! will result in a new emit!, which makes creating an infinite loop simple:

;; Don't do this unless your goal is to be kicked from the server for flooding.
(handle "message"
  (fn [msg]
    (send! websocket "I just saw '" (pr-str msg) "'!")))

About

He would just like to interject for a moment.

Resources

Stars

Watchers

Forks

Releases

No releases published

Packages

No packages published