-
Notifications
You must be signed in to change notification settings - Fork 5
/
Copy pathprovider.go
110 lines (96 loc) · 2.91 KB
/
provider.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
81
82
83
84
85
86
87
88
89
90
91
92
93
94
95
96
97
98
99
100
101
102
103
104
105
106
107
108
109
110
package main
import (
"fmt"
"os"
"strings"
"time"
"github.com/dghubble/go-twitter/twitter"
"github.com/dghubble/oauth1"
)
const (
dataSource = "Twitter"
layoutTwitter = "Mon Jan 02 15:04:05 -0700 2006"
layoutBigQuery = "2006-01-02 15:04:05"
streamLimitPauseMin = 10
)
// start initiates the Tweeter stream subscription and pumps all messages into
// the passed in channel
func subscribeToStream(stock Stock, ch chan<- Content) {
logInfo.Printf("Subscribing to [%v:%v]...", stock.Symbol, stock.Company)
consumerKey := os.Getenv("T_CONSUMER_KEY")
consumerSecret := os.Getenv("T_CONSUMER_SECRET")
accessToken := os.Getenv("T_ACCESS_TOKEN")
accessSecret := os.Getenv("T_ACCESS_SECRET")
if consumerKey == "" || consumerSecret == "" || accessToken == "" || accessSecret == "" {
logErr.Fatal("Both, consumer key/secret and access token/secret are required")
return
}
// init convif
config := oauth1.NewConfig(consumerKey, consumerSecret)
token := oauth1.NewToken(accessToken, accessSecret)
// HTTP Client - will automatically authorize Requests
httpClient := config.Client(appContext, token)
httpClient.Timeout = time.Duration(30 * time.Second)
client := twitter.NewClient(httpClient)
demux := twitter.NewSwitchDemux()
//Tweet processor
demux.Tweet = func(tweet *twitter.Tweet) {
// check if the tweet is a retweet
if tweet.RetweetedStatus == nil {
aquiredOn := time.Now()
username := strings.ToLower(tweet.User.ScreenName)
msg := Content{
Post: Post{
Symbol: stock.Symbol,
PostID: tweet.ID,
PostedOn: aquiredOn,
Content: tweet.Text,
Username: username,
},
Author: Author{
Username: username,
FullName: tweet.User.Name,
FriendCount: int64(tweet.User.FollowersCount),
PostCount: int64(tweet.User.StatusesCount),
Source: dataSource,
UpdatedOn: aquiredOn,
},
}
logDebug.Printf("Post [%v:%d]", stock.Symbol, msg.Post.PostID)
ch <- msg
}
}
// Tweet filter
filterParams := &twitter.StreamFilterParams{
Track: []string{
"#" + stock.Symbol, // hashtag
"$" + stock.Symbol, // stock sybmob search
stock.Company, // just plain name of the company
},
StallWarnings: twitter.Bool(true),
Language: []string{"en"},
}
// Start stream
stream, err := client.Streams.Filter(filterParams)
if err != nil {
providerErrors <- ProviderRerun{
Error: fmt.Sprintf("Error while creating stream filter: %v", err),
Channel: ch,
Stock: stock,
}
return
}
demux.StreamLimit = func(limit *twitter.StreamLimit) {
logErr.Printf("Reached stream limit %v - pausing: %d min",
limit.Track, streamLimitPauseMin)
time.Sleep(time.Duration(streamLimitPauseMin * time.Minute))
providerErrors <- ProviderRerun{
Error: fmt.Sprintf("Error while creating stream filter: %v", err),
Channel: ch,
Stock: stock,
}
return
}
// do the work
go demux.HandleChan(stream.Messages)
}