|
| 1 | +#!/usr/bin/env bash |
| 2 | +# |
| 3 | +# downloads a fresh copy of the MaxMind databases for ASN & geolocation lookups and makes an encrypted release |
| 4 | +# |
| 5 | + |
| 6 | +set -o errexit |
| 7 | +set -o pipefail |
| 8 | +set -o nounset |
| 9 | + |
| 10 | +echo "INFO: starting MaxMind update at $(date -u +%Y-%m-%dT%H:%M:%SZ)" |
| 11 | + |
| 12 | +SCRIPT_DIR="$( cd "$( dirname "$0" )" && pwd )" |
| 13 | +REPO_DIR="$(realpath "${SCRIPT_DIR}/..")" |
| 14 | + |
| 15 | +ENV_FILE="$(realpath "${REPO_DIR}/.env")" |
| 16 | +if [ -f "${ENV_FILE}" ]; then |
| 17 | + echo "INFO: loading ${ENV_FILE} into environment" |
| 18 | + export $(cat ${ENV_FILE}) |
| 19 | +fi |
| 20 | + |
| 21 | +TAR=tar |
| 22 | +if [[ $OSTYPE == 'darwin'* ]]; then |
| 23 | + echo "INFO: running on MacOS so using gtar instead of tar" |
| 24 | + TAR=gtar |
| 25 | +fi |
| 26 | + |
| 27 | +BUILD_DIR="$(realpath "${REPO_DIR}/build")" |
| 28 | +if [ ! -d "${BUILD_DIR}" ]; then |
| 29 | + echo "INFO: creating build directory ${BUILD_DIR}" |
| 30 | + mkdir -p "${BUILD_DIR}" |
| 31 | +else |
| 32 | + echo "INFO: using existing build directory ${BUILD_DIR}" |
| 33 | +fi |
| 34 | + |
| 35 | +TMP_ASN_FILE=$(mktemp) |
| 36 | +echo "INFO: download MaxMind ASN database into ${TMP_ASN_FILE}" |
| 37 | +curl --silent "https://download.maxmind.com/app/geoip_download?edition_id=GeoLite2-ASN&suffix=tar.gz&license_key=${MAXMIND_LICENSE_KEY}" >"${TMP_ASN_FILE}" |
| 38 | +${TAR} -xzf ${TMP_ASN_FILE} --directory="${BUILD_DIR}" --wildcards --strip-components 1 "*.mmdb" |
| 39 | +rm "${TMP_ASN_FILE}" |
| 40 | + |
| 41 | +TMP_CITY_FILE=$(mktemp) |
| 42 | +echo "INFO: download MaxMind City database into ${TMP_CITY_FILE}" |
| 43 | +curl --silent "https://download.maxmind.com/app/geoip_download?edition_id=GeoLite2-City&suffix=tar.gz&license_key=${MAXMIND_LICENSE_KEY}" >"${TMP_CITY_FILE}" |
| 44 | +${TAR} -xzf ${TMP_CITY_FILE} --directory="${BUILD_DIR}" --wildcards --strip-components 1 "*.mmdb" |
| 45 | +rm "${TMP_CITY_FILE}" |
| 46 | + |
| 47 | +md5sum ${BUILD_DIR}/*.mmdb | sort >${BUILD_DIR}/mmdb.md5 |
| 48 | + |
| 49 | +#LATER: curl release/download/latest/mmdb.md5 |
| 50 | +#DIFF=$(git diff --name-only "${BUILD_DIR}/mmdb.md5") |
| 51 | +# |
| 52 | +#if [ "${DIFF}" == "" ]; then |
| 53 | +# echo "INFO: no changes, exiting at $(date -u +%Y-%m-%dT%H:%M:%SZ)" |
| 54 | +# exit 0 |
| 55 | +#fi |
| 56 | + |
| 57 | +if [ "${MMDB_ENCRYPTION_KEY:-BAD}" = "BAD" ]; then |
| 58 | + echo "INFO: no encryption keys, exiting. (but app can still be run locally)" |
| 59 | + exit 1 |
| 60 | +fi |
| 61 | + |
| 62 | +# |
| 63 | +# generate (and save) a new IV every time |
| 64 | +# |
| 65 | +MMDB_ENCRYPTION_IV=$(head -c 16 /dev/urandom | xxd -l 16 -c 16 -p) |
| 66 | +echo -n ${MMDB_ENCRYPTION_IV} > ${BUILD_DIR}/mmdb.iv |
| 67 | + |
| 68 | +ASN_FILE="${BUILD_DIR}/GeoLite2-ASN.mmdb" |
| 69 | +echo "INFO: starting encryption of ${ASN_FILE} (file size=$(du ${ASN_FILE} | cut -f 1))" |
| 70 | +gzip --stdout ${ASN_FILE} | openssl enc -aes-256-ctr \ |
| 71 | + -K ${MMDB_ENCRYPTION_KEY} \ |
| 72 | + -iv ${MMDB_ENCRYPTION_IV} \ |
| 73 | + -out "${ASN_FILE}.enc" |
| 74 | +rm ${ASN_FILE} |
| 75 | +echo "INFO: encryption complete (file size=$(du ${ASN_FILE}.enc | cut -f 1))" |
| 76 | + |
| 77 | +CITY_FILE="${BUILD_DIR}/GeoLite2-City.mmdb" |
| 78 | +echo "INFO: starting encryption of ${CITY_FILE} (file size=$(du ${CITY_FILE} | cut -f 1))" |
| 79 | +gzip --stdout ${CITY_FILE} | openssl enc -aes-256-ctr \ |
| 80 | + -K ${MMDB_ENCRYPTION_KEY} \ |
| 81 | + -iv ${MMDB_ENCRYPTION_IV} \ |
| 82 | + -out "${CITY_FILE}.enc" |
| 83 | +rm ${CITY_FILE} |
| 84 | +echo "INFO: encryption complete (file size=$(du ${CITY_FILE}.enc | cut -f 1))" |
| 85 | + |
| 86 | +echo "INFO: complete MaxMind update at $(date -u +%Y-%m-%dT%H:%M:%SZ)" |
0 commit comments