/
twitter.go
80 lines (73 loc) · 2.06 KB
/
twitter.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
package main
import (
"io/ioutil"
"log"
"net/http"
"net/url"
"os"
"strings"
"github.com/kurrik/oauth1a"
"github.com/kurrik/twittergo"
)
type Twitter struct {
}
func (Twitter) LoadCredentials() (client *twittergo.Client, err error) {
credentials, err := ioutil.ReadFile(os.Getenv("HOME") + "/.turret/CREDENTIALS")
if err != nil {
return
}
lines := strings.Split(string(credentials), "\n")
config := &oauth1a.ClientConfig{
ConsumerKey: lines[0],
ConsumerSecret: lines[1],
}
user := oauth1a.NewAuthorizedConfig(lines[2], lines[3])
client = twittergo.NewClient(config, user)
return
}
func (Twitter) Post(client *twittergo.Client, status string) {
var (
err error
req *http.Request
resp *twittergo.APIResponse
tweet *twittergo.Tweet
)
data := url.Values{}
data.Set("status", status)
body := strings.NewReader(data.Encode())
req, err = http.NewRequest("POST", "/1.1/statuses/update.json", body)
if err != nil {
log.Printf("Error: Could not parse request: %v\n", err)
return
}
req.Header.Set("Content-Type", "application/x-www-form-urlencoded")
resp, err = client.SendRequest(req)
if err != nil {
log.Printf("Error: Could not send request: %v\n", err)
return
}
tweet = &twittergo.Tweet{}
err = resp.Parse(tweet)
if err != nil {
if rle, ok := err.(twittergo.RateLimitError); ok {
log.Printf("Error: Rate limited, reset at %v\n", rle.Reset)
} else if errs, ok := err.(twittergo.Errors); ok {
for i, val := range errs.Errors() {
log.Printf("Error #%v - ", i+1)
log.Printf("Code: %v ", val.Code())
log.Printf("Msg: %v\n", val.Message())
}
} else {
log.Printf("Error: Problem parsing response: %v\n", err)
}
return
}
log.Printf("ID: %v\n", tweet.Id())
log.Printf("Tweet: %v\n", tweet.Text())
log.Printf("User: %v\n", tweet.User().Name())
if resp.HasRateLimit() {
log.Printf("Rate limit: %v\n", resp.RateLimit())
log.Printf("Rate limit remaining: %v\n", resp.RateLimitRemaining())
log.Printf("Rate limit reset: %v\n", resp.RateLimitReset())
}
}