summaryrefslogtreecommitdiffstats
path: root/matterbridge.go
diff options
context:
space:
mode:
authorWim <wim@42.be>2015-10-24 16:39:01 +0200
committerWim <wim@42.be>2015-10-24 16:39:01 +0200
commitb346ac868b052f07e88cf092d5ee1a04e9f14f81 (patch)
tree7da6120344a09fca68985c1757d0590ade31623c /matterbridge.go
parentd0cda034786f98f40c8900b7f219c54939dc3c0d (diff)
downloadmatterbridge-msglm-b346ac868b052f07e88cf092d5ee1a04e9f14f81.tar.gz
matterbridge-msglm-b346ac868b052f07e88cf092d5ee1a04e9f14f81.tar.bz2
matterbridge-msglm-b346ac868b052f07e88cf092d5ee1a04e9f14f81.zip
Add support for JOIN, PART and CTCP_ACTION
Diffstat (limited to 'matterbridge.go')
-rw-r--r--matterbridge.go18
1 files changed, 17 insertions, 1 deletions
diff --git a/matterbridge.go b/matterbridge.go
index 4ba3c00a..d6ec67e1 100644
--- a/matterbridge.go
+++ b/matterbridge.go
@@ -6,6 +6,7 @@ import (
"github.com/thoj/go-ircevent"
"log"
"strconv"
+ "strings"
"time"
)
@@ -33,16 +34,31 @@ func (b *Bridge) createIRC(name string) *irc.Connection {
log.Println("Joining", b.Config.IRC.Channel, "as", b.Config.IRC.Nick)
i.Join(b.Config.IRC.Channel)
i.AddCallback("PRIVMSG", b.handlePrivMsg)
+ i.AddCallback("CTCP_ACTION", b.handlePrivMsg)
+ if b.Config.Mattermost.ShowJoinPart {
+ i.AddCallback("JOIN", b.handleJoinPart)
+ i.AddCallback("PART", b.handleJoinPart)
+ }
return i
}
func (b *Bridge) handlePrivMsg(event *irc.Event) {
matterMessage := matterhook.OMessage{}
- matterMessage.Text = event.Message()
+ if event.Code == "CTCP_ACTION" {
+ matterMessage.Text = event.Nick + " "
+ }
+ matterMessage.Text += event.Message()
matterMessage.UserName = "irc-" + event.Nick
b.m.Send(matterMessage)
}
+func (b *Bridge) handleJoinPart(event *irc.Event) {
+ matterMessage := matterhook.OMessage{}
+ matterMessage.Text = "irc-" + event.Nick + " " + strings.ToLower(event.Code) + "s " + event.Message()
+ matterMessage.UserName = b.Config.IRC.Nick
+ b.m.Send(matterMessage)
+}
+
func (b *Bridge) handleMatter() {
for {
message := b.m.Receive()