mirror of
https://github.com/ilyakooo0/nixpkgs.git
synced 2024-11-19 02:44:17 +03:00
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-geosite = callPackage ../data/misc/sing-geosite { };
|
||||
|
||||
sipcalc = callPackage ../tools/networking/sipcalc { };
|
||||
|
||||
skribilo = callPackage ../tools/typesetting/skribilo {
|
||||
|
Loading…
Reference in New Issue
Block a user