| @@ -68,7 +68,7 @@ Each file in the `data/` directory can be used as a rule in this format: `geosit | |||||||
|  |  | ||||||
| - Install `golang` and `git` | - Install `golang` and `git` | ||||||
| - Download and install project code: `go get -u -v --insecure github.com/v2ray/domain-list-community` | - Download and install project code: `go get -u -v --insecure github.com/v2ray/domain-list-community` | ||||||
| - Generate `dlc.dat` (without `datapath` option means to use `data` directory of this project): | - Generate `dlc.dat` (without `datapath` option means to use `data` directory of this repository in `$GOPATH`): | ||||||
|   - `$(go env GOPATH)/bin/domain-list-community` |   - `$(go env GOPATH)/bin/domain-list-community` | ||||||
|   - `$(go env GOPATH)/bin/domain-list-community --datapath=/path/to/your/custom/data/directory` |   - `$(go env GOPATH)/bin/domain-list-community --datapath=/path/to/your/custom/data/directory` | ||||||
|  |  | ||||||
|   | |||||||
							
								
								
									
										1
									
								
								data/bmw
									
									
									
									
									
								
							
							
						
						
									
										1
									
								
								data/bmw
									
									
									
									
									
								
							| @@ -38,7 +38,6 @@ bmw.com | |||||||
| bmw.com.ar | bmw.com.ar | ||||||
| bmw.com.au | bmw.com.au | ||||||
| bmw.com.bn | bmw.com.bn | ||||||
| bmw.com.cn |  | ||||||
| bmw.com.kh | bmw.com.kh | ||||||
| bmw.com.mt | bmw.com.mt | ||||||
| bmw.com.my | bmw.com.my | ||||||
|   | |||||||
							
								
								
									
										7
									
								
								data/dnspod
									
									
									
									
									
										Normal file
									
								
							
							
						
						
									
										7
									
								
								data/dnspod
									
									
									
									
									
										Normal file
									
								
							| @@ -0,0 +1,7 @@ | |||||||
|  | dns.pub | ||||||
|  | dnsapi.cn | ||||||
|  | dnspod.cn | ||||||
|  | dnspod.com | ||||||
|  | dnspod.com.cn | ||||||
|  | dnspod.org | ||||||
|  | doh.pub | ||||||
| @@ -4,7 +4,6 @@ ebay.at | |||||||
| ebay.be | ebay.be | ||||||
| ebay.ca | ebay.ca | ||||||
| ebay.ch | ebay.ch | ||||||
| ebay.cn |  | ||||||
| ebay.co.nz | ebay.co.nz | ||||||
| ebay.co.uk | ebay.co.uk | ||||||
| ebay.co.ve | ebay.co.ve | ||||||
|   | |||||||
							
								
								
									
										3
									
								
								data/emojipedia
									
									
									
									
									
										Normal file
									
								
							
							
						
						
									
										3
									
								
								data/emojipedia
									
									
									
									
									
										Normal file
									
								
							| @@ -0,0 +1,3 @@ | |||||||
|  | emojipedia.org | ||||||
|  | worldemojiawards.com | ||||||
|  | worldemojiday.com | ||||||
| @@ -228,6 +228,7 @@ include:reddit | |||||||
| include:archive | include:archive | ||||||
| include:change | include:change | ||||||
| include:csis | include:csis | ||||||
|  | include:emojipedia | ||||||
| include:globalsecurity | include:globalsecurity | ||||||
| include:ruleoflaw | include:ruleoflaw | ||||||
| include:un | include:un | ||||||
|   | |||||||
| @@ -6,7 +6,6 @@ scholar.google.ca | |||||||
| scholar.google.cat | scholar.google.cat | ||||||
| scholar.google.ch | scholar.google.ch | ||||||
| scholar.google.cl | scholar.google.cl | ||||||
| scholar.google.cn |  | ||||||
| scholar.google.co.cr | scholar.google.co.cr | ||||||
| scholar.google.co.id | scholar.google.co.id | ||||||
| scholar.google.co.il | scholar.google.co.il | ||||||
|   | |||||||
| @@ -25,7 +25,6 @@ mastercard.com.au | |||||||
| mastercard.com.bh | mastercard.com.bh | ||||||
| mastercard.com.br | mastercard.com.br | ||||||
| mastercard.com.bz | mastercard.com.bz | ||||||
| mastercard.com.cn |  | ||||||
| mastercard.com.co | mastercard.com.co | ||||||
| mastercard.com.cy | mastercard.com.cy | ||||||
| mastercard.com.eg | mastercard.com.eg | ||||||
|   | |||||||
| @@ -4,7 +4,6 @@ mcd | |||||||
| # All .mcdonalds domains | # All .mcdonalds domains | ||||||
| mcdonalds | mcdonalds | ||||||
|  |  | ||||||
| 4008-517-517.cn |  | ||||||
| aboutmcdonalds.com | aboutmcdonalds.com | ||||||
| happymeal.co.nz | happymeal.co.nz | ||||||
| happymeal.com.au | happymeal.com.au | ||||||
|   | |||||||
| @@ -1,3 +1,6 @@ | |||||||
|  | include:tencent-ads | ||||||
|  | include:dnspod | ||||||
|  |  | ||||||
| apcdns.net | apcdns.net | ||||||
| foxmail.com | foxmail.com | ||||||
| foxmail.com.cn | foxmail.com.cn | ||||||
| @@ -28,5 +31,3 @@ tenpay.com | |||||||
| wechat.com | wechat.com | ||||||
| wegame.com | wegame.com | ||||||
| weiyun.com | weiyun.com | ||||||
|  |  | ||||||
| include:tencent-ads |  | ||||||
|   | |||||||
| @@ -1,2 +1,3 @@ | |||||||
| uber.com |  | ||||||
| uber-assets.com | uber-assets.com | ||||||
|  | uber.com | ||||||
|  | ubereats.com | ||||||
|   | |||||||
| @@ -24,7 +24,6 @@ visa.com.bo | |||||||
| visa.com.br | visa.com.br | ||||||
| visa.com.bs | visa.com.bs | ||||||
| visa.com.bz | visa.com.bz | ||||||
| visa.com.cn |  | ||||||
| visa.com.co | visa.com.co | ||||||
| visa.com.cy | visa.com.cy | ||||||
| visa.com.dm | visa.com.dm | ||||||
|   | |||||||
							
								
								
									
										64
									
								
								main.go
									
									
									
									
									
								
							
							
						
						
									
										64
									
								
								main.go
									
									
									
									
									
								
							| @@ -5,6 +5,7 @@ import ( | |||||||
| 	"errors" | 	"errors" | ||||||
| 	"flag" | 	"flag" | ||||||
| 	"fmt" | 	"fmt" | ||||||
|  | 	"go/build" | ||||||
| 	"io/ioutil" | 	"io/ioutil" | ||||||
| 	"os" | 	"os" | ||||||
| 	"path/filepath" | 	"path/filepath" | ||||||
| @@ -15,7 +16,10 @@ import ( | |||||||
| 	"v2ray.com/core/app/router" | 	"v2ray.com/core/app/router" | ||||||
| ) | ) | ||||||
|  |  | ||||||
| var dataPath = flag.String("datapath", "", "Path to the custom data folder") | var ( | ||||||
|  | 	dataPath        = flag.String("datapath", "", "Path to your custom 'data' directory") | ||||||
|  | 	defaultDataPath = filepath.Join("src", "github.com", "v2ray", "domain-list-community", "data") | ||||||
|  | ) | ||||||
|  |  | ||||||
| type Entry struct { | type Entry struct { | ||||||
| 	Type  string | 	Type  string | ||||||
| @@ -145,13 +149,13 @@ func parseEntry(line string) (Entry, error) { | |||||||
| func DetectPath(path string) (string, error) { | func DetectPath(path string) (string, error) { | ||||||
| 	arrPath := strings.Split(path, string(filepath.ListSeparator)) | 	arrPath := strings.Split(path, string(filepath.ListSeparator)) | ||||||
| 	for _, content := range arrPath { | 	for _, content := range arrPath { | ||||||
| 		fullPath := filepath.Join(content, "src", "github.com", "v2ray", "domain-list-community", "data") | 		fullPath := filepath.Join(content, defaultDataPath) | ||||||
| 		_, err := os.Stat(fullPath) | 		_, err := os.Stat(fullPath) | ||||||
| 		if err == nil || os.IsExist(err) { | 		if err == nil || os.IsExist(err) { | ||||||
| 			return fullPath, nil | 			return fullPath, nil | ||||||
| 		} | 		} | ||||||
| 	} | 	} | ||||||
| 	err := errors.New("No file found in GOPATH") | 	err := fmt.Errorf("directory '%s' not found in '$GOPATH'", defaultDataPath) | ||||||
| 	return "", err | 	return "", err | ||||||
| } | } | ||||||
|  |  | ||||||
| @@ -218,6 +222,45 @@ func ParseList(list *List, ref map[string]*List) (*ParsedList, error) { | |||||||
| 	return pl, nil | 	return pl, nil | ||||||
| } | } | ||||||
|  |  | ||||||
|  | func envFile() (string, error) { | ||||||
|  | 	if file := os.Getenv("GOENV"); file != "" { | ||||||
|  | 		if file == "off" { | ||||||
|  | 			return "", fmt.Errorf("GOENV=off") | ||||||
|  | 		} | ||||||
|  | 		return file, nil | ||||||
|  | 	} | ||||||
|  | 	dir, err := os.UserConfigDir() | ||||||
|  | 	if err != nil { | ||||||
|  | 		return "", err | ||||||
|  | 	} | ||||||
|  | 	if dir == "" { | ||||||
|  | 		return "", fmt.Errorf("missing user-config dir") | ||||||
|  | 	} | ||||||
|  | 	return filepath.Join(dir, "go", "env"), nil | ||||||
|  | } | ||||||
|  |  | ||||||
|  | func getRuntimeEnv(key string) (string, error) { | ||||||
|  | 	file, err := envFile() | ||||||
|  | 	if err != nil { | ||||||
|  | 		return "", err | ||||||
|  | 	} | ||||||
|  | 	if file == "" { | ||||||
|  | 		return "", fmt.Errorf("missing runtime env file") | ||||||
|  | 	} | ||||||
|  | 	var data []byte | ||||||
|  | 	var runtimeEnv string | ||||||
|  | 	data, err = ioutil.ReadFile(file) | ||||||
|  | 	envStrings := strings.Split(string(data), "\n") | ||||||
|  | 	for _, envItem := range envStrings { | ||||||
|  | 		envItem = strings.TrimSuffix(envItem, "\r") | ||||||
|  | 		envKeyValue := strings.Split(envItem, "=") | ||||||
|  | 		if strings.ToLower(envKeyValue[0]) == strings.ToLower(key) { | ||||||
|  | 			runtimeEnv = envKeyValue[1] | ||||||
|  | 		} | ||||||
|  | 	} | ||||||
|  | 	return runtimeEnv, nil | ||||||
|  | } | ||||||
|  |  | ||||||
| func main() { | func main() { | ||||||
| 	flag.Parse() | 	flag.Parse() | ||||||
|  |  | ||||||
| @@ -226,12 +269,23 @@ func main() { | |||||||
| 	if *dataPath != "" { | 	if *dataPath != "" { | ||||||
| 		dir = *dataPath | 		dir = *dataPath | ||||||
| 	} else { | 	} else { | ||||||
| 		dir, err = DetectPath(os.Getenv("GOPATH")) | 		goPath, envErr := getRuntimeEnv("GOPATH") | ||||||
|  | 		if envErr != nil { | ||||||
|  | 			fmt.Println("Failed: please set '$GOPATH' manually, or use 'datapath' option to specify the path to your custom 'data' directory") | ||||||
|  | 			return | ||||||
|  | 		} | ||||||
|  | 		if goPath == "" { | ||||||
|  | 			goPath = build.Default.GOPATH | ||||||
|  | 		} | ||||||
|  | 		fmt.Println("Use $GOPATH:", goPath) | ||||||
|  | 		fmt.Printf("Searching directory '%s' in '%s'...\n", defaultDataPath, goPath) | ||||||
|  | 		dir, err = DetectPath(goPath) | ||||||
| 	} | 	} | ||||||
| 	if err != nil { | 	if err != nil { | ||||||
| 		fmt.Println("Failed: ", err) | 		fmt.Println("Failed: ", err) | ||||||
| 		return | 		return | ||||||
| 	} | 	} | ||||||
|  | 	fmt.Println("Use domain lists in", dir) | ||||||
|  |  | ||||||
| 	ref := make(map[string]*List) | 	ref := make(map[string]*List) | ||||||
| 	err = filepath.Walk(dir, func(path string, info os.FileInfo, err error) error { | 	err = filepath.Walk(dir, func(path string, info os.FileInfo, err error) error { | ||||||
| @@ -275,6 +329,6 @@ func main() { | |||||||
| 	if err := ioutil.WriteFile("dlc.dat", protoBytes, 0777); err != nil { | 	if err := ioutil.WriteFile("dlc.dat", protoBytes, 0777); err != nil { | ||||||
| 		fmt.Println("Failed: ", err) | 		fmt.Println("Failed: ", err) | ||||||
| 	} else { | 	} else { | ||||||
| 		fmt.Println("dlc.dat has been generated successfully.") | 		fmt.Println("dlc.dat has been generated successfully in the directory. You can rename 'dlc.dat' to 'geosite.dat' and use it in V2Ray.") | ||||||
| 	} | 	} | ||||||
| } | } | ||||||
|   | |||||||
		Reference in New Issue
	
	Block a user