Compare commits

...

5 Commits

Author SHA1 Message Date
zu1k
89338d7152 remove nouse getter 2020-08-19 06:50:45 +08:00
zu1k
1fee5e87ff rename func 2020-08-18 19:07:52 +08:00
zu1k
2ba481e388 clean for all 2020-08-18 19:06:47 +08:00
zu1k
daea47552d opti 2020-08-18 18:37:38 +08:00
zu1k
59ea871190 fix proxy list clone 2020-08-18 18:31:45 +08:00
12 changed files with 38 additions and 144 deletions

4
app/cache/cache.go vendored
View File

@@ -13,10 +13,10 @@ var c = cache.New(cache.NoExpiration, 10*time.Minute)
func GetProxies(key string) proxy.ProxyList {
result, found := c.Get(key)
if found {
log.Println(len(result.(proxy.ProxyList)))
log.Println("found cache for:", key, "length:", len(result.(proxy.ProxyList)))
return result.(proxy.ProxyList)
}
log.Println("Cache not found")
log.Println("cache not found:", key)
return nil
}

View File

@@ -39,17 +39,13 @@ func CrawlGo() {
// 节点去重
proxies = proxies.Deduplication()
log.Println("CrawlGo node count:", len(proxies))
proxies = provider.Clash{Proxies: proxies}.CleanProxies()
proxies.NameAddCounrty().Sort().NameAddIndex()
cache.SetProxies("allproxies", proxies)
// 可用性检测
proxiesUseful := proxy.CleanProxies(provider.Clash{Proxies: proxies}.CleanProxies())
proxies = make(proxy.ProxyList, len(proxiesUseful))
copy(proxies, proxiesUseful)
proxies = proxy.CleanBadProxies(proxies)
log.Println("CrawlGo clash useable node count:", len(proxies))
// 排序和重命名
proxies.NameAddCounrty().Sort().NameAddIndex()
cache.SetProxies("proxies", proxies)

View File

@@ -1,4 +1,8 @@
sources:
- type: webfuzzsub
options:
url: https://raw.githubusercontent.com/du5/free/master/sub.list
- type: subscribe
options:
url: https://raw.githubusercontent.com/ssrsub/ssr/master/v2ray
@@ -19,6 +23,3 @@ sources:
- type: web-freessrxyz
options:
- type: web-lucnorg
options:

View File

@@ -1,85 +0,0 @@
package getter
import (
"encoding/base64"
"encoding/json"
"io/ioutil"
"sync"
"github.com/zu1k/proxypool/proxy"
"github.com/zu1k/proxypool/tool"
)
func init() {
Register("web-lucnorg", NewWebLucnorg)
}
const lucnorgSsrLink = "https://lncn.org/api/ssrList"
type WebLucnOrg struct {
}
func NewWebLucnorg(options tool.Options) (getter Getter, err error) {
return &WebLucnOrg{}, nil
}
func (w *WebLucnOrg) Get() proxy.ProxyList {
resp, err := tool.GetHttpClient().Post(lucnorgSsrLink, nil)
if err != nil {
return nil
}
defer resp.Body.Close()
body, err := ioutil.ReadAll(resp.Body)
if err != nil {
return nil
}
response := struct {
Code string `json:"code"`
Ssrs string `json:"ssrs"`
}{}
err = json.Unmarshal(body, &response)
if err != nil {
return nil
}
dec := decryptAesForLucn(response.Code, response.Ssrs)
if dec == nil {
return nil
}
type node struct {
Url string `json:"url"`
}
ssrs := make([]node, 0)
err = json.Unmarshal(dec, &ssrs)
if err != nil {
return nil
}
result := make([]string, 0)
for _, node := range ssrs {
result = append(result, node.Url)
}
return StringArray2ProxyArray(result)
}
func (w *WebLucnOrg) Get2Chan(pc chan proxy.Proxy, wg *sync.WaitGroup) {
defer wg.Done()
nodes := w.Get()
for _, node := range nodes {
pc <- node
}
}
func decryptAesForLucn(code string, c string) []byte {
if code == "" {
code = "abclnv561cqqfg30"
}
cipher, err := base64.StdEncoding.DecodeString(c)
if err != nil {
return nil
}
result := tool.AesEcbDecryptWithPKCS7Unpadding(cipher, []byte(code))
return result
}

View File

@@ -23,6 +23,11 @@ func (b *Base) BaseInfo() *Base {
return b
}
func (b *Base) Clone() Base {
c := *b
return c
}
type Proxy interface {
String() string
ToClash() string
@@ -31,4 +36,5 @@ type Proxy interface {
SetName(name string)
TypeName() string
BaseInfo() *Base
Clone() Proxy
}

View File

@@ -35,7 +35,7 @@ func testDelay(p Proxy) (delay uint16, err error) {
return delay, err
}
func CleanProxies(proxies []Proxy) (cproxies []Proxy) {
func CleanBadProxies(proxies []Proxy) (cproxies []Proxy) {
c := make(chan checkResult, 40)
defer close(c)
for _, p := range proxies {
@@ -52,7 +52,7 @@ func CleanProxies(proxies []Proxy) (cproxies []Proxy) {
cproxies = make([]Proxy, 0)
for _, p := range proxies {
if _, ok := okMap[p.Identifier()]; ok {
cproxies = append(cproxies, p)
cproxies = append(cproxies, p.Clone())
}
}
return

View File

@@ -71,3 +71,13 @@ func Deduplication(src ProxyList) ProxyList {
}
return result
}
func (ps ProxyList) Clone() ProxyList {
result := make(ProxyList, 0, len(ps))
for _, pp := range ps {
if pp != nil {
result = append(result, pp.Clone())
}
}
return result
}

View File

@@ -61,6 +61,10 @@ func (ss Shadowsocks) ToSurge() string {
}
}
func (ss Shadowsocks) Clone() Proxy {
return &ss
}
func ParseSSLink(link string) (*Shadowsocks, error) {
if !strings.HasPrefix(link, "ss://") {
return nil, ErrorNotSSRLink

View File

@@ -57,6 +57,10 @@ func (ssr ShadowsocksR) ToSurge() string {
return ""
}
func (ssr ShadowsocksR) Clone() Proxy {
return &ssr
}
func ParseSSRLink(link string) (*ShadowsocksR, error) {
if !strings.HasPrefix(link, "ssr") {
return nil, ErrorNotSSRLink

View File

@@ -82,6 +82,10 @@ func (v Vmess) ToSurge() string {
}
}
func (v Vmess) Clone() Proxy {
return &v
}
type vmessLinkJson struct {
Add string `json:"add"`
V string `json:"v"`

View File

@@ -311,6 +311,3 @@ sources:
- type: web-freessrxyz
options:
- type: web-lucnorg
options:

View File

@@ -1,43 +0,0 @@
package tool
import (
"bytes"
"crypto/aes"
)
func PKCS7Padding(ciphertext []byte, blockSize int) []byte {
padding := blockSize - len(ciphertext)%blockSize
padtext := bytes.Repeat([]byte{byte(padding)}, padding)
return append(ciphertext, padtext...)
}
func PKCS7UnPadding(origData []byte) []byte {
length := len(origData)
unpadding := int(origData[length-1])
return origData[:(length - unpadding)]
}
func AesEcbDecryptWithPKCS7Unpadding(data, key []byte) []byte {
block, _ := aes.NewCipher(key)
decrypted := make([]byte, len(data))
size := block.BlockSize()
for bs, be := 0, size; bs < len(data); bs, be = bs+size, be+size {
block.Decrypt(decrypted[bs:be], data[bs:be])
}
return PKCS7UnPadding(decrypted)
}
func AesEcbEncryptWithPKCS7Padding(data, key []byte) []byte {
block, _ := aes.NewCipher(key)
data = PKCS7Padding(data, block.BlockSize())
decrypted := make([]byte, len(data))
size := block.BlockSize()
for bs, be := 0, size; bs < len(data); bs, be = bs+size, be+size {
block.Encrypt(decrypted[bs:be], data[bs:be])
}
return decrypted
}