This repository has been archived by the owner on Mar 17, 2024. It is now read-only.
-
Notifications
You must be signed in to change notification settings - Fork 0
/
Copy pathmain.go
73 lines (61 loc) · 1.83 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
package main
import (
"flag"
"fmt"
"net/url"
"os"
"time"
"github.com/ChimeraCoder/anaconda"
log "github.com/sirupsen/logrus"
)
var (
logger = log.New()
)
func getTimeline(api *anaconda.TwitterApi) ([]anaconda.Tweet, error) {
args := url.Values{}
args.Add("count", "3200") // Twitter only returns most recent 20 tweets by default, so override
args.Add("include_rts", "true") // When using count argument, RTs are excluded, so include them as recommended
timeline, err := api.GetUserTimeline(args)
if err != nil {
return make([]anaconda.Tweet, 0), err
}
return timeline, nil
}
func main() {
var tweetDays = flag.Int("d", 28, "days after which to delete a tweet")
flag.Parse()
anaconda.SetConsumerKey(os.Getenv("TC_TWITTER_CONSUMER_KEY"))
anaconda.SetConsumerSecret(os.Getenv("TC_TWITTER_CONSUMER_SECRET"))
api := anaconda.NewTwitterApi(os.Getenv("TC_TWITTER_ACCESS_TOKEN"), os.Getenv("TC_TWITTER_ACCESS_TOKEN_SECRET"))
api.SetLogger(anaconda.BasicLogger)
fmter := new(log.TextFormatter)
fmter.FullTimestamp = true
log.SetFormatter(fmter)
log.SetLevel(log.InfoLevel)
tweetHours := fmt.Sprintf("%dh", *tweetDays*24)
log.Info("STARTED: ", *tweetDays, " days (", tweetHours, " hours)")
ageLimit, err := time.ParseDuration(tweetHours)
if err != nil {
log.Error("Could not parse tweetDays: ", err)
os.Exit(-1)
}
timeline, err := getTimeline(api)
if err != nil {
log.Error("Could not get timeline: ", err)
os.Exit(-1)
}
for _, t := range timeline {
createdTime, err := t.CreatedAtTime()
if err != nil {
log.Error("Couldn't parse time: ", err)
} else {
if time.Since(createdTime) > ageLimit {
_, err := api.DeleteTweet(t.Id, true)
log.Info("DELETED: Age - ", time.Since(createdTime).Round(1*time.Minute), " - ", t.Text)
if err != nil {
log.Error("Failed to delete: ", err)
}
}
}
}
}