sing-geosite: init at 20230202101858

This commit is contained in:
linsui 2023-02-18 20:59:30 +08:00
parent 815a21e9f1
commit 99892e9bfb
3 changed files with 71 additions and 0 deletions

View 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 ];
};
}

View 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)
}
}

View file

@ -11957,6 +11957,8 @@ with pkgs;
sing-box = callPackage ../tools/networking/sing-box { };
sing-geosite = callPackage ../data/misc/sing-geosite { };
sipcalc = callPackage ../tools/networking/sipcalc { };
skribilo = callPackage ../tools/typesetting/skribilo {