mirror of
https://github.com/2dust/AndroidLibXrayLite.git
synced 2025-06-28 22:29:51 +00:00
fix a bug in gen_assets.sh (#136)
* fix a bug in gen_assets.sh * Update gen_assets.sh * Update gen_assets.sh * Update gen_assets.sh * Update gen_assets.sh --------- Co-authored-by: Pk-web6936 <202365630+Pk-web6936@users.noreply.github.com>
This commit is contained in:
parent
6f650d49f3
commit
74b37729bd
1 changed files with 2 additions and 70 deletions
|
@ -11,12 +11,6 @@ __base="$(basename "${__file}" .sh)"
|
||||||
|
|
||||||
DATADIR="${__dir}/data"
|
DATADIR="${__dir}/data"
|
||||||
|
|
||||||
# Function to handle errors
|
|
||||||
error_exit() {
|
|
||||||
echo -e "Aborted, error $? in command: $BASH_COMMAND"
|
|
||||||
[[ -d "$TMPDIR" ]] && rm -rf "$TMPDIR"
|
|
||||||
exit 1
|
|
||||||
}
|
|
||||||
|
|
||||||
# Check for required dependencies
|
# Check for required dependencies
|
||||||
check_dependencies() {
|
check_dependencies() {
|
||||||
|
@ -24,75 +18,14 @@ check_dependencies() {
|
||||||
command -v go >/dev/null 2>&1 || { echo >&2 "Go is required but it's not installed. Aborting."; exit 1; }
|
command -v go >/dev/null 2>&1 || { echo >&2 "Go is required but it's not installed. Aborting."; exit 1; }
|
||||||
}
|
}
|
||||||
|
|
||||||
# Compile data function
|
|
||||||
compile_dat() {
|
|
||||||
TMPDIR=$(mktemp -d "${TMPDIR:-/tmp}/compile_dat.XXXXXX")
|
|
||||||
trap 'error_exit' ERR
|
|
||||||
|
|
||||||
local GEOSITE="${GOPATH}/src/github.com/Loyalsoldier/v2ray-rules-dat"
|
|
||||||
|
|
||||||
# Clone or update the geosite repository
|
|
||||||
if [[ -d ${GEOSITE} ]]; then
|
|
||||||
echo "Updating geosite repository..."
|
|
||||||
(cd "${GEOSITE}" && git pull)
|
|
||||||
else
|
|
||||||
echo "Cloning geosite repository..."
|
|
||||||
git clone https://github.com/Loyalsoldier/v2ray-rules-dat.git "${GEOSITE}"
|
|
||||||
fi
|
|
||||||
|
|
||||||
echo "Running geosite generation..."
|
|
||||||
(cd "${GEOSITE}" && go run main.go)
|
|
||||||
|
|
||||||
# Update geosite.dat if dlc.dat exists
|
|
||||||
if [[ -e "${GEOSITE}/dlc.dat" ]]; then
|
|
||||||
mv -f "${GEOSITE}/dlc.dat" "$DATADIR/geosite.dat"
|
|
||||||
echo "----------> geosite.dat updated."
|
|
||||||
else
|
|
||||||
echo "----------> geosite.dat failed to update."
|
|
||||||
fi
|
|
||||||
|
|
||||||
# Install geoip if not already installed
|
|
||||||
if [[ ! -x "$GOPATH/bin/geoip" ]]; then
|
|
||||||
echo "Installing geoip..."
|
|
||||||
go install github.com/Loyalsoldier/geoip@latest
|
|
||||||
fi
|
|
||||||
|
|
||||||
cd "$TMPDIR"
|
|
||||||
|
|
||||||
# Download and process GeoLite2 data
|
|
||||||
echo "Downloading GeoLite2 data..."
|
|
||||||
curl -L -O http://geolite.maxmind.com/download/geoip/database/GeoLite2-Country-CSV.zip
|
|
||||||
unzip -q GeoLite2-Country-CSV.zip
|
|
||||||
mkdir geoip && mv *.csv geoip/
|
|
||||||
|
|
||||||
echo "Generating geoip.dat..."
|
|
||||||
"$GOPATH/bin/geoip" \
|
|
||||||
--country=./geoip/GeoLite2-Country-Locations-en.csv \
|
|
||||||
--ipv4=./geoip/GeoLite2-Country-Blocks-IPv4.csv \
|
|
||||||
--ipv6=./geoip/GeoLite2-Country-Blocks-IPv6.csv
|
|
||||||
|
|
||||||
# Update geoip.dat if it exists
|
|
||||||
if [[ -e geoip.dat ]]; then
|
|
||||||
mv -f geoip.dat "$DATADIR/geoip.dat"
|
|
||||||
echo "----------> geoip.dat updated."
|
|
||||||
else
|
|
||||||
echo "----------> geoip.dat failed to update."
|
|
||||||
fi
|
|
||||||
|
|
||||||
trap - ERR # Disable error trap
|
|
||||||
}
|
|
||||||
|
|
||||||
# Download data function
|
# Download data function
|
||||||
download_dat() {
|
download_dat() {
|
||||||
echo "Downloading geoip.dat..."
|
echo "Downloading geoip.dat..."
|
||||||
wget -qO - https://api.github.com/repos/Loyalsoldier/v2ray-rules-dat/releases/latest \
|
curl -sL https://github.com/Loyalsoldier/v2ray-rules-dat/releases/latest/download/geoip.dat -o "$DATADIR/geoip.dat"
|
||||||
| jq -r .assets[].browser_download_url | grep geoip.dat \
|
|
||||||
| xargs wget -O "$DATADIR/geoip.dat"
|
|
||||||
|
|
||||||
echo "Downloading geosite.dat..."
|
echo "Downloading geosite.dat..."
|
||||||
wget -qO - https://api.github.com/repos/Loyalsoldier/v2ray-rules-dat/releases/latest \
|
curl -sL https://github.com/Loyalsoldier/v2ray-rules-dat/releases/latest/download/geosite.dat -o "$DATADIR/geosite.dat"
|
||||||
| grep browser_download_url | cut -d '"' -f 4 \
|
|
||||||
| xargs wget -O "$DATADIR/geosite.dat"
|
|
||||||
}
|
}
|
||||||
|
|
||||||
# Main execution logic
|
# Main execution logic
|
||||||
|
@ -102,6 +35,5 @@ check_dependencies
|
||||||
|
|
||||||
case $ACTION in
|
case $ACTION in
|
||||||
"download") download_dat ;;
|
"download") download_dat ;;
|
||||||
"compile") compile_dat ;;
|
|
||||||
*) echo "Invalid action: $ACTION" ; exit 1 ;;
|
*) echo "Invalid action: $ACTION" ; exit 1 ;;
|
||||||
esac
|
esac
|
||||||
|
|
Loading…
Add table
Add a link
Reference in a new issue