-
Notifications
You must be signed in to change notification settings - Fork 1
/
app.go
94 lines (77 loc) · 1.74 KB
/
app.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
package lock
import (
"os"
"net/http"
"net/http/cookiejar"
"time"
"net/url"
"fmt"
"github.com/Sirupsen/logrus"
"github.com/robfig/cron"
"github.com/spf13/viper"
)
func Boot() {
var appleIDs []AppleID
err := viper.UnmarshalKey("AppleIDs", &appleIDs)
if err != nil {
logrus.Infoln("Can't parse Apple ID config!")
os.Exit(1)
}
var cronStr string
err = viper.UnmarshalKey("cron", &cronStr)
if err != nil {
logrus.Infoln("Can't parse cron config!")
os.Exit(1)
}
var pool IPPool
err = viper.UnmarshalKey("pool", &pool)
if err != nil {
logrus.Infoln("Can't parse ip pool config!")
os.Exit(1)
}
err = pool.Start()
if err != nil {
logrus.Infof("Start IP Pool failed: %s", err)
os.Exit(1)
}
logrus.Infoln("IP Pool started, wait pool ready...")
<-pool.WaitReady()
c := cron.New()
for i := range appleIDs {
x := i
logrus.Infof("Apple ID [%s] cron starting", appleIDs[x].ID)
c.AddFunc(cronStr, func() {
for i := 0; i < 20; i++ {
Retry:
jar, _ := cookiejar.New(nil)
ip, err := pool.GetIP()
if err != nil {
logrus.Errorf("Apple lock failed: %s", err)
return
}
logrus.Infof("Lock apple id [%s] use IP: %s", appleIDs[x].ID, ip.IP)
proxyAddr := fmt.Sprintf("http://%s:%s", ip.IP, ip.Port)
p := func(_ *http.Request) (*url.URL, error) {
return url.Parse(proxyAddr)
}
transport := &http.Transport{Proxy: p}
client := &http.Client{
Timeout: 5 * time.Second,
Jar: jar,
Transport: transport,
}
if err := appleIDs[x].Lock(client); err == nil {
break
} else {
pool.cache.Delete(ip.IP)
goto Retry
}
}
if appleIDs[x].State {
logrus.Infof("Apple ID [%s] locked!", appleIDs[x].ID)
}
})
}
c.Start()
select {}
}