sing-geosite: init at 20230202101858
This commit is contained in:
parent
815a21e9f1
commit
99892e9bfb
50
pkgs/data/misc/sing-geosite/default.nix
Normal file
50
pkgs/data/misc/sing-geosite/default.nix
Normal file
|
@ -0,0 +1,50 @@
|
||||||
|
{ lib
|
||||||
|
, buildGoModule
|
||||||
|
, fetchFromGitHub
|
||||||
|
, substituteAll
|
||||||
|
, v2ray-domain-list-community
|
||||||
|
}:
|
||||||
|
|
||||||
|
let
|
||||||
|
patch = substituteAll {
|
||||||
|
src = ./main.go;
|
||||||
|
geosite_data = "${v2ray-domain-list-community}/share/v2ray/geosite.dat";
|
||||||
|
};
|
||||||
|
in
|
||||||
|
buildGoModule rec {
|
||||||
|
pname = "sing-geosite";
|
||||||
|
inherit (v2ray-domain-list-community) version;
|
||||||
|
|
||||||
|
src = fetchFromGitHub {
|
||||||
|
owner = "SagerNet";
|
||||||
|
repo = "sing-geosite";
|
||||||
|
rev = "4a32d56c1705f77668beb5828df0b0a051efdeb9";
|
||||||
|
hash = "sha256-P/EBcwJI2G9327BNi84R+q6BABx9DEKpN6ETTp8Q4NU=";
|
||||||
|
};
|
||||||
|
|
||||||
|
vendorHash = "sha256-uQOmUXT2wd40DwwTCMnFFKd47eu+BPBDjiCGtUNFoKY=";
|
||||||
|
|
||||||
|
patchPhase = ''
|
||||||
|
sed -i -e '/func main()/,/^}/d' -e '/"io"/a "io/ioutil"' main.go
|
||||||
|
cat ${patch} >> main.go
|
||||||
|
'';
|
||||||
|
|
||||||
|
buildPhase = ''
|
||||||
|
runHook preBuild
|
||||||
|
go run -v .
|
||||||
|
runHook postBuild
|
||||||
|
'';
|
||||||
|
|
||||||
|
installPhase = ''
|
||||||
|
runHook preInstall
|
||||||
|
install -Dm644 geosite.db $out/share/sing-box/geosite.db
|
||||||
|
runHook postInstall
|
||||||
|
'';
|
||||||
|
|
||||||
|
meta = with lib; {
|
||||||
|
description = "community managed domain list";
|
||||||
|
homepage = "https://github.com/SagerNet/sing-geosite";
|
||||||
|
license = licenses.gpl3Plus;
|
||||||
|
maintainers = with maintainers; [ linsui ];
|
||||||
|
};
|
||||||
|
}
|
19
pkgs/data/misc/sing-geosite/main.go
Normal file
19
pkgs/data/misc/sing-geosite/main.go
Normal file
|
@ -0,0 +1,19 @@
|
||||||
|
func main() {
|
||||||
|
outputFile, err := os.Create("geosite.db")
|
||||||
|
if err != nil {
|
||||||
|
panic(err)
|
||||||
|
}
|
||||||
|
defer outputFile.Close()
|
||||||
|
vData, err := ioutil.ReadFile("@geosite_data@")
|
||||||
|
if err != nil {
|
||||||
|
panic(err)
|
||||||
|
}
|
||||||
|
domainMap, err := parse(vData)
|
||||||
|
if err != nil {
|
||||||
|
panic(err)
|
||||||
|
}
|
||||||
|
err = geosite.Write(outputFile, domainMap)
|
||||||
|
if err != nil {
|
||||||
|
panic(err)
|
||||||
|
}
|
||||||
|
}
|
|
@ -11957,6 +11957,8 @@ with pkgs;
|
||||||
|
|
||||||
sing-box = callPackage ../tools/networking/sing-box { };
|
sing-box = callPackage ../tools/networking/sing-box { };
|
||||||
|
|
||||||
|
sing-geosite = callPackage ../data/misc/sing-geosite { };
|
||||||
|
|
||||||
sipcalc = callPackage ../tools/networking/sipcalc { };
|
sipcalc = callPackage ../tools/networking/sipcalc { };
|
||||||
|
|
||||||
skribilo = callPackage ../tools/typesetting/skribilo {
|
skribilo = callPackage ../tools/typesetting/skribilo {
|
||||||
|
|
Loading…
Reference in a new issue