-
Notifications
You must be signed in to change notification settings - Fork 197
/
Copy pathmain.go
80 lines (66 loc) · 2.11 KB
/
main.go
1
2
3
4
5
6
7
8
9
10
11
12
13
14
15
16
17
18
19
20
21
22
23
24
25
26
27
28
29
30
31
32
33
34
35
36
37
38
39
40
41
42
43
44
45
46
47
48
49
50
51
52
53
54
55
56
57
58
59
60
61
62
63
64
65
66
67
68
69
70
71
72
73
74
75
76
77
78
79
80
// Copyright 2017 Google Inc. All rights reserved.
// Licensed under the Apache License, Version 2.0 (the "License");
// you may not use this file except in compliance with the License.
// You may obtain a copy of the License at
// http://www.apache.org/licenses/LICENSE-2.0
//
// Unless required by applicable law or agreed to writing, software distributed
// under the License is distributed on a "AS IS" BASIS, WITHOUT WARRANTIES OR
// CONDITIONS OF ANY KIND, either express or implied.
//
// See the License for the specific language governing permissions and
// limitations under the License.
package main
import (
"net/url"
"os"
"github.com/ChimeraCoder/anaconda"
"github.com/sirupsen/logrus"
)
var (
consumerKey = getenv("TWITTER_CONSUMER_KEY")
consumerSecret = getenv("TWITTER_CONSUMER_SECRET")
accessToken = getenv("TWITTER_ACCESS_TOKEN")
accessTokenSecret = getenv("TWITTER_ACCESS_TOKEN_SECRET")
)
func getenv(name string) string {
v := os.Getenv(name)
if v == "" {
panic("missing required environment variable " + name)
}
return v
}
func main() {
anaconda.SetConsumerKey(consumerKey)
anaconda.SetConsumerSecret(consumerSecret)
api := anaconda.NewTwitterApi(accessToken, accessTokenSecret)
log := &logger{logrus.New()}
api.SetLogger(log)
stream := api.PublicStreamFilter(url.Values{
"track": []string{"#justforfunc"},
})
defer stream.Stop()
for v := range stream.C {
t, ok := v.(anaconda.Tweet)
if !ok {
log.Warningf("received unexpected value of type %T", v)
continue
}
if t.RetweetedStatus != nil {
continue
}
_, err := api.Retweet(t.Id, false)
if err != nil {
log.Errorf("could not retweet %d: %v", t.Id, err)
continue
}
log.Infof("retweeted %d", t.Id)
}
}
type logger struct {
*logrus.Logger
}
func (log *logger) Critical(args ...interface{}) { log.Error(args...) }
func (log *logger) Criticalf(format string, args ...interface{}) { log.Errorf(format, args...) }
func (log *logger) Notice(args ...interface{}) { log.Info(args...) }
func (log *logger) Noticef(format string, args ...interface{}) { log.Infof(format, args...) }