summaryrefslogtreecommitdiffstats
path: root/vendor/github.com/nlopes/slack/examples/websocket/websocket.go
diff options
context:
space:
mode:
authorWim <wim@42.be>2018-01-08 22:41:38 +0100
committerWim <wim@42.be>2018-01-09 00:07:55 +0100
commitbe898b44c3c057c7b70efb83f66b7bbbdd5e9276 (patch)
tree01c8983913bcae177b5e0e015de9a45abe8369a7 /vendor/github.com/nlopes/slack/examples/websocket/websocket.go
parent4828c434439949f62a6e219ab9947c221a06b111 (diff)
downloadmatterbridge-msglm-be898b44c3c057c7b70efb83f66b7bbbdd5e9276.tar.gz
matterbridge-msglm-be898b44c3c057c7b70efb83f66b7bbbdd5e9276.tar.bz2
matterbridge-msglm-be898b44c3c057c7b70efb83f66b7bbbdd5e9276.zip
Update vendor (slack)
Diffstat (limited to 'vendor/github.com/nlopes/slack/examples/websocket/websocket.go')
-rw-r--r--vendor/github.com/nlopes/slack/examples/websocket/websocket.go54
1 files changed, 54 insertions, 0 deletions
diff --git a/vendor/github.com/nlopes/slack/examples/websocket/websocket.go b/vendor/github.com/nlopes/slack/examples/websocket/websocket.go
new file mode 100644
index 00000000..c232951a
--- /dev/null
+++ b/vendor/github.com/nlopes/slack/examples/websocket/websocket.go
@@ -0,0 +1,54 @@
+package main
+
+import (
+ "fmt"
+ "log"
+ "os"
+
+ "github.com/nlopes/slack"
+)
+
+func main() {
+ api := slack.New("YOUR TOKEN HERE")
+ logger := log.New(os.Stdout, "slack-bot: ", log.Lshortfile|log.LstdFlags)
+ slack.SetLogger(logger)
+ api.SetDebug(true)
+
+ rtm := api.NewRTM()
+ go rtm.ManageConnection()
+
+ for msg := range rtm.IncomingEvents {
+ fmt.Print("Event Received: ")
+ switch ev := msg.Data.(type) {
+ case *slack.HelloEvent:
+ // Ignore hello
+
+ case *slack.ConnectedEvent:
+ fmt.Println("Infos:", ev.Info)
+ fmt.Println("Connection counter:", ev.ConnectionCount)
+ // Replace C2147483705 with your Channel ID
+ rtm.SendMessage(rtm.NewOutgoingMessage("Hello world", "C2147483705"))
+
+ case *slack.MessageEvent:
+ fmt.Printf("Message: %v\n", ev)
+
+ case *slack.PresenceChangeEvent:
+ fmt.Printf("Presence Change: %v\n", ev)
+
+ case *slack.LatencyReport:
+ fmt.Printf("Current latency: %v\n", ev.Value)
+
+ case *slack.RTMError:
+ fmt.Printf("Error: %s\n", ev.Error())
+
+ case *slack.InvalidAuthEvent:
+ fmt.Printf("Invalid credentials")
+ return
+
+ default:
+
+ // Ignore other events..
+ // fmt.Printf("Unexpected: %v\n", msg.Data)
+ }
+ }
+}